Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
signalapp
GitHub Repository: signalapp/Signal-iOS
Path: blob/main/SignalServiceKit/Upload/UploadMetadata.swift
1 views
//
// Copyright 2024 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
//

import Foundation

/// Applies to attachment uploads, backup proto uploads, etc.
public protocol UploadMetadata {
    var encryptedDataLength: UInt32 { get }
}

/// Includes extra info like digest for validation.
public protocol ValidatedUploadMetadata: UploadMetadata {
    /// The digest of the encrypted file.  The encrypted file consist of "iv + encrypted data + hmac"
    var digest: Data { get }

    /// The length of the unencrypted data
    var plaintextDataLength: UInt32 { get }
}

/// Specifically an upload of an attachment.
public protocol AttachmentUploadMetadata: ValidatedUploadMetadata {
    /// encryption key + hmac
    var key: Data { get }

    /// True if the upload represents the reuse of an existing transit tier upload
    /// with metadata we had stored locally on disk.
    var isReusedTransitTierUpload: Bool { get }
}