@giveitsmaller/contracts 0.2.3 → 0.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/asyncapi/events.yaml +1777 -172
- package/availability/availability.json +2449 -0
- package/dist/asyncapi/Failure.d.ts +25 -0
- package/dist/asyncapi/Failure.js +1 -0
- package/dist/asyncapi/JobInputRole.d.ts +6 -0
- package/dist/asyncapi/JobInputRole.js +7 -0
- package/dist/asyncapi/MergeOutputType.d.ts +1 -3
- package/dist/asyncapi/MergeOutputType.js +0 -2
- package/dist/asyncapi/MultiOutputCompletion.d.ts +25 -0
- package/dist/asyncapi/MultiOutputCompletion.js +1 -0
- package/dist/asyncapi/NotificationsOperationsQueue.d.ts +4 -2
- package/dist/asyncapi/OperationMetrics.d.ts +3 -0
- package/dist/asyncapi/OperationProgress.d.ts +2 -0
- package/dist/asyncapi/OperationResult.d.ts +4 -19
- package/dist/asyncapi/OperationType.d.ts +6 -6
- package/dist/asyncapi/OperationType.js +5 -5
- package/dist/asyncapi/PageIndexed.d.ts +8 -0
- package/dist/asyncapi/PageIndexed.js +1 -0
- package/dist/asyncapi/PositionIndexed.d.ts +8 -0
- package/dist/asyncapi/PositionIndexed.js +1 -0
- package/dist/asyncapi/ProgressStatus.d.ts +3 -0
- package/dist/asyncapi/ProgressStatus.js +3 -0
- package/dist/asyncapi/ReEncodeDecision.d.ts +5 -0
- package/dist/asyncapi/ReEncodeDecision.js +6 -0
- package/dist/asyncapi/SingleOutputCompletion.d.ts +25 -0
- package/dist/asyncapi/SingleOutputCompletion.js +1 -0
- package/dist/asyncapi/SourceEntry.d.ts +2 -1
- package/dist/asyncapi/Unindexed.d.ts +8 -0
- package/dist/asyncapi/Unindexed.js +1 -0
- package/dist/asyncapi/UploadProbeCompletion.d.ts +16 -0
- package/dist/asyncapi/UploadProbeCompletion.js +1 -0
- package/dist/asyncapi/UploadProbeMediaMetadata.d.ts +18 -0
- package/dist/asyncapi/UploadProbeMediaMetadata.js +1 -0
- package/dist/asyncapi/UploadProbeProcessingClass.d.ts +6 -0
- package/dist/asyncapi/UploadProbeProcessingClass.js +7 -0
- package/dist/asyncapi/UploadProbeRequest.d.ts +10 -0
- package/dist/asyncapi/UploadProbeRequest.js +1 -0
- package/dist/asyncapi/UploadProbeStatus.d.ts +7 -0
- package/dist/asyncapi/UploadProbeStatus.js +8 -0
- package/dist/asyncapi/index.d.ts +13 -0
- package/dist/asyncapi/index.js +4 -0
- package/dist/openapi/models/AudioWatermarkDecodeRequest.d.ts +64 -0
- package/dist/openapi/models/AudioWatermarkDecodeRequest.js +53 -0
- package/dist/openapi/models/AudioWatermarkDecodeResponse.d.ts +80 -0
- package/dist/openapi/models/AudioWatermarkDecodeResponse.js +64 -0
- package/dist/openapi/models/AuthErrorResponse.d.ts +135 -0
- package/dist/openapi/models/AuthErrorResponse.js +66 -0
- package/dist/openapi/models/AuthErrorType.d.ts +73 -0
- package/dist/openapi/models/AuthErrorType.js +91 -0
- package/dist/openapi/models/AvailabilityValue.d.ts +43 -0
- package/dist/openapi/models/AvailabilityValue.js +61 -0
- package/dist/openapi/models/BalanceExhaustedResponse.d.ts +176 -0
- package/dist/openapi/models/BalanceExhaustedResponse.js +86 -0
- package/dist/openapi/models/BalanceExhaustedResponseAllOfLinks.d.ts +38 -0
- package/dist/openapi/models/BalanceExhaustedResponseAllOfLinks.js +43 -0
- package/dist/openapi/models/CallbackEventType.d.ts +2 -2
- package/dist/openapi/models/CallbackEventType.js +2 -2
- package/dist/openapi/models/ConnectionSource.d.ts +64 -0
- package/dist/openapi/models/ConnectionSource.js +57 -0
- package/dist/openapi/models/ContactRequest.d.ts +2 -2
- package/dist/openapi/models/ContactRequest.js +2 -2
- package/dist/openapi/models/ContactSubject.d.ts +2 -2
- package/dist/openapi/models/ContactSubject.js +2 -2
- package/dist/openapi/models/ContactValidationErrorResponse.d.ts +2 -2
- package/dist/openapi/models/ContactValidationErrorResponse.js +2 -2
- package/dist/openapi/models/CreateExternalImport403Response.d.ts +24 -0
- package/dist/openapi/models/CreateExternalImport403Response.js +58 -0
- package/dist/openapi/models/CreateExternalImport422Response.d.ts +23 -0
- package/dist/openapi/models/CreateExternalImport422Response.js +51 -0
- package/dist/openapi/models/CreateWorkflow422Response.d.ts +24 -0
- package/dist/openapi/models/CreateWorkflow422Response.js +58 -0
- package/dist/openapi/models/CreditTransaction.d.ts +186 -0
- package/dist/openapi/models/CreditTransaction.js +100 -0
- package/dist/openapi/models/CreditTransactionSourceBucket.d.ts +46 -0
- package/dist/openapi/models/CreditTransactionSourceBucket.js +64 -0
- package/dist/openapi/models/CreditsBalanceResponse.d.ts +84 -0
- package/dist/openapi/models/CreditsBalanceResponse.js +68 -0
- package/dist/openapi/models/CreditsBalanceSuccessEnvelope.d.ts +46 -0
- package/dist/openapi/models/CreditsBalanceSuccessEnvelope.js +54 -0
- package/dist/openapi/models/CreditsUsageResponse.d.ts +51 -0
- package/dist/openapi/models/CreditsUsageResponse.js +56 -0
- package/dist/openapi/models/CreditsUsageSuccessEnvelope.d.ts +46 -0
- package/dist/openapi/models/CreditsUsageSuccessEnvelope.js +54 -0
- package/dist/openapi/models/Delivery.d.ts +98 -0
- package/dist/openapi/models/Delivery.js +65 -0
- package/dist/openapi/models/DeliveryOutputRef.d.ts +44 -0
- package/dist/openapi/models/DeliveryOutputRef.js +45 -0
- package/dist/openapi/models/DeliveryPlan.d.ts +77 -0
- package/dist/openapi/models/DeliveryPlan.js +72 -0
- package/dist/openapi/models/DeliveryPlanOutput.d.ts +53 -0
- package/dist/openapi/models/DeliveryPlanOutput.js +52 -0
- package/dist/openapi/models/DeliveryPlanReason.d.ts +35 -0
- package/dist/openapi/models/DeliveryPlanReason.js +53 -0
- package/dist/openapi/models/DeliverySelection.d.ts +62 -0
- package/dist/openapi/models/DeliverySelection.js +54 -0
- package/dist/openapi/models/ErrorEnvelope.d.ts +102 -5
- package/dist/openapi/models/ErrorEnvelope.js +10 -2
- package/dist/openapi/models/EstimateQuality.d.ts +34 -0
- package/dist/openapi/models/EstimateQuality.js +52 -0
- package/dist/openapi/models/EstimateRange.d.ts +48 -0
- package/dist/openapi/models/EstimateRange.js +51 -0
- package/dist/openapi/models/ExternalDestination.d.ts +41 -0
- package/dist/openapi/models/ExternalDestination.js +47 -0
- package/dist/openapi/models/ExternalImportCreatedResponse.d.ts +49 -0
- package/dist/openapi/models/ExternalImportCreatedResponse.js +51 -0
- package/dist/openapi/models/ExternalImportCreatedSuccessEnvelope.d.ts +46 -0
- package/dist/openapi/models/ExternalImportCreatedSuccessEnvelope.js +54 -0
- package/dist/openapi/models/ExternalImportRequest.d.ts +92 -0
- package/dist/openapi/models/ExternalImportRequest.js +61 -0
- package/dist/openapi/models/ExternalImportToken.d.ts +51 -0
- package/dist/openapi/models/ExternalImportToken.js +53 -0
- package/dist/openapi/models/ExternalSource.d.ts +31 -0
- package/dist/openapi/models/ExternalSource.js +47 -0
- package/dist/openapi/models/FeatureNotAvailableResponse.d.ts +163 -0
- package/dist/openapi/models/FeatureNotAvailableResponse.js +76 -0
- package/dist/openapi/models/FeatureTierRestrictedResponse.d.ts +154 -0
- package/dist/openapi/models/FeatureTierRestrictedResponse.js +76 -0
- package/dist/openapi/models/FeatureViolation.d.ts +108 -0
- package/dist/openapi/models/FeatureViolation.js +63 -0
- package/dist/openapi/models/JobDefinition.d.ts +125 -14
- package/dist/openapi/models/JobDefinition.js +25 -4
- package/dist/openapi/models/JobDownload.d.ts +2 -2
- package/dist/openapi/models/JobDownload.js +2 -2
- package/dist/openapi/models/JobInputV2.d.ts +89 -0
- package/dist/openapi/models/JobInputV2.js +56 -0
- package/dist/openapi/models/JobOutputSource.d.ts +57 -0
- package/dist/openapi/models/JobOutputSource.js +55 -0
- package/dist/openapi/models/JobResponse.d.ts +2 -2
- package/dist/openapi/models/JobResponse.js +2 -2
- package/dist/openapi/models/JobStatus.d.ts +17 -8
- package/dist/openapi/models/JobStatus.js +17 -8
- package/dist/openapi/models/JobType.d.ts +2 -2
- package/dist/openapi/models/JobType.js +2 -2
- package/dist/openapi/models/LivenessResponse.d.ts +2 -2
- package/dist/openapi/models/LivenessResponse.js +2 -2
- package/dist/openapi/models/LoginUser200Response.d.ts +46 -0
- package/dist/openapi/models/LoginUser200Response.js +54 -0
- package/dist/openapi/models/LoginUser200ResponseData.d.ts +33 -0
- package/dist/openapi/models/LoginUser200ResponseData.js +44 -0
- package/dist/openapi/models/LoginUser200ResponseDataUser.d.ts +50 -0
- package/dist/openapi/models/LoginUser200ResponseDataUser.js +51 -0
- package/dist/openapi/models/LoginUserRequest.d.ts +38 -0
- package/dist/openapi/models/LoginUserRequest.js +47 -0
- package/dist/openapi/models/LogoutUser200Response.d.ts +50 -0
- package/dist/openapi/models/LogoutUser200Response.js +53 -0
- package/dist/openapi/models/MetadataResponse.d.ts +13 -2
- package/dist/openapi/models/MetadataResponse.js +6 -2
- package/dist/openapi/models/MetadataResponseDimensions.d.ts +2 -2
- package/dist/openapi/models/MetadataResponseDimensions.js +2 -2
- package/dist/openapi/models/MetadataResponseExif.d.ts +2 -2
- package/dist/openapi/models/MetadataResponseExif.js +3 -3
- package/dist/openapi/models/MetadataResponseExifGps.d.ts +2 -2
- package/dist/openapi/models/MetadataResponseExifGps.js +2 -2
- package/dist/openapi/models/MetadataSuccessEnvelope.d.ts +3 -3
- package/dist/openapi/models/MetadataSuccessEnvelope.js +2 -2
- package/dist/openapi/models/MimeGroupSchema.d.ts +46 -2
- package/dist/openapi/models/MimeGroupSchema.js +11 -2
- package/dist/openapi/models/MultipartCompleteRequest.d.ts +3 -3
- package/dist/openapi/models/MultipartCompleteRequest.js +2 -2
- package/dist/openapi/models/MultipartCompleteRequestPartsInner.d.ts +2 -2
- package/dist/openapi/models/MultipartCompleteRequestPartsInner.js +2 -2
- package/dist/openapi/models/MultipartCompleteResponse.d.ts +7 -4
- package/dist/openapi/models/MultipartCompleteResponse.js +2 -2
- package/dist/openapi/models/MultipartCompleteSuccessEnvelope.d.ts +3 -3
- package/dist/openapi/models/MultipartCompleteSuccessEnvelope.js +2 -2
- package/dist/openapi/models/MultipartInitiateRequestMetadataHint.d.ts +56 -0
- package/dist/openapi/models/MultipartInitiateRequestMetadataHint.js +45 -0
- package/dist/openapi/models/MultipartInitiateResponse.d.ts +38 -6
- package/dist/openapi/models/MultipartInitiateResponse.js +7 -2
- package/dist/openapi/models/MultipartInitiateSuccessEnvelope.d.ts +3 -3
- package/dist/openapi/models/MultipartInitiateSuccessEnvelope.js +2 -2
- package/dist/openapi/models/MultipartKeepaliveResponse.d.ts +43 -0
- package/dist/openapi/models/MultipartKeepaliveResponse.js +47 -0
- package/dist/openapi/models/MultipartKeepaliveSuccessEnvelope.d.ts +46 -0
- package/dist/openapi/models/MultipartKeepaliveSuccessEnvelope.js +54 -0
- package/dist/openapi/models/MultipartPartListing.d.ts +59 -0
- package/dist/openapi/models/MultipartPartListing.js +55 -0
- package/dist/openapi/models/MultipartPresignRequest.d.ts +41 -0
- package/dist/openapi/models/MultipartPresignRequest.js +43 -0
- package/dist/openapi/models/MultipartPresignResponse.d.ts +46 -0
- package/dist/openapi/models/MultipartPresignResponse.js +48 -0
- package/dist/openapi/models/MultipartPresignSuccessEnvelope.d.ts +46 -0
- package/dist/openapi/models/MultipartPresignSuccessEnvelope.js +54 -0
- package/dist/openapi/models/MultipartStatusResponse.d.ts +103 -0
- package/dist/openapi/models/MultipartStatusResponse.js +76 -0
- package/dist/openapi/models/MultipartStatusSuccessEnvelope.d.ts +46 -0
- package/dist/openapi/models/MultipartStatusSuccessEnvelope.js +54 -0
- package/dist/openapi/models/OperationDefinition.d.ts +2 -2
- package/dist/openapi/models/OperationDefinition.js +2 -2
- package/dist/openapi/models/OperationDownload.d.ts +30 -2
- package/dist/openapi/models/OperationDownload.js +6 -2
- package/dist/openapi/models/OperationInputModel.d.ts +4 -4
- package/dist/openapi/models/OperationInputModel.js +4 -4
- package/dist/openapi/models/OperationResponse.d.ts +21 -2
- package/dist/openapi/models/OperationResponse.js +6 -2
- package/dist/openapi/models/OperationResult.d.ts +2 -2
- package/dist/openapi/models/OperationResult.js +2 -2
- package/dist/openapi/models/OperationResultMetrics.d.ts +2 -2
- package/dist/openapi/models/OperationResultMetrics.js +2 -2
- package/dist/openapi/models/OperationSchemaDefinition.d.ts +52 -5
- package/dist/openapi/models/OperationSchemaDefinition.js +10 -6
- package/dist/openapi/models/OperationStatus.d.ts +2 -2
- package/dist/openapi/models/OperationStatus.js +2 -2
- package/dist/openapi/models/OperationType.d.ts +17 -5
- package/dist/openapi/models/OperationType.js +18 -6
- package/dist/openapi/models/OperationsSchemaResponse.d.ts +70 -10
- package/dist/openapi/models/OperationsSchemaResponse.js +17 -2
- package/dist/openapi/models/OptionSchema.d.ts +42 -4
- package/dist/openapi/models/OptionSchema.js +12 -2
- package/dist/openapi/models/PerValueAvailabilityEntry.d.ts +80 -0
- package/dist/openapi/models/PerValueAvailabilityEntry.js +53 -0
- package/dist/openapi/models/PresignedUrlPart.d.ts +2 -2
- package/dist/openapi/models/PresignedUrlPart.js +3 -3
- package/dist/openapi/models/ProcessingClass.d.ts +35 -0
- package/dist/openapi/models/ProcessingClass.js +53 -0
- package/dist/openapi/models/ProcessingClassBandViolation.d.ts +149 -0
- package/dist/openapi/models/ProcessingClassBandViolation.js +81 -0
- package/dist/openapi/models/ProcessingClassExceedsBandResponse.d.ts +174 -0
- package/dist/openapi/models/ProcessingClassExceedsBandResponse.js +76 -0
- package/dist/openapi/models/ProcessingClassHint.d.ts +36 -0
- package/dist/openapi/models/ProcessingClassHint.js +54 -0
- package/dist/openapi/models/ProcessingClassReason.d.ts +46 -0
- package/dist/openapi/models/ProcessingClassReason.js +64 -0
- package/dist/openapi/models/ProcessingClassRejectReason.d.ts +53 -0
- package/dist/openapi/models/ProcessingClassRejectReason.js +71 -0
- package/dist/openapi/models/ProcessingPlan.d.ts +70 -0
- package/dist/openapi/models/ProcessingPlan.js +49 -0
- package/dist/openapi/models/ProcessingPlanJob.d.ts +81 -0
- package/dist/openapi/models/ProcessingPlanJob.js +71 -0
- package/dist/openapi/models/ReadinessResponse.d.ts +2 -2
- package/dist/openapi/models/ReadinessResponse.js +2 -2
- package/dist/openapi/models/ResponseEnvelope.d.ts +2 -2
- package/dist/openapi/models/ResponseEnvelope.js +2 -2
- package/dist/openapi/models/RetryResponse.d.ts +5 -5
- package/dist/openapi/models/RetryResponse.js +2 -2
- package/dist/openapi/models/RetrySuccessEnvelope.d.ts +3 -3
- package/dist/openapi/models/RetrySuccessEnvelope.js +2 -2
- package/dist/openapi/models/SseEventType.d.ts +2 -2
- package/dist/openapi/models/SseEventType.js +2 -2
- package/dist/openapi/models/SseJobCompletedData.d.ts +3 -3
- package/dist/openapi/models/SseJobCompletedData.js +2 -2
- package/dist/openapi/models/SseJobFailedData.d.ts +3 -3
- package/dist/openapi/models/SseJobFailedData.js +2 -2
- package/dist/openapi/models/SseOperationCompletedData.d.ts +4 -4
- package/dist/openapi/models/SseOperationCompletedData.js +2 -2
- package/dist/openapi/models/SseOperationFailedData.d.ts +3 -3
- package/dist/openapi/models/SseOperationFailedData.js +2 -2
- package/dist/openapi/models/SseOperationProgressData.d.ts +61 -3
- package/dist/openapi/models/SseOperationProgressData.js +22 -2
- package/dist/openapi/models/SseWorkflowTerminalData.d.ts +26 -4
- package/dist/openapi/models/SseWorkflowTerminalData.js +4 -2
- package/dist/openapi/models/TierRestrictionKind.d.ts +33 -0
- package/dist/openapi/models/TierRestrictionKind.js +51 -0
- package/dist/openapi/models/TierRestrictionResponse.d.ts +173 -0
- package/dist/openapi/models/TierRestrictionResponse.js +83 -0
- package/dist/openapi/models/UploadConstraintsApplied.d.ts +70 -0
- package/dist/openapi/models/UploadConstraintsApplied.js +57 -0
- package/dist/openapi/models/UploadDurationExceedsTierResponse.d.ts +155 -0
- package/dist/openapi/models/UploadDurationExceedsTierResponse.js +82 -0
- package/dist/openapi/models/UploadFile403Response.d.ts +27 -0
- package/dist/openapi/models/UploadFile403Response.js +47 -0
- package/dist/openapi/models/UploadFile422Response.d.ts +27 -0
- package/dist/openapi/models/UploadFile422Response.js +47 -0
- package/dist/openapi/models/UploadProbeMediaMetadata.d.ts +172 -0
- package/dist/openapi/models/UploadProbeMediaMetadata.js +69 -0
- package/dist/openapi/models/UploadProbeProcessingClass.d.ts +33 -0
- package/dist/openapi/models/UploadProbeProcessingClass.js +51 -0
- package/dist/openapi/models/UploadProbeResponse.d.ts +58 -0
- package/dist/openapi/models/UploadProbeResponse.js +58 -0
- package/dist/openapi/models/UploadProbeStatus.d.ts +41 -0
- package/dist/openapi/models/UploadProbeStatus.js +59 -0
- package/dist/openapi/models/UploadResponse.d.ts +17 -3
- package/dist/openapi/models/UploadResponse.js +7 -2
- package/dist/openapi/models/UploadSizeExceedsTierResponse.d.ts +155 -0
- package/dist/openapi/models/UploadSizeExceedsTierResponse.js +82 -0
- package/dist/openapi/models/UploadSource.d.ts +48 -0
- package/dist/openapi/models/UploadSource.js +53 -0
- package/dist/openapi/models/UploadSuccessEnvelope.d.ts +3 -3
- package/dist/openapi/models/UploadSuccessEnvelope.js +2 -2
- package/dist/openapi/models/UploadThresholds.d.ts +126 -0
- package/dist/openapi/models/UploadThresholds.js +79 -0
- package/dist/openapi/models/UserTier.d.ts +41 -0
- package/dist/openapi/models/UserTier.js +59 -0
- package/dist/openapi/models/ValidationErrorEnvelope.d.ts +51 -4
- package/dist/openapi/models/ValidationErrorEnvelope.js +10 -2
- package/dist/openapi/models/ValidationErrorEnvelopeDetailsInner.d.ts +37 -4
- package/dist/openapi/models/ValidationErrorEnvelopeDetailsInner.js +6 -2
- package/dist/openapi/models/WarningType.d.ts +48 -0
- package/dist/openapi/models/WarningType.js +66 -0
- package/dist/openapi/models/WebhookOperationContext.d.ts +3 -3
- package/dist/openapi/models/WebhookOperationContext.js +2 -2
- package/dist/openapi/models/WebhookPayload.d.ts +2 -2
- package/dist/openapi/models/WebhookPayload.js +3 -3
- package/dist/openapi/models/WorkflowCancelBillingEffect.d.ts +36 -0
- package/dist/openapi/models/WorkflowCancelBillingEffect.js +54 -0
- package/dist/openapi/models/WorkflowCancelResponse.d.ts +66 -0
- package/dist/openapi/models/WorkflowCancelResponse.js +62 -0
- package/dist/openapi/models/WorkflowCancelSuccessEnvelope.d.ts +46 -0
- package/dist/openapi/models/WorkflowCancelSuccessEnvelope.js +54 -0
- package/dist/openapi/models/WorkflowCreateRequest.d.ts +39 -5
- package/dist/openapi/models/WorkflowCreateRequest.js +11 -5
- package/dist/openapi/models/WorkflowCreateResponse.d.ts +63 -2
- package/dist/openapi/models/WorkflowCreateResponse.js +21 -2
- package/dist/openapi/models/WorkflowCreateSuccessEnvelope.d.ts +3 -3
- package/dist/openapi/models/WorkflowCreateSuccessEnvelope.js +2 -2
- package/dist/openapi/models/WorkflowDownloadResponse.d.ts +2 -2
- package/dist/openapi/models/WorkflowDownloadResponse.js +2 -2
- package/dist/openapi/models/WorkflowDownloadSuccessEnvelope.d.ts +3 -3
- package/dist/openapi/models/WorkflowDownloadSuccessEnvelope.js +2 -2
- package/dist/openapi/models/WorkflowEdge.d.ts +2 -2
- package/dist/openapi/models/WorkflowEdge.js +2 -2
- package/dist/openapi/models/WorkflowExpiredResponse.d.ts +145 -0
- package/dist/openapi/models/WorkflowExpiredResponse.js +75 -0
- package/dist/openapi/models/WorkflowPauseRequiredAction.d.ts +30 -0
- package/dist/openapi/models/WorkflowPauseRequiredAction.js +48 -0
- package/dist/openapi/models/WorkflowPausedDetail.d.ts +99 -0
- package/dist/openapi/models/WorkflowPausedDetail.js +65 -0
- package/dist/openapi/models/WorkflowPausedDetailLinks.d.ts +47 -0
- package/dist/openapi/models/WorkflowPausedDetailLinks.js +45 -0
- package/dist/openapi/models/WorkflowProcessing.d.ts +36 -0
- package/dist/openapi/models/WorkflowProcessing.js +42 -0
- package/dist/openapi/models/WorkflowResumeResponse.d.ts +55 -0
- package/dist/openapi/models/WorkflowResumeResponse.js +57 -0
- package/dist/openapi/models/WorkflowResumeSuccessEnvelope.d.ts +46 -0
- package/dist/openapi/models/WorkflowResumeSuccessEnvelope.js +54 -0
- package/dist/openapi/models/WorkflowSource.d.ts +40 -0
- package/dist/openapi/models/WorkflowSource.js +57 -0
- package/dist/openapi/models/WorkflowStatus.d.ts +31 -8
- package/dist/openapi/models/WorkflowStatus.js +32 -9
- package/dist/openapi/models/WorkflowStatusResponse.d.ts +34 -2
- package/dist/openapi/models/WorkflowStatusResponse.js +13 -2
- package/dist/openapi/models/WorkflowStatusSuccessEnvelope.d.ts +3 -3
- package/dist/openapi/models/WorkflowStatusSuccessEnvelope.js +2 -2
- package/dist/openapi/models/WorkflowWarning.d.ts +119 -0
- package/dist/openapi/models/WorkflowWarning.js +63 -0
- package/dist/openapi/models/WorkflowWarningSeverity.d.ts +29 -0
- package/dist/openapi/models/WorkflowWarningSeverity.js +47 -0
- package/dist/openapi/models/index.d.ts +87 -3
- package/dist/openapi/models/index.js +87 -3
- package/dist/openapi/runtime.d.ts +2 -2
- package/dist/openapi/runtime.js +17 -2
- package/dist/operations/archive.metadata.d.ts +2 -0
- package/dist/operations/archive.metadata.js +13 -0
- package/dist/operations/audio_overlay.d.ts +48 -0
- package/dist/operations/audio_overlay.js +19 -0
- package/dist/operations/audio_overlay.metadata.d.ts +2 -0
- package/dist/operations/audio_overlay.metadata.js +167 -0
- package/dist/operations/audio_watermark.d.ts +42 -0
- package/dist/operations/audio_watermark.js +37 -0
- package/dist/operations/audio_watermark.metadata.d.ts +2 -0
- package/dist/operations/audio_watermark.metadata.js +94 -0
- package/dist/operations/compress.metadata.d.ts +2 -0
- package/dist/operations/compress.metadata.js +205 -0
- package/dist/operations/convert.metadata.d.ts +2 -0
- package/dist/operations/convert.metadata.js +85 -0
- package/dist/operations/custom_luma.d.ts +7 -0
- package/dist/operations/custom_luma.js +2 -0
- package/dist/operations/custom_luma.metadata.d.ts +2 -0
- package/dist/operations/custom_luma.metadata.js +49 -0
- package/dist/operations/image_watermark.d.ts +54 -0
- package/dist/operations/image_watermark.js +37 -0
- package/dist/operations/image_watermark.metadata.d.ts +2 -0
- package/dist/operations/image_watermark.metadata.js +97 -0
- package/dist/operations/index.d.ts +16 -1
- package/dist/operations/index.js +16 -1
- package/dist/operations/merge.d.ts +111 -31
- package/dist/operations/merge.js +106 -20
- package/dist/operations/merge.metadata.d.ts +2 -0
- package/dist/operations/merge.metadata.js +385 -0
- package/dist/operations/metadata-types.d.ts +47 -0
- package/dist/operations/metadata-types.js +2 -0
- package/dist/operations/text_watermark.d.ts +31 -0
- package/dist/operations/text_watermark.js +22 -0
- package/dist/operations/text_watermark.metadata.d.ts +2 -0
- package/dist/operations/text_watermark.metadata.js +46 -0
- package/dist/operations/thumbnail.metadata.d.ts +2 -0
- package/dist/operations/thumbnail.metadata.js +88 -0
- package/openapi/api.yaml +6413 -821
- package/operations/schemas/audio_overlay.yaml +409 -0
- package/operations/schemas/audio_watermark.yaml +192 -0
- package/operations/schemas/compress.yaml +26 -3
- package/operations/schemas/convert.yaml +25 -3
- package/operations/schemas/custom_luma.yaml +116 -0
- package/operations/schemas/image_watermark.yaml +287 -0
- package/operations/schemas/merge.yaml +301 -66
- package/operations/schemas/text_watermark.yaml +147 -0
- package/operations/schemas/thumbnail.yaml +22 -0
- package/package.json +10 -4
- package/dist/openapi/models/ExportConfig.d.ts +0 -63
- package/dist/openapi/models/ExportConfig.js +0 -59
- package/dist/openapi/models/JobInput.d.ts +0 -53
- package/dist/openapi/models/JobInput.js +0 -47
- package/dist/openapi/models/JobSource.d.ts +0 -43
- package/dist/openapi/models/JobSource.js +0 -45
- package/dist/operations/watermark.d.ts +0 -28
- package/dist/operations/watermark.js +0 -19
- package/operations/schemas/watermark.yaml +0 -87
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GISL Compression API
|
|
3
|
+
* REST API for the GISL (Give It Smaller) file compression and processing service. **Architecture:** - Upload files to get a `file_id` - Create workflows referencing uploaded files with operations (compress, thumbnail, image_watermark, text_watermark, merge, archive, convert, custom_luma, audio_overlay, audio_watermark) - Poll status, stream SSE events, or receive webhook callbacks - Download results per operation output **Response envelope:** All mutation and query endpoints return `{ success: true, data: {...} }` on success and `{ success: false, error: \"...\", details: [...] }` on failure. Exceptions: `GET /api/operations/schema` returns raw JSON (per-tier private caching with ETag/Last-Modified revalidation per ADR-0002 + I3), health probes return flat objects, and `POST /api/contact` returns 204 with no body. **Availability metadata.** This spec uses the `x-availability` vendor extension as **decorative documentation only**. Per [ADR-0001](../docs/decisions/0001-contract-first-availability.md) §1.5, the runtime endpoint `GET /api/operations/schema` (ticket I3) is the authoritative source; the sidecar `availability.json` (ticket I3b) is the authoritative companion (generated, never hand-edited; CI cross-checks runtime ⇄ sidecar). SDKs MUST NOT depend on `x-availability` reaching generated code — code-generators that surface vendor extensions may emit it as documentation, but consumers read availability from the runtime endpoint, not from the generated bindings. The 5-value vocabulary (`stable | beta | experimental | planned | deprecated`) is defined in the `AvailabilityValue` schema. See `schemas/FORMAT.md` §Availability Taxonomy for the operational rules (parser obligation: absent = stable; per-enum-value granularity is the `per_value_availability` primitive landed via ticket I17). **Localisation (per ticket [I26](https://trello.com/c/rcnqwgI4)).** Error responses + paused/blocked workflow statuses carry a localised human-readable `message` alongside a stable, never-localised `message_key`. Machine-readable fields (`error`, enum values, status codes) stay canonical English. - **Request:** `Accept-Language` header per RFC 9110 §12.5.4 (q-value negotiation supported). The server selects the best-match locale from its supported list; falls back to `en-GB` when no match. - **Response:** `Content-Language: <locale>` echo on every localised response; `Vary: Accept-Language` on every response (CDN/cache correctness — different `Accept-Language` requests produce different responses). - **Fallback locale:** `en-GB` (also the canonical locale for `message_key` translations and English `message` prose). - **SDK guidance:** switch on `error` (machine code) for typed error branches; surface `message_key` to client-side i18n catalogs (SDK companion work tracked at X19, cross-repo); display `message` for end-user UI; **never parse `message` for control flow** — it changes per locale. Carrier shape lives on `ErrorEnvelope` (envelope-level optional `message_key` + `message` + `locale` + `message_params`) and `ValidationErrorEnvelope` (also per-`details[]` entry). Existing 402 / 403 / 422 envelopes (`BalanceExhaustedResponse`, `FeatureNotAvailableResponse`, `FeatureTierRestrictedResponse`, `WorkflowPausedDetail`) inherit the convention. **Upload thresholds (per tickets [u0ar7Yye](https://trello.com/c/u0ar7Yye) + [58nBQLWQ](https://trello.com/c/58nBQLWQ)).** Canonical upload constants (single-shot cap, multipart chunk size, multipart concurrency default, multipart first-chunk size) live on the `UploadThresholds` schema with `const:`-pinned values. SDK generators emit these as typed binding constants so frontend / API / SDKs reference one source of truth instead of hardcoding magic numbers. A runtime `GET /api/uploads/limits` endpoint for dynamic discovery (per-tier / per-environment overrides) is a deferred follow-up.
|
|
4
|
+
*
|
|
5
|
+
* The version of the OpenAPI document: 2.12.0
|
|
6
|
+
*
|
|
7
|
+
*
|
|
8
|
+
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
|
|
9
|
+
* https://openapi-generator.tech
|
|
10
|
+
* Do not edit the class manually.
|
|
11
|
+
*/
|
|
12
|
+
import type { UserTier } from './UserTier.js';
|
|
13
|
+
import type { ProcessingClass } from './ProcessingClass.js';
|
|
14
|
+
import type { OperationType } from './OperationType.js';
|
|
15
|
+
import type { ProcessingClassRejectReason } from './ProcessingClassRejectReason.js';
|
|
16
|
+
/**
|
|
17
|
+
* One band-ceiling overflow on a workflow-create reject. Carries
|
|
18
|
+
* the I26 localisation quad on the violation (mirrors
|
|
19
|
+
* `FeatureViolation`); envelope-level localisation rides via
|
|
20
|
+
* `allOf [ErrorEnvelope]` on `ProcessingClassExceedsBandResponse`.
|
|
21
|
+
*
|
|
22
|
+
* `job_ref`, `actual`, `ceiling`, `operation`, and
|
|
23
|
+
* `processing_class` are REQUIRED — the server always knows them
|
|
24
|
+
* at reject time and consumers rely on them to (a) correlate
|
|
25
|
+
* fail-all violations back to the offending job in multi-job
|
|
26
|
+
* workflows and (b) render "X exceeded by Y" without re-deriving
|
|
27
|
+
* caps from the per-tier overlay.
|
|
28
|
+
*
|
|
29
|
+
* @export
|
|
30
|
+
* @interface ProcessingClassBandViolation
|
|
31
|
+
*/
|
|
32
|
+
export interface ProcessingClassBandViolation {
|
|
33
|
+
/**
|
|
34
|
+
*
|
|
35
|
+
* @type {ProcessingClassRejectReason}
|
|
36
|
+
* @memberof ProcessingClassBandViolation
|
|
37
|
+
*/
|
|
38
|
+
reason: ProcessingClassRejectReason;
|
|
39
|
+
/**
|
|
40
|
+
* Workflow-local job identifier — `JobDefinition.id` if the
|
|
41
|
+
* caller supplied one, otherwise the auto-generated `job_N`
|
|
42
|
+
* positional token assigned by the server during request
|
|
43
|
+
* validation (e.g. `job_0`, `job_1`). Workflow-create rejects
|
|
44
|
+
* fire BEFORE persisted server UUIDs are assigned; `job_ref`
|
|
45
|
+
* is the request-local handle that survives across reject
|
|
46
|
+
* and (later) success paths. Per `JobDefinition.id` pattern
|
|
47
|
+
* + auto-generation rules.
|
|
48
|
+
*
|
|
49
|
+
* @type {string}
|
|
50
|
+
* @memberof ProcessingClassBandViolation
|
|
51
|
+
*/
|
|
52
|
+
jobRef: string;
|
|
53
|
+
/**
|
|
54
|
+
* 0-based ordinal into `JobDefinition.inputs[]` identifying
|
|
55
|
+
* the specific input that violated the per-input ceiling.
|
|
56
|
+
* Set ONLY on `input_*_exceeds_long_form` reasons for
|
|
57
|
+
* multi-input operations; omitted on single-input
|
|
58
|
+
* operations (no positional ambiguity) and on
|
|
59
|
+
* `combined_*_exceeds_long_form` reasons (whole-job
|
|
60
|
+
* violation across all inputs).
|
|
61
|
+
*
|
|
62
|
+
* @type {number}
|
|
63
|
+
* @memberof ProcessingClassBandViolation
|
|
64
|
+
*/
|
|
65
|
+
inputIndex?: number;
|
|
66
|
+
/**
|
|
67
|
+
* Operation type that triggered the band-ceiling reject.
|
|
68
|
+
* @type {OperationType}
|
|
69
|
+
* @memberof ProcessingClassBandViolation
|
|
70
|
+
*/
|
|
71
|
+
operation: OperationType;
|
|
72
|
+
/**
|
|
73
|
+
* The class whose ceiling was exceeded — typically `long_form`
|
|
74
|
+
* or `long_form_re_encode`.
|
|
75
|
+
*
|
|
76
|
+
* @type {ProcessingClass}
|
|
77
|
+
* @memberof ProcessingClassBandViolation
|
|
78
|
+
*/
|
|
79
|
+
processingClass: ProcessingClass;
|
|
80
|
+
/**
|
|
81
|
+
* Observed value. Bytes for `*_size_exceeds_long_form`
|
|
82
|
+
* reasons; whole seconds for `*_duration_exceeds_long_form`
|
|
83
|
+
* reasons.
|
|
84
|
+
*
|
|
85
|
+
* @type {number}
|
|
86
|
+
* @memberof ProcessingClassBandViolation
|
|
87
|
+
*/
|
|
88
|
+
actual: number;
|
|
89
|
+
/**
|
|
90
|
+
* Effective per-tier ceiling for this caller (same units as
|
|
91
|
+
* `actual`). The binding cap after `per_tier_constraints`
|
|
92
|
+
* overlay; lets consumers render "X exceeded by Y" without
|
|
93
|
+
* re-deriving caps from the per-tier overlay.
|
|
94
|
+
*
|
|
95
|
+
* @type {number}
|
|
96
|
+
* @memberof ProcessingClassBandViolation
|
|
97
|
+
*/
|
|
98
|
+
ceiling: number;
|
|
99
|
+
/**
|
|
100
|
+
*
|
|
101
|
+
* @type {UserTier}
|
|
102
|
+
* @memberof ProcessingClassBandViolation
|
|
103
|
+
*/
|
|
104
|
+
requiredTier?: UserTier | null;
|
|
105
|
+
/**
|
|
106
|
+
* Optional link to processing-class documentation.
|
|
107
|
+
* @type {string}
|
|
108
|
+
* @memberof ProcessingClassBandViolation
|
|
109
|
+
*/
|
|
110
|
+
documentationUrl?: string;
|
|
111
|
+
/**
|
|
112
|
+
* Per I26. See `ErrorEnvelope.message_key`.
|
|
113
|
+
* @type {string}
|
|
114
|
+
* @memberof ProcessingClassBandViolation
|
|
115
|
+
*/
|
|
116
|
+
messageKey?: string;
|
|
117
|
+
/**
|
|
118
|
+
* Per I26. Human-readable, localised per `Accept-Language`.
|
|
119
|
+
* Never parse for control flow.
|
|
120
|
+
*
|
|
121
|
+
* @type {string}
|
|
122
|
+
* @memberof ProcessingClassBandViolation
|
|
123
|
+
*/
|
|
124
|
+
message?: string;
|
|
125
|
+
/**
|
|
126
|
+
* BCP 47 locale tag. See `ErrorEnvelope.locale`.
|
|
127
|
+
* @type {string}
|
|
128
|
+
* @memberof ProcessingClassBandViolation
|
|
129
|
+
*/
|
|
130
|
+
locale?: string;
|
|
131
|
+
/**
|
|
132
|
+
* Per I26. Optional interpolation values for the localised
|
|
133
|
+
* `message`. Excludes cost numbers.
|
|
134
|
+
*
|
|
135
|
+
* @type {{ [key: string]: any; }}
|
|
136
|
+
* @memberof ProcessingClassBandViolation
|
|
137
|
+
*/
|
|
138
|
+
messageParams?: {
|
|
139
|
+
[key: string]: any;
|
|
140
|
+
};
|
|
141
|
+
}
|
|
142
|
+
/**
|
|
143
|
+
* Check if a given object implements the ProcessingClassBandViolation interface.
|
|
144
|
+
*/
|
|
145
|
+
export declare function instanceOfProcessingClassBandViolation(value: object): value is ProcessingClassBandViolation;
|
|
146
|
+
export declare function ProcessingClassBandViolationFromJSON(json: any): ProcessingClassBandViolation;
|
|
147
|
+
export declare function ProcessingClassBandViolationFromJSONTyped(json: any, ignoreDiscriminator: boolean): ProcessingClassBandViolation;
|
|
148
|
+
export declare function ProcessingClassBandViolationToJSON(json: any): ProcessingClassBandViolation;
|
|
149
|
+
export declare function ProcessingClassBandViolationToJSONTyped(value?: ProcessingClassBandViolation | null, ignoreDiscriminator?: boolean): any;
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
/* tslint:disable */
|
|
2
|
+
/* eslint-disable */
|
|
3
|
+
/**
|
|
4
|
+
* GISL Compression API
|
|
5
|
+
* REST API for the GISL (Give It Smaller) file compression and processing service. **Architecture:** - Upload files to get a `file_id` - Create workflows referencing uploaded files with operations (compress, thumbnail, image_watermark, text_watermark, merge, archive, convert, custom_luma, audio_overlay, audio_watermark) - Poll status, stream SSE events, or receive webhook callbacks - Download results per operation output **Response envelope:** All mutation and query endpoints return `{ success: true, data: {...} }` on success and `{ success: false, error: \"...\", details: [...] }` on failure. Exceptions: `GET /api/operations/schema` returns raw JSON (per-tier private caching with ETag/Last-Modified revalidation per ADR-0002 + I3), health probes return flat objects, and `POST /api/contact` returns 204 with no body. **Availability metadata.** This spec uses the `x-availability` vendor extension as **decorative documentation only**. Per [ADR-0001](../docs/decisions/0001-contract-first-availability.md) §1.5, the runtime endpoint `GET /api/operations/schema` (ticket I3) is the authoritative source; the sidecar `availability.json` (ticket I3b) is the authoritative companion (generated, never hand-edited; CI cross-checks runtime ⇄ sidecar). SDKs MUST NOT depend on `x-availability` reaching generated code — code-generators that surface vendor extensions may emit it as documentation, but consumers read availability from the runtime endpoint, not from the generated bindings. The 5-value vocabulary (`stable | beta | experimental | planned | deprecated`) is defined in the `AvailabilityValue` schema. See `schemas/FORMAT.md` §Availability Taxonomy for the operational rules (parser obligation: absent = stable; per-enum-value granularity is the `per_value_availability` primitive landed via ticket I17). **Localisation (per ticket [I26](https://trello.com/c/rcnqwgI4)).** Error responses + paused/blocked workflow statuses carry a localised human-readable `message` alongside a stable, never-localised `message_key`. Machine-readable fields (`error`, enum values, status codes) stay canonical English. - **Request:** `Accept-Language` header per RFC 9110 §12.5.4 (q-value negotiation supported). The server selects the best-match locale from its supported list; falls back to `en-GB` when no match. - **Response:** `Content-Language: <locale>` echo on every localised response; `Vary: Accept-Language` on every response (CDN/cache correctness — different `Accept-Language` requests produce different responses). - **Fallback locale:** `en-GB` (also the canonical locale for `message_key` translations and English `message` prose). - **SDK guidance:** switch on `error` (machine code) for typed error branches; surface `message_key` to client-side i18n catalogs (SDK companion work tracked at X19, cross-repo); display `message` for end-user UI; **never parse `message` for control flow** — it changes per locale. Carrier shape lives on `ErrorEnvelope` (envelope-level optional `message_key` + `message` + `locale` + `message_params`) and `ValidationErrorEnvelope` (also per-`details[]` entry). Existing 402 / 403 / 422 envelopes (`BalanceExhaustedResponse`, `FeatureNotAvailableResponse`, `FeatureTierRestrictedResponse`, `WorkflowPausedDetail`) inherit the convention. **Upload thresholds (per tickets [u0ar7Yye](https://trello.com/c/u0ar7Yye) + [58nBQLWQ](https://trello.com/c/58nBQLWQ)).** Canonical upload constants (single-shot cap, multipart chunk size, multipart concurrency default, multipart first-chunk size) live on the `UploadThresholds` schema with `const:`-pinned values. SDK generators emit these as typed binding constants so frontend / API / SDKs reference one source of truth instead of hardcoding magic numbers. A runtime `GET /api/uploads/limits` endpoint for dynamic discovery (per-tier / per-environment overrides) is a deferred follow-up.
|
|
6
|
+
*
|
|
7
|
+
* The version of the OpenAPI document: 2.12.0
|
|
8
|
+
*
|
|
9
|
+
*
|
|
10
|
+
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
|
|
11
|
+
* https://openapi-generator.tech
|
|
12
|
+
* Do not edit the class manually.
|
|
13
|
+
*/
|
|
14
|
+
import { UserTierFromJSON, UserTierToJSON, } from './UserTier.js';
|
|
15
|
+
import { ProcessingClassFromJSON, ProcessingClassToJSON, } from './ProcessingClass.js';
|
|
16
|
+
import { OperationTypeFromJSON, OperationTypeToJSON, } from './OperationType.js';
|
|
17
|
+
import { ProcessingClassRejectReasonFromJSON, ProcessingClassRejectReasonToJSON, } from './ProcessingClassRejectReason.js';
|
|
18
|
+
/**
|
|
19
|
+
* Check if a given object implements the ProcessingClassBandViolation interface.
|
|
20
|
+
*/
|
|
21
|
+
export function instanceOfProcessingClassBandViolation(value) {
|
|
22
|
+
if (!('reason' in value) || value['reason'] === undefined)
|
|
23
|
+
return false;
|
|
24
|
+
if (!('jobRef' in value) || value['jobRef'] === undefined)
|
|
25
|
+
return false;
|
|
26
|
+
if (!('operation' in value) || value['operation'] === undefined)
|
|
27
|
+
return false;
|
|
28
|
+
if (!('processingClass' in value) || value['processingClass'] === undefined)
|
|
29
|
+
return false;
|
|
30
|
+
if (!('actual' in value) || value['actual'] === undefined)
|
|
31
|
+
return false;
|
|
32
|
+
if (!('ceiling' in value) || value['ceiling'] === undefined)
|
|
33
|
+
return false;
|
|
34
|
+
return true;
|
|
35
|
+
}
|
|
36
|
+
export function ProcessingClassBandViolationFromJSON(json) {
|
|
37
|
+
return ProcessingClassBandViolationFromJSONTyped(json, false);
|
|
38
|
+
}
|
|
39
|
+
export function ProcessingClassBandViolationFromJSONTyped(json, ignoreDiscriminator) {
|
|
40
|
+
if (json == null) {
|
|
41
|
+
return json;
|
|
42
|
+
}
|
|
43
|
+
return {
|
|
44
|
+
'reason': ProcessingClassRejectReasonFromJSON(json['reason']),
|
|
45
|
+
'jobRef': json['job_ref'],
|
|
46
|
+
'inputIndex': json['input_index'] == null ? undefined : json['input_index'],
|
|
47
|
+
'operation': OperationTypeFromJSON(json['operation']),
|
|
48
|
+
'processingClass': ProcessingClassFromJSON(json['processing_class']),
|
|
49
|
+
'actual': json['actual'],
|
|
50
|
+
'ceiling': json['ceiling'],
|
|
51
|
+
'requiredTier': json['required_tier'] == null ? undefined : UserTierFromJSON(json['required_tier']),
|
|
52
|
+
'documentationUrl': json['documentation_url'] == null ? undefined : json['documentation_url'],
|
|
53
|
+
'messageKey': json['message_key'] == null ? undefined : json['message_key'],
|
|
54
|
+
'message': json['message'] == null ? undefined : json['message'],
|
|
55
|
+
'locale': json['locale'] == null ? undefined : json['locale'],
|
|
56
|
+
'messageParams': json['message_params'] == null ? undefined : json['message_params'],
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
export function ProcessingClassBandViolationToJSON(json) {
|
|
60
|
+
return ProcessingClassBandViolationToJSONTyped(json, false);
|
|
61
|
+
}
|
|
62
|
+
export function ProcessingClassBandViolationToJSONTyped(value, ignoreDiscriminator = false) {
|
|
63
|
+
if (value == null) {
|
|
64
|
+
return value;
|
|
65
|
+
}
|
|
66
|
+
return {
|
|
67
|
+
'reason': ProcessingClassRejectReasonToJSON(value['reason']),
|
|
68
|
+
'job_ref': value['jobRef'],
|
|
69
|
+
'input_index': value['inputIndex'],
|
|
70
|
+
'operation': OperationTypeToJSON(value['operation']),
|
|
71
|
+
'processing_class': ProcessingClassToJSON(value['processingClass']),
|
|
72
|
+
'actual': value['actual'],
|
|
73
|
+
'ceiling': value['ceiling'],
|
|
74
|
+
'required_tier': UserTierToJSON(value['requiredTier']),
|
|
75
|
+
'documentation_url': value['documentationUrl'],
|
|
76
|
+
'message_key': value['messageKey'],
|
|
77
|
+
'message': value['message'],
|
|
78
|
+
'locale': value['locale'],
|
|
79
|
+
'message_params': value['messageParams'],
|
|
80
|
+
};
|
|
81
|
+
}
|
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GISL Compression API
|
|
3
|
+
* REST API for the GISL (Give It Smaller) file compression and processing service. **Architecture:** - Upload files to get a `file_id` - Create workflows referencing uploaded files with operations (compress, thumbnail, image_watermark, text_watermark, merge, archive, convert, custom_luma, audio_overlay, audio_watermark) - Poll status, stream SSE events, or receive webhook callbacks - Download results per operation output **Response envelope:** All mutation and query endpoints return `{ success: true, data: {...} }` on success and `{ success: false, error: \"...\", details: [...] }` on failure. Exceptions: `GET /api/operations/schema` returns raw JSON (per-tier private caching with ETag/Last-Modified revalidation per ADR-0002 + I3), health probes return flat objects, and `POST /api/contact` returns 204 with no body. **Availability metadata.** This spec uses the `x-availability` vendor extension as **decorative documentation only**. Per [ADR-0001](../docs/decisions/0001-contract-first-availability.md) §1.5, the runtime endpoint `GET /api/operations/schema` (ticket I3) is the authoritative source; the sidecar `availability.json` (ticket I3b) is the authoritative companion (generated, never hand-edited; CI cross-checks runtime ⇄ sidecar). SDKs MUST NOT depend on `x-availability` reaching generated code — code-generators that surface vendor extensions may emit it as documentation, but consumers read availability from the runtime endpoint, not from the generated bindings. The 5-value vocabulary (`stable | beta | experimental | planned | deprecated`) is defined in the `AvailabilityValue` schema. See `schemas/FORMAT.md` §Availability Taxonomy for the operational rules (parser obligation: absent = stable; per-enum-value granularity is the `per_value_availability` primitive landed via ticket I17). **Localisation (per ticket [I26](https://trello.com/c/rcnqwgI4)).** Error responses + paused/blocked workflow statuses carry a localised human-readable `message` alongside a stable, never-localised `message_key`. Machine-readable fields (`error`, enum values, status codes) stay canonical English. - **Request:** `Accept-Language` header per RFC 9110 §12.5.4 (q-value negotiation supported). The server selects the best-match locale from its supported list; falls back to `en-GB` when no match. - **Response:** `Content-Language: <locale>` echo on every localised response; `Vary: Accept-Language` on every response (CDN/cache correctness — different `Accept-Language` requests produce different responses). - **Fallback locale:** `en-GB` (also the canonical locale for `message_key` translations and English `message` prose). - **SDK guidance:** switch on `error` (machine code) for typed error branches; surface `message_key` to client-side i18n catalogs (SDK companion work tracked at X19, cross-repo); display `message` for end-user UI; **never parse `message` for control flow** — it changes per locale. Carrier shape lives on `ErrorEnvelope` (envelope-level optional `message_key` + `message` + `locale` + `message_params`) and `ValidationErrorEnvelope` (also per-`details[]` entry). Existing 402 / 403 / 422 envelopes (`BalanceExhaustedResponse`, `FeatureNotAvailableResponse`, `FeatureTierRestrictedResponse`, `WorkflowPausedDetail`) inherit the convention. **Upload thresholds (per tickets [u0ar7Yye](https://trello.com/c/u0ar7Yye) + [58nBQLWQ](https://trello.com/c/58nBQLWQ)).** Canonical upload constants (single-shot cap, multipart chunk size, multipart concurrency default, multipart first-chunk size) live on the `UploadThresholds` schema with `const:`-pinned values. SDK generators emit these as typed binding constants so frontend / API / SDKs reference one source of truth instead of hardcoding magic numbers. A runtime `GET /api/uploads/limits` endpoint for dynamic discovery (per-tier / per-environment overrides) is a deferred follow-up.
|
|
4
|
+
*
|
|
5
|
+
* The version of the OpenAPI document: 2.12.0
|
|
6
|
+
*
|
|
7
|
+
*
|
|
8
|
+
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
|
|
9
|
+
* https://openapi-generator.tech
|
|
10
|
+
* Do not edit the class manually.
|
|
11
|
+
*/
|
|
12
|
+
import type { ProcessingClassBandViolation } from './ProcessingClassBandViolation.js';
|
|
13
|
+
/**
|
|
14
|
+
* 422 response body when one or more jobs cannot be classified
|
|
15
|
+
* because input size/duration exceeds the `long_form` (or
|
|
16
|
+
* `long_form_re_encode`) ceiling under the caller's effective
|
|
17
|
+
* per-tier caps (per
|
|
18
|
+
* [ADR-0011](../docs/decisions/0011-per-tier-processing-class-constraints.md)
|
|
19
|
+
* `per_tier_constraints`).
|
|
20
|
+
*
|
|
21
|
+
* Distinct from `TierRestrictionResponse` (403, request-level
|
|
22
|
+
* tier-quota — resolvable by upload-size reduction or quota
|
|
23
|
+
* change) and from `FeatureNotAvailableResponse` (422, feature
|
|
24
|
+
* tagged not-yet-shipped — resolvable by waiting for the
|
|
25
|
+
* availability flip). Resolution path is per-violation:
|
|
26
|
+
* `required_tier` on each `ProcessingClassBandViolation` names
|
|
27
|
+
* the tier (if any) whose `per_tier_constraints` would
|
|
28
|
+
* accommodate the request; `null` means terminal (e.g. enterprise
|
|
29
|
+
* already at the 120 GB hard ceiling).
|
|
30
|
+
*
|
|
31
|
+
* Per
|
|
32
|
+
* [ADR-0012](../docs/decisions/0012-processing-class-band-reject-envelope.md)
|
|
33
|
+
* for the band-vs-tier rationale and routing rule (why this
|
|
34
|
+
* envelope is 422, not an extension of `TierRestrictionResponse`
|
|
35
|
+
* on 403).
|
|
36
|
+
*
|
|
37
|
+
* Delivered on `POST /api/workflows` 422 in a naked `oneOf`
|
|
38
|
+
* alongside `ValidationErrorEnvelope` and
|
|
39
|
+
* `FeatureNotAvailableResponse` — branches distinguished by
|
|
40
|
+
* required-field shape (`details` vs `error_type` value).
|
|
41
|
+
*
|
|
42
|
+
* @export
|
|
43
|
+
* @interface ProcessingClassExceedsBandResponse
|
|
44
|
+
*/
|
|
45
|
+
export interface ProcessingClassExceedsBandResponse {
|
|
46
|
+
/**
|
|
47
|
+
*
|
|
48
|
+
* @type {ProcessingClassExceedsBandResponseSuccessEnum}
|
|
49
|
+
* @memberof ProcessingClassExceedsBandResponse
|
|
50
|
+
*/
|
|
51
|
+
success: ProcessingClassExceedsBandResponseSuccessEnum;
|
|
52
|
+
/**
|
|
53
|
+
* Stable, machine-readable error code (e.g.
|
|
54
|
+
* `INVALID_OPTIONS`, `BALANCE_EXHAUSTED`,
|
|
55
|
+
* `REQUIRES_REENCODE`). Canonical English; never localised.
|
|
56
|
+
* SDKs duck-type on this field for typed error-branch
|
|
57
|
+
* helpers.
|
|
58
|
+
*
|
|
59
|
+
* Multipart-session resume codes (per ticket
|
|
60
|
+
* [`HxUmVr3Y`](https://trello.com/c/HxUmVr3Y), V2.10.0):
|
|
61
|
+
* - `MULTIPART_SESSION_NOT_FOUND` (404) — upload_id does
|
|
62
|
+
* not match an in-flight session (expired / never
|
|
63
|
+
* existed / wrong account namespace). Fired by /status,
|
|
64
|
+
* /presign, /keepalive.
|
|
65
|
+
* - `MULTIPART_SESSION_OWNERSHIP` (403) — authenticated
|
|
66
|
+
* caller is not the session owner. Fired by /status,
|
|
67
|
+
* /presign, /keepalive, /complete (when manifest.userId
|
|
68
|
+
* is non-null and differs).
|
|
69
|
+
* - `MULTIPART_SESSION_AUTH_REQUIRED` (403) — session was
|
|
70
|
+
* anonymously initiated; the three resume endpoints
|
|
71
|
+
* require authentication. The `8LABloaz` follow-up will
|
|
72
|
+
* flip `/initiate` to also require auth.
|
|
73
|
+
* - `FILE_TOO_LARGE_FOR_MULTIPART` (422) — assembled object
|
|
74
|
+
* would exceed the S3 multipart capacity cap. Pre-S3
|
|
75
|
+
* server-side capacity gate; distinct from tier-quota
|
|
76
|
+
* rejections (`upload_size_exceeds_tier`).
|
|
77
|
+
*
|
|
78
|
+
* @type {string}
|
|
79
|
+
* @memberof ProcessingClassExceedsBandResponse
|
|
80
|
+
*/
|
|
81
|
+
error: string;
|
|
82
|
+
/**
|
|
83
|
+
* Human-readable error message, localised per the
|
|
84
|
+
* request's `Accept-Language` header (fallback locale
|
|
85
|
+
* `en-GB`). The response carries `Content-Language:
|
|
86
|
+
* <locale>` + `Vary: Accept-Language` headers. **Never
|
|
87
|
+
* parse this field for control flow** — it changes per
|
|
88
|
+
* locale.
|
|
89
|
+
*
|
|
90
|
+
* @type {string}
|
|
91
|
+
* @memberof ProcessingClassExceedsBandResponse
|
|
92
|
+
*/
|
|
93
|
+
message?: string;
|
|
94
|
+
/**
|
|
95
|
+
* Stable canonical lookup key for the message (e.g.
|
|
96
|
+
* `error.balance_exhausted.add_credits`,
|
|
97
|
+
* `error.upload_size_exceeds_tier`). Never localised. SDK +
|
|
98
|
+
* frontend translation layers gate on this for client-side
|
|
99
|
+
* i18n catalogs (per ticket X19, cross-repo SDK companion
|
|
100
|
+
* work). Stable across server message-prose updates.
|
|
101
|
+
*
|
|
102
|
+
* @type {string}
|
|
103
|
+
* @memberof ProcessingClassExceedsBandResponse
|
|
104
|
+
*/
|
|
105
|
+
messageKey?: string;
|
|
106
|
+
/**
|
|
107
|
+
* BCP 47 locale tag echoing the resolved `Content-Language`
|
|
108
|
+
* response header value (e.g. `en-GB`, `pt-BR`, `ja-JP`).
|
|
109
|
+
* Lets the SDK confirm which locale the server selected
|
|
110
|
+
* when the request used q-value negotiation across multiple
|
|
111
|
+
* `Accept-Language` values.
|
|
112
|
+
*
|
|
113
|
+
* @type {string}
|
|
114
|
+
* @memberof ProcessingClassExceedsBandResponse
|
|
115
|
+
*/
|
|
116
|
+
locale?: string;
|
|
117
|
+
/**
|
|
118
|
+
* Optional interpolation values for the localised
|
|
119
|
+
* `message`. Keys are stable parameter names referenced by
|
|
120
|
+
* the translation table (e.g.
|
|
121
|
+
* `{ "filename": "photo.heic", "max_size_mb": 100 }`).
|
|
122
|
+
* **Excludes cost / monetary numbers** per plan v5 §F11
|
|
123
|
+
* round-13 narrowing — pricing-related localisation reads
|
|
124
|
+
* numeric state from `GET /api/v2/credits/balance`, not
|
|
125
|
+
* from this field. Values are JSON-native scalars
|
|
126
|
+
* (`string` / `integer` / `number` / `boolean` / `null`)
|
|
127
|
+
* — no nested objects, to keep translation-table
|
|
128
|
+
* integration simple.
|
|
129
|
+
*
|
|
130
|
+
* @type {{ [key: string]: any; }}
|
|
131
|
+
* @memberof ProcessingClassExceedsBandResponse
|
|
132
|
+
*/
|
|
133
|
+
messageParams?: {
|
|
134
|
+
[key: string]: any;
|
|
135
|
+
};
|
|
136
|
+
/**
|
|
137
|
+
* Discriminator for the 422 oneOf. Always `processing_class_exceeds_band` for this envelope.
|
|
138
|
+
* @type {ProcessingClassExceedsBandResponseErrorTypeEnum}
|
|
139
|
+
* @memberof ProcessingClassExceedsBandResponse
|
|
140
|
+
*/
|
|
141
|
+
errorType: ProcessingClassExceedsBandResponseErrorTypeEnum;
|
|
142
|
+
/**
|
|
143
|
+
* One entry per offending job/input. Per ADR-0001 §F6
|
|
144
|
+
* batched-violations rule, multiple violations in a
|
|
145
|
+
* single request are ALL returned here (fail-all, not
|
|
146
|
+
* fail-fast).
|
|
147
|
+
*
|
|
148
|
+
* @type {Array<ProcessingClassBandViolation>}
|
|
149
|
+
* @memberof ProcessingClassExceedsBandResponse
|
|
150
|
+
*/
|
|
151
|
+
violations: Array<ProcessingClassBandViolation>;
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* @export
|
|
155
|
+
*/
|
|
156
|
+
export declare const ProcessingClassExceedsBandResponseSuccessEnum: {
|
|
157
|
+
readonly false: false;
|
|
158
|
+
};
|
|
159
|
+
export type ProcessingClassExceedsBandResponseSuccessEnum = typeof ProcessingClassExceedsBandResponseSuccessEnum[keyof typeof ProcessingClassExceedsBandResponseSuccessEnum];
|
|
160
|
+
/**
|
|
161
|
+
* @export
|
|
162
|
+
*/
|
|
163
|
+
export declare const ProcessingClassExceedsBandResponseErrorTypeEnum: {
|
|
164
|
+
readonly processing_class_exceeds_band: "processing_class_exceeds_band";
|
|
165
|
+
};
|
|
166
|
+
export type ProcessingClassExceedsBandResponseErrorTypeEnum = typeof ProcessingClassExceedsBandResponseErrorTypeEnum[keyof typeof ProcessingClassExceedsBandResponseErrorTypeEnum];
|
|
167
|
+
/**
|
|
168
|
+
* Check if a given object implements the ProcessingClassExceedsBandResponse interface.
|
|
169
|
+
*/
|
|
170
|
+
export declare function instanceOfProcessingClassExceedsBandResponse(value: object): value is ProcessingClassExceedsBandResponse;
|
|
171
|
+
export declare function ProcessingClassExceedsBandResponseFromJSON(json: any): ProcessingClassExceedsBandResponse;
|
|
172
|
+
export declare function ProcessingClassExceedsBandResponseFromJSONTyped(json: any, ignoreDiscriminator: boolean): ProcessingClassExceedsBandResponse;
|
|
173
|
+
export declare function ProcessingClassExceedsBandResponseToJSON(json: any): ProcessingClassExceedsBandResponse;
|
|
174
|
+
export declare function ProcessingClassExceedsBandResponseToJSONTyped(value?: ProcessingClassExceedsBandResponse | null, ignoreDiscriminator?: boolean): any;
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
/* tslint:disable */
|
|
2
|
+
/* eslint-disable */
|
|
3
|
+
/**
|
|
4
|
+
* GISL Compression API
|
|
5
|
+
* REST API for the GISL (Give It Smaller) file compression and processing service. **Architecture:** - Upload files to get a `file_id` - Create workflows referencing uploaded files with operations (compress, thumbnail, image_watermark, text_watermark, merge, archive, convert, custom_luma, audio_overlay, audio_watermark) - Poll status, stream SSE events, or receive webhook callbacks - Download results per operation output **Response envelope:** All mutation and query endpoints return `{ success: true, data: {...} }` on success and `{ success: false, error: \"...\", details: [...] }` on failure. Exceptions: `GET /api/operations/schema` returns raw JSON (per-tier private caching with ETag/Last-Modified revalidation per ADR-0002 + I3), health probes return flat objects, and `POST /api/contact` returns 204 with no body. **Availability metadata.** This spec uses the `x-availability` vendor extension as **decorative documentation only**. Per [ADR-0001](../docs/decisions/0001-contract-first-availability.md) §1.5, the runtime endpoint `GET /api/operations/schema` (ticket I3) is the authoritative source; the sidecar `availability.json` (ticket I3b) is the authoritative companion (generated, never hand-edited; CI cross-checks runtime ⇄ sidecar). SDKs MUST NOT depend on `x-availability` reaching generated code — code-generators that surface vendor extensions may emit it as documentation, but consumers read availability from the runtime endpoint, not from the generated bindings. The 5-value vocabulary (`stable | beta | experimental | planned | deprecated`) is defined in the `AvailabilityValue` schema. See `schemas/FORMAT.md` §Availability Taxonomy for the operational rules (parser obligation: absent = stable; per-enum-value granularity is the `per_value_availability` primitive landed via ticket I17). **Localisation (per ticket [I26](https://trello.com/c/rcnqwgI4)).** Error responses + paused/blocked workflow statuses carry a localised human-readable `message` alongside a stable, never-localised `message_key`. Machine-readable fields (`error`, enum values, status codes) stay canonical English. - **Request:** `Accept-Language` header per RFC 9110 §12.5.4 (q-value negotiation supported). The server selects the best-match locale from its supported list; falls back to `en-GB` when no match. - **Response:** `Content-Language: <locale>` echo on every localised response; `Vary: Accept-Language` on every response (CDN/cache correctness — different `Accept-Language` requests produce different responses). - **Fallback locale:** `en-GB` (also the canonical locale for `message_key` translations and English `message` prose). - **SDK guidance:** switch on `error` (machine code) for typed error branches; surface `message_key` to client-side i18n catalogs (SDK companion work tracked at X19, cross-repo); display `message` for end-user UI; **never parse `message` for control flow** — it changes per locale. Carrier shape lives on `ErrorEnvelope` (envelope-level optional `message_key` + `message` + `locale` + `message_params`) and `ValidationErrorEnvelope` (also per-`details[]` entry). Existing 402 / 403 / 422 envelopes (`BalanceExhaustedResponse`, `FeatureNotAvailableResponse`, `FeatureTierRestrictedResponse`, `WorkflowPausedDetail`) inherit the convention. **Upload thresholds (per tickets [u0ar7Yye](https://trello.com/c/u0ar7Yye) + [58nBQLWQ](https://trello.com/c/58nBQLWQ)).** Canonical upload constants (single-shot cap, multipart chunk size, multipart concurrency default, multipart first-chunk size) live on the `UploadThresholds` schema with `const:`-pinned values. SDK generators emit these as typed binding constants so frontend / API / SDKs reference one source of truth instead of hardcoding magic numbers. A runtime `GET /api/uploads/limits` endpoint for dynamic discovery (per-tier / per-environment overrides) is a deferred follow-up.
|
|
6
|
+
*
|
|
7
|
+
* The version of the OpenAPI document: 2.12.0
|
|
8
|
+
*
|
|
9
|
+
*
|
|
10
|
+
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
|
|
11
|
+
* https://openapi-generator.tech
|
|
12
|
+
* Do not edit the class manually.
|
|
13
|
+
*/
|
|
14
|
+
import { ProcessingClassBandViolationFromJSON, ProcessingClassBandViolationToJSON, } from './ProcessingClassBandViolation.js';
|
|
15
|
+
/**
|
|
16
|
+
* @export
|
|
17
|
+
*/
|
|
18
|
+
export const ProcessingClassExceedsBandResponseSuccessEnum = {
|
|
19
|
+
false: false
|
|
20
|
+
};
|
|
21
|
+
/**
|
|
22
|
+
* @export
|
|
23
|
+
*/
|
|
24
|
+
export const ProcessingClassExceedsBandResponseErrorTypeEnum = {
|
|
25
|
+
processing_class_exceeds_band: 'processing_class_exceeds_band'
|
|
26
|
+
};
|
|
27
|
+
/**
|
|
28
|
+
* Check if a given object implements the ProcessingClassExceedsBandResponse interface.
|
|
29
|
+
*/
|
|
30
|
+
export function instanceOfProcessingClassExceedsBandResponse(value) {
|
|
31
|
+
if (!('success' in value) || value['success'] === undefined)
|
|
32
|
+
return false;
|
|
33
|
+
if (!('error' in value) || value['error'] === undefined)
|
|
34
|
+
return false;
|
|
35
|
+
if (!('errorType' in value) || value['errorType'] === undefined)
|
|
36
|
+
return false;
|
|
37
|
+
if (!('violations' in value) || value['violations'] === undefined)
|
|
38
|
+
return false;
|
|
39
|
+
return true;
|
|
40
|
+
}
|
|
41
|
+
export function ProcessingClassExceedsBandResponseFromJSON(json) {
|
|
42
|
+
return ProcessingClassExceedsBandResponseFromJSONTyped(json, false);
|
|
43
|
+
}
|
|
44
|
+
export function ProcessingClassExceedsBandResponseFromJSONTyped(json, ignoreDiscriminator) {
|
|
45
|
+
if (json == null) {
|
|
46
|
+
return json;
|
|
47
|
+
}
|
|
48
|
+
return {
|
|
49
|
+
'success': json['success'],
|
|
50
|
+
'error': json['error'],
|
|
51
|
+
'message': json['message'] == null ? undefined : json['message'],
|
|
52
|
+
'messageKey': json['message_key'] == null ? undefined : json['message_key'],
|
|
53
|
+
'locale': json['locale'] == null ? undefined : json['locale'],
|
|
54
|
+
'messageParams': json['message_params'] == null ? undefined : json['message_params'],
|
|
55
|
+
'errorType': json['error_type'],
|
|
56
|
+
'violations': (json['violations'].map(ProcessingClassBandViolationFromJSON)),
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
export function ProcessingClassExceedsBandResponseToJSON(json) {
|
|
60
|
+
return ProcessingClassExceedsBandResponseToJSONTyped(json, false);
|
|
61
|
+
}
|
|
62
|
+
export function ProcessingClassExceedsBandResponseToJSONTyped(value, ignoreDiscriminator = false) {
|
|
63
|
+
if (value == null) {
|
|
64
|
+
return value;
|
|
65
|
+
}
|
|
66
|
+
return {
|
|
67
|
+
'success': value['success'],
|
|
68
|
+
'error': value['error'],
|
|
69
|
+
'message': value['message'],
|
|
70
|
+
'message_key': value['messageKey'],
|
|
71
|
+
'locale': value['locale'],
|
|
72
|
+
'message_params': value['messageParams'],
|
|
73
|
+
'error_type': value['errorType'],
|
|
74
|
+
'violations': (value['violations'].map(ProcessingClassBandViolationToJSON)),
|
|
75
|
+
};
|
|
76
|
+
}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* GISL Compression API
|
|
3
|
+
* REST API for the GISL (Give It Smaller) file compression and processing service. **Architecture:** - Upload files to get a `file_id` - Create workflows referencing uploaded files with operations (compress, thumbnail, image_watermark, text_watermark, merge, archive, convert, custom_luma, audio_overlay, audio_watermark) - Poll status, stream SSE events, or receive webhook callbacks - Download results per operation output **Response envelope:** All mutation and query endpoints return `{ success: true, data: {...} }` on success and `{ success: false, error: \"...\", details: [...] }` on failure. Exceptions: `GET /api/operations/schema` returns raw JSON (per-tier private caching with ETag/Last-Modified revalidation per ADR-0002 + I3), health probes return flat objects, and `POST /api/contact` returns 204 with no body. **Availability metadata.** This spec uses the `x-availability` vendor extension as **decorative documentation only**. Per [ADR-0001](../docs/decisions/0001-contract-first-availability.md) §1.5, the runtime endpoint `GET /api/operations/schema` (ticket I3) is the authoritative source; the sidecar `availability.json` (ticket I3b) is the authoritative companion (generated, never hand-edited; CI cross-checks runtime ⇄ sidecar). SDKs MUST NOT depend on `x-availability` reaching generated code — code-generators that surface vendor extensions may emit it as documentation, but consumers read availability from the runtime endpoint, not from the generated bindings. The 5-value vocabulary (`stable | beta | experimental | planned | deprecated`) is defined in the `AvailabilityValue` schema. See `schemas/FORMAT.md` §Availability Taxonomy for the operational rules (parser obligation: absent = stable; per-enum-value granularity is the `per_value_availability` primitive landed via ticket I17). **Localisation (per ticket [I26](https://trello.com/c/rcnqwgI4)).** Error responses + paused/blocked workflow statuses carry a localised human-readable `message` alongside a stable, never-localised `message_key`. Machine-readable fields (`error`, enum values, status codes) stay canonical English. - **Request:** `Accept-Language` header per RFC 9110 §12.5.4 (q-value negotiation supported). The server selects the best-match locale from its supported list; falls back to `en-GB` when no match. - **Response:** `Content-Language: <locale>` echo on every localised response; `Vary: Accept-Language` on every response (CDN/cache correctness — different `Accept-Language` requests produce different responses). - **Fallback locale:** `en-GB` (also the canonical locale for `message_key` translations and English `message` prose). - **SDK guidance:** switch on `error` (machine code) for typed error branches; surface `message_key` to client-side i18n catalogs (SDK companion work tracked at X19, cross-repo); display `message` for end-user UI; **never parse `message` for control flow** — it changes per locale. Carrier shape lives on `ErrorEnvelope` (envelope-level optional `message_key` + `message` + `locale` + `message_params`) and `ValidationErrorEnvelope` (also per-`details[]` entry). Existing 402 / 403 / 422 envelopes (`BalanceExhaustedResponse`, `FeatureNotAvailableResponse`, `FeatureTierRestrictedResponse`, `WorkflowPausedDetail`) inherit the convention. **Upload thresholds (per tickets [u0ar7Yye](https://trello.com/c/u0ar7Yye) + [58nBQLWQ](https://trello.com/c/58nBQLWQ)).** Canonical upload constants (single-shot cap, multipart chunk size, multipart concurrency default, multipart first-chunk size) live on the `UploadThresholds` schema with `const:`-pinned values. SDK generators emit these as typed binding constants so frontend / API / SDKs reference one source of truth instead of hardcoding magic numbers. A runtime `GET /api/uploads/limits` endpoint for dynamic discovery (per-tier / per-environment overrides) is a deferred follow-up.
|
|
4
|
+
*
|
|
5
|
+
* The version of the OpenAPI document: 2.12.0
|
|
6
|
+
*
|
|
7
|
+
*
|
|
8
|
+
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
|
|
9
|
+
* https://openapi-generator.tech
|
|
10
|
+
* Do not edit the class manually.
|
|
11
|
+
*/
|
|
12
|
+
/**
|
|
13
|
+
* Caller-supplied logical-policy hint on `WorkflowCreateRequest`.
|
|
14
|
+
* NOT a backend selector — server is final authority on routing.
|
|
15
|
+
* - `auto` (default): server routes safely.
|
|
16
|
+
* - `short_form_only`: fail fast (422 with `reason:
|
|
17
|
+
* tier_policy`) if any job would require `long_form`.
|
|
18
|
+
* - `long_form_allowed`: caller accepts slower queue/runtime
|
|
19
|
+
* semantics.
|
|
20
|
+
* - `long_form_preferred`: prefer `long_form` pool when
|
|
21
|
+
* eligible (test/isolation use cases).
|
|
22
|
+
*
|
|
23
|
+
* @export
|
|
24
|
+
*/
|
|
25
|
+
export declare const ProcessingClassHint: {
|
|
26
|
+
readonly auto: "auto";
|
|
27
|
+
readonly short_form_only: "short_form_only";
|
|
28
|
+
readonly long_form_allowed: "long_form_allowed";
|
|
29
|
+
readonly long_form_preferred: "long_form_preferred";
|
|
30
|
+
};
|
|
31
|
+
export type ProcessingClassHint = typeof ProcessingClassHint[keyof typeof ProcessingClassHint];
|
|
32
|
+
export declare function instanceOfProcessingClassHint(value: any): boolean;
|
|
33
|
+
export declare function ProcessingClassHintFromJSON(json: any): ProcessingClassHint;
|
|
34
|
+
export declare function ProcessingClassHintFromJSONTyped(json: any, ignoreDiscriminator: boolean): ProcessingClassHint;
|
|
35
|
+
export declare function ProcessingClassHintToJSON(value?: ProcessingClassHint | null): any;
|
|
36
|
+
export declare function ProcessingClassHintToJSONTyped(value: any, ignoreDiscriminator: boolean): ProcessingClassHint;
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
/* tslint:disable */
|
|
2
|
+
/* eslint-disable */
|
|
3
|
+
/**
|
|
4
|
+
* GISL Compression API
|
|
5
|
+
* REST API for the GISL (Give It Smaller) file compression and processing service. **Architecture:** - Upload files to get a `file_id` - Create workflows referencing uploaded files with operations (compress, thumbnail, image_watermark, text_watermark, merge, archive, convert, custom_luma, audio_overlay, audio_watermark) - Poll status, stream SSE events, or receive webhook callbacks - Download results per operation output **Response envelope:** All mutation and query endpoints return `{ success: true, data: {...} }` on success and `{ success: false, error: \"...\", details: [...] }` on failure. Exceptions: `GET /api/operations/schema` returns raw JSON (per-tier private caching with ETag/Last-Modified revalidation per ADR-0002 + I3), health probes return flat objects, and `POST /api/contact` returns 204 with no body. **Availability metadata.** This spec uses the `x-availability` vendor extension as **decorative documentation only**. Per [ADR-0001](../docs/decisions/0001-contract-first-availability.md) §1.5, the runtime endpoint `GET /api/operations/schema` (ticket I3) is the authoritative source; the sidecar `availability.json` (ticket I3b) is the authoritative companion (generated, never hand-edited; CI cross-checks runtime ⇄ sidecar). SDKs MUST NOT depend on `x-availability` reaching generated code — code-generators that surface vendor extensions may emit it as documentation, but consumers read availability from the runtime endpoint, not from the generated bindings. The 5-value vocabulary (`stable | beta | experimental | planned | deprecated`) is defined in the `AvailabilityValue` schema. See `schemas/FORMAT.md` §Availability Taxonomy for the operational rules (parser obligation: absent = stable; per-enum-value granularity is the `per_value_availability` primitive landed via ticket I17). **Localisation (per ticket [I26](https://trello.com/c/rcnqwgI4)).** Error responses + paused/blocked workflow statuses carry a localised human-readable `message` alongside a stable, never-localised `message_key`. Machine-readable fields (`error`, enum values, status codes) stay canonical English. - **Request:** `Accept-Language` header per RFC 9110 §12.5.4 (q-value negotiation supported). The server selects the best-match locale from its supported list; falls back to `en-GB` when no match. - **Response:** `Content-Language: <locale>` echo on every localised response; `Vary: Accept-Language` on every response (CDN/cache correctness — different `Accept-Language` requests produce different responses). - **Fallback locale:** `en-GB` (also the canonical locale for `message_key` translations and English `message` prose). - **SDK guidance:** switch on `error` (machine code) for typed error branches; surface `message_key` to client-side i18n catalogs (SDK companion work tracked at X19, cross-repo); display `message` for end-user UI; **never parse `message` for control flow** — it changes per locale. Carrier shape lives on `ErrorEnvelope` (envelope-level optional `message_key` + `message` + `locale` + `message_params`) and `ValidationErrorEnvelope` (also per-`details[]` entry). Existing 402 / 403 / 422 envelopes (`BalanceExhaustedResponse`, `FeatureNotAvailableResponse`, `FeatureTierRestrictedResponse`, `WorkflowPausedDetail`) inherit the convention. **Upload thresholds (per tickets [u0ar7Yye](https://trello.com/c/u0ar7Yye) + [58nBQLWQ](https://trello.com/c/58nBQLWQ)).** Canonical upload constants (single-shot cap, multipart chunk size, multipart concurrency default, multipart first-chunk size) live on the `UploadThresholds` schema with `const:`-pinned values. SDK generators emit these as typed binding constants so frontend / API / SDKs reference one source of truth instead of hardcoding magic numbers. A runtime `GET /api/uploads/limits` endpoint for dynamic discovery (per-tier / per-environment overrides) is a deferred follow-up.
|
|
6
|
+
*
|
|
7
|
+
* The version of the OpenAPI document: 2.12.0
|
|
8
|
+
*
|
|
9
|
+
*
|
|
10
|
+
* NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
|
|
11
|
+
* https://openapi-generator.tech
|
|
12
|
+
* Do not edit the class manually.
|
|
13
|
+
*/
|
|
14
|
+
/**
|
|
15
|
+
* Caller-supplied logical-policy hint on `WorkflowCreateRequest`.
|
|
16
|
+
* NOT a backend selector — server is final authority on routing.
|
|
17
|
+
* - `auto` (default): server routes safely.
|
|
18
|
+
* - `short_form_only`: fail fast (422 with `reason:
|
|
19
|
+
* tier_policy`) if any job would require `long_form`.
|
|
20
|
+
* - `long_form_allowed`: caller accepts slower queue/runtime
|
|
21
|
+
* semantics.
|
|
22
|
+
* - `long_form_preferred`: prefer `long_form` pool when
|
|
23
|
+
* eligible (test/isolation use cases).
|
|
24
|
+
*
|
|
25
|
+
* @export
|
|
26
|
+
*/
|
|
27
|
+
export const ProcessingClassHint = {
|
|
28
|
+
auto: 'auto',
|
|
29
|
+
short_form_only: 'short_form_only',
|
|
30
|
+
long_form_allowed: 'long_form_allowed',
|
|
31
|
+
long_form_preferred: 'long_form_preferred'
|
|
32
|
+
};
|
|
33
|
+
export function instanceOfProcessingClassHint(value) {
|
|
34
|
+
for (const key in ProcessingClassHint) {
|
|
35
|
+
if (Object.prototype.hasOwnProperty.call(ProcessingClassHint, key)) {
|
|
36
|
+
if (ProcessingClassHint[key] === value) {
|
|
37
|
+
return true;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
return false;
|
|
42
|
+
}
|
|
43
|
+
export function ProcessingClassHintFromJSON(json) {
|
|
44
|
+
return ProcessingClassHintFromJSONTyped(json, false);
|
|
45
|
+
}
|
|
46
|
+
export function ProcessingClassHintFromJSONTyped(json, ignoreDiscriminator) {
|
|
47
|
+
return json;
|
|
48
|
+
}
|
|
49
|
+
export function ProcessingClassHintToJSON(value) {
|
|
50
|
+
return value;
|
|
51
|
+
}
|
|
52
|
+
export function ProcessingClassHintToJSONTyped(value, ignoreDiscriminator) {
|
|
53
|
+
return value;
|
|
54
|
+
}
|