@stack0/sdk 0.5.7 → 0.5.8

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.
@@ -306,6 +306,52 @@ interface ExtractAudioResponse {
306
306
  jobId: string;
307
307
  status: TranscodingStatus;
308
308
  }
309
+ type GifStatus = "pending" | "processing" | "completed" | "failed";
310
+ interface GenerateGifRequest {
311
+ /** Project slug */
312
+ projectSlug: string;
313
+ /** ID of the video asset to generate GIF from */
314
+ assetId: string;
315
+ /** Start time in seconds (default: 0) */
316
+ startTime?: number;
317
+ /** Duration in seconds (0.5-30, default: 5) */
318
+ duration?: number;
319
+ /** Output width in pixels (100-800, default: 480) */
320
+ width?: number;
321
+ /** Frames per second (5-30, default: 10) */
322
+ fps?: number;
323
+ /** Use two-pass palette optimization for smaller file size (default: true) */
324
+ optimizePalette?: boolean;
325
+ }
326
+ interface VideoGif {
327
+ id: string;
328
+ assetId: string;
329
+ /** Start time in seconds */
330
+ startTime: number;
331
+ /** Duration in seconds */
332
+ duration: number;
333
+ /** Frames per second */
334
+ fps: number;
335
+ /** CDN URL of the generated GIF (null if pending/processing) */
336
+ url: string | null;
337
+ /** Width in pixels */
338
+ width: number | null;
339
+ /** Height in pixels */
340
+ height: number | null;
341
+ /** File size in bytes */
342
+ sizeBytes: number | null;
343
+ /** Number of frames in the GIF */
344
+ frameCount: number | null;
345
+ /** Current status of the GIF generation */
346
+ status: GifStatus;
347
+ /** Error message if failed */
348
+ errorMessage: string | null;
349
+ createdAt: Date;
350
+ completedAt: Date | null;
351
+ }
352
+ interface ListGifsRequest {
353
+ assetId: string;
354
+ }
309
355
  type PrivateFileStatus = "pending" | "ready" | "failed" | "deleted";
310
356
  interface PrivateFile {
311
357
  id: string;
@@ -1033,6 +1079,60 @@ declare class CDN {
1033
1079
  * ```
1034
1080
  */
1035
1081
  extractAudio(request: ExtractAudioRequest): Promise<ExtractAudioResponse>;
1082
+ /**
1083
+ * Generate an animated GIF from a video segment
1084
+ *
1085
+ * Creates an optimized GIF from a portion of the video. Uses two-pass
1086
+ * palette generation by default for smaller file sizes with better quality.
1087
+ *
1088
+ * @example
1089
+ * ```typescript
1090
+ * const gif = await cdn.generateGif({
1091
+ * projectSlug: 'my-project',
1092
+ * assetId: 'video-asset-id',
1093
+ * startTime: 5, // Start at 5 seconds
1094
+ * duration: 3, // 3 second GIF
1095
+ * width: 480, // 480px wide
1096
+ * fps: 10, // 10 frames per second
1097
+ * });
1098
+ *
1099
+ * // Poll for completion
1100
+ * let result = await cdn.getGif(gif.id);
1101
+ * while (result?.status === 'pending' || result?.status === 'processing') {
1102
+ * await new Promise(r => setTimeout(r, 1000));
1103
+ * result = await cdn.getGif(gif.id);
1104
+ * }
1105
+ *
1106
+ * console.log(`GIF URL: ${result?.url}`);
1107
+ * ```
1108
+ */
1109
+ generateGif(request: GenerateGifRequest): Promise<VideoGif>;
1110
+ /**
1111
+ * Get a specific GIF by ID
1112
+ *
1113
+ * @example
1114
+ * ```typescript
1115
+ * const gif = await cdn.getGif('gif-id');
1116
+ * if (gif?.status === 'completed') {
1117
+ * console.log(`GIF URL: ${gif.url}`);
1118
+ * console.log(`Size: ${gif.sizeBytes} bytes`);
1119
+ * }
1120
+ * ```
1121
+ */
1122
+ getGif(gifId: string): Promise<VideoGif | null>;
1123
+ /**
1124
+ * List all GIFs generated for a video asset
1125
+ *
1126
+ * @example
1127
+ * ```typescript
1128
+ * const gifs = await cdn.listGifs({ assetId: 'video-asset-id' });
1129
+ * for (const gif of gifs) {
1130
+ * console.log(`GIF at ${gif.startTime}s: ${gif.url}`);
1131
+ * }
1132
+ * ```
1133
+ */
1134
+ listGifs(request: ListGifsRequest): Promise<VideoGif[]>;
1135
+ private convertGifDates;
1036
1136
  private convertJobDates;
1037
1137
  /**
1038
1138
  * Generate a presigned URL for uploading a private file
@@ -1383,4 +1483,4 @@ declare class CDN {
1383
1483
  private convertMergeJobWithOutputDates;
1384
1484
  }
1385
1485
 
1386
- export { type Asset, type AssetStatus, type AssetType, type AudioTrackInput, type BundleDownloadUrlRequest, type BundleDownloadUrlResponse, type BundleStatus, CDN, type CancelMergeJobRequest, type CdnEnvironment, type CdnStorageBreakdownItem, type CdnStorageBreakdownRequest, type CdnStorageBreakdownResponse, type CdnUsageDataPoint, type CdnUsageHistoryRequest, type CdnUsageHistoryResponse, type CdnUsageRequest, type CdnUsageResponse, type ConfirmUploadRequest, type ConfirmUploadResponse, type CreateBundleRequest, type CreateBundleResponse, type CreateFolderRequest, type CreateMergeJobRequest, type DeleteAssetRequest, type DeleteAssetsRequest, type DeleteAssetsResponse, type DownloadBundle, type ExtractAudioRequest, type ExtractAudioResponse, type Folder, type FolderListItem, type FolderTreeNode, type GetAssetRequest, type GetFolderByPathRequest, type GetFolderRequest, type GetFolderTreeRequest, type GetMergeJobRequest, type ImageWatermarkConfig, type ImageWatermarkPosition, type ImageWatermarkSizingMode, type ListAssetsRequest, type ListAssetsResponse, type ListBundlesRequest, type ListBundlesResponse, type ListFoldersRequest, type ListFoldersResponse, type ListJobsRequest, type ListJobsResponse, type ListMergeJobsRequest, type ListMergeJobsResponse, type ListPrivateFilesRequest, type ListPrivateFilesResponse, type ListThumbnailsRequest, type ListThumbnailsResponse, type MergeInputItem, type MergeJob, type MergeJobWithOutput, type MergeOutputConfig, type MergeOutputFormat, type MergeQuality, type MergeStatus, type MoveAssetsRequest, type MoveAssetsResponse, type MoveFolderRequest, type MoveFolderResponse, type MovePrivateFilesRequest, type MovePrivateFilesResponse, type PrivateDownloadUrlRequest, type PrivateDownloadUrlResponse, type PrivateFile, type PrivateFileStatus, type PrivateUploadUrlRequest, type PrivateUploadUrlResponse, type RegenerateThumbnailRequest, type RegenerateThumbnailResponse, type StreamingUrls, type TextOverlay, type TextOverlayShadow, type TextOverlayStroke, type ThumbnailRequest, type ThumbnailResponse, type TranscodeJob, type TranscodeVideoRequest, type TranscodingStatus, type TransformOptions, type TrimOptions, type UpdateAssetRequest, type UpdateFolderRequest, type UpdatePrivateFileRequest, type UploadUrlRequest, type UploadUrlResponse, type VideoCodec, type VideoOutputFormat, type VideoQuality, type VideoThumbnail, type VideoVariant, type WatermarkOptions };
1486
+ export { type Asset, type AssetStatus, type AssetType, type AudioTrackInput, type BundleDownloadUrlRequest, type BundleDownloadUrlResponse, type BundleStatus, CDN, type CancelMergeJobRequest, type CdnEnvironment, type CdnStorageBreakdownItem, type CdnStorageBreakdownRequest, type CdnStorageBreakdownResponse, type CdnUsageDataPoint, type CdnUsageHistoryRequest, type CdnUsageHistoryResponse, type CdnUsageRequest, type CdnUsageResponse, type ConfirmUploadRequest, type ConfirmUploadResponse, type CreateBundleRequest, type CreateBundleResponse, type CreateFolderRequest, type CreateMergeJobRequest, type DeleteAssetRequest, type DeleteAssetsRequest, type DeleteAssetsResponse, type DownloadBundle, type ExtractAudioRequest, type ExtractAudioResponse, type Folder, type FolderListItem, type FolderTreeNode, type GenerateGifRequest, type GetAssetRequest, type GetFolderByPathRequest, type GetFolderRequest, type GetFolderTreeRequest, type GetMergeJobRequest, type GifStatus, type ImageWatermarkConfig, type ImageWatermarkPosition, type ImageWatermarkSizingMode, type ListAssetsRequest, type ListAssetsResponse, type ListBundlesRequest, type ListBundlesResponse, type ListFoldersRequest, type ListFoldersResponse, type ListGifsRequest, type ListJobsRequest, type ListJobsResponse, type ListMergeJobsRequest, type ListMergeJobsResponse, type ListPrivateFilesRequest, type ListPrivateFilesResponse, type ListThumbnailsRequest, type ListThumbnailsResponse, type MergeInputItem, type MergeJob, type MergeJobWithOutput, type MergeOutputConfig, type MergeOutputFormat, type MergeQuality, type MergeStatus, type MoveAssetsRequest, type MoveAssetsResponse, type MoveFolderRequest, type MoveFolderResponse, type MovePrivateFilesRequest, type MovePrivateFilesResponse, type PrivateDownloadUrlRequest, type PrivateDownloadUrlResponse, type PrivateFile, type PrivateFileStatus, type PrivateUploadUrlRequest, type PrivateUploadUrlResponse, type RegenerateThumbnailRequest, type RegenerateThumbnailResponse, type StreamingUrls, type TextOverlay, type TextOverlayShadow, type TextOverlayStroke, type ThumbnailRequest, type ThumbnailResponse, type TranscodeJob, type TranscodeVideoRequest, type TranscodingStatus, type TransformOptions, type TrimOptions, type UpdateAssetRequest, type UpdateFolderRequest, type UpdatePrivateFileRequest, type UploadUrlRequest, type UploadUrlResponse, type VideoCodec, type VideoGif, type VideoOutputFormat, type VideoQuality, type VideoThumbnail, type VideoVariant, type WatermarkOptions };
@@ -306,6 +306,52 @@ interface ExtractAudioResponse {
306
306
  jobId: string;
307
307
  status: TranscodingStatus;
308
308
  }
309
+ type GifStatus = "pending" | "processing" | "completed" | "failed";
310
+ interface GenerateGifRequest {
311
+ /** Project slug */
312
+ projectSlug: string;
313
+ /** ID of the video asset to generate GIF from */
314
+ assetId: string;
315
+ /** Start time in seconds (default: 0) */
316
+ startTime?: number;
317
+ /** Duration in seconds (0.5-30, default: 5) */
318
+ duration?: number;
319
+ /** Output width in pixels (100-800, default: 480) */
320
+ width?: number;
321
+ /** Frames per second (5-30, default: 10) */
322
+ fps?: number;
323
+ /** Use two-pass palette optimization for smaller file size (default: true) */
324
+ optimizePalette?: boolean;
325
+ }
326
+ interface VideoGif {
327
+ id: string;
328
+ assetId: string;
329
+ /** Start time in seconds */
330
+ startTime: number;
331
+ /** Duration in seconds */
332
+ duration: number;
333
+ /** Frames per second */
334
+ fps: number;
335
+ /** CDN URL of the generated GIF (null if pending/processing) */
336
+ url: string | null;
337
+ /** Width in pixels */
338
+ width: number | null;
339
+ /** Height in pixels */
340
+ height: number | null;
341
+ /** File size in bytes */
342
+ sizeBytes: number | null;
343
+ /** Number of frames in the GIF */
344
+ frameCount: number | null;
345
+ /** Current status of the GIF generation */
346
+ status: GifStatus;
347
+ /** Error message if failed */
348
+ errorMessage: string | null;
349
+ createdAt: Date;
350
+ completedAt: Date | null;
351
+ }
352
+ interface ListGifsRequest {
353
+ assetId: string;
354
+ }
309
355
  type PrivateFileStatus = "pending" | "ready" | "failed" | "deleted";
310
356
  interface PrivateFile {
311
357
  id: string;
@@ -1033,6 +1079,60 @@ declare class CDN {
1033
1079
  * ```
1034
1080
  */
1035
1081
  extractAudio(request: ExtractAudioRequest): Promise<ExtractAudioResponse>;
1082
+ /**
1083
+ * Generate an animated GIF from a video segment
1084
+ *
1085
+ * Creates an optimized GIF from a portion of the video. Uses two-pass
1086
+ * palette generation by default for smaller file sizes with better quality.
1087
+ *
1088
+ * @example
1089
+ * ```typescript
1090
+ * const gif = await cdn.generateGif({
1091
+ * projectSlug: 'my-project',
1092
+ * assetId: 'video-asset-id',
1093
+ * startTime: 5, // Start at 5 seconds
1094
+ * duration: 3, // 3 second GIF
1095
+ * width: 480, // 480px wide
1096
+ * fps: 10, // 10 frames per second
1097
+ * });
1098
+ *
1099
+ * // Poll for completion
1100
+ * let result = await cdn.getGif(gif.id);
1101
+ * while (result?.status === 'pending' || result?.status === 'processing') {
1102
+ * await new Promise(r => setTimeout(r, 1000));
1103
+ * result = await cdn.getGif(gif.id);
1104
+ * }
1105
+ *
1106
+ * console.log(`GIF URL: ${result?.url}`);
1107
+ * ```
1108
+ */
1109
+ generateGif(request: GenerateGifRequest): Promise<VideoGif>;
1110
+ /**
1111
+ * Get a specific GIF by ID
1112
+ *
1113
+ * @example
1114
+ * ```typescript
1115
+ * const gif = await cdn.getGif('gif-id');
1116
+ * if (gif?.status === 'completed') {
1117
+ * console.log(`GIF URL: ${gif.url}`);
1118
+ * console.log(`Size: ${gif.sizeBytes} bytes`);
1119
+ * }
1120
+ * ```
1121
+ */
1122
+ getGif(gifId: string): Promise<VideoGif | null>;
1123
+ /**
1124
+ * List all GIFs generated for a video asset
1125
+ *
1126
+ * @example
1127
+ * ```typescript
1128
+ * const gifs = await cdn.listGifs({ assetId: 'video-asset-id' });
1129
+ * for (const gif of gifs) {
1130
+ * console.log(`GIF at ${gif.startTime}s: ${gif.url}`);
1131
+ * }
1132
+ * ```
1133
+ */
1134
+ listGifs(request: ListGifsRequest): Promise<VideoGif[]>;
1135
+ private convertGifDates;
1036
1136
  private convertJobDates;
1037
1137
  /**
1038
1138
  * Generate a presigned URL for uploading a private file
@@ -1383,4 +1483,4 @@ declare class CDN {
1383
1483
  private convertMergeJobWithOutputDates;
1384
1484
  }
1385
1485
 
1386
- export { type Asset, type AssetStatus, type AssetType, type AudioTrackInput, type BundleDownloadUrlRequest, type BundleDownloadUrlResponse, type BundleStatus, CDN, type CancelMergeJobRequest, type CdnEnvironment, type CdnStorageBreakdownItem, type CdnStorageBreakdownRequest, type CdnStorageBreakdownResponse, type CdnUsageDataPoint, type CdnUsageHistoryRequest, type CdnUsageHistoryResponse, type CdnUsageRequest, type CdnUsageResponse, type ConfirmUploadRequest, type ConfirmUploadResponse, type CreateBundleRequest, type CreateBundleResponse, type CreateFolderRequest, type CreateMergeJobRequest, type DeleteAssetRequest, type DeleteAssetsRequest, type DeleteAssetsResponse, type DownloadBundle, type ExtractAudioRequest, type ExtractAudioResponse, type Folder, type FolderListItem, type FolderTreeNode, type GetAssetRequest, type GetFolderByPathRequest, type GetFolderRequest, type GetFolderTreeRequest, type GetMergeJobRequest, type ImageWatermarkConfig, type ImageWatermarkPosition, type ImageWatermarkSizingMode, type ListAssetsRequest, type ListAssetsResponse, type ListBundlesRequest, type ListBundlesResponse, type ListFoldersRequest, type ListFoldersResponse, type ListJobsRequest, type ListJobsResponse, type ListMergeJobsRequest, type ListMergeJobsResponse, type ListPrivateFilesRequest, type ListPrivateFilesResponse, type ListThumbnailsRequest, type ListThumbnailsResponse, type MergeInputItem, type MergeJob, type MergeJobWithOutput, type MergeOutputConfig, type MergeOutputFormat, type MergeQuality, type MergeStatus, type MoveAssetsRequest, type MoveAssetsResponse, type MoveFolderRequest, type MoveFolderResponse, type MovePrivateFilesRequest, type MovePrivateFilesResponse, type PrivateDownloadUrlRequest, type PrivateDownloadUrlResponse, type PrivateFile, type PrivateFileStatus, type PrivateUploadUrlRequest, type PrivateUploadUrlResponse, type RegenerateThumbnailRequest, type RegenerateThumbnailResponse, type StreamingUrls, type TextOverlay, type TextOverlayShadow, type TextOverlayStroke, type ThumbnailRequest, type ThumbnailResponse, type TranscodeJob, type TranscodeVideoRequest, type TranscodingStatus, type TransformOptions, type TrimOptions, type UpdateAssetRequest, type UpdateFolderRequest, type UpdatePrivateFileRequest, type UploadUrlRequest, type UploadUrlResponse, type VideoCodec, type VideoOutputFormat, type VideoQuality, type VideoThumbnail, type VideoVariant, type WatermarkOptions };
1486
+ export { type Asset, type AssetStatus, type AssetType, type AudioTrackInput, type BundleDownloadUrlRequest, type BundleDownloadUrlResponse, type BundleStatus, CDN, type CancelMergeJobRequest, type CdnEnvironment, type CdnStorageBreakdownItem, type CdnStorageBreakdownRequest, type CdnStorageBreakdownResponse, type CdnUsageDataPoint, type CdnUsageHistoryRequest, type CdnUsageHistoryResponse, type CdnUsageRequest, type CdnUsageResponse, type ConfirmUploadRequest, type ConfirmUploadResponse, type CreateBundleRequest, type CreateBundleResponse, type CreateFolderRequest, type CreateMergeJobRequest, type DeleteAssetRequest, type DeleteAssetsRequest, type DeleteAssetsResponse, type DownloadBundle, type ExtractAudioRequest, type ExtractAudioResponse, type Folder, type FolderListItem, type FolderTreeNode, type GenerateGifRequest, type GetAssetRequest, type GetFolderByPathRequest, type GetFolderRequest, type GetFolderTreeRequest, type GetMergeJobRequest, type GifStatus, type ImageWatermarkConfig, type ImageWatermarkPosition, type ImageWatermarkSizingMode, type ListAssetsRequest, type ListAssetsResponse, type ListBundlesRequest, type ListBundlesResponse, type ListFoldersRequest, type ListFoldersResponse, type ListGifsRequest, type ListJobsRequest, type ListJobsResponse, type ListMergeJobsRequest, type ListMergeJobsResponse, type ListPrivateFilesRequest, type ListPrivateFilesResponse, type ListThumbnailsRequest, type ListThumbnailsResponse, type MergeInputItem, type MergeJob, type MergeJobWithOutput, type MergeOutputConfig, type MergeOutputFormat, type MergeQuality, type MergeStatus, type MoveAssetsRequest, type MoveAssetsResponse, type MoveFolderRequest, type MoveFolderResponse, type MovePrivateFilesRequest, type MovePrivateFilesResponse, type PrivateDownloadUrlRequest, type PrivateDownloadUrlResponse, type PrivateFile, type PrivateFileStatus, type PrivateUploadUrlRequest, type PrivateUploadUrlResponse, type RegenerateThumbnailRequest, type RegenerateThumbnailResponse, type StreamingUrls, type TextOverlay, type TextOverlayShadow, type TextOverlayStroke, type ThumbnailRequest, type ThumbnailResponse, type TranscodeJob, type TranscodeVideoRequest, type TranscodingStatus, type TransformOptions, type TrimOptions, type UpdateAssetRequest, type UpdateFolderRequest, type UpdatePrivateFileRequest, type UploadUrlRequest, type UploadUrlResponse, type VideoCodec, type VideoGif, type VideoOutputFormat, type VideoQuality, type VideoThumbnail, type VideoVariant, type WatermarkOptions };
package/dist/cdn/index.js CHANGED
@@ -558,6 +558,80 @@ var CDN = class {
558
558
  async extractAudio(request) {
559
559
  return this.http.post("/cdn/video/extract-audio", request);
560
560
  }
561
+ // ============================================================================
562
+ // GIF Generation Methods
563
+ // ============================================================================
564
+ /**
565
+ * Generate an animated GIF from a video segment
566
+ *
567
+ * Creates an optimized GIF from a portion of the video. Uses two-pass
568
+ * palette generation by default for smaller file sizes with better quality.
569
+ *
570
+ * @example
571
+ * ```typescript
572
+ * const gif = await cdn.generateGif({
573
+ * projectSlug: 'my-project',
574
+ * assetId: 'video-asset-id',
575
+ * startTime: 5, // Start at 5 seconds
576
+ * duration: 3, // 3 second GIF
577
+ * width: 480, // 480px wide
578
+ * fps: 10, // 10 frames per second
579
+ * });
580
+ *
581
+ * // Poll for completion
582
+ * let result = await cdn.getGif(gif.id);
583
+ * while (result?.status === 'pending' || result?.status === 'processing') {
584
+ * await new Promise(r => setTimeout(r, 1000));
585
+ * result = await cdn.getGif(gif.id);
586
+ * }
587
+ *
588
+ * console.log(`GIF URL: ${result?.url}`);
589
+ * ```
590
+ */
591
+ async generateGif(request) {
592
+ const response = await this.http.post("/cdn/video/gif", request);
593
+ return this.convertGifDates(response);
594
+ }
595
+ /**
596
+ * Get a specific GIF by ID
597
+ *
598
+ * @example
599
+ * ```typescript
600
+ * const gif = await cdn.getGif('gif-id');
601
+ * if (gif?.status === 'completed') {
602
+ * console.log(`GIF URL: ${gif.url}`);
603
+ * console.log(`Size: ${gif.sizeBytes} bytes`);
604
+ * }
605
+ * ```
606
+ */
607
+ async getGif(gifId) {
608
+ const response = await this.http.get(`/cdn/video/gif/${gifId}`);
609
+ return response ? this.convertGifDates(response) : null;
610
+ }
611
+ /**
612
+ * List all GIFs generated for a video asset
613
+ *
614
+ * @example
615
+ * ```typescript
616
+ * const gifs = await cdn.listGifs({ assetId: 'video-asset-id' });
617
+ * for (const gif of gifs) {
618
+ * console.log(`GIF at ${gif.startTime}s: ${gif.url}`);
619
+ * }
620
+ * ```
621
+ */
622
+ async listGifs(request) {
623
+ const response = await this.http.get(`/cdn/video/${request.assetId}/gifs`);
624
+ return response.map((gif) => this.convertGifDates(gif));
625
+ }
626
+ convertGifDates(gif) {
627
+ if (typeof gif.createdAt === "string") {
628
+ gif.createdAt = new Date(gif.createdAt);
629
+ }
630
+ if (gif.completedAt && typeof gif.completedAt === "string") {
631
+ gif.completedAt = new Date(gif.completedAt);
632
+ }
633
+ return gif;
634
+ }
561
635
  convertJobDates(job) {
562
636
  if (typeof job.createdAt === "string") {
563
637
  job.createdAt = new Date(job.createdAt);