Skip to main content

API Data Structures

AddBucketResponseMessage

class AddBucketResponseMessage extends CometAPIResponseMessage, NewBucketDetail {
}

AdminAccountPropertiesResponse

class AdminAccountPropertiesResponse {
    string               OrganizationID
    AdminUserPermissions Permissions
    AdminSecurityOptions Security // This field is available in Comet 18.9.9 and later.
}

AdminEmailOptions

class AdminEmailOptions {
    string FromEmail
    string FromName
}

AdminResourceResponse

class AdminResourceResponse extends CometAPIResponseMessage {
    string ResourceHash
}

AdminSecurityOptions

class AdminSecurityOptions {
    int                             PasswordFormat // One of the PASSWORD_FORMAT_ constants
    string                          Password
    bool                            AllowPasswordLogin
    bool                            AllowPasswordAndTOTPLogin
    bool                            AllowPasswordAndU2FLogin // AllowPasswordAndU2FLogin has been deprecated since Comet version 21.12.0
    bool                            AllowPasswordAndWebAuthnLogin

    // U2FRegistrations has been deprecated since Comet version 21.12.0
    // Omission from JSON document implies an empty array
    List<AdminU2FRegistration>      U2FRegistrations
    List<AdminWebAuthnRegistration> WebAuthnRegistrations // Omission from JSON document implies an empty array
    bool                            RequirePasswordChange // This field is available in Comet 24.12.0 and later.

    // One of the ENCRYPTIONMETHOD_ constants
    // Omission from JSON document implies 0
    int                             TOTPKeyEncryptionFormat
    string                          TOTPKey // Omission from JSON document implies empty string

    // A regular expression in Go regex syntax, for which IP addresses are allowed to authenticate as this admin account
    // Omission from JSON document implies empty string
    string                          IPWhitelist
}

AdminU2FRegistration

This type has been deprecated since Comet version 21.12.0

class AdminU2FRegistration {
    string     Description
    int        RegisterTime // Unix timestamp, in seconds.
    List<byte> Registration // This field is intended to contain raw binary data. When this field is marshalled as JSON format for the API, the field is expressed as base64. If you are using one of the public SDKs, this may take place automatically.
}

AdminUserPermissions

class AdminUserPermissions {
    bool         PreventEditServerSettings // Omission from JSON document implies false
    bool         PreventServerShutdown // Omission from JSON document implies false
    bool         PreventChangePassword // Omission from JSON document implies false
    bool         AllowEditBranding // Omission from JSON document implies false
    bool         AllowEditEmailOptions // Omission from JSON document implies false
    bool         AllowEditRemoteStorage // Omission from JSON document implies false
    bool         AllowEditWebhooks // Omission from JSON document implies false
    bool         AllowEditExternalAuthSources // Omission from JSON document implies false
    bool         DenyConstellationRole // Omission from JSON document implies false

    // This field is available in Comet 23.6.0 and later.
    // Omission from JSON document implies false
    bool         DenyViewServerHistory

    // This field is available in Comet 23.6.0 and later.
    // Omission from JSON document implies false
    bool         DenyViewServerInfo

    // This field is available in Comet 24.3.2 and later.
    // Omission from JSON document implies false
    bool         PreventDeleteStorageVault

    // This field is available in Comet 23.6.0 and later.
    // Omission from JSON document implies false
    bool         PreventRequestStorageVault

    // This field is available in Comet 23.6.0 and later.
    // Omission from JSON document implies false
    bool         PreventAddCustomStorageVault

    // This field is available in Comet 23.6.0 and later.
    // Omission from JSON document implies false
    bool         HideCloudStorageBranding

    // This field is available in Comet 23.6.0 and later.
    // Omission from JSON document implies false
    bool         ShouldRestrictProviderList

    // This field is available in Comet 23.6.0 and later.
    // Omission from JSON document implies an empty array
    List<int>    AllowedProvidersWhenRestricted

    // This field is available in Comet 23.9.11 and later.
    // Omission from JSON document implies an empty array
    List<string> AllowedUserPolicies

    // This field is available in Comet 24.6.1 and later.
    // Omission from JSON document implies false
    bool         DenySoftwareBuildRole
}

AdminWebAuthnRegistration

class AdminWebAuthnRegistration {
    string             Description
    int                RegisterTime // Unix timestamp, in seconds.
    int                Type
    bool               IsLegacyU2F // Omission from JSON document implies false

    // This field is intended to contain raw binary data. When this field is marshalled as JSON format for the API, the field is expressed as base64. If you are using one of the public SDKs, this may take place automatically.
    // Omission from JSON document implies an empty array
    List<byte>         ID
    WebAuthnCredential Credential // Omission from JSON document implies zero-initialised WebAuthnCredential class instance
}

AllowedAdminUser

class AllowedAdminUser extends AdminSecurityOptions {
    string               Username
    string               OrganizationID
    string               ExternalAuthenticationSource // Omission from JSON document implies empty string
    AdminUserPermissions Permissions
}

AmazonAWSVirtualStorageRoleSettings

class AmazonAWSVirtualStorageRoleSettings extends ObjectLockStorageTemplateSettings {

    // If set, the Storage Template will generate Storage Vaults pointing to a subdirectory within this bucket. A single dynamic IAM policy will cover all created Storage Vaults.
    // This is preferable for platforms that have limits on the total number of IAM policies. However, it requires a high level of IAM compatibility.
    // If left blank, the Storage Template will generate Storage Vaults pointing to new, separate S3 buckets each time. An additional IAM policy is created for each new Storage Vault.
    // This is preferable for platforms that have a lower level of IAM compatibility.
    string MasterBucket
    string AccessKey
    string SecretKey
}

AuthenticationRoleOptions

class AuthenticationRoleOptions {
    bool                      RoleEnabled
    int                       DatabaseCheckLevel // One of the INTEGRITYCHECK_ constants
    bool                      GenerateMissedBackupEvents
    int                       NoMissedBackupEventsBefore // Unix timestamp in seconds, before which no Missed jobs are created
    bool                      GenerateScheduledEmails
    int                       PruneLogsAfterDays
    List<RemoteStorageOption> RemoteStorage
    List<ReplicaServer>       ReplicateTo
    GlobalOverrideOptions     GlobalOverrides // Omission from JSON document implies zero-initialised GlobalOverrideOptions class instance
}

AvailableDownload

class AvailableDownload {
    string Category
    string Description
    bool   Recommended
}

AzureDestinationLocation

AzureDestinationLocation allows configuring connection settings for storage locations using the Azure Blob Storage API (DESTINATIONTYPE_AZURE).

class AzureDestinationLocation {
    string AZBAccountName
    string AZBAccountKey
    string AZBContainer
    string AZBRealm // The base URL for the Azure Blob Storage service. Leave blank to use the global default URL.
    string AZBPrefix
}

B2DestinationLocation

B2DestinationLocation allows configuring connection settings for storage locations using the Backblaze B2 native API (DESTINATIONTYPE_B2).

class B2DestinationLocation {

    // Key ID
    // Omission from JSON document implies empty string
    string AccountID

    // Application Key
    // Omission from JSON document implies empty string
    string Key
    string Bucket // Omission from JSON document implies empty string
    string Prefix // Omission from JSON document implies empty string

    // MaxConnections has been deprecated since Comet version 21.9.7
    // Omission from JSON document implies 0
    int    MaxConnections

    // Hide files instead of deleting them. This can be used for ransomware protection if (A) the B2 credentials have the hideFile permission but not the deleteFile permission, and (B) you use the Backblaze B2 server-side lifecycle policies to clean up old hidden files.
    // Omission from JSON document implies false
    bool   HideDeletedFiles
}

B2StorageExtraInfo

class B2StorageExtraInfo {
    Dictionary<int, B2TransactionTotals> TotalTransactionsInTimeInterval
}

B2TransactionTotals

class B2TransactionTotals {
    int ClassA
    int ClassB
    int ClassC
}

B2VirtualStorageRoleSettings

class B2VirtualStorageRoleSettings {
    string MasterBucket
    string KeyID
    string AppKey
    bool   HideDeletedFiles
}

BackupJobAdvancedOptions

BackupJobAdvancedOptions control additional advanced options for running a backup job. They can be specified as part of a schedule in the BackupRuleConfig type, or supplied immediately when running a job.

class BackupJobAdvancedOptions {
    bool   SkipAlreadyRunning
    int    StopAfter // If Zero: disabled
    int    LimitVaultSpeedBps // If Zero: disabled
    bool   ReduceDiskConcurrency // Default disabled
    bool   UseOnDiskIndexes // Default disabled
    bool   AllowZeroFilesSuccess // Default disabled
    int    AutoRetentionLevel // If Zero: default Automatic (BACKUPJOBAUTORETENTION_AUTOMATIC)
    int    ConcurrencyCount // Desired concurrency count. If Zero, uses mode defaults
    string LogLevel // Log verbosity level. LOG_DEBUG has the greatest verbosity
}

BackupJobDetail

class BackupJobDetail {
    string            GUID
    string            Username
    int               Classification
    int               Status
    int               StartTime // Unix timestamp in seconds
    int               EndTime // Unix timestamp in seconds. Will be zero if the job is still running.
    int               RetryCount
    string            SourceGUID // The Protected Item that this job is for
    string            DestinationGUID // The Storage Vault that this job is for
    string            DeviceID
    string            SnapshotID // Omission from JSON document implies empty string

    // The ID of the backup rule that contains the schedule that triggered this job
    // This field is available in Comet 24.6.6 and later.
    // Omission from JSON document implies empty string
    string            BackupRuleGUID
    string            ClientVersion
    int               TotalDirectories
    int               TotalFiles
    int               TotalSize
    int               TotalChunks
    int               UploadSize
    int               DownloadSize

    // For Hyper-V and VMware backup jobs, the total number of virtual machines.
    // Omission from JSON document implies 0
    int               TotalVmCount

    // For Office 365 backup jobs, the total number of mailboxes.
    // Omission from JSON document implies 0
    int               TotalMailsCount

    // For Office 365 backup jobs, the total number of SharePoint sites.
    // Omission from JSON document implies 0
    int               TotalSitesCount

    // For Office 365 backup jobs, the calculated effective number of protected accounts.
    // Omission from JSON document implies 0
    int               TotalAccountsCount

    // For Office 365 backup jobs, the number of licensed mailboxes.
    // Omission from JSON document implies 0
    int               TotalLicensedMailsCount

    // For Office 365 backup jobs, the number of unlicensed mailboxes.
    // Omission from JSON document implies 0
    int               TotalUnlicensedMailsCount

    // If this field is present, this job did not perform some work because the Storage Vault is currently busy.
    // This field is available in Comet 24.9.2 and later.
    // Omission from JSON document implies empty string
    string            ConflictingJobID

    // If this field is present, it is possible to request cancellation of this job via the API.
    // Omission from JSON document implies empty string
    string            CancellationID

    // If this backup job is still running, additional partial-progress information may be present in this field.
    // Omission from JSON document implies zero-initialised BackupJobProgress class instance
    BackupJobProgress Progress

    // The size of the Storage Vault, as measured at the start of the job.
    // Omission from JSON document implies zero-initialised SizeMeasurement class instance
    SizeMeasurement   DestinationSizeStart

    // The size of the Storage Vault, as measured at the end of the job.
    // Omission from JSON document implies zero-initialised SizeMeasurement class instance
    SizeMeasurement   DestinationSizeEnd
}

BackupJobProgress

class BackupJobProgress {
    int Counter // This field will always increase monotonically, exactly once, for every change to the BackupJobProgress for a given backup job.
    int SentTime // Unix timestamp in seconds
    int RecievedTime // Unix timestamp in seconds. The typo is preserved for backwards-compatibility reasons.
    int BytesDone
    int ItemsDone
    int ItemsTotal
}

BackupRuleConfig

A backup rule connects one source Protected Item and one destination Storage Vault, with multiple time schedules or event triggers

class BackupRuleConfig extends BackupJobAdvancedOptions {
    string                  Description
    int                     CreateTime // Unix timestamp in seconds
    int                     ModifyTime // Unix timestamp in seconds. The caller is responsible for updating this themselves.
    List<string>            PreExec // Custom commands to run before the job
    List<string>            ThawExec // Custom commands to run after taking a disk snapshot
    List<string>            PostExec // Custom commands to run after the job
    string                  Source // The source Protected Item ID to back up from, during this schedule
    string                  Destination // The destination Storage Vault ID to back up to, during this schedule
    List<ScheduleConfig>    Schedules // Scheduled start times
    BackupRuleEventTriggers EventTriggers // Other events that will cause this scheduled job to start
}

BackupRuleEventTriggers

class BackupRuleEventTriggers {

    // The "When PC Starts" option
    // Omission from JSON document implies false
    bool OnPCBoot

    // The "If the last job was Missed" option. In Comet 23.12.3 and later, this condition is evaluated when the PC starts and/or when the live connection is resumed.
    // Omission from JSON document implies false
    bool OnPCBootIfLastJobMissed

    // The option to enable retrying when a backup job failed.
    // This field is available in Comet 24.6.6 and later.
    // Omission from JSON document implies false
    bool OnLastJobFailDoRetry

    // The number of retries when the backup job fails.
    // This field is available in Comet 24.6.6 and later.
    // Omission from JSON document implies 0
    int  LastJobFailDoRetryCount

    // The number of minutes before retrying when the backup job fails.
    // This field is available in Comet 24.6.6 and later.
    // Omission from JSON document implies 0
    int  LastJobFailDoRetryTime
}

BrandingOptions

class BrandingOptions extends WebInterfaceBrandingProperties, BrandingProperties {
}

BrandingProperties

class BrandingProperties extends PublicBrandingProperties, PrivateBrandingProperties {
}

BrowseDiskDrivesResponse

class BrowseDiskDrivesResponse extends CometAPIResponseMessage {
    List<DiskDrive> Disks
}

BrowseEDBResponse

class BrowseEDBResponse extends CometAPIResponseMessage {
    List<EDBFileInfo> Databases
}

BrowseHVResponse

class BrowseHVResponse extends CometAPIResponseMessage {
    List<HyperVMachineInfo> VirtualMachines
}

BrowseOffice365ListVirtualAccountsResponse

class BrowseOffice365ListVirtualAccountsResponse extends CometAPIResponseMessage {
    List<Office365MixedVirtualAccount> Objects
}

BrowseOffice365ObjectsResponse

class BrowseOffice365ObjectsResponse extends CometAPIResponseMessage {
    List<Office365ObjectInfo> Objects
}

BrowseSQLServerResponse

class BrowseSQLServerResponse extends CometAPIResponseMessage {
    Dictionary<string, string> Objects
}

BrowseVMwareResponse

class BrowseVMwareResponse extends CometAPIResponseMessage {
    List<VMwareMachineInfo> VirtualMachines
}

BrowseVSSResponse

class BrowseVSSResponse extends CometAPIResponseMessage {
    Dictionary<string, VSSWriterInfo> VSSWriters
}

BucketProperties

class BucketProperties {
    string          OrganizationID
    int             CreateTime // Unix timestamp, in seconds.
    int             ReadWriteKeyFormat // One of the PASSWORD_FORMAT_ constants
    string          ReadWriteKey
    SizeMeasurement Size
}

BucketUsageInfo

class BucketUsageInfo {
    string             AccessKey
    List<int>          ExistsOnServers // The servers where this bucket was found. The 0-based indexes here correspond to the entries inside ConstellationRoleOptions->Servers.
    List<UserOnServer> InUseBy
}

CometAPIResponseMessage

class CometAPIResponseMessage {
    int    Status // If the operation was successful, the status will be in the 200-299 range.
    string Message
}

CometDestinationLocation

class CometDestinationLocation {
    string CometServer // The URL for the target Comet Server Storage Role, including http/https and trailing slash
    string CometBucket
    string CometBucketKey
}

ConstellationCheckReport

class ConstellationCheckReport {
    int                                 CheckStarted // Unix timestamp in seconds
    int                                 CheckCompleted // Unix timestamp in seconds
    Dictionary<string, BucketUsageInfo> Usage
}

ConstellationRoleOptions

class ConstellationRoleOptions {
    bool                      RoleEnabled
    bool                      DeleteUnusedData
    List<RemoteServerAddress> Servers
}

ConstellationStats

class ConstellationStats {
    int LastCheckStart // Unix timestamp, in seconds.
    int TotalChecksStarted // The total number of Constellation bucket report scans that have been performed since this Comet Server was last restarted
    int TotalBucketsDeleted // The total number of buckets that Constellation has successfully deleted since this Comet Server was last restarted
    int ChecksCurrentlyActive
}

ConstellationStatusAPIResponse

class ConstellationStatusAPIResponse {
    bool               DeletionEnabled
    List<string>       Targets

    // This field is available in Comet 18.6.2 and later.
    // Omission from JSON document implies an empty array
    List<string>       TargetNames
    ConstellationStats Stats
}

ContentMeasurement

class ContentMeasurement {
    int                               MeasureStarted // Unix timestamp in seconds
    int                               MeasureCompleted // Unix timestamp in seconds
    List<ContentMeasurementComponent> Components
}

ContentMeasurementComponent

class ContentMeasurementComponent {
    int          Bytes

    // A list of strings describing which groups of snapshots rely on reaching this component of data.
    // The strings may take the following formats:
    // - source_id/CURRENT - this data is required by the most recent backup job snapshot for the listed Protected Item source.
    // - source_id/HISTORIC - this data is required by an older backup job snapshot for the listed Protected Item source.
    // - TRUNCATED/* - there are too many separate components to show, and this component represents data that is used by some other combination of components. If present, it will be the only entry in the UsedBy array.
    // - the empty string - this amount of data is not currently referenced by any backup job snapshots. If that remains the case by the next retention pass, this much data will be deleted to free up space. If present, it will be the only entry in the UsedBy array.
    List<string> UsedBy
}

CountJobsResponse

class CountJobsResponse {
    int Count
}

CreateGroupPolicyResponse

class CreateGroupPolicyResponse extends CometAPIResponseMessage {
    string PolicyHash
}

CreateUserGroupResponse

class CreateUserGroupResponse extends CometAPIResponseMessage {
    string UserGroupID
}

CustomRemoteBucketSettings

class CustomRemoteBucketSettings {
    string                     URL
    Dictionary<string, string> CustomHeaders // This field is available in Comet 23.12.5 and later.
    string                     CustomBody // This field is available in Comet 24.5.0 and later.
    string                     CustomBodyType
}

DaysOfWeekConfig

class DaysOfWeekConfig {
    bool Sunday
    bool Monday
    bool Tuesday
    bool Wednesday
    bool Thursday
    bool Friday
    bool Saturday
}

DefaultEmailReportPolicy

class DefaultEmailReportPolicy extends UserCustomEmailSettings {

    // If true, the email reports will use the custom configuration that is defined in UserCustomEmailSettings / Reports fields.
    // If false, the email reports will use configuration from the policy setting if present, or else from the built-in system default email report configuration.
    bool ShouldOverrideDefaultReports
}

DefaultSourceWithOSRestriction

class DefaultSourceWithOSRestriction {
    SourceConfig SourceConfig
    int          RestrictOS
}

DestinationConfig

class DestinationConfig extends DestinationLocation {
    string                Description
    int                   CreateTime // Unix timestamp in seconds
    int                   ModifyTime // Unix timestamp in seconds
    List<string>          PreExec // Custom commands to run before the job
    List<string>          ThawExec // Custom commands to run after taking a disk snapshot
    List<string>          PostExec // Custom commands to run after the job
    int                   EncryptionKeyEncryptionMethod // One of the ENCRYPTIONMETHOD_ constants
    string                EncryptedEncryptionKey
    int                   RepoInitTimestamp // Unix timestamp in seconds. If zero, the Storage Vault has not yet been initialized for the first time.
    bool                  StorageLimitEnabled // Storage Vault quota
    int                   StorageLimitBytes // Storage Vault quota
    DestinationStatistics Statistics // Omission from JSON document implies zero-initialised DestinationStatistics class instance
    RetentionPolicy       DefaultRetention // Configure the retention policy for this Storage Vault. The rules will be applied to any snapshot inside this Storage Vault, unless that snapshot belongs to a Protected Item source that has an overriding retention policy.
    bool                  RebrandStorage // The "Prevent users from viewing the actual storage type" option
    string                RetentionError // If not empty, an error occured during a retention pass. Describes the error.
    List<string>          AssociatedDevices
}

DestinationLocation

This type is available in Comet 17.3.3 and later.

DestinationLocation describes the underlying storage location for a Storage Vault. Prior to Comet 17.3.3 this was an embedded part of the DestinationConfig type.

class DestinationLocation extends CometDestinationLocation, S3DestinationLocation, SFTPDestinationLocation, FTPDestinationLocation, AzureDestinationLocation, LocalDestinationLocation, SpannedDestinationLocation {
    int                       DestinationType // One of the DESTINATIONTYPE_ constants
    SwiftDestinationLocation  Swift
    B2DestinationLocation     B2
    WebDavDestinationLocation WebDav // This field is available in Comet 23.6.9 and later.
    StorjDestinationLocation  Storj
    SMBDestinationLocation    SMB
    string                    Tag
}

DestinationStatistics

class DestinationStatistics {
    SizeMeasurement    ClientProvidedSize
    ContentMeasurement ClientProvidedContent
    string             LastSuccessfulDeepVerify_GUID // Omission from JSON document implies empty string

    // Unix timestamp in seconds
    // Omission from JSON document implies 0
    int                LastSuccessfulDeepVerify_StartTime

    // Unix timestamp in seconds
    // Omission from JSON document implies 0
    int                LastSuccessfulDeepVerify_EndTime
}

DeviceConfig

class DeviceConfig {
    string                              FriendlyName

    // Unix timestamp in seconds
    // Omission from JSON document implies 0
    int                                 RegistrationTime

    // The operating system that the device uses.
    // Omission from JSON document implies zero-initialised OSInfo class instance
    OSInfo                              PlatformVersion

    // Minimal information about the device's private Protected Items, so that other devices can safely run retention passes on a shared Storage Vault.
    // Omission from JSON document implies an empty Dictionary
    Dictionary<string, SourceBasicInfo> Sources

    // The device's reported timezone in IANA format.
    // Omission from JSON document implies empty string
    string                              DeviceTimezone

    // This field is available in Comet 23.6.0 and later.
    // Omission from JSON document implies empty string
    string                              ClientVersion

    // This field is available in Comet 23.9.8 and later.
    // Omission from JSON document implies empty string
    string                              SyncroUUID
}

DiskDrive

class DiskDrive {
    string          ID
    string          DeviceName
    string          Caption
    string          Model
    string          SerialNumber
    int             Size // Bytes
    List<Partition> Partitions

    // For physical disks, this array will be empty. For virtual disks, RAID devices or Linux DM devices, this array may contain the DeviceName of the parent device.
    // This field is available in Comet 24.6.x and later.
    List<string>    DeviceParents
    int             Flags // See WINDISKFLAG_ constants
    int             Cylinders // Cylinders has been deprecated since Comet version 24.6.x This value is reported from the disk driver if available. Otherwise emulates a value based on modern LBA addressing. The field value is not used.
    int             Heads // Heads has been deprecated since Comet version 24.6.x This value is reported from the disk driver if available. Otherwise emulates a value based on modern LBA addressing. The field value is not used.
    int             Sectors // Sectors has been deprecated since Comet version 24.6.x This value is reported from the disk driver if available. Otherwise emulates a value based on modern LBA addressing. The field value is not used.
    int             SectorSize
}

DispatcherAdminSourcesResponse

class DispatcherAdminSourcesResponse extends CometAPIResponseMessage {
    Dictionary<string, string> ImportSources
}

DispatcherStoredObjectsResponse

class DispatcherStoredObjectsResponse extends CometAPIResponseMessage {
    List<StoredObject> StoredObjects
}

DispatcherVaultSnapshotsResponse

class DispatcherVaultSnapshotsResponse extends CometAPIResponseMessage {
    List<VaultSnapshot> Snapshots
}

DispatcherWindiskSnapshotResponse

class DispatcherWindiskSnapshotResponse extends CometAPIResponseMessage {
    List<DiskDrive> WindiskSnapshot
}

EDBFileInfo

class EDBFileInfo {
    string Name
    string Guid
    string ServerName
    bool   CircularLoggingEnabled
}

EmailOptions

class EmailOptions extends AdminEmailOptions {
    string                     Mode // One of the EMAIL_DELIVERY_ constants
    List<EmailReportingOption> EmailReportingOptions // Omission from JSON document implies an empty array
    string                     SMTPHost // Omission from JSON document implies empty string
    int                        SMTPPort // Omission from JSON document implies 0
    string                     SMTPUsername // Omission from JSON document implies empty string
    string                     SMTPPassword // Omission from JSON document implies empty string
    bool                       SMTPAllowInvalidCertificate // Omission from JSON document implies false
    bool                       SMTPAllowUnencrypted // Omission from JSON document implies false

    // Override the HELO/EHLO hostname for SMTP or MX Direct modes. If blank, uses system default HELO/EHLO hostname.
    // Omission from JSON document implies empty string
    string                     SMTPCustomEhlo
}

EmailReportConfig

class EmailReportConfig {
    int                  ReportType // One of the EMAILREPORTTYPE_ constants
    List<ScheduleConfig> SummaryFrequency // Used as a list of scheduled times to send

    // Used to the determine the time bounds of a report
    // Omission from JSON document implies zero-initialised TimeSpan class instance
    TimeSpan             TimeSpan
    SearchClause         Filter
}

EmailReportGeneratedPreview

class EmailReportGeneratedPreview extends CometAPIResponseMessage {
    string       From
    List<string> To
    string       EmailSubject
    string       EmailBodyHTML
    string       EmailBodyPlaintext
}

EmailReportingOption

class EmailReportingOption {
    EmailReportConfig EmailReportConfig
    string            LanguageCode // A supported language code (e.g. "en_US" or the DEFAULT_LANGUAGE constant)
    string            LocalTimezone // The timezone in IANA format (e.g. "Pacific/Auckland" or the DEFAULT_TIMEZONE constant)
    List<string>      Recipients
}

ExternalAuthenticationSource

class ExternalAuthenticationSource extends RemoteServerAddress {
    AdminUserPermissions NewUserPermissions
}

ExternalAuthenticationSourceDisplay

class ExternalAuthenticationSourceDisplay {
    string DisplayName
    string LoginStartURL
}

ExternalAuthenticationSourceResponse

class ExternalAuthenticationSourceResponse {
    int                          Status
    string                       Message
    string                       ID
    ExternalAuthenticationSource Source
}

ExternalLDAPAuthenticationSourceServer

class ExternalLDAPAuthenticationSourceServer {
    string Hostname
    int    Port
    string SecurityMethod // One of the LDAPSECURITYMETHOD_ constants (e.g. "plain" / "ldaps" / "starttls")
    bool   AcceptInvalidSSL
}

ExternalLDAPAuthenticationSourceSettings

class ExternalLDAPAuthenticationSourceSettings extends ExternalLDAPAuthenticationSourceServer {
    List<ExternalLDAPAuthenticationSourceServer> FallbackServers
    string                                       BindUser
    string                                       BindPassword
    string                                       SearchDN
    string                                       SearchFilter
}

ExtraFileExclusion

class ExtraFileExclusion {
    string Exclude // The glob or regular expression to exclude from backup jobs
    bool   Regex // Choose whether the 'Exclude' parameter will be treated as a regular expression (true) or a glob (false)
    int    RestrictOS // Either OS_ANY or one of the OS_ONLY constants
}

FTPDestinationLocation

class FTPDestinationLocation {
    string FTPServer
    string FTPUsername
    string FTPPassword
    bool   FTPBaseUseHomeDirectory // If true, store data in the default home directory given by the FTP server. If false, store data in the FTPCustomBaseDirectory path.
    string FTPCustomBaseDirectory // If FTPBaseUseHomeDirectory is false, this field controls the path where data is stored.
    int    FTPSMode // Control whether this is plaintext FTP or secure FTPS by using one of the FTPS_MODE_ constants.
    int    FTPPort
    int    FTPMaxConnections // If set to zero, uses a system default value that is not unlimited.
    bool   FTPAcceptInvalidSSL
}

FileOption

This type is available in Comet 23.3.7 and later.

FileOption defines the configuration for Comet Server to log live events to a file. See the SEVT_ constants for more information.

class FileOption {
    string    Filename // The prefix for the log filename. It will be stored in the same file location as the Comet Server log files

    // Configure a subset of allowed event types (see SEVT_ constants). If the array is empty, all events will be sent
    // Omission from JSON document implies an empty array
    List<int> AllowEventTypes

    // One of the STREAM_LEVEL_ constants. This controls how much data is logged into the file
    // Omission from JSON document implies empty string
    string    Level

    // Enables pruning of log files
    // Omission from JSON document implies false
    bool      PruningEnabled

    // Limit in days to keep log files when PruningEnabled is set to true. If not set or 0, uses server's PruneLogsAfterDays
    // Omission from JSON document implies 0
    int       PruningLimit
}

GetGroupPolicyResponse

class GetGroupPolicyResponse extends CometAPIResponseMessage {
    GroupPolicy Policy
    string      PolicyHash
}

GetProfileAndHashResponseMessage

class GetProfileAndHashResponseMessage extends CometAPIResponseMessage {
    string            ProfileHash // A hash identifier for the current state of the user's profile. If you supply this in the AdminSetUserProfileHash API, the server can safely reject your change if another change has happened concurrently. This allows you to retry the request.
    UserProfileConfig Profile
}

GetProfileHashResponseMessage

class GetProfileHashResponseMessage extends CometAPIResponseMessage {
    string ProfileHash
}

GetUserGroupResponse

class GetUserGroupResponse {
    UserGroup UserGroup
    string    UserGroupHash
}

GetUserGroupWithUsersResponse

class GetUserGroupWithUsersResponse {
    UserGroup                             UserGroup
    Dictionary<string, UserProfileConfig> Users
}

GlobalOverrideOptions

class GlobalOverrideOptions {
    int RandomDelaySecs // Omission from JSON document implies 0
}

GroupPolicy

class GroupPolicy {
    string     Description
    string     OrganizationID
    UserPolicy Policy
    bool       DefaultUserPolicy // DefaultUserPolicy marks that this UserPolicy should be applied to all new users. The Comet Server will ensure that only one policy can be set as default.
    int        CreatedDate // Unix timestamp in seconds. May be zero for Policies created prior to Comet 23.3.3.
    int        ModifiedDate // Unix timestamp in seconds. May be zero for Policies created prior to Comet 23.3.3.
}

HTTPConnectorOptions

class HTTPConnectorOptions {
    string ListenAddress
    string SSLCertPath // Omission from JSON document implies empty string
    string SSLIntermediate // Omission from JSON document implies empty string
    string SSLCertKey // Omission from JSON document implies empty string
    string AutoSSLDomains // Omission from JSON document implies empty string
    string SSLPfxPath // Omission from JSON document implies empty string
    string SSLPfxPassword // Omission from JSON document implies empty string
}

HourSchedConfig

class HourSchedConfig {
    int Hour
    int Minutes
}

HyperVMachineInfo

class HyperVMachineInfo {
    string ID
    string Name
}

ImpossibleCloudIAMTemplateSettings

This type is available in Comet 24.3.1 and later.

class ImpossibleCloudIAMTemplateSettings extends ObjectLockStorageTemplateSettings {
    string AccessKey
    string SecretKey
    string Region // Optional. The region for both IAM communication and for provisioning new buckets. If blank, uses the default region for Impossible Cloud (eu-central-2).
}

ImpossibleCloudPartnerTemplateSettings

This type is available in Comet 24.3.1 and later.

class ImpossibleCloudPartnerTemplateSettings extends ObjectLockStorageTemplateSettings {
    string Region // Optional. The region for your Partner console and for provisioning new buckets. If blank, uses the default region for Impossible Cloud (eu-central-2).
    string AccessKey
}

InstallCreds

class InstallCreds {
    string Username
    string Password
    string TOTPCode
    string Server
    bool   AutoLogin
}

InstallToken

class InstallToken {
    string Username
    string Server // The URL of the Comet Server (Auth Role) for the target user to log in to.
    string Token // The token for use with the "/TOKEN=" silent install flag.
    int    CreateTime // Unix timestamp, in seconds.
    bool   Used // If the token has been used, it cannot be used again.
    int    ExpireTime // Unix timestamp, in seconds.
}

InstallTokenResponse

class InstallTokenResponse extends CometAPIResponseMessage {
    InstallToken InstallToken
}

JobEntry

JobEntry is a single entry within a job report.

class JobEntry {
    int    Time // Unix timestamp in seconds
    string Severity // One of the SEVERITY_ constants.
    string Message
}

LicenseLimits

class LicenseLimits {
    int                     deviceCount // Omission from JSON document implies 0
    Dictionary<string, int> boosterCount // Omission from JSON document implies an empty Dictionary
}

LicenseOptions

class LicenseOptions {
    string Email // Omission from JSON document implies empty string
    string SerialNumber
}

LiveUserConnection

class LiveUserConnection {
    string Username
    string DeviceID
    string ReportedVersion // The Comet Backup software version that this live-connected device reports that it is running. It takes the format "MAJOR.MINOR.PATCH", such as "23.2.0". See the APPLICATION_VERSION constant for more information.
    string ReportedPlatform // The operating system of the device. It is one of the PLATFORM_ constants; then a forwardslash (/); then the device's GOARCH.

    // The operating system of the device, in extended detail.
    // Omission from JSON document implies zero-initialised OSInfo class instance
    OSInfo ReportedPlatformVersion

    // The reported timezone of the device, in IANA format.
    // Omission from JSON document implies empty string
    string DeviceTimeZone

    // The live-connected device's remote IP address, as seen from the Comet Server.
    // Omission from JSON document implies empty string
    string IPAddress
    int    ConnectionTime // Unix timestamp, in seconds.
    bool   AllowsFilenames // The current state of the "Allow administrator to view my files" client-side option. If this option is refused, some live-connected actions will be refused by the device.
}

LocalDestinationLocation

class LocalDestinationLocation {
    string LocalcopyPath
    string LocalcopyWinSMBUsername // If logging in to a Windows network share (SMB/CIFS) is required, enter the username here.
    string LocalcopyWinSMBPassword // If logging in to a Windows network share (SMB/CIFS) is required, enter the password here. The password may be hashed as per the LocalcopyWinSMBPasswordFormat field.
    int    LocalcopyWinSMBPasswordFormat // One of the PASSWORD_FORMAT_ constants. It controls the hash format of the LocalcopyWinSMBPassword field.
}

LocalStorageDirectory

class LocalStorageDirectory {
    string Path
}

LoginProtectionOptions

class LoginProtectionOptions {
    bool Enabled // Enable this feature to block repeated failed login attempts to the Comet Server.
    int  FailureThreshold // The number of failed attempts before a cooldown is applied. If the feature is enabled, should be at least 1.
    int  CooldownSeconds // The duration to block requests, in seconds. If the feature is enabled, should be at least 1 second.
}

MSSQLConnection

class MSSQLConnection {
    string Type // One of the MSSQL_AUTH_ constants (e.g. "windows" or "native")
    string Username
    string Password
    string Hostname // Hostname has been deprecated since Comet version Unused
    string InstanceName
    string Method // One of the MSSQL_METHOD_ constants, to control using x86_32 or x86_64 OLEDB drivers
}

MSSQLLoginArgs

class MSSQLLoginArgs {
    string Instance
    string AuthMode
    string Username
    string Password
    bool   MethodIsOledb32Bit
    bool   RestoreNoRecovery // If this MSSQLLoginArgs structure is used for a restore job (RestoreJobAdvancedOptions) using RESTORETYPE_MSSQL, then, this field controls the RECOVERY / NO RECOVERY option state.
}

MacOSCodeSignProperties

class MacOSCodeSignProperties {
    int           Level // One of the MACOSCODESIGN_LEVEL_ constants
    bool          SignLocally
    SSHConnection SSHServer
    string        CertificateName // "Developer ID Installer" certificate, either a local filepath or a resource:// URI. Used for signing the final flat *.pkg.
    string        AppCertificateName // "Developer ID Application" certificate, either a local filepath or a resource:// URI. Used for signing internal binaries if Notary is enabled
    string        AppleID
    string        AppleIDPass
    int           AppleIDPassFormat // One of the ENCRYPTIONMETHOD_ constants
    string        CertificateFile
    string        AppCertificateFile
    string        PfxFilePassword
    int           PfxFilePasswordFormat // One of the ENCRYPTIONMETHOD_ constants
    string        NotaryAPIIssuerID
    string        NotaryAPIKeyID
    string        NotaryAPIKeyFile
}

MongoDBConnection

class MongoDBConnection {
    string        Server
    int           Port
    string        Username
    string        Password
    string        AuthenticationDB

    // Prior to Comet 22.12.3, must be a filesystem path to `mongo` (n.b. not `mongosh`). In Comet >= 22.12.3, not used.
    // MongoShellPath has been deprecated since Comet version 22.12.3
    string        MongoShellPath
    string        MongodumpPath
    string        ReadPreference
    bool          UseReplica
    string        ReplicaName
    List<string>  ReplicaMembers
    bool          UseSSL
    string        ClientSSLPEMPath
    string        ServerSSLPEMPath
    string        SSLClientKeyPassword
    bool          AllowInvalidCertificate
    bool          AllowInvalidHostname
    bool          UseSSH
    SSHConnection SSHConnection // Omission from JSON document implies zero-initialised SSHConnection class instance
}

MySQLConnection

class MySQLConnection {
    string Host
    string Port
    string Username // Optional
    string Password // Optional
    bool   UseTLS
    bool   TLSSkipVerify
    string TLSCustomServerCAPath
    string TLSCustomClientCrtPath
    string TLSCustomClientKeyPath
}

NewBucketDetail

class NewBucketDetail {
    string NewBucketID
    string NewBucketKey
}

NewsEntry

class NewsEntry {
    string OrganizationID
    int    DateTime // Unix timestamp, in seconds.
    string TextContent
}

OSInfo

OSInfo represents the common set of version information between all operating systems

class OSInfo {

    // The primary version number (e.g. on Windows: 1703 / 2009, on Linux: 20.04 / 22.04)
    // Omission from JSON document implies empty string
    string version

    // The primary presentation name (e.g. "Windows 10 Pro", "debian", "Synology DSM")
    // Omission from JSON document implies empty string
    string distribution

    // The detailed build number (e.g. 19043)
    // Omission from JSON document implies empty string
    string build

    // The GOOS value
    // This field is available in Comet 23.6.0 and later.
    // Omission from JSON document implies empty string
    string os

    // The GOARCH value
    // This field is available in Comet 23.6.0 and later.
    // Omission from JSON document implies empty string
    string arch
}

ObjectLockStorageTemplateSettings

class ObjectLockStorageTemplateSettings {
    bool UseObjectLock // UseObjectLock has been deprecated since Comet version 23.x.x
    int  ObjectLockMode // Control whether the resulting Storage Vaults are configured for Object Lock. One of the OBJECT_LOCK_ constants
    int  ObjectLockDays

    // Control whether the "Allow removal of deleted files" checkbox is enabled for Storage Vaults generated from this Storage Template.
    // When configuring a Storage Template from the Comet Server web interface, this field is set automatically for Storage Templates using Object Lock.
    bool RemoveDeleted
}

Office365Connection

class Office365Connection {
    int                      Concurrency
    Office365Credential      Credential
    Office365CustomSetting   CustomSetting
    Office365CustomSettingV2 CustomSettingV2
    string                   FeatureFlag
    string                   LogLevel
    List<string>             MailboxUniqueMembers
    List<string>             SiteUniqueMembers
}

Office365Credential

class Office365Credential {
    string AppID
    string TenantID
    string Secret
    string AppCert
    string Region
}

Office365CustomSetting

This type has been deprecated since Comet version 21.9.xx

Office365CustomSetting is used in the EngineProps for an Office 365 Protected Item (see ENGINE_BUILTIN_MSOFFICE). If present, it will be automatically converted to the replacement Office365CustomSettingV2 type.

class Office365CustomSetting {
    string       MailboxStrategy
    string       SiteStrategy
    List<string> MailboxUserIDs
    List<string> MailboxGroupIDs
    List<string> SiteIDs
}

Office365CustomSettingV2

This type is available in Comet 21.9.xx and later.

Office365CustomSettingV2 is used in the EngineProps for an Office 365 Protected Item (see ENGINE_BUILTIN_MSOFFICE).

class Office365CustomSettingV2 {
    bool                    Organization // If true, then backup the entire Office 365 Tenant except the selected members. If false, backup the selected members only.

    // Key can be the ID of user, group or SharePoint
    // Value is a bitset of the SERVICE_ constants, to select which services to back up for this member.
    // Omission from JSON document implies an empty Dictionary
    Dictionary<string, int> BackupOptions

    // Key must be a group ID
    // Value is a bitset of the SERVICE_ constants, to select which services to back up for this member.
    // Omission from JSON document implies an empty Dictionary
    Dictionary<string, int> MemberBackupOptions
}

Office365MixedVirtualAccount

class Office365MixedVirtualAccount {
    string       DefaultDriveID // Omission from JSON document implies empty string
    bool         Disabled // Omission from JSON document implies false
    string       DisplayName // Omission from JSON document implies empty string
    int          EnabledServiceOption // Omission from JSON document implies 0
    string       id
    string       JobTitle // Omission from JSON document implies empty string
    string       Mail // Omission from JSON document implies empty string
    string       SiteID // Omission from JSON document implies empty string
    int          Type // Omission from JSON document implies 0
    string       UserPrincipalName // Omission from JSON document implies empty string
    string       WebID // Omission from JSON document implies empty string
    string       WebURL // Omission from JSON document implies empty string
    List<string> Members // Omission from JSON document implies an empty array
    int          ServiceOptions // Omission from JSON document implies 0
    int          MemberServiceOptions // Omission from JSON document implies 0
    bool         hasLicense // Omission from JSON document implies false
}

Office365ObjectInfo

class Office365ObjectInfo {
    string       GUID
    string       Name
    string       Type
    string       Value // May be an email address or a SharePoint site URL
    List<string> Members
}

OidcClaim

class OidcClaim {
    string Name
    string Value // Omission from JSON document implies empty string
}

OidcConfig

class OidcConfig {
    string          DisplayName
    List<string>    Hosts // Omission from JSON document implies an empty array
    string          OrganizationID // Omission from JSON document implies empty string
    string          Provider
    string          ClientID
    string          ClientSecret
    bool            SkipMFA
    List<string>    Scopes // Omission from JSON document implies an empty array
    List<OidcClaim> RequiredClaims // Omission from JSON document implies an empty array
    string          DiscoveryDocumentURL // Omission from JSON document implies empty string
    string          AzureTenantID // Omission from JSON document implies empty string
    string          GoogleHostedDomain // Omission from JSON document implies empty string
}

Organization

class Organization {
    Dictionary<string, FileOption>    AuditFileOptions
    BrandingOptions                   Branding
    ConstellationRoleOptions          ConstellationRole
    EmailOptions                      Email
    List<string>                      ExperimentalOptions // Omission from JSON document implies an empty array
    List<string>                      Hosts
    string                            Name
    bool                              IsSuspended
    List<PSAConfig>                   PSAConfigs
    List<RemoteStorageOption>         RemoteStorage
    SoftwareBuildRoleOptions          SoftwareBuildRole
    Dictionary<string, WebhookOption> WebhookOptions
}

OrganizationLoginURLResponse

class OrganizationLoginURLResponse {
    string LoginURL
}

OrganizationResponse

class OrganizationResponse {
    int          Status
    string       Message
    string       ID
    Organization Organization
}

PSAConfig

class PSAConfig {
    bool                       AlertsDisabled // For PSA_TYPE_GRADIENT. Defaults to enabled

    // Custom headers to send with each PSA request
    // Omission from JSON document implies an empty Dictionary
    Dictionary<string, string> CustomHeaders

    // Specified API key for the target PSA
    // Omission from JSON document implies empty string
    string                     PartnerKey
    int                        Type // One of the PSA_TYPE_ constants
    string                     URL // The URL or subdomain for outbound PSA requests
    PSAGroupedBy               GroupedBy
}

PSAGroupedBy

class PSAGroupedBy {
    bool Users
    bool Tenants
    bool AccountName
}

Partition

class Partition {
    string       DeviceName
    string       Filesystem // The name of the filesystem used on this partition (e.g. "NTFS")
    string       VolumeName
    string       VolumeGuid
    string       VolumeSerial
    List<string> MountPoints
    int          ReadOffset // Bytes. The partition's offset within the DeviceName. It will be zero if this partition has a direct DeviceName handle.
    int          Size // Bytes
    int          UsedSize // Bytes. Only present for supported filesystems that are currently mounted by the OS
    int          Flags
    int          BytesPerFilesystemCluster
}

PrivateBrandingProperties

class PrivateBrandingProperties extends WindowsCodeSignProperties {
    int                     BuildMode // One of the CLIENTBRANDINGBUILD_ constants
    string                  PathIcoFile
    string                  PathIcnsFile
    string                  PathMenuBarIcnsFile
    string                  PathEulaRtf
    string                  PathTilePng
    string                  PathHeaderImage
    string                  PathAppIconImage
    string                  PackageIdentifier
    MacOSCodeSignProperties MacOSCodeSign
}

ProtectedItemEngineTypePolicy

class ProtectedItemEngineTypePolicy {
    bool         ShouldRestrictEngineTypeList
    List<string> AllowedEngineTypeWhenRestricted
}

PublicBrandingProperties

class PublicBrandingProperties {
    string ProductName
    string CompanyName
    string HelpURL
    bool   HelpIsPopup
    string DefaultLoginServerURL
    string TileBackgroundColor
    string AccountRegisterURL
    bool   HideBackgroundLogo
    string CloudStorageName
    bool   AdminHidePreBuiltClientOption
    bool   AdminHideBrandedCloudStorage
}

RatelimitOptions

class RatelimitOptions {
    List<RatelimitRule> Rules // Omission from JSON document implies an empty array
}

RatelimitRule

class RatelimitRule {
    string MatchRegex
    int    BytesPerSecond
}

RegisterOfficeApplicationBeginResponse

class RegisterOfficeApplicationBeginResponse {
    string Continuation
    string VerificationURL
    string UserCode
}

RegisterOfficeApplicationCheckResponse

class RegisterOfficeApplicationCheckResponse {
    string              Continuation
    bool                Completed
    string              Error
    Office365Credential Result // Omission from JSON document implies zero-initialised Office365Credential class instance
}

RegistrationLobbyConnection

class RegistrationLobbyConnection {
    string DeviceID
    string OrganizationID
    string FriendlyName
    string ReportedVersion
    string ReportedPlatform
    OSInfo ReportedPlatformVersion // Omission from JSON document implies zero-initialised OSInfo class instance
    string DeviceTimeZone // Omission from JSON document implies empty string
    string IPAddress // Omission from JSON document implies empty string
    int    ConnectionTime
}

RemoteServerAddress

class RemoteServerAddress {
    string                                   Type
    string                                   Description

    // For use with Comet Server (Storage Role / Auth Role)
    // Omission from JSON document implies empty string
    string                                   RemoteAddress

    // For use with Comet Server (Storage Role / Auth Role)
    // Omission from JSON document implies empty string
    string                                   Username

    // For use with Comet Server (Storage Role / Auth Role)
    // Omission from JSON document implies empty string
    string                                   Password
    ExternalLDAPAuthenticationSourceSettings LDAP // Omission from JSON document implies zero-initialised ExternalLDAPAuthenticationSourceSettings class instance
    OidcConfig                               OIDC // Omission from JSON document implies zero-initialised OidcConfig class instance

    // Backblaze B2 (Storage Template / Constellation)
    // Omission from JSON document implies zero-initialised B2VirtualStorageRoleSettings class instance
    B2VirtualStorageRoleSettings             B2

    // Wasabi, or Comet Storage powered by Wasabi (Storage Template / Constellation)
    // Omission from JSON document implies zero-initialised WasabiVirtualStorageRoleSettings class instance
    WasabiVirtualStorageRoleSettings         Wasabi

    // Custom Remote Bucket HTTP protocol (Storage Template)
    // Omission from JSON document implies zero-initialised CustomRemoteBucketSettings class instance
    CustomRemoteBucketSettings               Custom

    // IDrive e2, or Custom IAM-compatible (Storage Template / Constellation)
    // Omission from JSON document implies zero-initialised S3GenericVirtualStorageRole class instance
    S3GenericVirtualStorageRole              S3

    // Amazon AWS (Storage Template / Constellation)
    // Omission from JSON document implies zero-initialised AmazonAWSVirtualStorageRoleSettings class instance
    AmazonAWSVirtualStorageRoleSettings      AWS

    // Storj (Storage Template / Constellation)
    // Omission from JSON document implies zero-initialised StorjVirtualStorageRoleSetting class instance
    StorjVirtualStorageRoleSetting           Storj

    // Impossible Cloud Partner API (Storage Template / Constellation)
    // Omission from JSON document implies zero-initialised ImpossibleCloudPartnerTemplateSettings class instance
    ImpossibleCloudPartnerTemplateSettings   ImpPartner

    // Impossible Cloud IAM API (Storage Template / Constellation)
    // Omission from JSON document implies zero-initialised ImpossibleCloudIAMTemplateSettings class instance
    ImpossibleCloudIAMTemplateSettings       ImpUser
}

RemoteStorageOption

class RemoteStorageOption extends RemoteServerAddress {
    bool   StorageLimitEnabled
    int    StorageLimitBytes
    bool   RebrandStorage
    string ID
    bool   Default
}

ReplicaServer

class ReplicaServer extends RemoteServerAddress {
    string ReplicaDeletionStrategy // Omission from JSON document implies empty string
}

ReplicatorStateAPIResponse

class ReplicatorStateAPIResponse {
    string Description
    string RemoteServerID
    int    DisplayClass
    int    ActiveWorkers
    int    TotalWorkers
    int    State
    int    ItemsQueued
    int    BytesQueued
    int    LastWorkerSubmitTime
    int    CurrentTime
    int    ItemsReplicated
    int    BytesReplicated
}

RequestStorageVaultResponseMessage

class RequestStorageVaultResponseMessage extends CometAPIResponseMessage {
    string DestinationID
}

RestoreJobAdvancedOptions

class RestoreJobAdvancedOptions {
    int                 Type // One of the RESTORETYPE_ constants
    bool                OverwriteExistingFiles // For RESTORETYPE_FILE
    bool                OverwriteIfNewer // For RESTORETYPE_FILE. If set, OverwriteExistingFiles must be true
    bool                OverwriteIfDifferentContent // For RESTORETYPE_FILE. If set, OverwriteExistingFiles must be true
    bool                OverwriteForcePermissions // For RESTORETYPE_FILE. If set, OverwriteExistingFiles must be true. This can be set in combination with other OverwriteIf options.
    bool                DestIsOriginalLocation // For RESTORETYPE_FILE. If set, DestPath must be blank
    string              DestPath // For RESTORETYPE_FILE or RESTORETYPE_PROCESS_xxx
    List<string>        ExactDestPaths // For RESTORETYPE_WINDISK only. Must have one entry for each selected restore path
    int                 ArchiveFormat // For RESTORETYPE_FILE_ARCHIVE or RESTORETYPE_PROCESS_ARCHIVE. Default 0 is *.tar, for backward compatibility

    // Default disabled. For RESTORETYPE_FILE and RESTORETYPE_WINDISK. Used to continue the restore job when unreadable data chunks are found.
    // Corresponds to the "Allow partial file restores (zero-out unrecoverable data)" option
    // This field is available in Comet 23.6.4 and later.
    bool                SkipUnreadableChunks

    // Default disabled. Used to store the index files on disk instead of in memory.
    // Corresponds to the "Prefer temporary files instead of RAM (slower)" option
    // This field is available in Comet 23.6.4 and later.
    bool                OnDiskIndexesKey

    // For RESTORETYPE_OFFICE365_CLOUD.
    // Omission from JSON document implies zero-initialised Office365Credential class instance
    Office365Credential Office365Credential
    string              Username // For RESTORETYPE_MYSQL
    string              Password // For RESTORETYPE_MYSQL
    string              Host // For RESTORETYPE_MYSQL
    string              Port // For RESTORETYPE_MYSQL
    bool                UseSsl // For RESTORETYPE_MYSQL
    bool                SslAllowInvalid // For RESTORETYPE_MYSQL i.e.: Self signed certs
    string              SslCaFile // For RESTORETYPE_MYSQL
    string              SslCrtFile // For RESTORETYPE_MYSQL
    string              SslKeyFile // For RESTORETYPE_MYSQL

    // For RESTORETYPE_MSSQL.
    // Omission from JSON document implies zero-initialised MSSQLLoginArgs class instance
    MSSQLLoginArgs      MsSqlConnection
}

RetentionPolicy

class RetentionPolicy {
    int                  Mode // One of the RETENTIONMODE_ constants
    List<RetentionRange> Ranges
}

RetentionRange

The Type field controls which fields of this data type are used. For additional information, see the notes on the RETENTIONRANGE_ constants.

class RetentionRange {
    int Type // One of the RETENTIONRANGE_ constants
    int Timestamp // Unix timestamp, in seconds. Used by RETENTIONRANGE_NEWER_THAN_X.
    int Jobs
    int Days
    int Weeks
    int Months
    int WeekOffset // 0: Sunday, 6: Saturday

    // 1: 1st, 31: 31st
    // Prior to Comet version 23.6.2, 31 was treated as 30.
    // For months that do not have a day equal to the specified offset, no backup will be retained.
    // For example, if the offset is set to 30, no backup will be kept for February.
    int MonthOffset
}

S3DestinationLocation

class S3DestinationLocation {
    string S3Server
    bool   S3UsesTLS
    string S3AccessKey
    string S3SecretKey
    string S3BucketName
    string S3Subdir
    string S3CustomRegion
    bool   S3UsesV2Signing // If true, use legacy v2 signing. If false (default), use modern v4 signing
    bool   S3RemoveDeleted
    int    S3ObjectLockMode
    int    S3ObjectLockDays
}

S3GenericVirtualStorageRole

class S3GenericVirtualStorageRole extends AmazonAWSVirtualStorageRoleSettings {
    string S3Endpoint // The URL for S3 API calls (e.g. "s3.amazonaws.com")
    string IAMEndpoint // The URL for IAM API calls (e.g. "iam.amazonaws.com")

    // Optional. The region to be used for new buckets. If blank, uses the default region for the S3-compatible provider (e.g. us-east-1).
    // This field is available in Comet 24.3.1 and later.
    string Region

    // Optional. Prefix to use for bucket paths.
    // This field is available in Comet 24.6.3 and later.
    string Prefix
}

SFTPDestinationLocation

class SFTPDestinationLocation {
    string SFTPServer
    string SFTPUsername
    string SFTPRemotePath // The directory on the SFTP server in which data is stored.
    int    SFTPAuthMode // One of the DESTINATION_SFTP_AUTHMODE_ constants
    string SFTPPassword // For use with DESTINATION_SFTP_AUTHMODE_PASSWORD only: the SSH password to connect with
    string SFTPPrivateKey // For use with DESTINATION_SFTP_AUTHMODE_PRIVATEKEY only: the SSH private key to connect with, in OpenSSH format.
    bool   SFTPCustomAuth_UseKnownHostsFile // If true, then the SFTPCustomAuth_KnownHostsFile will be used to verify the remote SSH server's host key, using Trust On First Use (TOFU).
    string SFTPCustomAuth_KnownHostsFile // If SFTPCustomAuth_UseKnownHostFile is true, the path to the SSH known_hosts file.
}

SMBDestinationLocation

class SMBDestinationLocation {
    string SMBServer
    string SMBShare
    string SMBDirectory
    string SMBUsername
    string SMBPassword
}

SSHConnection

class SSHConnection {
    string SSHServer
    string SSHUsername
    int    SSHAuthMode // One of the SSHCONNECTION_AUTHMODE_ constants
    string SSHPassword // For use with SSHCONNECTION_AUTHMODE_PASSWORD only: the SSH password to connect with
    string SSHPrivateKey // For use with SSHCONNECTION_AUTHMODE_PRIVATEKEY only: the SSH private key to connect with, in OpenSSH format.
    bool   SSHCustomAuth_UseKnownHostsFile // If true, then the SSHCustomAuth_KnownHostsFile will be used to verify the remote SSH server's host key, using Trust On First Use (TOFU).
    string SSHCustomAuth_KnownHostsFile // If SSHCustomAuth_UseKnownHostsFile is true, the path to the SSH known_hosts file.
}

ScheduleConfig

class ScheduleConfig {
    int              FrequencyType
    int              SecondsPast
    int              Offset // Omission from JSON document implies 0
    bool             RestrictRuntime
    HourSchedConfig  FromTime
    HourSchedConfig  ToTime
    bool             RestrictDays
    DaysOfWeekConfig DaysSelect
    int              RandomDelaySecs // Omission from JSON document implies 0
}

SearchClause

class SearchClause {
    string             ClauseType // One of the SEARCHCLAUSE_ constants (e.g. empty-string if this is a rule, or "and"/"or" if there are ClauseChildren)
    string             RuleField // The field name to search. Check the specific API for more information about which fields are available for searching. For use with ClauseType = SEARCHCLAUSE_RULE.
    string             RuleOperator // One of the SEARCHOPERATOR_ constants. The operator must match the type of the particular field. For use with ClauseType = SEARCHCLAUSE_RULE.

    // The value to compare the field against.
    // - If the field is a string, any string is permissable.
    // - If the field is an integer, the integer should be cast to a base-10 string. There is currently no support for fractional or floating-point numbers.
    // - If the field is a boolean, the following values can be used for true ("1", "t", "T", "true", "TRUE", "True") and the following values can be used for false ("0", "f", "F", "false", "FALSE", "False").
    // For use with ClauseType = SEARCHCLAUSE_RULE.
    string             RuleValue

    // If ClauseType is not SEARCHCLAUSE_RULE, the child rules will be applied according to the ClauseType (e.g. "and"/"or")
    // Omission from JSON document implies an empty array
    List<SearchClause> ClauseChildren
}

SearchResultFileInfo

SearchResultFileInfo describes a single result entry when searching for files within a Storage Vault snapshot.

class SearchResultFileInfo {
    string path // Path to the file within the selected snapshot, using forwardslash (/) separators
    string name // Filename
    string type // One of the STOREDOBJECTTYPE_ constants
    string mode // Omission from JSON document implies empty string

    // Timestamp in RFC3339 format with subsecond precision and time zone offset. See the Golang time.RFC3339Nano for more information.
    // Omission from JSON document implies empty string
    string mtime

    // Timestamp in RFC3339 format with subsecond precision and time zone offset. See the Golang time.RFC3339Nano for more information.
    // Omission from JSON document implies empty string
    string atime

    // Timestamp in RFC3339 format with subsecond precision and time zone offset. See the Golang time.RFC3339Nano for more information.
    // Omission from JSON document implies empty string
    string ctime

    // Bytes
    // Omission from JSON document implies 0
    int    size
}

SearchSnapshotsResponse

class SearchSnapshotsResponse extends CometAPIResponseMessage {
    Dictionary<string, List<SearchResultFileInfo>> SnapshotFiles
}

SelfBackupExportOptions

class SelfBackupExportOptions {
    DestinationLocation Location
    string              EncryptionKey
    int                 EncryptionKeyFormat // One of the ENCRYPTIONMETHOD_ constants
    int                 Compression // One of the COMPRESS_LVL_ constants
    bool                ExcludeJobsDB // The jobs database is often the largest component of the Server Self-Backup archive. By excluding it, you could run the Server Self-Backup more often.
    bool                IncludeServerLogs
    string              RestrictToSingleOrgID // Omission from JSON document implies empty string
    int                 Index
}

SelfBackupOptions

class SelfBackupOptions {
    List<SelfBackupTarget> Targets
}

SelfBackupStatistics

class SelfBackupStatistics {
    int  CurrentRunStart
    int  LastRunStart
    int  LastRunEnd
    bool LastRunSuccess
    int  LastRunSize
}

SelfBackupTarget

class SelfBackupTarget extends SelfBackupExportOptions {
    List<ScheduleConfig> Schedule
    string               ScheduleTimezone // Timezone in IANA format
    RetentionPolicy      RetentionPolicy
}

ServerConfigOptions

class ServerConfigOptions {
    List<AllowedAdminUser>                           AdminUsers
    AuthenticationRoleOptions                        AuthenticationRole
    BrandingOptions                                  Branding
    ConstellationRoleOptions                         ConstellationRole

    // This field is defined for compatibility with 17.x.x versions of Comet Server. Do not rely on this field. In Comet 23.2.x, if this field is defined, it is imported into the replacement 'ConstellationRole' field under the assumption that you are upgrading this Comet Server from a 17.x.x version. In Comet 23.3.x and later, this field is ignored and will not be respected during the import process.
    // Omission from JSON document implies zero-initialised ConstellationRoleOptions class instance
    ConstellationRoleOptions                         OverseerRole
    EmailOptions                                     Email

    // An array of GUIDs that can enable additional early-access functionality
    // Omission from JSON document implies an empty array
    List<string>                                     ExperimentalOptions
    Dictionary<string, ExternalAuthenticationSource> ExternalAdminUserSources
    RatelimitOptions                                 IPRateLimit // The Comet Server can enforce a bandwidth limit based on the target IP address
    LoginProtectionOptions                           LoginProtection // This field is available in Comet 24.9.x and later.
    LicenseOptions                                   License
    List<HTTPConnectorOptions>                       ListenAddresses // Configure ip, port, and SSL settings for this self-hosted Comet Server.
    Dictionary<string, Organization>                 Organizations // Tenants
    List<PSAConfig>                                  PSAConfigs
    SelfBackupOptions                                SelfBackup // Automatically create backup zip files of this Comet Server's configuration
    SessionOptions                                   SessionSettings // Control how long admin accounts can remain logged in to the Comet Server web interface
    SoftwareBuildRoleOptions                         SoftwareBuildRole
    StorageRoleOptions                               StorageRole
    bool                                             TrustXForwardedFor // If true, the X-Forwarded-For header will be trusted for the purposes of IP allowlisting. This should only be enabled when you explicitly configure Comet Server behind a reverse proxy, otherwise it could allow malicious users to bypass the IP allowlist.
    Dictionary<string, WebhookOption>                WebhookOptions
    Dictionary<string, FileOption>                   AuditFileOptions
}

ServerConfigOptionsBrandingFragment

class ServerConfigOptionsBrandingFragment {
    BrandingOptions Branding
}

ServerConfigOptionsSoftwareBuildRoleFragment

class ServerConfigOptionsSoftwareBuildRoleFragment {
    SoftwareBuildRoleOptions SoftwareBuildRole
}

ServerMetaBrandingProperties

class ServerMetaBrandingProperties {
    string                                    BrandName
    string                                    ProductName
    bool                                      HasImage // If true, this Comet Server has an image configured for its main logo. You can access it from the /gen/logo.img endpoint. If false, this Comet Server has text configured for its main logo.
    string                                    ImageEtag // A value that will change if the branding image (/gen/logo.img) changes. You can use this as a cache key.
    string                                    TopColor // Colour in RGB hex format (e.g. "#FFFFFF")
    string                                    AccentColor // Colour in RGB hex format (e.g. "#FFFFFF")
    bool                                      HideNewsArea
    bool                                      AllowUnauthenticatedDownloads
    bool                                      AllowAuthenticatedDownloads
    int                                       PruneLogsAfterDays
    int                                       ExpiredInSeconds
    List<ExternalAuthenticationSourceDisplay> ExternalAuthenticationSources // Omission from JSON document implies an empty array
    bool                                      ServerIsEmpty // If true, this Comet Server currently has no admins or users.
    string                                    CloudStorageName
    bool                                      AdminHidePreBuiltClientOption // Will hide the "Pre-built software client" option from the server settings. Only properly enforced when custom branding is enforced via the license.
    bool                                      AdminHideBrandedCloudStorage // Will hide Comet Storage from everywhere, including the admin view. Only properly enforced when custom branding is enforced via the license.
}

ServerMetaVersionInfo

class ServerMetaVersionInfo {
    string                     Version
    string                     VersionCodename
    bool                       StorageRole
    bool                       AuthenticationRole
    bool                       SoftwareBuildRole
    bool                       OverseerRole // OverseerRole has been deprecated since Comet version 18.2.0 "Overseer Role" was the old name for the Constellation Role. This field is a duplicate of ConstellationRole for backward compatibility with earlier API consumers.
    bool                       ConstellationRole
    List<string>               ExperimentalOptions // Omission from JSON document implies an empty array
    int                        ServerStartTime // Unix timestamp, in seconds.
    string                     ServerStartHash // A GUID that was randomly generated when this Comet Server started up. You can check this value to see if the Comet Server has restarted.
    int                        CurrentTime // The current time on the Comet Server host machine. Unix timestamp, in seconds. You can check this value to see if clock drift is occuring.
    string                     ServerLicenseHash // A hash derived from the Comet Server's serial number. You can check this value to see if two Comet Server endpoints point to an identical server.
    bool                       ServerLicenseFeaturesAll // ServerLicenseFeaturesAll has been deprecated since Comet version 24.9.x
    int                        ServerLicenseFeatureSet // A bitset of feature flags representing functionality available in this Comet Server's plan

    // If non-zero, the maximum numbers of devices and Protected Item types that this server is allowed.
    // This field is available in Comet 24.6.3 and later.
    LicenseLimits              ServerLicenseLimit

    // A count of the devices registered on the server that have a configured Protected Item.
    // This field is available in Comet 24.6.3 and later.
    int                        ConfiguredDevices

    // The current number of Protected Item types configured on the server.
    // This field is available in Comet 24.6.3 and later.
    Dictionary<string, int>    BoosterLimit
    int                        LicenseValidUntil // Unix timestamp, in seconds.
    int                        EmailsSentSuccessfully
    int                        EmailsSentErrors
    int                        EmailsWaitingInQueue
    int                        ScheduledEmailThreadCurrentState
    int                        ScheduledEmailThreadLastCalculateDurationNanos
    int                        ScheduledEmailThreadWaitingUntil
    int                        ScheduledEmailThreadLastWakeTime
    bool                       ScheduledEmailThreadLastWakeSentEmails
    List<SelfBackupStatistics> SelfBackup // This field is available in Comet 21.3.2 and later.
}

SessionKeyRegeneratedResponse

class SessionKeyRegeneratedResponse extends CometAPIResponseMessage {
    string SessionKey

    // e.g. "admin" or "user"
    // This field is available in Comet 18.12.3 and later.
    string SessionType
}

SessionOptions

class SessionOptions {
    int ExpiredInSeconds // The number of seconds, after which an administrator should be automatically logged out of the Comet Server web interface. If zero, will be replaced with DEFAULT_SESSIONTIMEOUT.
}

SingleFieldSource

class SingleFieldSource {
    string FieldName
    string FieldType // One of "bool" / "int" / "string"
    bool   BoolVal
    int    IntVal
    string StrVal
}

SizeMeasurement

class SizeMeasurement {
    int Size // Bytes
    int MeasureStarted // Unix timestamp in seconds
    int MeasureCompleted // Unix timestamp in seconds
}

SoftwareBuildRoleOptions

class SoftwareBuildRoleOptions {
    bool RoleEnabled
    bool AllowUnauthenticatedDownloads

    // 0 will default to CPU core count - 2
    // This field is available in Comet 24.3.8 and later.
    int  MaxBuilders
}

SoftwareUpdateNewsResponse

class SoftwareUpdateNewsResponse {
    string       latest_stable // The latest "Quarterly" release version of Comet known to the account.cometbackup.com system.
    string       latest_prerelease // The latest "Voyager" release version of Comet known to the account.cometbackup.com system.
    string       downloads_url // A URL linking to the Comet Server downloads page.
    List<string> updates_info // An array of recent news items written by Comet Backup staff. Entries are english plaintext.
}

SourceBasicInfo

SourceBasicInfo is the minimal amount of information one device knows about another device's Protected Items, in order to safely perform retention passes on their behalf.

class SourceBasicInfo {
    string                              Engine
    string                              Description
    int                                 O365AccountCount
    int                                 TotalVmCount
    int                                 Size // Bytes
    Dictionary<string, RetentionPolicy> OverrideDestinationRetention // Omission from JSON document implies an empty Dictionary
}

SourceConfig

class SourceConfig {
    string                              Engine // One of the ENGINE_BUILTIN_ constants
    string                              Description
    string                              OwnerDevice
    int                                 CreateTime // Unix timestamp in seconds
    int                                 ModifyTime // Unix timestamp in seconds
    List<string>                        PreExec // Custom commands to run before the job
    List<string>                        ThawExec // Custom commands to run after taking a disk snapshot
    List<string>                        PostExec // Custom commands to run after the job

    // Configuration for the selected Protected Item type. Each "Engine" supports
    // different configuration options for the EngineProps values.
    // 
    // For engine1/file, Comet understands the following EngineProp keys:
    // 
    // - Any key starting with INCLUDE: A path that is included
    // - Any key starting with EXCLUDE: An exclusion (glob format)
    // - Any key starting with REXCLUDE: An exclusion (regular expression format)
    // - Any key starting with PINCLUDE: A SourceIncludePattern type encoded in JSON format, describing an advanced inclusion in glob format
    // - Any key starting with RINCLUDE: A SourceIncludePattern type encoded in JSON format, describing an advanced inclusion in regular expression format
    // - Any key starting with SMBAUTH: A set of Windows network share credentials in WinSMBAuth JSON format
    // - USE_WIN_VSS: If present, the 'Take filesystem snapshot' checkbox is checked
    // - CONFIRM_EFS: If present, the 'Dismiss EFS warning' checkbox is checked
    // - RESCAN_UNCHANGED: If present, the 'Rescan unchanged files' checkbox is checked
    // - EXTRA_ATTRIBUTES: If present, the 'Back up extra system permissions and attributes' checkbox is checked
    // 
    // For engine1/mssql, Comet understands the following EngineProp keys:
    // 
    // - ALL_DATABASES: If present, include all databases with specified exclusions. If not present, only back up the specified inclusions
    // - Any key starting with DATABASE- : A database that is included. Only valid if ALL_DATABASES is not present.
    // - Any key starting with EXCEPT-DATABASE- : A database that is excluded. Only valid if ALL_DATABASES is present.
    // - INSTANCE: The Microsoft SQL Server instance name
    // - USERNAME: The username to connect to Microsoft SQL Server
    // - PASSWORD: The password to connect to Microsoft SQL Server
    // - AUTHMODE: Either "windows" or "native" (corresponding to the declared MSSQL_AUTH_WINDOWS and MSSQL_AUTH_NATIVE constant values). If not present, use native authentication if the USERNAME and/or PASSWORD fields are filled in, use windows authentication if they are blank
    // - METHOD: Either "OLEDB_NATIVE" or "OLEDB_32" (corresponding to the declared MSSQL_METHOD_OLEDB_NATIVE and MSSQL_METHOD_OLEDB_32 constant values). If not present, defaults to Native
    // - DIFFBASE: If present, take a "Full (base image)" backup job. Otherwise, take a "Full (copy only)" backup job.
    // - DIFFERENTIAL: If present, take a "Differential increment" backup job. Otherwise, take a "Full (copy only)" backup job.
    // - LOGTRUNC: If present, take a "Log (truncating)" backup job. Otherwise, take a "Full (copy only)" backup job.
    // - LOGNOTRUNC: If present, take a "Log (no truncation)" backup job. Otherwise, take a "Full (copy only)" backup job.
    // 
    Dictionary<string, string>          EngineProps

    // If set, this SourceConfig was added from a Policy with the specified ID.
    // This field is available in Comet 23.6.0 and later.
    string                              PolicySourceID

    // For a Policy-defined SourceConfig, this field controls whether the Protected Item will stay linked with the policy.
    // This field is available in Comet 23.6.0 and later.
    bool                                ExistingUserUpdate

    // By default, backup jobs from this Protected Item will be subject
    // to the overall retention policy for the Storage Vault. You can override the policy
    // for specific Storage Vaults by putting their destination ID as a key here.
    // Omission from JSON document implies an empty Dictionary
    Dictionary<string, RetentionPolicy> OverrideDestinationRetention
    SourceStatistics                    Statistics // Omission from JSON document implies zero-initialised SourceStatistics class instance
}

SourceIncludePattern

SourceIncludePattern is used for pattern inclusions for File and Folder Protected Items (ENGINE_BUILTIN_FILE). It should be marshalled as JSON and then stored in the PINCLUDE / RINCLUDE EngineProp keys.

class SourceIncludePattern {
    string TopDirectory // The filesystem path to search within, for matches
    string Value // The pattern (glob or regex format) to match
}

SourceStatistics

class SourceStatistics {
    int             LastStartTime
    BackupJobDetail LastBackupJob
    BackupJobDetail LastSuccessfulBackupJob
}

SpannedDestinationLocation

class SpannedDestinationLocation {
    List<DestinationLocation> SpanTargets // A list of underlying destinations, that will be combined and presented as one.

    // If true, this Spanned destination will use a consistent hashing scheme
    // to immediately find specific files on exactly one of the target destinations.
    // In the Static Slots mode, the span targets cannot be moved or merged, and
    // the files must always remain in their original location.
    // 
    // If false, the Spanned destination system will search all targets to find
    // the requested file. This is slightly slower, but allows you to freely merge,
    // split, and reorder the underlying destination locations.
    // 
    // The default option is false.
    bool                      SpanUseStaticSlots
}

SpannedStorageExtraInfo

class SpannedStorageExtraInfo {
    List<StorageFreeSpaceInfo> Targets
}

StatResult

class StatResult {
    int Buckets
    int Users
    int Devices
    int Boosters
    int NetworkDevices
}

StorageFreeSpaceInfo

class StorageFreeSpaceInfo {
    bool                    Unlimited
    float32                 UsedPercent
    int                     AvailableBytes
    SpannedStorageExtraInfo Spanned // Omission from JSON document implies zero-initialised SpannedStorageExtraInfo class instance
    B2StorageExtraInfo      B2 // Omission from JSON document implies zero-initialised B2StorageExtraInfo class instance
}

StorageRoleOptions

class StorageRoleOptions {
    bool                        RoleEnabled
    DestinationLocation         Storage

    // LocalStorage has been deprecated since Comet version 17.3.5
    // Omission from JSON document implies an empty array
    List<LocalStorageDirectory> LocalStorage
    List<ReplicaServer>         ReplicateTo
}

StorageVaultProviderPolicy

class StorageVaultProviderPolicy {
    bool      ShouldRestrictProviderList
    List<int> AllowedProvidersWhenRestricted
}

StoredObject

class StoredObject {
    string name // The name of the stored object. It is unique within this directory tree.
    int    mtime // Unix timestamp in seconds
    string type // One of the STOREDOBJECTTYPE_... constant values
    string subtree // If this StoredObject represents a directory, this value can be used to recursively select the directory contents.
    int    size // Bytes
    string dname // Omission from JSON document implies empty string
    string itemClass // Omission from JSON document implies empty string
    string from // Omission from JSON document implies empty string
    string to // Omission from JSON document implies empty string
    int    rtime // Omission from JSON document implies 0
    bool   has_attachments // Omission from JSON document implies false

    // Unix timestamp in seconds
    // Omission from JSON document implies 0
    int    stime

    // Unix timestamp in seconds
    // Omission from JSON document implies 0
    int    etime
    bool   r // Omission from JSON document implies false
    int    f // Omission from JSON document implies 0
    int    b // Omission from JSON document implies 0
    int    d // Omission from JSON document implies 0
}

StorjDestinationLocation

class StorjDestinationLocation {
    string SatelliteAddress
    string APIKey
    string Passphrase
    string StorjBucket
    string StorjBucketPrefix // Omission from JSON document implies empty string
}

StorjVirtualStorageRoleSetting

class StorjVirtualStorageRoleSetting {
    string SatelliteAddress
    string APIKey
    string Passphrase
    string Bucket
}

StreamableEvent

class StreamableEvent {
    string      Actor
    string      OwnerOrganizationID
    string      ResourceID // Omission from JSON document implies empty string
    int         Type
    int         Timestamp // Omission from JSON document implies 0
    string      TypeString // Omission from JSON document implies empty string
    any Data // Omission from JSON document implies any value
}

SwiftDestinationLocation

class SwiftDestinationLocation {

    // Username or UserID or Application Credential name or Application Credential ID, or blank for token authentication
    // Omission from JSON document implies empty string
    string Username

    // User Password, or Application Credential Key, or token if the Username field is blank
    // Omission from JSON document implies empty string
    string APIKey
    string Region // Omission from JSON document implies empty string

    // Mandatory
    // Omission from JSON document implies empty string
    string AuthURL
    string Domain // Omission from JSON document implies empty string

    // Tenant name (v2) or Project name (v3)
    // Omission from JSON document implies empty string
    string Tenant

    // Project domain name (v3)
    // Omission from JSON document implies empty string
    string TenantDomain
    string TenantID // Omission from JSON document implies empty string
    string TrustID // Omission from JSON document implies empty string

    // AuthToken has been deprecated since Comet version 17.8.0
    // Omission from JSON document implies empty string
    string AuthToken
    string Prefix // Omission from JSON document implies empty string
    string Container // Omission from JSON document implies empty string
    string DefaultContainerPolicy // Omission from JSON document implies empty string
}

TestResponse

class TestResponse extends CometAPIResponseMessage {
    bool Exists
}

TimeSpan

class TimeSpan {
    int FrequencyType // SCHEDULE_FREQUENCY_
    int Seconds // Used for Periodic and Once Only
}

TotpRegeneratedResponse

class TotpRegeneratedResponse extends CometAPIResponseMessage {
    string Image // A data URI of an image of a TOTP code (e.g. "...")
    string URL // This field is available in Comet 18.9.9 and later.
    string ProfileHash // This field is available in Comet 20.3.2 and later.
}

U2FRegisterRequest

This type has been deprecated since Comet version 21.12.0

class U2FRegisterRequest {
    string Challenge
    string Version
}

U2FRegisteredKey

This type has been deprecated since Comet version 21.12.0

class U2FRegisteredKey {
    string AppID
    string KeyHandle
    string Version
}

U2FRegistrationChallengeResponse

This type has been deprecated since Comet version 21.12.0

class U2FRegistrationChallengeResponse extends CometAPIResponseMessage {
    string                   ChallengeID
    string                   AppID
    List<U2FRegisteredKey>   RegisteredKeys
    List<U2FRegisterRequest> RegisterRequests
}

U2FSignRequest

This type has been deprecated since Comet version 21.12.0

class U2FSignRequest {
    string                 ChallengeID
    string                 ChallengeData
    string                 AppID
    List<U2FRegisteredKey> RegisteredKeys
}

U2FSignResponse

This type has been deprecated since Comet version 21.12.0

class U2FSignResponse {
    string ChallengeID
    string KeyHandle
    string Signature
    string ClientData
}

UninstallConfig

UninstallConfig allows configuring whether the target device will be uninstalled or not.

class UninstallConfig {
    bool UninstallFlag // If this option is true, the target device will receive a message asking it to uninstall the Comet Backup app.
    bool RemoveConfigFile // This controls the "Remove all user settings from this device" option.
}

UpdateCampaignDeviceStatus

class UpdateCampaignDeviceStatus {
    int Status // One of the UPDATESTATUS_ constants
}

UpdateCampaignOptions

This data structure describes which devices should receive a remote software upgrade. Both the target version criteria (UpgradeOlder/ReinstallCurrentVer/DowngradeNewer) and the target device criteria (ApplyDeviceFilter/DeviceFilter) must be met in order for the remote upgrade to be applied.

class UpdateCampaignOptions {
    bool         Active
    bool         UpgradeOlder
    bool         ReinstallCurrentVer
    bool         DowngradeNewer
    bool         ForceUpgradeRunning // Choose whether this bulk upgrade campaign is allowed to interrupt a running backup job.
    bool         ApplyDeviceFilter // If true, then the UserFilter will be used to restrict which accounts and devices will be eligible for the software update. If false, all users and devices will be eligible for the software update.
    SearchClause DeviceFilter
}

UpdateCampaignProperties

class UpdateCampaignProperties extends UpdateCampaignOptions {
    int    StartTime // Unix timestamp, in seconds
    string TargetVersion
}

UpdateCampaignStatus

class UpdateCampaignStatus extends UpdateCampaignProperties {
    List<UpdateCampaignStatusDeviceEntry> Devices
}

UpdateCampaignStatusDeviceEntry

class UpdateCampaignStatusDeviceEntry extends UpdateCampaignDeviceStatus {
    string Username
    string DeviceID
}

UserCustomEmailSettings

class UserCustomEmailSettings {
    List<EmailReportConfig> Reports
}

UserGroup

class UserGroup {
    int    CreatedAt // Unix timestamp in seconds
    string OrganizationID
    string Name
}

UserOnServer

class UserOnServer {
    int    ServerID // The server where this user was found. The 0-based indexes here correspond to the entries inside ConstellationRoleOptions->Servers.
    string Username
}

UserPolicy

class UserPolicy {
    bool                                               PreventRequestStorageVault
    bool                                               PreventAddCustomStorageVault
    bool                                               PreventEditStorageVault
    bool                                               HideCloudStorageBranding
    bool                                               PreventDeleteStorageVault
    StorageVaultProviderPolicy                         StorageVaultProviders
    string                                             DefaultNewStorageVault
    bool                                               PreventNewProtectedItem
    bool                                               PreventEditProtectedItem
    bool                                               PreventDeleteProtectedItem
    ProtectedItemEngineTypePolicy                      ProtectedItemEngineTypes
    List<ExtraFileExclusion>                           FileAndFolderMandatoryExclusions // Omission from JSON document implies an empty array
    int                                                ModeScheduleSkipAlreadyRunning // Omission from JSON document implies 0
    int                                                ModeScheduleLastJobFailDoRetry // Omission from JSON document implies 0
    int                                                ModeLastJobFailDoRetryTime // Omission from JSON document implies 0
    int                                                ModeLastJobFailDoRetryCount // Omission from JSON document implies 0
    int                                                ModeAdminResetPassword // Omission from JSON document implies 0
    int                                                ModeAdminViewFilenames // Omission from JSON document implies 0
    int                                                ModeRequireUserResetPassword // Omission from JSON document implies 0
    bool                                               PreventDeleteSingleSnapshots
    bool                                               PreventChangeAccountPassword
    bool                                               PreventChangeEmailSettings
    bool                                               PreventChangeAccountName
    bool                                               PreventOpenAppUI
    bool                                               RequirePasswordOpenAppUI
    bool                                               HideAppImport
    bool                                               HideAppVersion
    bool                                               PreventOpenWebUI
    bool                                               PreventViewDeviceNames
    DefaultEmailReportPolicy                           DefaultEmailReports
    RetentionPolicy                                    DefaultStorageVaultRetention
    bool                                               EnforceStorageVaultRetention
    bool                                               PreventProtectedItemRetention
    bool                                               AllowEditObjectLockRetention
    Dictionary<string, SourceConfig>                   DefaultSources
    Dictionary<string, BackupRuleConfig>               DefaultSourcesBackupRules
    Dictionary<string, DefaultSourceWithOSRestriction> DefaultSourcesWithOSRestriction
    Dictionary<string, BackupRuleConfig>               DefaultBackupRules
    int                                                RandomDelaySecs // Omission from JSON document implies 0
}

UserProfileConfig

This is the main data structure for a user's profile.

class UserProfileConfig {
    string                                      Username // The name for this account. It uniquely identifies this UserProfileConfig across the entire Comet Server. It cannot be changed directly.
    string                                      AccountName // A longer descriptive name for this account. It is not necessarily unique to the Comet Server. The end-user might be able to change it inside the Comet Backup desktop app.
    string                                      LocalTimezone // Timezone in IANA format. Individual devices may declare a more specific timezone in the Devices field.
    string                                      LanguageCode // One of the supported languages, such as en_US (DEFAULT_LANGUAGE).

    // Tenant
    // Omission from JSON document implies empty string
    string                                      OrganizationID
    string                                      GroupID
    List<string>                                Emails // A list of email addresses to send reports to.
    Dictionary<string, UserCustomEmailSettings> OverrideEmailSettings // By default, all the email addresses in the Emails field will receive the policy-default or server-wide-default style of email report. Add an override for a specific email address in here to allow customizing the email report that will be received.
    bool                                        SendEmailReports // This option can be used to control whether any email reports are sent.

    // Storage Vaults
    // The string keys can be any unique key. Using a GUID is recommended, but optional.
    Dictionary<string, DestinationConfig>       Destinations
    bool                                        SupportsDeviceAssociations // Leave as true

    // Protected Items
    // The string keys can be any unique key. Using a GUID is recommended, but optional.
    Dictionary<string, SourceConfig>            Sources

    // Schedules
    // The string keys can be any unique key. Using a GUID is recommended, but optional.
    Dictionary<string, BackupRuleConfig>        BackupRules

    // Devices
    // The string keys are the device's ID. The device ID is generated automatically based on a mix of hardware and software identifiers on the installed PC.
    // To revoke a device, use the AdminRevokeDevice API instead of accessing these fields directly. This API can also remove associated Protected Items, uninstall the remote device, and disconnect its live connection.
    Dictionary<string, DeviceConfig>            Devices
    bool                                        IsSuspended

    // Unix timestamp in seconds. Zero if the device is not suspended.
    // Omission from JSON document implies 0
    int                                         LastSuspended
    bool                                        AllProtectedItemsQuotaEnabled // A limit on the total Size of all Protected Items in this account. The number of bytes should be configured in AllProtectedItemsQuotaBytes.
    int                                         AllProtectedItemsQuotaBytes // A limit on the total Size of all Protected Items in this account. It is enforced if AllProtectedItemsQuotaEnabled is true.
    int                                         MaximumDevices // A limit on the total number of devices registered in this account. Set to zero to allow unlimited devices.
    int                                         QuotaOffice365ProtectedAccounts // A limit on the total number of Office 365 Protected Accounts across all Office 365 Protected Items in this account. Set to zero to allow unlimited Office 365 Protected Accounts.
    int                                         QuotaHyperVGuests // A limit on the total number of Hyper-V guests across all Hyper-V Protected Items in this account. Set to zero to allow unlimited Office 365 Protected Accounts.
    int                                         QuotaVMwareGuests // A limit on the total number of VMware guests across all VMware Protected Items in this account. Set to zero to allow unlimited Office 365 Protected Accounts.
    string                                      PolicyID // If the PolicyID field is set to a non-empty string, the Comet Server will enforce the contents of the Policy field based on the matching server's policy. Otherwise if the PolicyID field is set to an empty string, the administrator may configure any custom values in the Policy field.
    UserPolicy                                  Policy // The Policy field contains a read-only copy of the effective Policy that is applied to this user account.

    // One of the PASSWORD_FORMAT_ constants
    // To change the user's password, use the AdminResetUserPassword API instead of accessing these fields directly. Otherwise, other encrypted fields in the user profile may become corrupted.
    int                                         PasswordFormat
    string                                      PasswordHash

    // If this field is empty, the "Allow administrator to reset my password" feature is turned off. If this field is filled, it contains a cryptographic root of trust that can decrypt and re-encrypt other secrets in this profile.
    // Omission from JSON document implies empty string
    string                                      PasswordRecovery
    bool                                        AllowPasswordLogin // Allow login using the password alone. Set this to false if the password alone should not be sufficient.
    bool                                        AllowPasswordAndTOTPLogin // If true, then TOTP is required to open the desktop app or the Comet Server web interface with this user's credentials.
    int                                         TOTPKeyEncryptionFormat // One of the ENCRYPTIONMETHOD_ constants
    string                                      TOTPKey
    bool                                        RequirePasswordChange // This field is available in Comet 20.3.4 and later.
    int                                         CreateTime // Unix timestamp in seconds
    string                                      CreationGUID // A random GUID that is allocated when the user profile is created for the first time. You can use this to help disambiguate users with the same username across multiple Comet Servers.

    // Additional server-wide settings that are enforced for this user profile
    // Omission from JSON document implies zero-initialised UserServerConfig class instance
    UserServerConfig                            ServerConfig
    string                                      AutoStorageTemplateGUID
}

UserProfileFragment

This type has been deprecated since Comet version 23.3.5

class UserProfileFragment {
    string Username
}

UserServerConfig

class UserServerConfig {
    int RandomDelaySecs // Omission from JSON document implies 0
}

VMDKSnapshotViewOptions

class VMDKSnapshotViewOptions {
    bool   Enabled // Request a list of stored objects in vmdk file. It should be always true for restoring single files from vmdk file
    string PartitionGUID // The vmdk filename inside subdirectory of disk image, should be end with .vmdk
    string ListPath // Browse objects' paths inside vmdk file
    string PartitionName
}

VMwareConnection

class VMwareConnection {
    string            ConnectionType // One of the VMWARE_CONNECTION_ constants
    SSHConnection     SSH // SSH has been deprecated since Comet version 23.9.11
    VSphereConnection VSphere
}

VMwareMachineInfo

class VMwareMachineInfo {
    string Name
}

VSSComponent

class VSSComponent {
    string Path
    string Name
    string CType // "VSS_CT_DATABASE" or "VSS_CT_FILEGROUP"
    bool   Selectable
}

VSSWriterInfo

class VSSWriterInfo {
    string             DisplayName
    List<VSSComponent> Components
}

VSphereConnection

class VSphereConnection {
    string Hostname
    bool   Https
    bool   AllowInvalidCertificate
    string Username
    string Password
    string ThumbPrint
}

VaultSnapshot

class VaultSnapshot {
    string Snapshot
    string EngineType // This field is available in Comet 24.3.x and later.
    string Source
    int    CreateTime
    bool   HasOriginalPathInfo // This field is available in Comet 20.12.4 and later.
}

WasabiVirtualStorageRoleSettings

This is an alias type for AmazonAWSVirtualStorageRoleSettings.

class WasabiVirtualStorageRoleSettings extends AmazonAWSVirtualStorageRoleSettings {
}

WebAuthnAuthenticatorSelection

class WebAuthnAuthenticatorSelection {
    string authenticatorAttachment // Omission from JSON document implies empty string
    bool   requireResidentKey // Omission from JSON document implies false
    string residentKey // Omission from JSON document implies empty string
    string userVerification // Omission from JSON document implies empty string
}

WebAuthnCredential

class WebAuthnCredential {
    List<byte> PublicKey // This field is intended to contain raw binary data. When this field is marshalled as JSON format for the API, the field is expressed as base64. If you are using one of the public SDKs, this may take place automatically.
    string     AttestationType
    List<byte> AAGUID // This field is intended to contain raw binary data. When this field is marshalled as JSON format for the API, the field is expressed as base64. If you are using one of the public SDKs, this may take place automatically.
    int        SignCount
    bool       CloneWarning
}

WebAuthnCredentialAssertion

class WebAuthnCredentialAssertion {
    WebAuthnPublicKeyCredentialRequestOptions publicKey
}

WebAuthnCredentialDescriptor

class WebAuthnCredentialDescriptor {
    string       type
    List<byte>   id // This field is intended to contain raw binary data. When this field is marshalled as JSON format for the API, the field is expressed as base64. If you are using one of the public SDKs, this may take place automatically.
    List<string> transports // Omission from JSON document implies an empty array
}

WebAuthnCredentialEntity

class WebAuthnCredentialEntity {
    string name
    string icon // Omission from JSON document implies empty string
}

WebAuthnCredentialParameter

class WebAuthnCredentialParameter {
    string type
    int    alg
}

WebAuthnPublicKeyCredentialCreationOptions

class WebAuthnPublicKeyCredentialCreationOptions {
    List<byte>                         challenge // This field is intended to contain raw binary data. When this field is marshalled as JSON format for the API, the field is expressed as base64. If you are using one of the public SDKs, this may take place automatically.
    WebAuthnRelyingPartyEntity         rp
    WebAuthnUserEntity                 user
    List<WebAuthnCredentialParameter>  pubKeyCredParams // Omission from JSON document implies an empty array
    WebAuthnAuthenticatorSelection     authenticatorSelection // Omission from JSON document implies zero-initialised WebAuthnAuthenticatorSelection class instance
    int                                timeout // Omission from JSON document implies 0
    List<WebAuthnCredentialDescriptor> excludeCredentials // Omission from JSON document implies an empty array
    Dictionary<string, any>    extensions // Omission from JSON document implies an empty Dictionary
    string                             attestation // Omission from JSON document implies empty string
}

WebAuthnPublicKeyCredentialRequestOptions

class WebAuthnPublicKeyCredentialRequestOptions {
    List<byte>                         challenge // This field is intended to contain raw binary data. When this field is marshalled as JSON format for the API, the field is expressed as base64. If you are using one of the public SDKs, this may take place automatically.
    int                                timeout // Omission from JSON document implies 0
    string                             rpId // Omission from JSON document implies empty string
    List<WebAuthnCredentialDescriptor> allowCredentials // Omission from JSON document implies an empty array
    string                             userVerification // Omission from JSON document implies empty string
    Dictionary<string, any>    extensions // Omission from JSON document implies an empty Dictionary
}

WebAuthnRegistrationChallengeResponse

class WebAuthnRegistrationChallengeResponse extends CometAPIResponseMessage {
    string                                     ChallengeID
    WebAuthnPublicKeyCredentialCreationOptions CredentialCreationOptions
}

WebAuthnRelyingPartyEntity

class WebAuthnRelyingPartyEntity extends WebAuthnCredentialEntity {
    string id
}

WebAuthnSignRequest

class WebAuthnSignRequest {
    string                      ChallengeID
    WebAuthnCredentialAssertion Assertion
}

WebAuthnSignResponse

class WebAuthnSignResponse {
    string ChallengeID
    string CredentialJSON
}

WebAuthnUserEntity

class WebAuthnUserEntity extends WebAuthnCredentialEntity {
    string     displayName // Omission from JSON document implies empty string
    List<byte> id // This field is intended to contain raw binary data. When this field is marshalled as JSON format for the API, the field is expressed as base64. If you are using one of the public SDKs, this may take place automatically.
}

WebDavDestinationLocation

This type is available in Comet 23.6.9 and later.

class WebDavDestinationLocation {

    // The URL of the WebDAV server, including http/https and any custom port
    // Omission from JSON document implies empty string
    string DavServer

    // The username for logging in to the WebDAV server
    // Omission from JSON document implies empty string
    string UserName

    // The password for logging in to the WebDAV server
    // Omission from JSON document implies empty string
    string AccessKey

    // The target directory path within the WebDAV server
    // Omission from JSON document implies empty string
    string Path
}

WebInterfaceBrandingProperties

class WebInterfaceBrandingProperties {

    // One of the BRANDINGSTYLETYPE_ constants
    // This field is available in Comet 23.3.3 and later.
    int    BrandingStyleType
    string BrandName
    string LogoImage
    string TopColor
    string AccentColor
    string Favicon
    bool   HideNewsArea
}

WebhookOption

WebhookOption defines the configuration of a webhook target. The Comet Server will send a live HTTP POST event to the webhook URL when certain events happen.

class WebhookOption {
    string                     URL // The target URL to POST the event data to

    // CustomHeaders allows specifying custom headers which are added to the outgoing POST request
    // from Comet Server. Custom headers are specified as (header name, header value) pairs. If a
    // custom header conflicts with a header required by HTTP or the Comet tracing ID header
    // (`x-Comet-Tracing-Id`), it will be ignored.
    Dictionary<string, string> CustomHeaders
    string                     Level // One of the STREAM_LEVEL_ constants. This controls how much data is sent in the webhook event.
    List<int>                  WhiteListedEventTypes // Configure a subset of allowed event types (see SEVT_ constants). If the array is empty, all events will be sent
}

WinSMBAuth

class WinSMBAuth {
    string SharePath // The UNC path for the Windows network share (SMB).
    string Username // The username to log in to the Windows network share (SMB).
    string Password // The password might be hashed. To set this in cleartext, set PasswordFormat to 0 (PASSWORD_FORMAT_PLAINTEXT).
    int    PasswordFormat // The hash algorithm that is used for the Password field. It is one of the PASSWORD_FORMAT_ constants.
}

WindowsCodeSignProperties

class WindowsCodeSignProperties {
    int    WindowsCodeSignMethod // One of the WINDOWSCODESIGN_METHOD_ constants
    string WindowsCodeSignPKCS12FilePath
    int    WindowsCodeSignPKCS12PasswordFormat // One of the ENCRYPTIONMETHOD_ constants
    string WindowsCodeSignPKCS12Password
    string WindowsCodeSignPKCS11Engine
    string WindowsCodeSignPKCS11Module
    string WindowsCodeSignPKCS11Certfile // This field was deprecated between 23.3.0 and 23.6.x, but is now used again.
    string WindowsCodeSignPKCS11KeyID
    int    WindowsCodeSignPKCS11PasswordFormat // One of the ENCRYPTIONMETHOD_ constants
    string WindowsCodeSignPKCS11Password
    string WindowsCodeSignAzureVaultName
    string WindowsCodeSignAzureCertName
    string WindowsCodeSignAzureAppID
    int    WindowsCodeSignAzureAppSecretFormat // One of the ENCRYPTIONMETHOD_ constants
    string WindowsCodeSignAzureAppSecret
    string WindowsCodeSignAzureTenantID
}