@giveitsmaller/contracts 0.8.0 → 0.9.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.
Files changed (355) hide show
  1. package/asyncapi/events.yaml +288 -153
  2. package/availability/availability.json +50 -17
  3. package/dist/asyncapi/LongFormJobMessage.d.ts +4 -3
  4. package/dist/asyncapi/LongFormOperationType.d.ts +5 -0
  5. package/dist/asyncapi/LongFormOperationType.js +6 -0
  6. package/dist/asyncapi/LongFormProcessingClass.d.ts +4 -0
  7. package/dist/asyncapi/LongFormProcessingClass.js +5 -0
  8. package/dist/asyncapi/SourceEntry.d.ts +2 -0
  9. package/dist/asyncapi/index.d.ts +2 -1
  10. package/dist/asyncapi/index.js +2 -1
  11. package/dist/openapi/models/AudioWatermarkDecodeRequest.d.ts +1 -1
  12. package/dist/openapi/models/AudioWatermarkDecodeRequest.js +1 -1
  13. package/dist/openapi/models/AudioWatermarkDecodeResponse.d.ts +1 -1
  14. package/dist/openapi/models/AudioWatermarkDecodeResponse.js +1 -1
  15. package/dist/openapi/models/AuthErrorResponse.d.ts +1 -1
  16. package/dist/openapi/models/AuthErrorResponse.js +1 -1
  17. package/dist/openapi/models/AuthErrorType.d.ts +1 -1
  18. package/dist/openapi/models/AuthErrorType.js +1 -1
  19. package/dist/openapi/models/AvailabilityValue.d.ts +1 -1
  20. package/dist/openapi/models/AvailabilityValue.js +1 -1
  21. package/dist/openapi/models/BalanceExhaustedResponse.d.ts +1 -1
  22. package/dist/openapi/models/BalanceExhaustedResponse.js +1 -1
  23. package/dist/openapi/models/BalanceExhaustedResponseAllOfLinks.d.ts +1 -1
  24. package/dist/openapi/models/BalanceExhaustedResponseAllOfLinks.js +1 -1
  25. package/dist/openapi/models/CallbackEventType.d.ts +1 -1
  26. package/dist/openapi/models/CallbackEventType.js +1 -1
  27. package/dist/openapi/models/ConnectionSource.d.ts +1 -1
  28. package/dist/openapi/models/ConnectionSource.js +1 -1
  29. package/dist/openapi/models/ContactRequest.d.ts +1 -1
  30. package/dist/openapi/models/ContactRequest.js +1 -1
  31. package/dist/openapi/models/ContactSubject.d.ts +1 -1
  32. package/dist/openapi/models/ContactSubject.js +1 -1
  33. package/dist/openapi/models/ContactValidationErrorResponse.d.ts +1 -1
  34. package/dist/openapi/models/ContactValidationErrorResponse.js +1 -1
  35. package/dist/openapi/models/CreateExternalImport403Response.d.ts +1 -1
  36. package/dist/openapi/models/CreateExternalImport403Response.js +1 -1
  37. package/dist/openapi/models/CreateExternalImport422Response.d.ts +6 -2
  38. package/dist/openapi/models/CreateExternalImport422Response.js +17 -21
  39. package/dist/openapi/models/CreateWorkflow422Response.d.ts +10 -2
  40. package/dist/openapi/models/CreateWorkflow422Response.js +27 -35
  41. package/dist/openapi/models/CreditTransaction.d.ts +1 -1
  42. package/dist/openapi/models/CreditTransaction.js +1 -1
  43. package/dist/openapi/models/CreditTransactionSourceBucket.d.ts +1 -1
  44. package/dist/openapi/models/CreditTransactionSourceBucket.js +1 -1
  45. package/dist/openapi/models/CreditsBalanceResponse.d.ts +1 -1
  46. package/dist/openapi/models/CreditsBalanceResponse.js +1 -1
  47. package/dist/openapi/models/CreditsBalanceSuccessEnvelope.d.ts +1 -1
  48. package/dist/openapi/models/CreditsBalanceSuccessEnvelope.js +1 -1
  49. package/dist/openapi/models/CreditsUsageResponse.d.ts +1 -1
  50. package/dist/openapi/models/CreditsUsageResponse.js +1 -1
  51. package/dist/openapi/models/CreditsUsageSuccessEnvelope.d.ts +1 -1
  52. package/dist/openapi/models/CreditsUsageSuccessEnvelope.js +1 -1
  53. package/dist/openapi/models/Delivery.d.ts +1 -1
  54. package/dist/openapi/models/Delivery.js +1 -1
  55. package/dist/openapi/models/DeliveryOutputRef.d.ts +1 -1
  56. package/dist/openapi/models/DeliveryOutputRef.js +1 -1
  57. package/dist/openapi/models/DeliveryPlan.d.ts +1 -1
  58. package/dist/openapi/models/DeliveryPlan.js +1 -1
  59. package/dist/openapi/models/DeliveryPlanOutput.d.ts +1 -1
  60. package/dist/openapi/models/DeliveryPlanOutput.js +1 -1
  61. package/dist/openapi/models/DeliveryPlanReason.d.ts +1 -1
  62. package/dist/openapi/models/DeliveryPlanReason.js +1 -1
  63. package/dist/openapi/models/DeliverySelection.d.ts +1 -1
  64. package/dist/openapi/models/DeliverySelection.js +1 -1
  65. package/dist/openapi/models/EndpointProjection.d.ts +1 -1
  66. package/dist/openapi/models/EndpointProjection.js +1 -1
  67. package/dist/openapi/models/ErrorEnvelope.d.ts +1 -1
  68. package/dist/openapi/models/ErrorEnvelope.js +1 -1
  69. package/dist/openapi/models/EstimateQuality.d.ts +1 -1
  70. package/dist/openapi/models/EstimateQuality.js +1 -1
  71. package/dist/openapi/models/EstimateRange.d.ts +1 -1
  72. package/dist/openapi/models/EstimateRange.js +1 -1
  73. package/dist/openapi/models/ExternalDestination.d.ts +1 -1
  74. package/dist/openapi/models/ExternalDestination.js +1 -1
  75. package/dist/openapi/models/ExternalImportCreatedResponse.d.ts +1 -1
  76. package/dist/openapi/models/ExternalImportCreatedResponse.js +1 -1
  77. package/dist/openapi/models/ExternalImportCreatedSuccessEnvelope.d.ts +1 -1
  78. package/dist/openapi/models/ExternalImportCreatedSuccessEnvelope.js +1 -1
  79. package/dist/openapi/models/ExternalImportRequest.d.ts +1 -1
  80. package/dist/openapi/models/ExternalImportRequest.js +1 -1
  81. package/dist/openapi/models/ExternalImportToken.d.ts +1 -1
  82. package/dist/openapi/models/ExternalImportToken.js +1 -1
  83. package/dist/openapi/models/ExternalSource.d.ts +1 -1
  84. package/dist/openapi/models/ExternalSource.js +1 -1
  85. package/dist/openapi/models/FeatureNotAvailableResponse.d.ts +7 -8
  86. package/dist/openapi/models/FeatureNotAvailableResponse.js +1 -1
  87. package/dist/openapi/models/FeatureTierRestrictedResponse.d.ts +1 -1
  88. package/dist/openapi/models/FeatureTierRestrictedResponse.js +1 -1
  89. package/dist/openapi/models/FeatureViolation.d.ts +1 -1
  90. package/dist/openapi/models/FeatureViolation.js +1 -1
  91. package/dist/openapi/models/JobDefinition.d.ts +8 -5
  92. package/dist/openapi/models/JobDefinition.js +1 -1
  93. package/dist/openapi/models/JobDownload.d.ts +1 -1
  94. package/dist/openapi/models/JobDownload.js +1 -1
  95. package/dist/openapi/models/JobInputV2.d.ts +1 -1
  96. package/dist/openapi/models/JobInputV2.js +1 -1
  97. package/dist/openapi/models/JobOutputSource.d.ts +1 -1
  98. package/dist/openapi/models/JobOutputSource.js +1 -1
  99. package/dist/openapi/models/JobResponse.d.ts +23 -1
  100. package/dist/openapi/models/JobResponse.js +4 -1
  101. package/dist/openapi/models/JobStatus.d.ts +1 -1
  102. package/dist/openapi/models/JobStatus.js +1 -1
  103. package/dist/openapi/models/JobType.d.ts +1 -1
  104. package/dist/openapi/models/JobType.js +1 -1
  105. package/dist/openapi/models/LivenessResponse.d.ts +1 -1
  106. package/dist/openapi/models/LivenessResponse.js +1 -1
  107. package/dist/openapi/models/LoginUser200Response.d.ts +1 -1
  108. package/dist/openapi/models/LoginUser200Response.js +1 -1
  109. package/dist/openapi/models/LoginUser200ResponseData.d.ts +1 -1
  110. package/dist/openapi/models/LoginUser200ResponseData.js +1 -1
  111. package/dist/openapi/models/LoginUser200ResponseDataUser.d.ts +1 -1
  112. package/dist/openapi/models/LoginUser200ResponseDataUser.js +1 -1
  113. package/dist/openapi/models/LoginUserRequest.d.ts +1 -1
  114. package/dist/openapi/models/LoginUserRequest.js +1 -1
  115. package/dist/openapi/models/LogoutUser200Response.d.ts +1 -1
  116. package/dist/openapi/models/LogoutUser200Response.js +1 -1
  117. package/dist/openapi/models/MetadataResponse.d.ts +1 -1
  118. package/dist/openapi/models/MetadataResponse.js +1 -1
  119. package/dist/openapi/models/MetadataResponseDimensions.d.ts +1 -1
  120. package/dist/openapi/models/MetadataResponseDimensions.js +1 -1
  121. package/dist/openapi/models/MetadataResponseExif.d.ts +1 -1
  122. package/dist/openapi/models/MetadataResponseExif.js +1 -1
  123. package/dist/openapi/models/MetadataResponseExifGps.d.ts +1 -1
  124. package/dist/openapi/models/MetadataResponseExifGps.js +1 -1
  125. package/dist/openapi/models/MetadataSuccessEnvelope.d.ts +1 -1
  126. package/dist/openapi/models/MetadataSuccessEnvelope.js +1 -1
  127. package/dist/openapi/models/MimeGroupSchema.d.ts +1 -1
  128. package/dist/openapi/models/MimeGroupSchema.js +1 -1
  129. package/dist/openapi/models/MultipartCompleteRequest.d.ts +1 -1
  130. package/dist/openapi/models/MultipartCompleteRequest.js +1 -1
  131. package/dist/openapi/models/MultipartCompleteRequestPartsInner.d.ts +1 -1
  132. package/dist/openapi/models/MultipartCompleteRequestPartsInner.js +1 -1
  133. package/dist/openapi/models/MultipartCompleteResponse.d.ts +1 -1
  134. package/dist/openapi/models/MultipartCompleteResponse.js +1 -1
  135. package/dist/openapi/models/MultipartCompleteSuccessEnvelope.d.ts +1 -1
  136. package/dist/openapi/models/MultipartCompleteSuccessEnvelope.js +1 -1
  137. package/dist/openapi/models/MultipartInitiateRequestMetadataHint.d.ts +1 -1
  138. package/dist/openapi/models/MultipartInitiateRequestMetadataHint.js +1 -1
  139. package/dist/openapi/models/MultipartInitiateResponse.d.ts +1 -1
  140. package/dist/openapi/models/MultipartInitiateResponse.js +1 -1
  141. package/dist/openapi/models/MultipartInitiateSuccessEnvelope.d.ts +1 -1
  142. package/dist/openapi/models/MultipartInitiateSuccessEnvelope.js +1 -1
  143. package/dist/openapi/models/MultipartKeepaliveResponse.d.ts +1 -1
  144. package/dist/openapi/models/MultipartKeepaliveResponse.js +1 -1
  145. package/dist/openapi/models/MultipartKeepaliveSuccessEnvelope.d.ts +1 -1
  146. package/dist/openapi/models/MultipartKeepaliveSuccessEnvelope.js +1 -1
  147. package/dist/openapi/models/MultipartPartListing.d.ts +1 -1
  148. package/dist/openapi/models/MultipartPartListing.js +1 -1
  149. package/dist/openapi/models/MultipartPresignRequest.d.ts +1 -1
  150. package/dist/openapi/models/MultipartPresignRequest.js +1 -1
  151. package/dist/openapi/models/MultipartPresignResponse.d.ts +1 -1
  152. package/dist/openapi/models/MultipartPresignResponse.js +1 -1
  153. package/dist/openapi/models/MultipartPresignSuccessEnvelope.d.ts +1 -1
  154. package/dist/openapi/models/MultipartPresignSuccessEnvelope.js +1 -1
  155. package/dist/openapi/models/MultipartStatusResponse.d.ts +1 -1
  156. package/dist/openapi/models/MultipartStatusResponse.js +1 -1
  157. package/dist/openapi/models/MultipartStatusSuccessEnvelope.d.ts +1 -1
  158. package/dist/openapi/models/MultipartStatusSuccessEnvelope.js +1 -1
  159. package/dist/openapi/models/OperationDefinition.d.ts +1 -1
  160. package/dist/openapi/models/OperationDefinition.js +1 -1
  161. package/dist/openapi/models/OperationDownload.d.ts +1 -1
  162. package/dist/openapi/models/OperationDownload.js +1 -1
  163. package/dist/openapi/models/OperationInputModel.d.ts +1 -1
  164. package/dist/openapi/models/OperationInputModel.js +1 -1
  165. package/dist/openapi/models/OperationResponse.d.ts +1 -1
  166. package/dist/openapi/models/OperationResponse.js +1 -1
  167. package/dist/openapi/models/OperationResult.d.ts +1 -1
  168. package/dist/openapi/models/OperationResult.js +1 -1
  169. package/dist/openapi/models/OperationResultMetrics.d.ts +1 -1
  170. package/dist/openapi/models/OperationResultMetrics.js +1 -1
  171. package/dist/openapi/models/OperationSchemaDefinition.d.ts +1 -1
  172. package/dist/openapi/models/OperationSchemaDefinition.js +1 -1
  173. package/dist/openapi/models/OperationStatus.d.ts +1 -1
  174. package/dist/openapi/models/OperationStatus.js +1 -1
  175. package/dist/openapi/models/OperationType.d.ts +14 -12
  176. package/dist/openapi/models/OperationType.js +14 -12
  177. package/dist/openapi/models/OperationsSchemaResponse.d.ts +8 -1
  178. package/dist/openapi/models/OperationsSchemaResponse.js +4 -1
  179. package/dist/openapi/models/OperationsSchemaResponseWorkflowFeatures.d.ts +55 -0
  180. package/dist/openapi/models/OperationsSchemaResponseWorkflowFeatures.js +42 -0
  181. package/dist/openapi/models/OperationsSchemaResponseWorkflowFeaturesDelivery.d.ts +40 -0
  182. package/dist/openapi/models/OperationsSchemaResponseWorkflowFeaturesDelivery.js +45 -0
  183. package/dist/openapi/models/OperationsSchemaResponseWorkflowFeaturesDeliveryMode.d.ts +45 -0
  184. package/dist/openapi/models/OperationsSchemaResponseWorkflowFeaturesDeliveryMode.js +43 -0
  185. package/dist/openapi/models/OperationsSchemaResponseWorkflowFeaturesDeliverySelection.d.ts +33 -0
  186. package/dist/openapi/models/OperationsSchemaResponseWorkflowFeaturesDeliverySelection.js +42 -0
  187. package/dist/openapi/models/OptionSchema.d.ts +1 -1
  188. package/dist/openapi/models/OptionSchema.js +1 -1
  189. package/dist/openapi/models/PerRoleCardinalityEntry.d.ts +1 -1
  190. package/dist/openapi/models/PerRoleCardinalityEntry.js +1 -1
  191. package/dist/openapi/models/PerValueAvailabilityEntry.d.ts +1 -1
  192. package/dist/openapi/models/PerValueAvailabilityEntry.js +1 -1
  193. package/dist/openapi/models/PresignedUrlPart.d.ts +1 -1
  194. package/dist/openapi/models/PresignedUrlPart.js +1 -1
  195. package/dist/openapi/models/ProbePendingResponse.d.ts +8 -7
  196. package/dist/openapi/models/ProbePendingResponse.js +1 -1
  197. package/dist/openapi/models/ProcessingClass.d.ts +1 -1
  198. package/dist/openapi/models/ProcessingClass.js +1 -1
  199. package/dist/openapi/models/ProcessingClassBandViolation.d.ts +1 -1
  200. package/dist/openapi/models/ProcessingClassBandViolation.js +1 -1
  201. package/dist/openapi/models/ProcessingClassExceedsBandResponse.d.ts +7 -5
  202. package/dist/openapi/models/ProcessingClassExceedsBandResponse.js +1 -1
  203. package/dist/openapi/models/ProcessingClassHint.d.ts +1 -1
  204. package/dist/openapi/models/ProcessingClassHint.js +1 -1
  205. package/dist/openapi/models/ProcessingClassReason.d.ts +1 -1
  206. package/dist/openapi/models/ProcessingClassReason.js +1 -1
  207. package/dist/openapi/models/ProcessingClassRejectReason.d.ts +1 -1
  208. package/dist/openapi/models/ProcessingClassRejectReason.js +1 -1
  209. package/dist/openapi/models/ProcessingPlan.d.ts +1 -1
  210. package/dist/openapi/models/ProcessingPlan.js +1 -1
  211. package/dist/openapi/models/ProcessingPlanJob.d.ts +1 -1
  212. package/dist/openapi/models/ProcessingPlanJob.js +1 -1
  213. package/dist/openapi/models/ReEncodeDecision.d.ts +1 -1
  214. package/dist/openapi/models/ReEncodeDecision.js +1 -1
  215. package/dist/openapi/models/ReadinessResponse.d.ts +1 -1
  216. package/dist/openapi/models/ReadinessResponse.js +1 -1
  217. package/dist/openapi/models/ResponseEnvelope.d.ts +1 -1
  218. package/dist/openapi/models/ResponseEnvelope.js +1 -1
  219. package/dist/openapi/models/RetryResponse.d.ts +1 -1
  220. package/dist/openapi/models/RetryResponse.js +1 -1
  221. package/dist/openapi/models/RetrySuccessEnvelope.d.ts +1 -1
  222. package/dist/openapi/models/RetrySuccessEnvelope.js +1 -1
  223. package/dist/openapi/models/SseCompletionBase.d.ts +1 -1
  224. package/dist/openapi/models/SseCompletionBase.js +1 -1
  225. package/dist/openapi/models/SseEventType.d.ts +1 -1
  226. package/dist/openapi/models/SseEventType.js +1 -1
  227. package/dist/openapi/models/SseJobCompletedData.d.ts +1 -1
  228. package/dist/openapi/models/SseJobCompletedData.js +1 -1
  229. package/dist/openapi/models/SseJobFailedData.d.ts +1 -1
  230. package/dist/openapi/models/SseJobFailedData.js +1 -1
  231. package/dist/openapi/models/SseMultiOutputCompletion.d.ts +1 -1
  232. package/dist/openapi/models/SseMultiOutputCompletion.js +1 -1
  233. package/dist/openapi/models/SseMultiOutputCompletionMetrics.d.ts +1 -1
  234. package/dist/openapi/models/SseMultiOutputCompletionMetrics.js +1 -1
  235. package/dist/openapi/models/SseMultiOutputCompletionWithKind.d.ts +1 -1
  236. package/dist/openapi/models/SseMultiOutputCompletionWithKind.js +1 -1
  237. package/dist/openapi/models/SseMultiOutputResultEntry.d.ts +1 -1
  238. package/dist/openapi/models/SseMultiOutputResultEntry.js +1 -1
  239. package/dist/openapi/models/SseOperationCompletedData.d.ts +1 -1
  240. package/dist/openapi/models/SseOperationCompletedData.js +1 -1
  241. package/dist/openapi/models/SseOperationCompletionResult.d.ts +1 -1
  242. package/dist/openapi/models/SseOperationCompletionResult.js +1 -1
  243. package/dist/openapi/models/SseOperationFailedData.d.ts +1 -1
  244. package/dist/openapi/models/SseOperationFailedData.js +1 -1
  245. package/dist/openapi/models/SseOperationProgressData.d.ts +3 -2
  246. package/dist/openapi/models/SseOperationProgressData.js +1 -1
  247. package/dist/openapi/models/SseSingleOutputCompletion.d.ts +1 -1
  248. package/dist/openapi/models/SseSingleOutputCompletion.js +1 -1
  249. package/dist/openapi/models/SseWorkflowTerminalData.d.ts +1 -1
  250. package/dist/openapi/models/SseWorkflowTerminalData.js +1 -1
  251. package/dist/openapi/models/TierRestrictionKind.d.ts +1 -1
  252. package/dist/openapi/models/TierRestrictionKind.js +1 -1
  253. package/dist/openapi/models/TierRestrictionResponse.d.ts +1 -1
  254. package/dist/openapi/models/TierRestrictionResponse.js +1 -1
  255. package/dist/openapi/models/UploadConstraintsApplied.d.ts +1 -1
  256. package/dist/openapi/models/UploadConstraintsApplied.js +1 -1
  257. package/dist/openapi/models/UploadDurationExceedsTierResponse.d.ts +1 -1
  258. package/dist/openapi/models/UploadDurationExceedsTierResponse.js +1 -1
  259. package/dist/openapi/models/UploadFile403Response.d.ts +1 -1
  260. package/dist/openapi/models/UploadFile403Response.js +1 -1
  261. package/dist/openapi/models/UploadFile422Response.d.ts +1 -1
  262. package/dist/openapi/models/UploadFile422Response.js +1 -1
  263. package/dist/openapi/models/UploadProbeMediaMetadata.d.ts +1 -1
  264. package/dist/openapi/models/UploadProbeMediaMetadata.js +1 -1
  265. package/dist/openapi/models/UploadProbeProcessingClass.d.ts +1 -1
  266. package/dist/openapi/models/UploadProbeProcessingClass.js +1 -1
  267. package/dist/openapi/models/UploadProbeResponse.d.ts +1 -1
  268. package/dist/openapi/models/UploadProbeResponse.js +1 -1
  269. package/dist/openapi/models/UploadProbeStatus.d.ts +1 -1
  270. package/dist/openapi/models/UploadProbeStatus.js +1 -1
  271. package/dist/openapi/models/UploadProbeSuccessEnvelope.d.ts +1 -1
  272. package/dist/openapi/models/UploadProbeSuccessEnvelope.js +1 -1
  273. package/dist/openapi/models/UploadResponse.d.ts +1 -1
  274. package/dist/openapi/models/UploadResponse.js +1 -1
  275. package/dist/openapi/models/UploadSizeExceedsTierResponse.d.ts +1 -1
  276. package/dist/openapi/models/UploadSizeExceedsTierResponse.js +1 -1
  277. package/dist/openapi/models/UploadSource.d.ts +1 -1
  278. package/dist/openapi/models/UploadSource.js +1 -1
  279. package/dist/openapi/models/UploadSuccessEnvelope.d.ts +1 -1
  280. package/dist/openapi/models/UploadSuccessEnvelope.js +1 -1
  281. package/dist/openapi/models/UploadThresholds.d.ts +1 -1
  282. package/dist/openapi/models/UploadThresholds.js +1 -1
  283. package/dist/openapi/models/UserTier.d.ts +1 -1
  284. package/dist/openapi/models/UserTier.js +1 -1
  285. package/dist/openapi/models/ValidationErrorEnvelope.d.ts +31 -4
  286. package/dist/openapi/models/ValidationErrorEnvelope.js +11 -1
  287. package/dist/openapi/models/ValidationErrorEnvelopeDetailsInner.d.ts +1 -1
  288. package/dist/openapi/models/ValidationErrorEnvelopeDetailsInner.js +1 -1
  289. package/dist/openapi/models/WarningType.d.ts +1 -1
  290. package/dist/openapi/models/WarningType.js +1 -1
  291. package/dist/openapi/models/WebhookOperationContext.d.ts +1 -1
  292. package/dist/openapi/models/WebhookOperationContext.js +1 -1
  293. package/dist/openapi/models/WebhookPayload.d.ts +1 -1
  294. package/dist/openapi/models/WebhookPayload.js +1 -1
  295. package/dist/openapi/models/WorkflowCancelBillingEffect.d.ts +1 -1
  296. package/dist/openapi/models/WorkflowCancelBillingEffect.js +1 -1
  297. package/dist/openapi/models/WorkflowCancelResponse.d.ts +1 -1
  298. package/dist/openapi/models/WorkflowCancelResponse.js +1 -1
  299. package/dist/openapi/models/WorkflowCancelSuccessEnvelope.d.ts +1 -1
  300. package/dist/openapi/models/WorkflowCancelSuccessEnvelope.js +1 -1
  301. package/dist/openapi/models/WorkflowCreateRequest.d.ts +1 -1
  302. package/dist/openapi/models/WorkflowCreateRequest.js +1 -1
  303. package/dist/openapi/models/WorkflowCreateResponse.d.ts +1 -1
  304. package/dist/openapi/models/WorkflowCreateResponse.js +1 -1
  305. package/dist/openapi/models/WorkflowCreateSuccessEnvelope.d.ts +1 -1
  306. package/dist/openapi/models/WorkflowCreateSuccessEnvelope.js +1 -1
  307. package/dist/openapi/models/WorkflowDownloadResponse.d.ts +1 -1
  308. package/dist/openapi/models/WorkflowDownloadResponse.js +1 -1
  309. package/dist/openapi/models/WorkflowDownloadSuccessEnvelope.d.ts +1 -1
  310. package/dist/openapi/models/WorkflowDownloadSuccessEnvelope.js +1 -1
  311. package/dist/openapi/models/WorkflowEdge.d.ts +1 -1
  312. package/dist/openapi/models/WorkflowEdge.js +1 -1
  313. package/dist/openapi/models/WorkflowExpiredResponse.d.ts +1 -1
  314. package/dist/openapi/models/WorkflowExpiredResponse.js +1 -1
  315. package/dist/openapi/models/WorkflowPauseRequiredAction.d.ts +1 -1
  316. package/dist/openapi/models/WorkflowPauseRequiredAction.js +1 -1
  317. package/dist/openapi/models/WorkflowPausedDetail.d.ts +1 -1
  318. package/dist/openapi/models/WorkflowPausedDetail.js +1 -1
  319. package/dist/openapi/models/WorkflowPausedDetailLinks.d.ts +1 -1
  320. package/dist/openapi/models/WorkflowPausedDetailLinks.js +1 -1
  321. package/dist/openapi/models/WorkflowProcessing.d.ts +1 -1
  322. package/dist/openapi/models/WorkflowProcessing.js +1 -1
  323. package/dist/openapi/models/WorkflowResumeResponse.d.ts +1 -1
  324. package/dist/openapi/models/WorkflowResumeResponse.js +1 -1
  325. package/dist/openapi/models/WorkflowResumeSuccessEnvelope.d.ts +1 -1
  326. package/dist/openapi/models/WorkflowResumeSuccessEnvelope.js +1 -1
  327. package/dist/openapi/models/WorkflowSource.d.ts +1 -1
  328. package/dist/openapi/models/WorkflowSource.js +1 -1
  329. package/dist/openapi/models/WorkflowStatus.d.ts +1 -1
  330. package/dist/openapi/models/WorkflowStatus.js +1 -1
  331. package/dist/openapi/models/WorkflowStatusResponse.d.ts +1 -1
  332. package/dist/openapi/models/WorkflowStatusResponse.js +1 -1
  333. package/dist/openapi/models/WorkflowStatusSuccessEnvelope.d.ts +1 -1
  334. package/dist/openapi/models/WorkflowStatusSuccessEnvelope.js +1 -1
  335. package/dist/openapi/models/WorkflowWarning.d.ts +1 -1
  336. package/dist/openapi/models/WorkflowWarning.js +1 -1
  337. package/dist/openapi/models/WorkflowWarningSeverity.d.ts +1 -1
  338. package/dist/openapi/models/WorkflowWarningSeverity.js +1 -1
  339. package/dist/openapi/models/index.d.ts +4 -0
  340. package/dist/openapi/models/index.js +4 -0
  341. package/dist/openapi/runtime.d.ts +1 -1
  342. package/dist/openapi/runtime.js +1 -1
  343. package/dist/operations/audio_to_video.metadata.js +1 -1
  344. package/dist/operations/merge.metadata.js +0 -3
  345. package/dist/operations/split.metadata.js +5 -1
  346. package/dist/operations/video_watermark.metadata.js +2 -2
  347. package/openapi/api.yaml +258 -72
  348. package/operations/schemas/audio_to_video.yaml +6 -4
  349. package/operations/schemas/custom_luma.yaml +3 -4
  350. package/operations/schemas/merge.yaml +6 -6
  351. package/operations/schemas/split.yaml +11 -4
  352. package/operations/schemas/video_watermark.yaml +13 -5
  353. package/package.json +1 -1
  354. package/dist/asyncapi/AnonymousSchema_253.d.ts +0 -5
  355. package/dist/asyncapi/AnonymousSchema_253.js +0 -6
@@ -2,7 +2,7 @@
2
2
  * GISL Compression API
3
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. - **Currently committed locales:** `en-GB` only (per ticket [`4GKyuYo6`](https://trello.com/c/4GKyuYo6)). The I26 carrier shape (`Accept-Language` + `Content-Language` + `Vary` headers + `locale` envelope field + `message_key` + `message_params`) is stable and exercised; the **catalog** of translated `message` strings is en-GB-only at runtime today. Additional locales (e.g. `pt-PT`) will be advertised by name when their catalogs ship — the request/response carrier shape does NOT change when a new locale lands. Treat unrequested locales as \"machine-code + `message_key` path is committed; localised `message` prose is not\" until this prose enumerates them by name. - **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 — which, until additional catalogs land, is every non-`en-GB` `Accept-Language`. - **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). `Vary` is emitted unconditionally so the header contract does not flip when a second locale ships. - **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
4
  *
5
- * The version of the OpenAPI document: 2.21.0
5
+ * The version of the OpenAPI document: 2.31.0
6
6
  *
7
7
  *
8
8
  * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
@@ -11,6 +11,7 @@
11
11
  */
12
12
  import type { UserTier } from './UserTier.js';
13
13
  import type { EndpointProjection } from './EndpointProjection.js';
14
+ import type { OperationsSchemaResponseWorkflowFeatures } from './OperationsSchemaResponseWorkflowFeatures.js';
14
15
  import type { OperationSchemaDefinition } from './OperationSchemaDefinition.js';
15
16
  /**
16
17
  * Operations meta-schema. Describes all available operation types,
@@ -125,6 +126,12 @@ export interface OperationsSchemaResponse {
125
126
  endpoints?: {
126
127
  [key: string]: EndpointProjection;
127
128
  };
129
+ /**
130
+ *
131
+ * @type {OperationsSchemaResponseWorkflowFeatures}
132
+ * @memberof OperationsSchemaResponse
133
+ */
134
+ workflowFeatures?: OperationsSchemaResponseWorkflowFeatures;
128
135
  }
129
136
  /**
130
137
  * Check if a given object implements the OperationsSchemaResponse interface.
@@ -4,7 +4,7 @@
4
4
  * GISL Compression API
5
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. - **Currently committed locales:** `en-GB` only (per ticket [`4GKyuYo6`](https://trello.com/c/4GKyuYo6)). The I26 carrier shape (`Accept-Language` + `Content-Language` + `Vary` headers + `locale` envelope field + `message_key` + `message_params`) is stable and exercised; the **catalog** of translated `message` strings is en-GB-only at runtime today. Additional locales (e.g. `pt-PT`) will be advertised by name when their catalogs ship — the request/response carrier shape does NOT change when a new locale lands. Treat unrequested locales as \"machine-code + `message_key` path is committed; localised `message` prose is not\" until this prose enumerates them by name. - **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 — which, until additional catalogs land, is every non-`en-GB` `Accept-Language`. - **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). `Vary` is emitted unconditionally so the header contract does not flip when a second locale ships. - **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
6
  *
7
- * The version of the OpenAPI document: 2.21.0
7
+ * The version of the OpenAPI document: 2.31.0
8
8
  *
9
9
  *
10
10
  * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
@@ -14,6 +14,7 @@
14
14
  import { mapValues } from '../runtime.js';
15
15
  import { UserTierFromJSON, UserTierToJSON, } from './UserTier.js';
16
16
  import { EndpointProjectionFromJSON, EndpointProjectionToJSON, } from './EndpointProjection.js';
17
+ import { OperationsSchemaResponseWorkflowFeaturesFromJSON, OperationsSchemaResponseWorkflowFeaturesToJSON, } from './OperationsSchemaResponseWorkflowFeatures.js';
17
18
  import { OperationSchemaDefinitionFromJSON, OperationSchemaDefinitionToJSON, } from './OperationSchemaDefinition.js';
18
19
  /**
19
20
  * Check if a given object implements the OperationsSchemaResponse interface.
@@ -45,6 +46,7 @@ export function OperationsSchemaResponseFromJSONTyped(json, ignoreDiscriminator)
45
46
  'userTier': json['user_tier'] == null ? undefined : UserTierFromJSON(json['user_tier']),
46
47
  'operations': (mapValues(json['operations'], OperationSchemaDefinitionFromJSON)),
47
48
  'endpoints': json['endpoints'] == null ? undefined : (mapValues(json['endpoints'], EndpointProjectionFromJSON)),
49
+ 'workflowFeatures': json['workflow_features'] == null ? undefined : OperationsSchemaResponseWorkflowFeaturesFromJSON(json['workflow_features']),
48
50
  };
49
51
  }
50
52
  export function OperationsSchemaResponseToJSON(json) {
@@ -63,5 +65,6 @@ export function OperationsSchemaResponseToJSONTyped(value, ignoreDiscriminator =
63
65
  'user_tier': UserTierToJSON(value['userTier']),
64
66
  'operations': (mapValues(value['operations'], OperationSchemaDefinitionToJSON)),
65
67
  'endpoints': value['endpoints'] == null ? undefined : (mapValues(value['endpoints'], EndpointProjectionToJSON)),
68
+ 'workflow_features': OperationsSchemaResponseWorkflowFeaturesToJSON(value['workflowFeatures']),
66
69
  };
67
70
  }
@@ -0,0 +1,55 @@
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. - **Currently committed locales:** `en-GB` only (per ticket [`4GKyuYo6`](https://trello.com/c/4GKyuYo6)). The I26 carrier shape (`Accept-Language` + `Content-Language` + `Vary` headers + `locale` envelope field + `message_key` + `message_params`) is stable and exercised; the **catalog** of translated `message` strings is en-GB-only at runtime today. Additional locales (e.g. `pt-PT`) will be advertised by name when their catalogs ship — the request/response carrier shape does NOT change when a new locale lands. Treat unrequested locales as \"machine-code + `message_key` path is committed; localised `message` prose is not\" until this prose enumerates them by name. - **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 — which, until additional catalogs land, is every non-`en-GB` `Accept-Language`. - **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). `Vary` is emitted unconditionally so the header contract does not flip when a second locale ships. - **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.31.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 { OperationsSchemaResponseWorkflowFeaturesDelivery } from './OperationsSchemaResponseWorkflowFeaturesDelivery.js';
13
+ /**
14
+ * Workflow-level option availability projection (ticket
15
+ * [`1ZQjSm0j`](https://trello.com/c/1ZQjSm0j)). Surfaces
16
+ * `per_value_availability` for workflow-level options that live in
17
+ * OpenAPI **component** schemas (not the per-operation
18
+ * `schemas/operations/*.yaml` that drive the `operations` map),
19
+ * keyed by REQUEST-shape path:
20
+ * - `delivery.mode.per_value_availability` (from the `Delivery.mode`
21
+ * schema)
22
+ * - `delivery.selection.type.per_value_availability` (from the
23
+ * `DeliverySelection.type` schema)
24
+ *
25
+ * Closes the co0CERtJ (v2.19.0) authority-hierarchy gap: those
26
+ * `planned` downgrades lived only in the (decorative per ADR-0001
27
+ * §1.5) openapi component tags; this surfaces them in the
28
+ * authoritative sidecar.
29
+ *
30
+ * **Optional in the wire envelope** (same incremental-mirroring
31
+ * stance as `endpoints`): the committed sidecar emits this block
32
+ * authoritatively; the runtime `GET /api/operations/schema` MAY
33
+ * mirror it once the API generator catches up. Consumers MUST
34
+ * tolerate its absence from the runtime endpoint (read the sidecar)
35
+ * and its presence from either source.
36
+ *
37
+ * @export
38
+ * @interface OperationsSchemaResponseWorkflowFeatures
39
+ */
40
+ export interface OperationsSchemaResponseWorkflowFeatures {
41
+ /**
42
+ *
43
+ * @type {OperationsSchemaResponseWorkflowFeaturesDelivery}
44
+ * @memberof OperationsSchemaResponseWorkflowFeatures
45
+ */
46
+ delivery?: OperationsSchemaResponseWorkflowFeaturesDelivery;
47
+ }
48
+ /**
49
+ * Check if a given object implements the OperationsSchemaResponseWorkflowFeatures interface.
50
+ */
51
+ export declare function instanceOfOperationsSchemaResponseWorkflowFeatures(value: object): value is OperationsSchemaResponseWorkflowFeatures;
52
+ export declare function OperationsSchemaResponseWorkflowFeaturesFromJSON(json: any): OperationsSchemaResponseWorkflowFeatures;
53
+ export declare function OperationsSchemaResponseWorkflowFeaturesFromJSONTyped(json: any, ignoreDiscriminator: boolean): OperationsSchemaResponseWorkflowFeatures;
54
+ export declare function OperationsSchemaResponseWorkflowFeaturesToJSON(json: any): OperationsSchemaResponseWorkflowFeatures;
55
+ export declare function OperationsSchemaResponseWorkflowFeaturesToJSONTyped(value?: OperationsSchemaResponseWorkflowFeatures | null, ignoreDiscriminator?: boolean): any;
@@ -0,0 +1,42 @@
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. - **Currently committed locales:** `en-GB` only (per ticket [`4GKyuYo6`](https://trello.com/c/4GKyuYo6)). The I26 carrier shape (`Accept-Language` + `Content-Language` + `Vary` headers + `locale` envelope field + `message_key` + `message_params`) is stable and exercised; the **catalog** of translated `message` strings is en-GB-only at runtime today. Additional locales (e.g. `pt-PT`) will be advertised by name when their catalogs ship — the request/response carrier shape does NOT change when a new locale lands. Treat unrequested locales as \"machine-code + `message_key` path is committed; localised `message` prose is not\" until this prose enumerates them by name. - **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 — which, until additional catalogs land, is every non-`en-GB` `Accept-Language`. - **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). `Vary` is emitted unconditionally so the header contract does not flip when a second locale ships. - **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.31.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 { OperationsSchemaResponseWorkflowFeaturesDeliveryFromJSON, OperationsSchemaResponseWorkflowFeaturesDeliveryToJSON, } from './OperationsSchemaResponseWorkflowFeaturesDelivery.js';
15
+ /**
16
+ * Check if a given object implements the OperationsSchemaResponseWorkflowFeatures interface.
17
+ */
18
+ export function instanceOfOperationsSchemaResponseWorkflowFeatures(value) {
19
+ return true;
20
+ }
21
+ export function OperationsSchemaResponseWorkflowFeaturesFromJSON(json) {
22
+ return OperationsSchemaResponseWorkflowFeaturesFromJSONTyped(json, false);
23
+ }
24
+ export function OperationsSchemaResponseWorkflowFeaturesFromJSONTyped(json, ignoreDiscriminator) {
25
+ if (json == null) {
26
+ return json;
27
+ }
28
+ return {
29
+ 'delivery': json['delivery'] == null ? undefined : OperationsSchemaResponseWorkflowFeaturesDeliveryFromJSON(json['delivery']),
30
+ };
31
+ }
32
+ export function OperationsSchemaResponseWorkflowFeaturesToJSON(json) {
33
+ return OperationsSchemaResponseWorkflowFeaturesToJSONTyped(json, false);
34
+ }
35
+ export function OperationsSchemaResponseWorkflowFeaturesToJSONTyped(value, ignoreDiscriminator = false) {
36
+ if (value == null) {
37
+ return value;
38
+ }
39
+ return {
40
+ 'delivery': OperationsSchemaResponseWorkflowFeaturesDeliveryToJSON(value['delivery']),
41
+ };
42
+ }
@@ -0,0 +1,40 @@
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. - **Currently committed locales:** `en-GB` only (per ticket [`4GKyuYo6`](https://trello.com/c/4GKyuYo6)). The I26 carrier shape (`Accept-Language` + `Content-Language` + `Vary` headers + `locale` envelope field + `message_key` + `message_params`) is stable and exercised; the **catalog** of translated `message` strings is en-GB-only at runtime today. Additional locales (e.g. `pt-PT`) will be advertised by name when their catalogs ship — the request/response carrier shape does NOT change when a new locale lands. Treat unrequested locales as \"machine-code + `message_key` path is committed; localised `message` prose is not\" until this prose enumerates them by name. - **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 — which, until additional catalogs land, is every non-`en-GB` `Accept-Language`. - **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). `Vary` is emitted unconditionally so the header contract does not flip when a second locale ships. - **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.31.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 { OperationsSchemaResponseWorkflowFeaturesDeliveryMode } from './OperationsSchemaResponseWorkflowFeaturesDeliveryMode.js';
13
+ import type { OperationsSchemaResponseWorkflowFeaturesDeliverySelection } from './OperationsSchemaResponseWorkflowFeaturesDeliverySelection.js';
14
+ /**
15
+ *
16
+ * @export
17
+ * @interface OperationsSchemaResponseWorkflowFeaturesDelivery
18
+ */
19
+ export interface OperationsSchemaResponseWorkflowFeaturesDelivery {
20
+ /**
21
+ *
22
+ * @type {OperationsSchemaResponseWorkflowFeaturesDeliveryMode}
23
+ * @memberof OperationsSchemaResponseWorkflowFeaturesDelivery
24
+ */
25
+ mode?: OperationsSchemaResponseWorkflowFeaturesDeliveryMode;
26
+ /**
27
+ *
28
+ * @type {OperationsSchemaResponseWorkflowFeaturesDeliverySelection}
29
+ * @memberof OperationsSchemaResponseWorkflowFeaturesDelivery
30
+ */
31
+ selection?: OperationsSchemaResponseWorkflowFeaturesDeliverySelection;
32
+ }
33
+ /**
34
+ * Check if a given object implements the OperationsSchemaResponseWorkflowFeaturesDelivery interface.
35
+ */
36
+ export declare function instanceOfOperationsSchemaResponseWorkflowFeaturesDelivery(value: object): value is OperationsSchemaResponseWorkflowFeaturesDelivery;
37
+ export declare function OperationsSchemaResponseWorkflowFeaturesDeliveryFromJSON(json: any): OperationsSchemaResponseWorkflowFeaturesDelivery;
38
+ export declare function OperationsSchemaResponseWorkflowFeaturesDeliveryFromJSONTyped(json: any, ignoreDiscriminator: boolean): OperationsSchemaResponseWorkflowFeaturesDelivery;
39
+ export declare function OperationsSchemaResponseWorkflowFeaturesDeliveryToJSON(json: any): OperationsSchemaResponseWorkflowFeaturesDelivery;
40
+ export declare function OperationsSchemaResponseWorkflowFeaturesDeliveryToJSONTyped(value?: OperationsSchemaResponseWorkflowFeaturesDelivery | null, ignoreDiscriminator?: boolean): any;
@@ -0,0 +1,45 @@
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. - **Currently committed locales:** `en-GB` only (per ticket [`4GKyuYo6`](https://trello.com/c/4GKyuYo6)). The I26 carrier shape (`Accept-Language` + `Content-Language` + `Vary` headers + `locale` envelope field + `message_key` + `message_params`) is stable and exercised; the **catalog** of translated `message` strings is en-GB-only at runtime today. Additional locales (e.g. `pt-PT`) will be advertised by name when their catalogs ship — the request/response carrier shape does NOT change when a new locale lands. Treat unrequested locales as \"machine-code + `message_key` path is committed; localised `message` prose is not\" until this prose enumerates them by name. - **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 — which, until additional catalogs land, is every non-`en-GB` `Accept-Language`. - **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). `Vary` is emitted unconditionally so the header contract does not flip when a second locale ships. - **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.31.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 { OperationsSchemaResponseWorkflowFeaturesDeliveryModeFromJSON, OperationsSchemaResponseWorkflowFeaturesDeliveryModeToJSON, } from './OperationsSchemaResponseWorkflowFeaturesDeliveryMode.js';
15
+ import { OperationsSchemaResponseWorkflowFeaturesDeliverySelectionFromJSON, OperationsSchemaResponseWorkflowFeaturesDeliverySelectionToJSON, } from './OperationsSchemaResponseWorkflowFeaturesDeliverySelection.js';
16
+ /**
17
+ * Check if a given object implements the OperationsSchemaResponseWorkflowFeaturesDelivery interface.
18
+ */
19
+ export function instanceOfOperationsSchemaResponseWorkflowFeaturesDelivery(value) {
20
+ return true;
21
+ }
22
+ export function OperationsSchemaResponseWorkflowFeaturesDeliveryFromJSON(json) {
23
+ return OperationsSchemaResponseWorkflowFeaturesDeliveryFromJSONTyped(json, false);
24
+ }
25
+ export function OperationsSchemaResponseWorkflowFeaturesDeliveryFromJSONTyped(json, ignoreDiscriminator) {
26
+ if (json == null) {
27
+ return json;
28
+ }
29
+ return {
30
+ 'mode': json['mode'] == null ? undefined : OperationsSchemaResponseWorkflowFeaturesDeliveryModeFromJSON(json['mode']),
31
+ 'selection': json['selection'] == null ? undefined : OperationsSchemaResponseWorkflowFeaturesDeliverySelectionFromJSON(json['selection']),
32
+ };
33
+ }
34
+ export function OperationsSchemaResponseWorkflowFeaturesDeliveryToJSON(json) {
35
+ return OperationsSchemaResponseWorkflowFeaturesDeliveryToJSONTyped(json, false);
36
+ }
37
+ export function OperationsSchemaResponseWorkflowFeaturesDeliveryToJSONTyped(value, ignoreDiscriminator = false) {
38
+ if (value == null) {
39
+ return value;
40
+ }
41
+ return {
42
+ 'mode': OperationsSchemaResponseWorkflowFeaturesDeliveryModeToJSON(value['mode']),
43
+ 'selection': OperationsSchemaResponseWorkflowFeaturesDeliverySelectionToJSON(value['selection']),
44
+ };
45
+ }
@@ -0,0 +1,45 @@
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. - **Currently committed locales:** `en-GB` only (per ticket [`4GKyuYo6`](https://trello.com/c/4GKyuYo6)). The I26 carrier shape (`Accept-Language` + `Content-Language` + `Vary` headers + `locale` envelope field + `message_key` + `message_params`) is stable and exercised; the **catalog** of translated `message` strings is en-GB-only at runtime today. Additional locales (e.g. `pt-PT`) will be advertised by name when their catalogs ship — the request/response carrier shape does NOT change when a new locale lands. Treat unrequested locales as \"machine-code + `message_key` path is committed; localised `message` prose is not\" until this prose enumerates them by name. - **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 — which, until additional catalogs land, is every non-`en-GB` `Accept-Language`. - **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). `Vary` is emitted unconditionally so the header contract does not flip when a second locale ships. - **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.31.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 { PerValueAvailabilityEntry } from './PerValueAvailabilityEntry.js';
13
+ /**
14
+ *
15
+ * @export
16
+ * @interface OperationsSchemaResponseWorkflowFeaturesDeliveryMode
17
+ */
18
+ export interface OperationsSchemaResponseWorkflowFeaturesDeliveryMode {
19
+ /**
20
+ * Map of enum-value → `PerValueAvailabilityEntry`. Attached to an
21
+ * option's `per_value_availability` field when individual enum
22
+ * values need different availability tags.
23
+ *
24
+ * Keys MUST be a subset of the option's `values[]` array. Used by
25
+ * the runtime capability endpoint ([I3 `eCWIpug8`](https://trello.com/c/eCWIpug8))
26
+ * and sidecar `availability.json` ([I3b `GbQU8FaS`](https://trello.com/c/GbQU8FaS))
27
+ * to surface per-value granularity. Consumed by SDK generators
28
+ * (TypeScript / PHP / Python / Rust) when emitting typed enum
29
+ * bindings with availability metadata.
30
+ *
31
+ * @type {{ [key: string]: PerValueAvailabilityEntry; }}
32
+ * @memberof OperationsSchemaResponseWorkflowFeaturesDeliveryMode
33
+ */
34
+ perValueAvailability?: {
35
+ [key: string]: PerValueAvailabilityEntry;
36
+ };
37
+ }
38
+ /**
39
+ * Check if a given object implements the OperationsSchemaResponseWorkflowFeaturesDeliveryMode interface.
40
+ */
41
+ export declare function instanceOfOperationsSchemaResponseWorkflowFeaturesDeliveryMode(value: object): value is OperationsSchemaResponseWorkflowFeaturesDeliveryMode;
42
+ export declare function OperationsSchemaResponseWorkflowFeaturesDeliveryModeFromJSON(json: any): OperationsSchemaResponseWorkflowFeaturesDeliveryMode;
43
+ export declare function OperationsSchemaResponseWorkflowFeaturesDeliveryModeFromJSONTyped(json: any, ignoreDiscriminator: boolean): OperationsSchemaResponseWorkflowFeaturesDeliveryMode;
44
+ export declare function OperationsSchemaResponseWorkflowFeaturesDeliveryModeToJSON(json: any): OperationsSchemaResponseWorkflowFeaturesDeliveryMode;
45
+ export declare function OperationsSchemaResponseWorkflowFeaturesDeliveryModeToJSONTyped(value?: OperationsSchemaResponseWorkflowFeaturesDeliveryMode | null, ignoreDiscriminator?: boolean): any;
@@ -0,0 +1,43 @@
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. - **Currently committed locales:** `en-GB` only (per ticket [`4GKyuYo6`](https://trello.com/c/4GKyuYo6)). The I26 carrier shape (`Accept-Language` + `Content-Language` + `Vary` headers + `locale` envelope field + `message_key` + `message_params`) is stable and exercised; the **catalog** of translated `message` strings is en-GB-only at runtime today. Additional locales (e.g. `pt-PT`) will be advertised by name when their catalogs ship — the request/response carrier shape does NOT change when a new locale lands. Treat unrequested locales as \"machine-code + `message_key` path is committed; localised `message` prose is not\" until this prose enumerates them by name. - **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 — which, until additional catalogs land, is every non-`en-GB` `Accept-Language`. - **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). `Vary` is emitted unconditionally so the header contract does not flip when a second locale ships. - **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.31.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 { mapValues } from '../runtime.js';
15
+ import { PerValueAvailabilityEntryFromJSON, PerValueAvailabilityEntryToJSON, } from './PerValueAvailabilityEntry.js';
16
+ /**
17
+ * Check if a given object implements the OperationsSchemaResponseWorkflowFeaturesDeliveryMode interface.
18
+ */
19
+ export function instanceOfOperationsSchemaResponseWorkflowFeaturesDeliveryMode(value) {
20
+ return true;
21
+ }
22
+ export function OperationsSchemaResponseWorkflowFeaturesDeliveryModeFromJSON(json) {
23
+ return OperationsSchemaResponseWorkflowFeaturesDeliveryModeFromJSONTyped(json, false);
24
+ }
25
+ export function OperationsSchemaResponseWorkflowFeaturesDeliveryModeFromJSONTyped(json, ignoreDiscriminator) {
26
+ if (json == null) {
27
+ return json;
28
+ }
29
+ return {
30
+ 'perValueAvailability': json['per_value_availability'] == null ? undefined : (mapValues(json['per_value_availability'], PerValueAvailabilityEntryFromJSON)),
31
+ };
32
+ }
33
+ export function OperationsSchemaResponseWorkflowFeaturesDeliveryModeToJSON(json) {
34
+ return OperationsSchemaResponseWorkflowFeaturesDeliveryModeToJSONTyped(json, false);
35
+ }
36
+ export function OperationsSchemaResponseWorkflowFeaturesDeliveryModeToJSONTyped(value, ignoreDiscriminator = false) {
37
+ if (value == null) {
38
+ return value;
39
+ }
40
+ return {
41
+ 'per_value_availability': value['perValueAvailability'] == null ? undefined : (mapValues(value['perValueAvailability'], PerValueAvailabilityEntryToJSON)),
42
+ };
43
+ }
@@ -0,0 +1,33 @@
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. - **Currently committed locales:** `en-GB` only (per ticket [`4GKyuYo6`](https://trello.com/c/4GKyuYo6)). The I26 carrier shape (`Accept-Language` + `Content-Language` + `Vary` headers + `locale` envelope field + `message_key` + `message_params`) is stable and exercised; the **catalog** of translated `message` strings is en-GB-only at runtime today. Additional locales (e.g. `pt-PT`) will be advertised by name when their catalogs ship — the request/response carrier shape does NOT change when a new locale lands. Treat unrequested locales as \"machine-code + `message_key` path is committed; localised `message` prose is not\" until this prose enumerates them by name. - **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 — which, until additional catalogs land, is every non-`en-GB` `Accept-Language`. - **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). `Vary` is emitted unconditionally so the header contract does not flip when a second locale ships. - **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.31.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 { OperationsSchemaResponseWorkflowFeaturesDeliveryMode } from './OperationsSchemaResponseWorkflowFeaturesDeliveryMode.js';
13
+ /**
14
+ *
15
+ * @export
16
+ * @interface OperationsSchemaResponseWorkflowFeaturesDeliverySelection
17
+ */
18
+ export interface OperationsSchemaResponseWorkflowFeaturesDeliverySelection {
19
+ /**
20
+ *
21
+ * @type {OperationsSchemaResponseWorkflowFeaturesDeliveryMode}
22
+ * @memberof OperationsSchemaResponseWorkflowFeaturesDeliverySelection
23
+ */
24
+ type?: OperationsSchemaResponseWorkflowFeaturesDeliveryMode;
25
+ }
26
+ /**
27
+ * Check if a given object implements the OperationsSchemaResponseWorkflowFeaturesDeliverySelection interface.
28
+ */
29
+ export declare function instanceOfOperationsSchemaResponseWorkflowFeaturesDeliverySelection(value: object): value is OperationsSchemaResponseWorkflowFeaturesDeliverySelection;
30
+ export declare function OperationsSchemaResponseWorkflowFeaturesDeliverySelectionFromJSON(json: any): OperationsSchemaResponseWorkflowFeaturesDeliverySelection;
31
+ export declare function OperationsSchemaResponseWorkflowFeaturesDeliverySelectionFromJSONTyped(json: any, ignoreDiscriminator: boolean): OperationsSchemaResponseWorkflowFeaturesDeliverySelection;
32
+ export declare function OperationsSchemaResponseWorkflowFeaturesDeliverySelectionToJSON(json: any): OperationsSchemaResponseWorkflowFeaturesDeliverySelection;
33
+ export declare function OperationsSchemaResponseWorkflowFeaturesDeliverySelectionToJSONTyped(value?: OperationsSchemaResponseWorkflowFeaturesDeliverySelection | null, ignoreDiscriminator?: boolean): any;
@@ -0,0 +1,42 @@
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. - **Currently committed locales:** `en-GB` only (per ticket [`4GKyuYo6`](https://trello.com/c/4GKyuYo6)). The I26 carrier shape (`Accept-Language` + `Content-Language` + `Vary` headers + `locale` envelope field + `message_key` + `message_params`) is stable and exercised; the **catalog** of translated `message` strings is en-GB-only at runtime today. Additional locales (e.g. `pt-PT`) will be advertised by name when their catalogs ship — the request/response carrier shape does NOT change when a new locale lands. Treat unrequested locales as \"machine-code + `message_key` path is committed; localised `message` prose is not\" until this prose enumerates them by name. - **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 — which, until additional catalogs land, is every non-`en-GB` `Accept-Language`. - **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). `Vary` is emitted unconditionally so the header contract does not flip when a second locale ships. - **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.31.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 { OperationsSchemaResponseWorkflowFeaturesDeliveryModeFromJSON, OperationsSchemaResponseWorkflowFeaturesDeliveryModeToJSON, } from './OperationsSchemaResponseWorkflowFeaturesDeliveryMode.js';
15
+ /**
16
+ * Check if a given object implements the OperationsSchemaResponseWorkflowFeaturesDeliverySelection interface.
17
+ */
18
+ export function instanceOfOperationsSchemaResponseWorkflowFeaturesDeliverySelection(value) {
19
+ return true;
20
+ }
21
+ export function OperationsSchemaResponseWorkflowFeaturesDeliverySelectionFromJSON(json) {
22
+ return OperationsSchemaResponseWorkflowFeaturesDeliverySelectionFromJSONTyped(json, false);
23
+ }
24
+ export function OperationsSchemaResponseWorkflowFeaturesDeliverySelectionFromJSONTyped(json, ignoreDiscriminator) {
25
+ if (json == null) {
26
+ return json;
27
+ }
28
+ return {
29
+ 'type': json['type'] == null ? undefined : OperationsSchemaResponseWorkflowFeaturesDeliveryModeFromJSON(json['type']),
30
+ };
31
+ }
32
+ export function OperationsSchemaResponseWorkflowFeaturesDeliverySelectionToJSON(json) {
33
+ return OperationsSchemaResponseWorkflowFeaturesDeliverySelectionToJSONTyped(json, false);
34
+ }
35
+ export function OperationsSchemaResponseWorkflowFeaturesDeliverySelectionToJSONTyped(value, ignoreDiscriminator = false) {
36
+ if (value == null) {
37
+ return value;
38
+ }
39
+ return {
40
+ 'type': OperationsSchemaResponseWorkflowFeaturesDeliveryModeToJSON(value['type']),
41
+ };
42
+ }
@@ -2,7 +2,7 @@
2
2
  * GISL Compression API
3
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. - **Currently committed locales:** `en-GB` only (per ticket [`4GKyuYo6`](https://trello.com/c/4GKyuYo6)). The I26 carrier shape (`Accept-Language` + `Content-Language` + `Vary` headers + `locale` envelope field + `message_key` + `message_params`) is stable and exercised; the **catalog** of translated `message` strings is en-GB-only at runtime today. Additional locales (e.g. `pt-PT`) will be advertised by name when their catalogs ship — the request/response carrier shape does NOT change when a new locale lands. Treat unrequested locales as \"machine-code + `message_key` path is committed; localised `message` prose is not\" until this prose enumerates them by name. - **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 — which, until additional catalogs land, is every non-`en-GB` `Accept-Language`. - **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). `Vary` is emitted unconditionally so the header contract does not flip when a second locale ships. - **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
4
  *
5
- * The version of the OpenAPI document: 2.21.0
5
+ * The version of the OpenAPI document: 2.31.0
6
6
  *
7
7
  *
8
8
  * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
@@ -4,7 +4,7 @@
4
4
  * GISL Compression API
5
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. - **Currently committed locales:** `en-GB` only (per ticket [`4GKyuYo6`](https://trello.com/c/4GKyuYo6)). The I26 carrier shape (`Accept-Language` + `Content-Language` + `Vary` headers + `locale` envelope field + `message_key` + `message_params`) is stable and exercised; the **catalog** of translated `message` strings is en-GB-only at runtime today. Additional locales (e.g. `pt-PT`) will be advertised by name when their catalogs ship — the request/response carrier shape does NOT change when a new locale lands. Treat unrequested locales as \"machine-code + `message_key` path is committed; localised `message` prose is not\" until this prose enumerates them by name. - **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 — which, until additional catalogs land, is every non-`en-GB` `Accept-Language`. - **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). `Vary` is emitted unconditionally so the header contract does not flip when a second locale ships. - **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
6
  *
7
- * The version of the OpenAPI document: 2.21.0
7
+ * The version of the OpenAPI document: 2.31.0
8
8
  *
9
9
  *
10
10
  * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
@@ -2,7 +2,7 @@
2
2
  * GISL Compression API
3
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. - **Currently committed locales:** `en-GB` only (per ticket [`4GKyuYo6`](https://trello.com/c/4GKyuYo6)). The I26 carrier shape (`Accept-Language` + `Content-Language` + `Vary` headers + `locale` envelope field + `message_key` + `message_params`) is stable and exercised; the **catalog** of translated `message` strings is en-GB-only at runtime today. Additional locales (e.g. `pt-PT`) will be advertised by name when their catalogs ship — the request/response carrier shape does NOT change when a new locale lands. Treat unrequested locales as \"machine-code + `message_key` path is committed; localised `message` prose is not\" until this prose enumerates them by name. - **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 — which, until additional catalogs land, is every non-`en-GB` `Accept-Language`. - **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). `Vary` is emitted unconditionally so the header contract does not flip when a second locale ships. - **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
4
  *
5
- * The version of the OpenAPI document: 2.21.0
5
+ * The version of the OpenAPI document: 2.31.0
6
6
  *
7
7
  *
8
8
  * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
@@ -4,7 +4,7 @@
4
4
  * GISL Compression API
5
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. - **Currently committed locales:** `en-GB` only (per ticket [`4GKyuYo6`](https://trello.com/c/4GKyuYo6)). The I26 carrier shape (`Accept-Language` + `Content-Language` + `Vary` headers + `locale` envelope field + `message_key` + `message_params`) is stable and exercised; the **catalog** of translated `message` strings is en-GB-only at runtime today. Additional locales (e.g. `pt-PT`) will be advertised by name when their catalogs ship — the request/response carrier shape does NOT change when a new locale lands. Treat unrequested locales as \"machine-code + `message_key` path is committed; localised `message` prose is not\" until this prose enumerates them by name. - **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 — which, until additional catalogs land, is every non-`en-GB` `Accept-Language`. - **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). `Vary` is emitted unconditionally so the header contract does not flip when a second locale ships. - **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
6
  *
7
- * The version of the OpenAPI document: 2.21.0
7
+ * The version of the OpenAPI document: 2.31.0
8
8
  *
9
9
  *
10
10
  * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).
@@ -2,7 +2,7 @@
2
2
  * GISL Compression API
3
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. - **Currently committed locales:** `en-GB` only (per ticket [`4GKyuYo6`](https://trello.com/c/4GKyuYo6)). The I26 carrier shape (`Accept-Language` + `Content-Language` + `Vary` headers + `locale` envelope field + `message_key` + `message_params`) is stable and exercised; the **catalog** of translated `message` strings is en-GB-only at runtime today. Additional locales (e.g. `pt-PT`) will be advertised by name when their catalogs ship — the request/response carrier shape does NOT change when a new locale lands. Treat unrequested locales as \"machine-code + `message_key` path is committed; localised `message` prose is not\" until this prose enumerates them by name. - **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 — which, until additional catalogs land, is every non-`en-GB` `Accept-Language`. - **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). `Vary` is emitted unconditionally so the header contract does not flip when a second locale ships. - **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
4
  *
5
- * The version of the OpenAPI document: 2.21.0
5
+ * The version of the OpenAPI document: 2.31.0
6
6
  *
7
7
  *
8
8
  * NOTE: This class is auto generated by OpenAPI Generator (https://openapi-generator.tech).