@stack0/sdk 0.5.5 → 0.5.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/lib/http-client.ts","../src/mail/audiences.ts","../src/mail/campaigns.ts","../src/mail/contacts.ts","../src/mail/domains.ts","../src/mail/events.ts","../src/mail/sequences.ts","../src/mail/templates.ts","../src/mail/client.ts","../src/cdn/client.ts","../src/screenshots/client.ts","../src/extraction/client.ts","../src/webdata/client.ts","../src/integrations/client.ts","../src/marketing/client.ts","../src/index.ts"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["/**\n * HTTP client for Stack0 API\n * Handles authentication, request/response formatting, and error handling\n */\n\nexport interface HttpClientConfig {\n apiKey: string;\n baseUrl?: string;\n}\n\nexport class HttpClient {\n private apiKey: string;\n private baseUrl: string;\n\n constructor(config: HttpClientConfig) {\n this.apiKey = config.apiKey;\n this.baseUrl = config.baseUrl || \"https://api.stack0.dev/v1\";\n }\n\n private getHeaders(includeContentType = true): Record<string, string> {\n const headers: Record<string, string> = {\n Authorization: `Bearer ${this.apiKey}`,\n };\n if (includeContentType) {\n headers[\"Content-Type\"] = \"application/json\";\n }\n return headers;\n }\n\n async request<T>(method: string, path: string, body?: unknown): Promise<T> {\n const url = `${this.baseUrl}${path}`;\n const bodyString = body === undefined ? undefined : JSON.stringify(body);\n const hasBody = bodyString !== undefined;\n\n try {\n const response = await fetch(url, {\n method,\n headers: this.getHeaders(hasBody),\n body: hasBody ? bodyString : undefined,\n });\n\n if (!response.ok) {\n await this.handleErrorResponse(response);\n }\n\n const data = await response.json();\n return data as T;\n } catch (error) {\n if (error instanceof Error && \"statusCode\" in error) {\n throw error; // Re-throw our custom errors\n }\n throw this.createError(\"Network error\", error);\n }\n }\n\n private async handleErrorResponse(response: Response): Promise<never> {\n let errorBody: { message: string } | undefined;\n try {\n errorBody = (await response.json()) as { message: string };\n } catch {\n errorBody = { message: response.statusText };\n }\n\n const error = new Error(errorBody?.message || `HTTP ${response.status}`) as Error & {\n statusCode: number;\n code: string;\n response: unknown;\n };\n error.statusCode = response.status;\n error.code = (errorBody as unknown as { code: string } | undefined)?.code ?? \"\";\n error.response = errorBody;\n throw error;\n }\n\n private createError(message: string, cause?: unknown): Error {\n const error = new Error(message) as Error & { cause: unknown };\n error.cause = cause;\n return error;\n }\n\n async get<T>(path: string): Promise<T> {\n return this.request<T>(\"GET\", path);\n }\n\n async post<T>(path: string, body: unknown): Promise<T> {\n return this.request<T>(\"POST\", path, body);\n }\n\n async put<T>(path: string, body: unknown): Promise<T> {\n return this.request<T>(\"PUT\", path, body);\n }\n\n async delete<T>(path: string): Promise<T> {\n return this.request<T>(\"DELETE\", path);\n }\n\n async deleteWithBody<T>(path: string, body: unknown): Promise<T> {\n return this.request<T>(\"DELETE\", path, body);\n }\n\n async patch<T>(path: string, body: unknown): Promise<T> {\n return this.request<T>(\"PATCH\", path, body);\n }\n}\n","/**\n * Audiences client for Stack0 Mail API\n */\n\nimport type { HttpClient } from \"../lib/http-client\";\nimport type {\n AddContactsToAudienceRequest,\n AddContactsToAudienceResponse,\n Audience,\n AudienceContact,\n CreateAudienceRequest,\n DeleteAudienceResponse,\n ListAudienceContactsRequest,\n ListAudienceContactsResponse,\n ListAudiencesRequest,\n ListAudiencesResponse,\n RemoveContactsFromAudienceRequest,\n RemoveContactsFromAudienceResponse,\n UpdateAudienceRequest,\n} from \"./types\";\n\nexport class Audiences {\n constructor(private http: HttpClient) {}\n\n /**\n * List all audiences\n */\n async list(request: ListAudiencesRequest = {}): Promise<ListAudiencesResponse> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.search) params.set(\"search\", request.search);\n\n const query = params.toString();\n return this.http.get<ListAudiencesResponse>(`/mail/audiences${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Get an audience by ID\n */\n async get(id: string): Promise<Audience> {\n return this.http.get<Audience>(`/mail/audiences/${id}`);\n }\n\n /**\n * Create a new audience\n */\n async create(request: CreateAudienceRequest): Promise<Audience> {\n return this.http.post<Audience>(\"/mail/audiences\", request);\n }\n\n /**\n * Update an audience\n */\n async update(request: UpdateAudienceRequest): Promise<Audience> {\n const { id, ...data } = request;\n return this.http.put<Audience>(`/mail/audiences/${id}`, data);\n }\n\n /**\n * Delete an audience\n */\n async delete(id: string): Promise<DeleteAudienceResponse> {\n return this.http.delete<DeleteAudienceResponse>(`/mail/audiences/${id}`);\n }\n\n /**\n * List contacts in an audience\n */\n async listContacts(request: ListAudienceContactsRequest): Promise<ListAudienceContactsResponse> {\n const { id, ...params } = request;\n const searchParams = new URLSearchParams();\n if (params.environment) searchParams.set(\"environment\", params.environment);\n if (params.limit) searchParams.set(\"limit\", params.limit.toString());\n if (params.offset) searchParams.set(\"offset\", params.offset.toString());\n if (params.search) searchParams.set(\"search\", params.search);\n if (params.status) searchParams.set(\"status\", params.status);\n\n const query = searchParams.toString();\n return this.http.get<ListAudienceContactsResponse>(`/mail/audiences/${id}/contacts${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Add contacts to an audience\n */\n async addContacts(request: AddContactsToAudienceRequest): Promise<AddContactsToAudienceResponse> {\n const { id, contactIds } = request;\n return this.http.post<AddContactsToAudienceResponse>(`/mail/audiences/${id}/contacts`, { contactIds });\n }\n\n /**\n * Remove contacts from an audience\n */\n async removeContacts(request: RemoveContactsFromAudienceRequest): Promise<RemoveContactsFromAudienceResponse> {\n const { id, contactIds } = request;\n return this.http.deleteWithBody<RemoveContactsFromAudienceResponse>(`/mail/audiences/${id}/contacts`, {\n contactIds,\n });\n }\n}\n","/**\n * Campaigns client for Stack0 Mail API\n */\n\nimport type { HttpClient } from \"../lib/http-client\";\nimport type {\n Campaign,\n CampaignStatsResponse,\n CancelCampaignResponse,\n CreateCampaignRequest,\n DeleteCampaignResponse,\n ListCampaignsRequest,\n ListCampaignsResponse,\n PauseCampaignResponse,\n SendCampaignRequest,\n SendCampaignResponse,\n UpdateCampaignRequest,\n} from \"./types\";\n\nexport class Campaigns {\n constructor(private http: HttpClient) {}\n\n /**\n * List all campaigns\n */\n async list(request: ListCampaignsRequest = {}): Promise<ListCampaignsResponse> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.search) params.set(\"search\", request.search);\n if (request.status) params.set(\"status\", request.status);\n\n const query = params.toString();\n return this.http.get<ListCampaignsResponse>(`/mail/campaigns${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Get a campaign by ID\n */\n async get(id: string): Promise<Campaign> {\n return this.http.get<Campaign>(`/mail/campaigns/${id}`);\n }\n\n /**\n * Create a new campaign\n */\n async create(request: CreateCampaignRequest): Promise<Campaign> {\n return this.http.post<Campaign>(\"/mail/campaigns\", request);\n }\n\n /**\n * Update a campaign\n */\n async update(request: UpdateCampaignRequest): Promise<Campaign> {\n const { id, ...data } = request;\n return this.http.put<Campaign>(`/mail/campaigns/${id}`, data);\n }\n\n /**\n * Delete a campaign\n */\n async delete(id: string): Promise<DeleteCampaignResponse> {\n return this.http.delete<DeleteCampaignResponse>(`/mail/campaigns/${id}`);\n }\n\n /**\n * Send a campaign\n */\n async send(request: SendCampaignRequest): Promise<SendCampaignResponse> {\n const { id, ...data } = request;\n return this.http.post<SendCampaignResponse>(`/mail/campaigns/${id}/send`, data);\n }\n\n /**\n * Pause a sending campaign\n */\n async pause(id: string): Promise<PauseCampaignResponse> {\n return this.http.post<PauseCampaignResponse>(`/mail/campaigns/${id}/pause`, {});\n }\n\n /**\n * Cancel a campaign\n */\n async cancel(id: string): Promise<CancelCampaignResponse> {\n return this.http.post<CancelCampaignResponse>(`/mail/campaigns/${id}/cancel`, {});\n }\n\n /**\n * Duplicate a campaign\n */\n async duplicate(id: string): Promise<Campaign> {\n return this.http.post<Campaign>(`/mail/campaigns/${id}/duplicate`, {});\n }\n\n /**\n * Get campaign statistics\n */\n async getStats(id: string): Promise<CampaignStatsResponse> {\n return this.http.get<CampaignStatsResponse>(`/mail/campaigns/${id}/stats`);\n }\n}\n","/**\n * Contacts client for Stack0 Mail API\n */\n\nimport type { HttpClient } from \"../lib/http-client\";\nimport type {\n MailContact,\n CreateContactRequest,\n DeleteContactResponse,\n ImportContactsRequest,\n ImportContactsResponse,\n ListContactsRequest,\n ListContactsResponse,\n UpdateContactRequest,\n} from \"./types\";\n\nexport class Contacts {\n constructor(private http: HttpClient) {}\n\n /**\n * List all contacts\n */\n async list(request: ListContactsRequest = {}): Promise<ListContactsResponse> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.search) params.set(\"search\", request.search);\n if (request.status) params.set(\"status\", request.status);\n\n const query = params.toString();\n return this.http.get<ListContactsResponse>(`/mail/contacts${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Get a contact by ID\n */\n async get(id: string): Promise<MailContact> {\n return this.http.get<MailContact>(`/mail/contacts/${id}`);\n }\n\n /**\n * Create a new contact\n */\n async create(request: CreateContactRequest): Promise<MailContact> {\n return this.http.post<MailContact>(\"/mail/contacts\", request);\n }\n\n /**\n * Update a contact\n */\n async update(request: UpdateContactRequest): Promise<MailContact> {\n const { id, ...data } = request;\n return this.http.put<MailContact>(`/mail/contacts/${id}`, data);\n }\n\n /**\n * Delete a contact\n */\n async delete(id: string): Promise<DeleteContactResponse> {\n return this.http.delete<DeleteContactResponse>(`/mail/contacts/${id}`);\n }\n\n /**\n * Import contacts in bulk\n */\n async import(request: ImportContactsRequest): Promise<ImportContactsResponse> {\n return this.http.post<ImportContactsResponse>(\"/mail/contacts/import\", request);\n }\n}\n","/**\n * Domains client for Stack0 Mail API\n */\n\nimport type { HttpClient } from \"../lib/http-client\";\nimport type {\n AddDomainRequest,\n AddDomainResponse,\n DeleteDomainResponse,\n Domain,\n GetDnsRecordsResponse,\n ListDomainsRequest,\n ListDomainsResponse,\n SetDefaultDomainResponse,\n VerifyDomainResponse,\n} from \"./types\";\n\nexport class Domains {\n constructor(private http: HttpClient) {}\n\n /**\n * List all domains for the organization\n */\n async list(request: ListDomainsRequest): Promise<ListDomainsResponse> {\n const params = new URLSearchParams();\n params.set(\"projectSlug\", request.projectSlug);\n if (request.environment) params.set(\"environment\", request.environment);\n\n return this.http.get<ListDomainsResponse>(`/mail/domains?${params.toString()}`);\n }\n\n /**\n * Add a new domain\n */\n async add(request: AddDomainRequest): Promise<AddDomainResponse> {\n return this.http.post<AddDomainResponse>(\"/mail/domains\", request);\n }\n\n /**\n * Get DNS records for a domain\n */\n async getDnsRecords(domainId: string): Promise<GetDnsRecordsResponse> {\n return this.http.get<GetDnsRecordsResponse>(`/mail/domains/${domainId}/dns`);\n }\n\n /**\n * Verify a domain\n */\n async verify(domainId: string): Promise<VerifyDomainResponse> {\n return this.http.post<VerifyDomainResponse>(`/mail/domains/${domainId}/verify`, {});\n }\n\n /**\n * Delete a domain\n */\n async delete(domainId: string): Promise<DeleteDomainResponse> {\n return this.http.delete<DeleteDomainResponse>(`/mail/domains/${domainId}`);\n }\n\n /**\n * Set a domain as the default\n */\n async setDefault(domainId: string): Promise<SetDefaultDomainResponse> {\n return this.http.post<SetDefaultDomainResponse>(`/mail/domains/${domainId}/default`, {});\n }\n}\n","/**\n * Events client for Stack0 Mail API\n */\n\nimport type { HttpClient } from \"../lib/http-client\";\nimport type {\n BatchTrackEventsRequest,\n BatchTrackEventsResponse,\n CreateEventRequest,\n DeleteEventResponse,\n EventAnalyticsResponse,\n ListEventOccurrencesRequest,\n ListEventOccurrencesResponse,\n ListEventsRequest,\n ListEventsResponse,\n MailEvent,\n TrackEventRequest,\n TrackEventResponse,\n UpdateEventRequest,\n} from \"./types\";\n\nexport class Events {\n constructor(private http: HttpClient) {}\n\n // ============================================================================\n // EVENT DEFINITIONS\n // ============================================================================\n\n /**\n * List all event definitions\n */\n async list(request: ListEventsRequest = {}): Promise<ListEventsResponse> {\n const params = new URLSearchParams();\n if (request.projectSlug) params.set(\"projectSlug\", request.projectSlug);\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.search) params.set(\"search\", request.search);\n\n const query = params.toString();\n return this.http.get<ListEventsResponse>(`/mail/events${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Get an event definition by ID\n */\n async get(id: string): Promise<MailEvent> {\n return this.http.get<MailEvent>(`/mail/events/${id}`);\n }\n\n /**\n * Create a new event definition\n */\n async create(request: CreateEventRequest): Promise<MailEvent> {\n return this.http.post<MailEvent>(\"/mail/events\", request);\n }\n\n /**\n * Update an event definition\n */\n async update(request: UpdateEventRequest): Promise<MailEvent> {\n const { id, ...data } = request;\n return this.http.put<MailEvent>(`/mail/events/${id}`, data);\n }\n\n /**\n * Delete an event definition\n */\n async delete(id: string): Promise<DeleteEventResponse> {\n return this.http.delete<DeleteEventResponse>(`/mail/events/${id}`);\n }\n\n // ============================================================================\n // EVENT TRACKING\n // ============================================================================\n\n /**\n * Track a single event\n * This can trigger email sequences configured to listen for this event\n */\n async track(request: TrackEventRequest): Promise<TrackEventResponse> {\n return this.http.post<TrackEventResponse>(\"/mail/events/track\", request);\n }\n\n /**\n * Track multiple events in a batch (max 100)\n */\n async trackBatch(request: BatchTrackEventsRequest): Promise<BatchTrackEventsResponse> {\n return this.http.post<BatchTrackEventsResponse>(\"/mail/events/track/batch\", request);\n }\n\n // ============================================================================\n // EVENT OCCURRENCES\n // ============================================================================\n\n /**\n * List event occurrences\n */\n async listOccurrences(request: ListEventOccurrencesRequest = {}): Promise<ListEventOccurrencesResponse> {\n const params = new URLSearchParams();\n if (request.eventId) params.set(\"eventId\", request.eventId);\n if (request.contactId) params.set(\"contactId\", request.contactId);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.startDate) {\n params.set(\"startDate\", request.startDate instanceof Date ? request.startDate.toISOString() : request.startDate);\n }\n if (request.endDate) {\n params.set(\"endDate\", request.endDate instanceof Date ? request.endDate.toISOString() : request.endDate);\n }\n\n const query = params.toString();\n return this.http.get<ListEventOccurrencesResponse>(`/mail/events/occurrences${query ? `?${query}` : \"\"}`);\n }\n\n // ============================================================================\n // ANALYTICS\n // ============================================================================\n\n /**\n * Get analytics for an event\n */\n async getAnalytics(id: string): Promise<EventAnalyticsResponse> {\n return this.http.get<EventAnalyticsResponse>(`/mail/events/analytics/${id}`);\n }\n}\n","/**\n * Sequences client for Stack0 Mail API\n */\n\nimport type { HttpClient } from \"../lib/http-client\";\nimport type {\n AddContactToSequenceRequest,\n ArchiveSequenceResponse,\n CreateConnectionRequest,\n CreateNodeRequest,\n CreateSequenceRequest,\n DeleteConnectionResponse,\n DeleteNodeResponse,\n DeleteSequenceResponse,\n ListSequenceEntriesRequest,\n ListSequenceEntriesResponse,\n ListSequencesRequest,\n ListSequencesResponse,\n PauseSequenceResponse,\n PublishSequenceResponse,\n RemoveContactFromSequenceRequest,\n RemoveContactFromSequenceResponse,\n ResumeSequenceResponse,\n Sequence,\n SequenceAnalyticsResponse,\n SequenceConnection,\n SequenceEntry,\n SequenceNode,\n SequenceWithNodes,\n SetNodeBranchRequest,\n SetNodeEmailRequest,\n SetNodeExperimentRequest,\n SetNodeFilterRequest,\n SetNodeTimerRequest,\n UpdateNodePositionRequest,\n UpdateNodeRequest,\n UpdateSequenceRequest,\n} from \"./types\";\n\nexport class Sequences {\n constructor(private http: HttpClient) {}\n\n // ============================================================================\n // SEQUENCE CRUD\n // ============================================================================\n\n /**\n * List all sequences\n */\n async list(request: ListSequencesRequest = {}): Promise<ListSequencesResponse> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.search) params.set(\"search\", request.search);\n if (request.status) params.set(\"status\", request.status);\n if (request.triggerType) params.set(\"triggerType\", request.triggerType);\n\n const query = params.toString();\n return this.http.get<ListSequencesResponse>(`/mail/sequences${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Get a sequence by ID with all nodes and connections\n */\n async get(id: string): Promise<SequenceWithNodes> {\n return this.http.get<SequenceWithNodes>(`/mail/sequences/${id}`);\n }\n\n /**\n * Create a new sequence\n */\n async create(request: CreateSequenceRequest): Promise<Sequence> {\n return this.http.post<Sequence>(\"/mail/sequences\", request);\n }\n\n /**\n * Update a sequence\n */\n async update(request: UpdateSequenceRequest): Promise<Sequence> {\n const { id, ...data } = request;\n return this.http.put<Sequence>(`/mail/sequences/${id}`, data);\n }\n\n /**\n * Delete a sequence\n */\n async delete(id: string): Promise<DeleteSequenceResponse> {\n return this.http.delete<DeleteSequenceResponse>(`/mail/sequences/${id}`);\n }\n\n // ============================================================================\n // SEQUENCE LIFECYCLE\n // ============================================================================\n\n /**\n * Publish (activate) a sequence\n */\n async publish(id: string): Promise<PublishSequenceResponse> {\n return this.http.post<PublishSequenceResponse>(`/mail/sequences/${id}/publish`, {});\n }\n\n /**\n * Pause an active sequence\n */\n async pause(id: string): Promise<PauseSequenceResponse> {\n return this.http.post<PauseSequenceResponse>(`/mail/sequences/${id}/pause`, {});\n }\n\n /**\n * Resume a paused sequence\n */\n async resume(id: string): Promise<ResumeSequenceResponse> {\n return this.http.post<ResumeSequenceResponse>(`/mail/sequences/${id}/resume`, {});\n }\n\n /**\n * Archive a sequence\n */\n async archive(id: string): Promise<ArchiveSequenceResponse> {\n return this.http.post<ArchiveSequenceResponse>(`/mail/sequences/${id}/archive`, {});\n }\n\n /**\n * Duplicate a sequence\n */\n async duplicate(id: string, name?: string): Promise<Sequence> {\n return this.http.post<Sequence>(`/mail/sequences/${id}/duplicate`, { name });\n }\n\n // ============================================================================\n // NODE MANAGEMENT\n // ============================================================================\n\n /**\n * Create a new node in a sequence\n */\n async createNode(request: CreateNodeRequest): Promise<SequenceNode> {\n const { id, ...data } = request;\n return this.http.post<SequenceNode>(`/mail/sequences/${id}/nodes`, data);\n }\n\n /**\n * Update a node\n */\n async updateNode(request: UpdateNodeRequest): Promise<SequenceNode> {\n const { id, nodeId, ...data } = request;\n return this.http.put<SequenceNode>(`/mail/sequences/${id}/nodes/${nodeId}`, data);\n }\n\n /**\n * Update node position (for visual editor)\n */\n async updateNodePosition(request: UpdateNodePositionRequest): Promise<SequenceNode> {\n const { id, nodeId, positionX, positionY } = request;\n return this.http.put<SequenceNode>(`/mail/sequences/${id}/nodes/${nodeId}/position`, { positionX, positionY });\n }\n\n /**\n * Delete a node\n */\n async deleteNode(sequenceId: string, nodeId: string): Promise<DeleteNodeResponse> {\n return this.http.delete<DeleteNodeResponse>(`/mail/sequences/${sequenceId}/nodes/${nodeId}`);\n }\n\n // ============================================================================\n // NODE CONFIGURATIONS\n // ============================================================================\n\n /**\n * Set email node content\n */\n async setNodeEmail(sequenceId: string, request: SetNodeEmailRequest): Promise<SequenceNode> {\n const { nodeId, ...data } = request;\n return this.http.put<SequenceNode>(`/mail/sequences/${sequenceId}/nodes/${nodeId}/email`, data);\n }\n\n /**\n * Set timer node configuration\n */\n async setNodeTimer(sequenceId: string, request: SetNodeTimerRequest): Promise<SequenceNode> {\n const { nodeId, ...data } = request;\n return this.http.put<SequenceNode>(`/mail/sequences/${sequenceId}/nodes/${nodeId}/timer`, data);\n }\n\n /**\n * Set filter node configuration\n */\n async setNodeFilter(sequenceId: string, request: SetNodeFilterRequest): Promise<SequenceNode> {\n const { nodeId, ...data } = request;\n return this.http.put<SequenceNode>(`/mail/sequences/${sequenceId}/nodes/${nodeId}/filter`, data);\n }\n\n /**\n * Set branch node configuration\n */\n async setNodeBranch(sequenceId: string, request: SetNodeBranchRequest): Promise<SequenceNode> {\n const { nodeId, ...data } = request;\n return this.http.put<SequenceNode>(`/mail/sequences/${sequenceId}/nodes/${nodeId}/branch`, data);\n }\n\n /**\n * Set experiment node configuration\n */\n async setNodeExperiment(sequenceId: string, request: SetNodeExperimentRequest): Promise<SequenceNode> {\n const { nodeId, ...data } = request;\n return this.http.put<SequenceNode>(`/mail/sequences/${sequenceId}/nodes/${nodeId}/experiment`, data);\n }\n\n // ============================================================================\n // CONNECTIONS\n // ============================================================================\n\n /**\n * Create a connection between nodes\n */\n async createConnection(request: CreateConnectionRequest): Promise<SequenceConnection> {\n const { id, ...data } = request;\n return this.http.post<SequenceConnection>(`/mail/sequences/${id}/connections`, data);\n }\n\n /**\n * Delete a connection\n */\n async deleteConnection(sequenceId: string, connectionId: string): Promise<DeleteConnectionResponse> {\n return this.http.delete<DeleteConnectionResponse>(`/mail/sequences/${sequenceId}/connections/${connectionId}`);\n }\n\n // ============================================================================\n // SEQUENCE ENTRIES (CONTACTS IN SEQUENCE)\n // ============================================================================\n\n /**\n * List contacts in a sequence\n */\n async listEntries(request: ListSequenceEntriesRequest): Promise<ListSequenceEntriesResponse> {\n const { id, ...params } = request;\n const searchParams = new URLSearchParams();\n if (params.limit) searchParams.set(\"limit\", params.limit.toString());\n if (params.offset) searchParams.set(\"offset\", params.offset.toString());\n if (params.status) searchParams.set(\"status\", params.status);\n\n const query = searchParams.toString();\n return this.http.get<ListSequenceEntriesResponse>(`/mail/sequences/${id}/entries${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Add a contact to a sequence\n */\n async addContact(request: AddContactToSequenceRequest): Promise<SequenceEntry> {\n const { id, contactId } = request;\n return this.http.post<SequenceEntry>(`/mail/sequences/${id}/add-contact`, { contactId });\n }\n\n /**\n * Remove a contact from a sequence\n */\n async removeContact(request: RemoveContactFromSequenceRequest): Promise<RemoveContactFromSequenceResponse> {\n const { id, entryId, reason } = request;\n return this.http.post<RemoveContactFromSequenceResponse>(`/mail/sequences/${id}/remove-contact`, {\n entryId,\n reason,\n });\n }\n\n // ============================================================================\n // ANALYTICS\n // ============================================================================\n\n /**\n * Get sequence analytics\n */\n async getAnalytics(id: string): Promise<SequenceAnalyticsResponse> {\n return this.http.get<SequenceAnalyticsResponse>(`/mail/sequences/${id}/analytics`);\n }\n}\n","/**\n * Templates client for Stack0 Mail API\n */\n\nimport type { HttpClient } from \"../lib/http-client\";\nimport type {\n CreateTemplateRequest,\n DeleteTemplateResponse,\n ListTemplatesRequest,\n ListTemplatesResponse,\n PreviewTemplateRequest,\n PreviewTemplateResponse,\n Template,\n UpdateTemplateRequest,\n} from \"./types\";\n\nexport class Templates {\n constructor(private http: HttpClient) {}\n\n /**\n * List all templates\n */\n async list(request: ListTemplatesRequest = {}): Promise<ListTemplatesResponse> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.isActive !== undefined) params.set(\"isActive\", request.isActive.toString());\n if (request.search) params.set(\"search\", request.search);\n\n const query = params.toString();\n return this.http.get<ListTemplatesResponse>(`/mail/templates${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Get a template by ID\n */\n async get(id: string): Promise<Template> {\n return this.http.get<Template>(`/mail/templates/${id}`);\n }\n\n /**\n * Get a template by slug\n */\n async getBySlug(slug: string): Promise<Template> {\n return this.http.get<Template>(`/mail/templates/slug/${slug}`);\n }\n\n /**\n * Create a new template\n */\n async create(request: CreateTemplateRequest): Promise<Template> {\n return this.http.post<Template>(\"/mail/templates\", request);\n }\n\n /**\n * Update a template\n */\n async update(request: UpdateTemplateRequest): Promise<Template> {\n const { id, ...data } = request;\n return this.http.put<Template>(`/mail/templates/${id}`, data);\n }\n\n /**\n * Delete a template\n */\n async delete(id: string): Promise<DeleteTemplateResponse> {\n return this.http.delete<DeleteTemplateResponse>(`/mail/templates/${id}`);\n }\n\n /**\n * Preview a template with variables\n */\n async preview(request: PreviewTemplateRequest): Promise<PreviewTemplateResponse> {\n const { id, variables } = request;\n return this.http.post<PreviewTemplateResponse>(`/mail/templates/${id}/preview`, { variables });\n }\n}\n","/**\n * Stack0 Mail Client\n * Complete email API with support for transactional emails, campaigns, sequences, and more\n */\n\nimport { HttpClient, type HttpClientConfig } from \"../lib/http-client\";\nimport { Audiences } from \"./audiences\";\nimport { Campaigns } from \"./campaigns\";\nimport { Contacts } from \"./contacts\";\nimport { Domains } from \"./domains\";\nimport { Events } from \"./events\";\nimport { Sequences } from \"./sequences\";\nimport { Templates } from \"./templates\";\nimport type {\n CancelEmailResponse,\n EmailAnalyticsResponse,\n GetEmailResponse,\n HourlyAnalyticsResponse,\n ListEmailsRequest,\n ListEmailsResponse,\n ListSendersRequest,\n ListSendersResponse,\n ResendEmailResponse,\n SendBatchEmailRequest,\n SendBatchEmailResponse,\n SendBroadcastEmailRequest,\n SendBroadcastEmailResponse,\n SendEmailRequest,\n SendEmailResponse,\n TimeSeriesAnalyticsRequest,\n TimeSeriesAnalyticsResponse,\n} from \"./types\";\n\nexport class Mail {\n private http: HttpClient;\n\n /** Manage sending domains */\n readonly domains: Domains;\n\n /** Manage email templates */\n readonly templates: Templates;\n\n /** Manage contact audiences/lists */\n readonly audiences: Audiences;\n\n /** Manage contacts */\n readonly contacts: Contacts;\n\n /** Manage email campaigns */\n readonly campaigns: Campaigns;\n\n /** Manage automated email sequences */\n readonly sequences: Sequences;\n\n /** Track and manage custom events */\n readonly events: Events;\n\n constructor(config: HttpClientConfig) {\n this.http = new HttpClient(config);\n\n // Initialize sub-clients\n this.domains = new Domains(this.http);\n this.templates = new Templates(this.http);\n this.audiences = new Audiences(this.http);\n this.contacts = new Contacts(this.http);\n this.campaigns = new Campaigns(this.http);\n this.sequences = new Sequences(this.http);\n this.events = new Events(this.http);\n }\n\n // ============================================================================\n // TRANSACTIONAL EMAILS\n // ============================================================================\n\n /**\n * Send a single email\n *\n * @example\n * ```typescript\n * const result = await mail.send({\n * from: 'noreply@example.com',\n * to: 'user@example.com',\n * subject: 'Hello World',\n * html: '<p>Welcome!</p>',\n * });\n * ```\n */\n async send(request: SendEmailRequest): Promise<SendEmailResponse> {\n return this.http.post<SendEmailResponse>(\"/mail/send\", request);\n }\n\n /**\n * Send multiple emails in a batch (up to 100)\n * Each email can have different content and recipients\n *\n * @example\n * ```typescript\n * const result = await mail.sendBatch({\n * emails: [\n * { from: 'noreply@example.com', to: 'user1@example.com', subject: 'Hello', html: '<p>Hi User 1</p>' },\n * { from: 'noreply@example.com', to: 'user2@example.com', subject: 'Hello', html: '<p>Hi User 2</p>' },\n * ]\n * });\n * ```\n */\n async sendBatch(request: SendBatchEmailRequest): Promise<SendBatchEmailResponse> {\n return this.http.post<SendBatchEmailResponse>(\"/mail/send/batch\", request);\n }\n\n /**\n * Send a broadcast email (same content to multiple recipients, up to 1000)\n *\n * @example\n * ```typescript\n * const result = await mail.sendBroadcast({\n * from: 'noreply@example.com',\n * to: ['user1@example.com', 'user2@example.com', 'user3@example.com'],\n * subject: 'Newsletter',\n * html: '<p>Our latest updates...</p>',\n * });\n * ```\n */\n async sendBroadcast(request: SendBroadcastEmailRequest): Promise<SendBroadcastEmailResponse> {\n return this.http.post<SendBroadcastEmailResponse>(\"/mail/send/broadcast\", request);\n }\n\n /**\n * Get email details by ID\n *\n * @example\n * ```typescript\n * const email = await mail.get('email-id');\n * console.log(email.status); // 'delivered'\n * ```\n */\n async get(id: string): Promise<GetEmailResponse> {\n return this.http.get<GetEmailResponse>(`/mail/${id}`);\n }\n\n /**\n * List emails with optional filters\n *\n * @example\n * ```typescript\n * const result = await mail.list({\n * status: 'delivered',\n * limit: 50,\n * });\n * ```\n */\n async list(request: ListEmailsRequest = {}): Promise<ListEmailsResponse> {\n const params = new URLSearchParams();\n if (request.projectSlug) params.set(\"projectSlug\", request.projectSlug);\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.status) params.set(\"status\", request.status);\n if (request.from) params.set(\"from\", request.from);\n if (request.to) params.set(\"to\", request.to);\n if (request.subject) params.set(\"subject\", request.subject);\n if (request.tag) params.set(\"tag\", request.tag);\n if (request.startDate) {\n params.set(\"startDate\", request.startDate instanceof Date ? request.startDate.toISOString() : request.startDate);\n }\n if (request.endDate) {\n params.set(\"endDate\", request.endDate instanceof Date ? request.endDate.toISOString() : request.endDate);\n }\n if (request.sortBy) params.set(\"sortBy\", request.sortBy);\n if (request.sortOrder) params.set(\"sortOrder\", request.sortOrder);\n\n const query = params.toString();\n return this.http.get<ListEmailsResponse>(`/mail${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Resend a previously sent email\n */\n async resend(id: string): Promise<ResendEmailResponse> {\n return this.http.post<ResendEmailResponse>(`/mail/${id}/resend`, {});\n }\n\n /**\n * Cancel a scheduled email\n */\n async cancel(id: string): Promise<CancelEmailResponse> {\n return this.http.post<CancelEmailResponse>(`/mail/${id}/cancel`, {});\n }\n\n // ============================================================================\n // ANALYTICS\n // ============================================================================\n\n /**\n * Get overall email analytics\n */\n async getAnalytics(): Promise<EmailAnalyticsResponse> {\n return this.http.get<EmailAnalyticsResponse>(\"/mail/analytics\");\n }\n\n /**\n * Get time series analytics (daily breakdown)\n */\n async getTimeSeriesAnalytics(request: TimeSeriesAnalyticsRequest = {}): Promise<TimeSeriesAnalyticsResponse> {\n const params = new URLSearchParams();\n if (request.days) params.set(\"days\", request.days.toString());\n\n const query = params.toString();\n return this.http.get<TimeSeriesAnalyticsResponse>(`/mail/analytics/timeseries${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Get hourly analytics\n */\n async getHourlyAnalytics(): Promise<HourlyAnalyticsResponse> {\n return this.http.get<HourlyAnalyticsResponse>(\"/mail/analytics/hourly\");\n }\n\n /**\n * List unique senders with their statistics\n */\n async listSenders(request: ListSendersRequest = {}): Promise<ListSendersResponse> {\n const params = new URLSearchParams();\n if (request.projectSlug) params.set(\"projectSlug\", request.projectSlug);\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.search) params.set(\"search\", request.search);\n\n const query = params.toString();\n return this.http.get<ListSendersResponse>(`/mail/senders${query ? `?${query}` : \"\"}`);\n }\n}\n","/**\n * Stack0 CDN Client\n * Upload, manage, and transform assets\n */\n\nimport { HttpClient, type HttpClientConfig } from \"../lib/http-client\";\nimport type {\n Asset,\n UploadUrlRequest,\n UploadUrlResponse,\n UpdateAssetRequest,\n DeleteAssetsResponse,\n ListAssetsRequest,\n ListAssetsResponse,\n MoveAssetsRequest,\n MoveAssetsResponse,\n TransformOptions,\n GetFolderTreeRequest,\n FolderTreeNode,\n CreateFolderRequest,\n Folder,\n TranscodeVideoRequest,\n TranscodeJob,\n ListJobsRequest,\n ListJobsResponse,\n StreamingUrls,\n ThumbnailRequest,\n ThumbnailResponse,\n RegenerateThumbnailRequest,\n RegenerateThumbnailResponse,\n ExtractAudioRequest,\n ExtractAudioResponse,\n // Private Files\n PrivateFile,\n PrivateUploadUrlRequest,\n PrivateUploadUrlResponse,\n PrivateDownloadUrlRequest,\n PrivateDownloadUrlResponse,\n ListPrivateFilesRequest,\n ListPrivateFilesResponse,\n UpdatePrivateFileRequest,\n MovePrivateFilesRequest,\n MovePrivateFilesResponse,\n // Bundles\n DownloadBundle,\n CreateBundleRequest,\n CreateBundleResponse,\n ListBundlesRequest,\n ListBundlesResponse,\n BundleDownloadUrlRequest,\n BundleDownloadUrlResponse,\n // Usage\n CdnUsageRequest,\n CdnUsageResponse,\n CdnUsageHistoryRequest,\n CdnUsageHistoryResponse,\n CdnUsageDataPoint,\n CdnStorageBreakdownRequest,\n CdnStorageBreakdownResponse,\n // Additional Folder Types\n UpdateFolderRequest,\n ListFoldersRequest,\n ListFoldersResponse,\n FolderListItem,\n MoveFolderRequest,\n MoveFolderResponse,\n // Additional Video Types\n VideoThumbnail,\n ListThumbnailsResponse,\n // Video Merge Types\n CreateMergeJobRequest,\n MergeJob,\n MergeJobWithOutput,\n ListMergeJobsRequest,\n ListMergeJobsResponse,\n} from \"./types\";\n\n// Allowed widths that match the CloudFront url-rewriter configuration\nconst ALLOWED_WIDTHS = [256, 384, 640, 750, 828, 1080, 1200, 1920, 2048, 3840];\n\nexport class CDN {\n private http: HttpClient;\n private cdnUrl?: string;\n\n constructor(config: HttpClientConfig, cdnUrl?: string) {\n this.http = new HttpClient(config);\n this.cdnUrl = cdnUrl;\n }\n\n /**\n * Generate a presigned URL for uploading a file\n *\n * @example\n * ```typescript\n * const { uploadUrl, assetId } = await cdn.getUploadUrl({\n * projectSlug: 'my-project',\n * filename: 'image.jpg',\n * mimeType: 'image/jpeg',\n * size: 1024 * 1024,\n * });\n *\n * // Upload file to the presigned URL\n * await fetch(uploadUrl, {\n * method: 'PUT',\n * body: file,\n * headers: { 'Content-Type': 'image/jpeg' },\n * });\n *\n * // Confirm the upload\n * const asset = await cdn.confirmUpload(assetId);\n * ```\n */\n async getUploadUrl(request: UploadUrlRequest): Promise<UploadUrlResponse> {\n const response = await this.http.post<UploadUrlResponse>(\"/cdn/upload\", request);\n\n if (typeof response.expiresAt === \"string\") {\n response.expiresAt = new Date(response.expiresAt);\n }\n\n return response;\n }\n\n /**\n * Confirm that an upload has completed\n */\n async confirmUpload(assetId: string): Promise<Asset> {\n const response = await this.http.post<Asset>(`/cdn/upload/${assetId}/confirm`, {});\n return this.convertAssetDates(response);\n }\n\n /**\n * Upload a file directly (handles presigned URL flow automatically)\n *\n * @example\n * ```typescript\n * const asset = await cdn.upload({\n * projectSlug: 'my-project',\n * file: fileBuffer,\n * filename: 'image.jpg',\n * mimeType: 'image/jpeg',\n * });\n * ```\n */\n async upload(options: {\n projectSlug: string;\n file: Blob | Buffer | ArrayBuffer;\n filename: string;\n mimeType: string;\n folder?: string;\n metadata?: Record<string, unknown>;\n }): Promise<Asset> {\n const { projectSlug, file, filename, mimeType, folder, metadata } = options;\n\n // Get file size\n let size: number;\n if (file instanceof Blob) {\n size = file.size;\n } else if (file instanceof ArrayBuffer) {\n size = file.byteLength;\n } else {\n // Buffer\n size = (file as Buffer).length;\n }\n\n // Get presigned URL\n const { uploadUrl, assetId } = await this.getUploadUrl({\n projectSlug,\n filename,\n mimeType,\n size,\n folder,\n metadata,\n });\n\n // Upload file\n const uploadResponse = await fetch(uploadUrl, {\n method: \"PUT\",\n body: file,\n headers: {\n \"Content-Type\": mimeType,\n },\n });\n\n if (!uploadResponse.ok) {\n throw new Error(`Upload failed: ${uploadResponse.statusText}`);\n }\n\n // Confirm upload\n return this.confirmUpload(assetId);\n }\n\n /**\n * Get an asset by ID\n *\n * @example\n * ```typescript\n * const asset = await cdn.get('asset-id');\n * console.log(asset.cdnUrl);\n * ```\n */\n async get(id: string): Promise<Asset> {\n const response = await this.http.get<Asset>(`/cdn/assets/${id}`);\n return this.convertAssetDates(response);\n }\n\n /**\n * Update asset metadata\n *\n * @example\n * ```typescript\n * const asset = await cdn.update({\n * id: 'asset-id',\n * alt: 'A beautiful sunset',\n * tags: ['nature', 'sunset'],\n * });\n * ```\n */\n async update(request: UpdateAssetRequest): Promise<Asset> {\n const { id, ...data } = request;\n const response = await this.http.patch<Asset>(`/cdn/assets/${id}`, data);\n return this.convertAssetDates(response);\n }\n\n /**\n * Delete an asset\n *\n * @example\n * ```typescript\n * await cdn.delete('asset-id');\n * ```\n */\n async delete(id: string): Promise<{ success: boolean }> {\n // NOTE: Our OpenAPI adapter parses JSON bodies for non-GET methods.\n // Some Fastify setups will throw if Content-Type is JSON but the body is empty.\n // Sending the id in the body keeps this endpoint compatible across adapters.\n return this.http.deleteWithBody<{ success: boolean }>(`/cdn/assets/${id}`, { id });\n }\n\n /**\n * Delete multiple assets\n *\n * @example\n * ```typescript\n * const result = await cdn.deleteMany(['asset-1', 'asset-2']);\n * console.log(`Deleted ${result.deletedCount} assets`);\n * ```\n */\n async deleteMany(ids: string[]): Promise<DeleteAssetsResponse> {\n return this.http.post<DeleteAssetsResponse>(\"/cdn/assets/delete\", { ids });\n }\n\n /**\n * List assets with filters and pagination\n *\n * @example\n * ```typescript\n * const { assets, total, hasMore } = await cdn.list({\n * projectSlug: 'my-project',\n * type: 'image',\n * limit: 20,\n * });\n * ```\n */\n async list(request: ListAssetsRequest): Promise<ListAssetsResponse> {\n const params = new URLSearchParams();\n\n params.set(\"projectSlug\", request.projectSlug);\n if (request.folder !== undefined) params.set(\"folder\", request.folder ?? \"\");\n if (request.type) params.set(\"type\", request.type);\n if (request.status) params.set(\"status\", request.status);\n if (request.search) params.set(\"search\", request.search);\n if (request.tags) params.set(\"tags\", request.tags.join(\",\"));\n if (request.sortBy) params.set(\"sortBy\", request.sortBy);\n if (request.sortOrder) params.set(\"sortOrder\", request.sortOrder);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n\n const response = await this.http.get<ListAssetsResponse>(`/cdn/assets?${params.toString()}`);\n\n return {\n ...response,\n assets: response.assets.map((asset) => this.convertAssetDates(asset)),\n };\n }\n\n /**\n * Move assets to a different folder\n *\n * @example\n * ```typescript\n * await cdn.move({\n * assetIds: ['asset-1', 'asset-2'],\n * folder: '/images/archive',\n * });\n * ```\n */\n async move(request: MoveAssetsRequest): Promise<MoveAssetsResponse> {\n return this.http.post<MoveAssetsResponse>(\"/cdn/assets/move\", request);\n }\n\n /**\n * Get a transformed image URL (client-side, no API call)\n *\n * @example\n * ```typescript\n * // Using asset's cdnUrl directly\n * const url = cdn.getTransformUrl(asset.cdnUrl, {\n * width: 800,\n * height: 600,\n * fit: 'cover',\n * format: 'webp',\n * quality: 80,\n * });\n *\n * // Or using cdnUrl from SDK config + s3Key\n * const url = cdn.getTransformUrl(asset.s3Key, { width: 400 });\n * ```\n */\n getTransformUrl(assetUrlOrS3Key: string, options: TransformOptions): string {\n // Determine base URL\n let baseUrl: string;\n if (assetUrlOrS3Key.startsWith(\"http://\") || assetUrlOrS3Key.startsWith(\"https://\")) {\n // It's already a full URL - extract base and path\n const url = new URL(assetUrlOrS3Key);\n baseUrl = `${url.protocol}//${url.host}${url.pathname}`;\n } else if (this.cdnUrl) {\n // It's an s3Key, use configured CDN URL\n const cdnBase = this.cdnUrl.endsWith(\"/\") ? this.cdnUrl.slice(0, -1) : this.cdnUrl;\n baseUrl = `${cdnBase}/${assetUrlOrS3Key}`;\n } else {\n throw new Error(\"getTransformUrl requires either a full URL or cdnUrl to be configured in Stack0 options\");\n }\n\n // Build query string\n const params = this.buildTransformQuery(options);\n if (!params) {\n return baseUrl;\n }\n return `${baseUrl}?${params}`;\n }\n\n /**\n * Build transform query parameters\n */\n private buildTransformQuery(options: TransformOptions): string {\n const params = new URLSearchParams();\n\n if (options.format) params.set(\"f\", options.format);\n if (options.quality !== undefined) params.set(\"q\", options.quality.toString());\n\n if (options.width !== undefined) {\n // Snap to nearest allowed width for better caching\n const width = this.getNearestWidth(options.width);\n params.set(\"w\", width.toString());\n }\n if (options.height !== undefined) params.set(\"h\", options.height.toString());\n if (options.fit) params.set(\"fit\", options.fit);\n if (options.crop) params.set(\"crop\", options.crop);\n if (options.cropX !== undefined) params.set(\"crop-x\", options.cropX.toString());\n if (options.cropY !== undefined) params.set(\"crop-y\", options.cropY.toString());\n if (options.cropWidth !== undefined) params.set(\"crop-w\", options.cropWidth.toString());\n if (options.cropHeight !== undefined) params.set(\"crop-h\", options.cropHeight.toString());\n if (options.blur !== undefined) params.set(\"blur\", options.blur.toString());\n if (options.sharpen !== undefined) params.set(\"sharpen\", options.sharpen.toString());\n if (options.brightness !== undefined) params.set(\"brightness\", options.brightness.toString());\n if (options.saturation !== undefined) params.set(\"saturation\", options.saturation.toString());\n if (options.grayscale) params.set(\"grayscale\", \"true\");\n if (options.rotate !== undefined) params.set(\"rotate\", options.rotate.toString());\n if (options.flip) params.set(\"flip\", \"y\");\n if (options.flop) params.set(\"flop\", \"x\");\n\n return params.toString();\n }\n\n /**\n * Find the nearest allowed width for optimal caching\n */\n private getNearestWidth(width: number): number {\n return ALLOWED_WIDTHS.reduce((prev, curr) => (Math.abs(curr - width) < Math.abs(prev - width) ? curr : prev));\n }\n\n /**\n * Get folder tree for navigation\n *\n * @example\n * ```typescript\n * const tree = await cdn.getFolderTree({\n * projectSlug: 'my-project',\n * maxDepth: 3,\n * });\n * ```\n */\n async getFolderTree(request: GetFolderTreeRequest): Promise<FolderTreeNode[]> {\n const params = new URLSearchParams();\n params.set(\"projectSlug\", request.projectSlug);\n if (request.maxDepth) params.set(\"maxDepth\", request.maxDepth.toString());\n\n const response = await this.http.get<{ tree: FolderTreeNode[] }>(`/cdn/folders/tree?${params.toString()}`);\n return response.tree;\n }\n\n /**\n * Create a new folder\n *\n * @example\n * ```typescript\n * const folder = await cdn.createFolder({\n * projectSlug: 'my-project',\n * name: 'images',\n * });\n * ```\n */\n async createFolder(request: CreateFolderRequest): Promise<Folder> {\n const response = await this.http.post<Folder>(\"/cdn/folders\", request);\n return this.convertFolderDates(response);\n }\n\n /**\n * Delete a folder\n *\n * @example\n * ```typescript\n * await cdn.deleteFolder('folder-id');\n * ```\n */\n async deleteFolder(id: string, deleteContents = false): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (deleteContents) params.set(\"deleteContents\", \"true\");\n\n return this.http.deleteWithBody<{ success: boolean }>(`/cdn/folders/${id}?${params.toString()}`, {\n id,\n deleteContents,\n });\n }\n\n private convertAssetDates(asset: Asset): Asset {\n if (typeof asset.createdAt === \"string\") {\n asset.createdAt = new Date(asset.createdAt);\n }\n if (asset.updatedAt && typeof asset.updatedAt === \"string\") {\n asset.updatedAt = new Date(asset.updatedAt);\n }\n return asset;\n }\n\n private convertFolderDates(folder: Folder): Folder {\n if (typeof folder.createdAt === \"string\") {\n folder.createdAt = new Date(folder.createdAt);\n }\n if (folder.updatedAt && typeof folder.updatedAt === \"string\") {\n folder.updatedAt = new Date(folder.updatedAt);\n }\n return folder;\n }\n\n // ============================================================================\n // Video Transcoding Methods\n // ============================================================================\n\n /**\n * Start a video transcoding job\n *\n * @example\n * ```typescript\n * const job = await cdn.transcode({\n * projectSlug: 'my-project',\n * assetId: 'video-asset-id',\n * outputFormat: 'hls',\n * variants: [\n * { quality: '720p', codec: 'h264' },\n * { quality: '1080p', codec: 'h264' },\n * ],\n * webhookUrl: 'https://your-app.com/webhook',\n * });\n * console.log(`Job started: ${job.id}`);\n * ```\n */\n async transcode(request: TranscodeVideoRequest): Promise<TranscodeJob> {\n const response = await this.http.post<TranscodeJob>(\"/cdn/video/transcode\", request);\n return this.convertJobDates(response);\n }\n\n /**\n * Get a transcoding job by ID\n *\n * @example\n * ```typescript\n * const job = await cdn.getJob('job-id');\n * console.log(`Status: ${job.status}, Progress: ${job.progress}%`);\n * ```\n */\n async getJob(jobId: string): Promise<TranscodeJob> {\n const response = await this.http.get<TranscodeJob>(`/cdn/video/jobs/${jobId}`);\n return this.convertJobDates(response);\n }\n\n /**\n * List transcoding jobs with filters\n *\n * @example\n * ```typescript\n * const { jobs, total } = await cdn.listJobs({\n * projectSlug: 'my-project',\n * status: 'processing',\n * limit: 20,\n * });\n * ```\n */\n async listJobs(request: ListJobsRequest): Promise<ListJobsResponse> {\n const params = new URLSearchParams();\n params.set(\"projectSlug\", request.projectSlug);\n if (request.assetId) params.set(\"assetId\", request.assetId);\n if (request.status) params.set(\"status\", request.status);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n\n const response = await this.http.get<ListJobsResponse>(`/cdn/video/jobs?${params.toString()}`);\n return {\n ...response,\n jobs: response.jobs.map((job) => this.convertJobDates(job)),\n };\n }\n\n /**\n * Cancel a pending or processing transcoding job\n *\n * @example\n * ```typescript\n * await cdn.cancelJob('job-id');\n * ```\n */\n async cancelJob(jobId: string): Promise<{ success: boolean }> {\n return this.http.post<{ success: boolean }>(`/cdn/video/jobs/${jobId}/cancel`, {});\n }\n\n /**\n * Get streaming URLs for a transcoded video\n *\n * @example\n * ```typescript\n * const urls = await cdn.getStreamingUrls('asset-id');\n * console.log(`HLS URL: ${urls.hlsUrl}`);\n * console.log(`MP4 720p: ${urls.mp4Urls.find(u => u.quality === '720p')?.url}`);\n * ```\n */\n async getStreamingUrls(assetId: string): Promise<StreamingUrls> {\n return this.http.get<StreamingUrls>(`/cdn/video/stream/${assetId}`);\n }\n\n /**\n * Generate a thumbnail from a video at a specific timestamp\n *\n * @example\n * ```typescript\n * const thumbnail = await cdn.getThumbnail({\n * assetId: 'video-asset-id',\n * timestamp: 10.5, // 10.5 seconds into the video\n * width: 320,\n * format: 'webp',\n * });\n * console.log(`Thumbnail URL: ${thumbnail.url}`);\n * ```\n */\n async getThumbnail(request: ThumbnailRequest): Promise<ThumbnailResponse> {\n const params = new URLSearchParams();\n params.set(\"timestamp\", request.timestamp.toString());\n if (request.width) params.set(\"width\", request.width.toString());\n if (request.format) params.set(\"format\", request.format);\n\n return this.http.get<ThumbnailResponse>(`/cdn/video/thumbnail/${request.assetId}?${params.toString()}`);\n }\n\n /**\n * Regenerate a thumbnail for a video (force regeneration even if one exists)\n *\n * Useful for retrying failed thumbnail generation or regenerating with different settings.\n *\n * @example\n * ```typescript\n * const result = await cdn.regenerateThumbnail({\n * assetId: 'video-asset-id',\n * timestamp: 5, // 5 seconds into the video\n * width: 1280,\n * format: 'jpg',\n * });\n * console.log(`Thumbnail regeneration queued: ${result.status}`);\n * ```\n */\n async regenerateThumbnail(request: RegenerateThumbnailRequest): Promise<RegenerateThumbnailResponse> {\n return this.http.post<RegenerateThumbnailResponse>(\"/cdn/video/thumbnail/regenerate\", request);\n }\n\n /**\n * Extract audio from a video file\n *\n * @example\n * ```typescript\n * const { jobId } = await cdn.extractAudio({\n * projectSlug: 'my-project',\n * assetId: 'video-asset-id',\n * format: 'mp3',\n * bitrate: 192,\n * });\n * ```\n */\n async extractAudio(request: ExtractAudioRequest): Promise<ExtractAudioResponse> {\n return this.http.post<ExtractAudioResponse>(\"/cdn/video/extract-audio\", request);\n }\n\n private convertJobDates(job: TranscodeJob): TranscodeJob {\n if (typeof job.createdAt === \"string\") {\n job.createdAt = new Date(job.createdAt);\n }\n if (job.startedAt && typeof job.startedAt === \"string\") {\n job.startedAt = new Date(job.startedAt);\n }\n if (job.completedAt && typeof job.completedAt === \"string\") {\n job.completedAt = new Date(job.completedAt);\n }\n return job;\n }\n\n // ============================================================================\n // Private Files Methods\n // ============================================================================\n\n /**\n * Generate a presigned URL for uploading a private file\n *\n * Private files are stored securely and can only be accessed through\n * authorized download links with configurable expiration.\n *\n * @example\n * ```typescript\n * const { uploadUrl, fileId } = await cdn.getPrivateUploadUrl({\n * projectSlug: 'my-project',\n * filename: 'confidential.pdf',\n * mimeType: 'application/pdf',\n * size: 1024 * 1024,\n * });\n *\n * // Upload file to the presigned URL\n * await fetch(uploadUrl, {\n * method: 'PUT',\n * body: file,\n * headers: { 'Content-Type': 'application/pdf' },\n * });\n *\n * // Confirm the upload\n * const privateFile = await cdn.confirmPrivateUpload(fileId);\n * ```\n */\n async getPrivateUploadUrl(request: PrivateUploadUrlRequest): Promise<PrivateUploadUrlResponse> {\n const response = await this.http.post<PrivateUploadUrlResponse>(\"/cdn/private/upload\", request);\n\n if (typeof response.expiresAt === \"string\") {\n response.expiresAt = new Date(response.expiresAt);\n }\n\n return response;\n }\n\n /**\n * Confirm that a private file upload has completed\n */\n async confirmPrivateUpload(fileId: string): Promise<PrivateFile> {\n const response = await this.http.post<PrivateFile>(`/cdn/private/upload/${fileId}/confirm`, {});\n return this.convertPrivateFileDates(response);\n }\n\n /**\n * Upload a private file directly (handles presigned URL flow automatically)\n *\n * @example\n * ```typescript\n * const privateFile = await cdn.uploadPrivate({\n * projectSlug: 'my-project',\n * file: fileBuffer,\n * filename: 'confidential.pdf',\n * mimeType: 'application/pdf',\n * });\n * ```\n */\n async uploadPrivate(options: {\n projectSlug: string;\n file: Blob | Buffer | ArrayBuffer;\n filename: string;\n mimeType: string;\n folder?: string;\n description?: string;\n metadata?: Record<string, unknown>;\n }): Promise<PrivateFile> {\n const { projectSlug, file, filename, mimeType, folder, description, metadata } = options;\n\n // Get file size\n let size: number;\n if (file instanceof Blob) {\n size = file.size;\n } else if (file instanceof ArrayBuffer) {\n size = file.byteLength;\n } else {\n size = (file as Buffer).length;\n }\n\n // Get presigned URL\n const { uploadUrl, fileId } = await this.getPrivateUploadUrl({\n projectSlug,\n filename,\n mimeType,\n size,\n folder,\n description,\n metadata,\n });\n\n // Upload file\n const uploadResponse = await fetch(uploadUrl, {\n method: \"PUT\",\n body: file,\n headers: {\n \"Content-Type\": mimeType,\n },\n });\n\n if (!uploadResponse.ok) {\n throw new Error(`Upload failed: ${uploadResponse.statusText}`);\n }\n\n // Confirm upload\n return this.confirmPrivateUpload(fileId);\n }\n\n /**\n * Generate a presigned download URL for a private file\n *\n * @example\n * ```typescript\n * const { downloadUrl, expiresAt } = await cdn.getPrivateDownloadUrl({\n * fileId: 'file-id',\n * expiresIn: 86400, // 24 hours\n * });\n * ```\n */\n async getPrivateDownloadUrl(request: PrivateDownloadUrlRequest): Promise<PrivateDownloadUrlResponse> {\n const response = await this.http.post<PrivateDownloadUrlResponse>(\n `/cdn/private/${request.fileId}/download`,\n { expiresIn: request.expiresIn },\n );\n\n if (typeof response.expiresAt === \"string\") {\n response.expiresAt = new Date(response.expiresAt);\n }\n\n return response;\n }\n\n /**\n * Get a private file by ID\n */\n async getPrivateFile(fileId: string): Promise<PrivateFile> {\n const response = await this.http.get<PrivateFile>(`/cdn/private/${fileId}`);\n return this.convertPrivateFileDates(response);\n }\n\n /**\n * Update a private file's metadata\n */\n async updatePrivateFile(request: UpdatePrivateFileRequest): Promise<PrivateFile> {\n const { fileId, ...data } = request;\n const response = await this.http.patch<PrivateFile>(`/cdn/private/${fileId}`, data);\n return this.convertPrivateFileDates(response);\n }\n\n /**\n * Delete a private file\n */\n async deletePrivateFile(fileId: string): Promise<{ success: boolean }> {\n return this.http.deleteWithBody<{ success: boolean }>(`/cdn/private/${fileId}`, { fileId });\n }\n\n /**\n * Delete multiple private files\n */\n async deletePrivateFiles(fileIds: string[]): Promise<{ success: boolean; deletedCount: number }> {\n return this.http.post<{ success: boolean; deletedCount: number }>(\"/cdn/private/delete\", { fileIds });\n }\n\n /**\n * List private files with filters and pagination\n *\n * @example\n * ```typescript\n * const { files, total, hasMore } = await cdn.listPrivateFiles({\n * projectSlug: 'my-project',\n * limit: 20,\n * });\n * ```\n */\n async listPrivateFiles(request: ListPrivateFilesRequest): Promise<ListPrivateFilesResponse> {\n const params = new URLSearchParams();\n\n params.set(\"projectSlug\", request.projectSlug);\n if (request.folder !== undefined) params.set(\"folder\", request.folder ?? \"\");\n if (request.status) params.set(\"status\", request.status);\n if (request.search) params.set(\"search\", request.search);\n if (request.sortBy) params.set(\"sortBy\", request.sortBy);\n if (request.sortOrder) params.set(\"sortOrder\", request.sortOrder);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n\n const response = await this.http.get<ListPrivateFilesResponse>(`/cdn/private?${params.toString()}`);\n\n return {\n ...response,\n files: response.files.map((file) => this.convertPrivateFileDates(file)),\n };\n }\n\n private convertPrivateFileDates(file: PrivateFile): PrivateFile {\n if (typeof file.createdAt === \"string\") {\n file.createdAt = new Date(file.createdAt);\n }\n if (file.updatedAt && typeof file.updatedAt === \"string\") {\n file.updatedAt = new Date(file.updatedAt);\n }\n return file;\n }\n\n // ============================================================================\n // Download Bundle Methods\n // ============================================================================\n\n /**\n * Create a download bundle from assets and/or private files\n *\n * The bundle will be created asynchronously. Check the status using getBundle().\n *\n * @example\n * ```typescript\n * const { bundle } = await cdn.createBundle({\n * projectSlug: 'my-project',\n * name: 'Project Assets - Dec 2024',\n * assetIds: ['asset-1', 'asset-2'],\n * privateFileIds: ['file-1', 'file-2'],\n * expiresIn: 86400, // 24 hours\n * });\n * console.log(`Bundle ${bundle.id} status: ${bundle.status}`);\n * ```\n */\n async createBundle(request: CreateBundleRequest): Promise<CreateBundleResponse> {\n const response = await this.http.post<CreateBundleResponse>(\"/cdn/bundles\", request);\n return {\n bundle: this.convertBundleDates(response.bundle),\n };\n }\n\n /**\n * Get a download bundle by ID\n */\n async getBundle(bundleId: string): Promise<DownloadBundle> {\n const response = await this.http.get<DownloadBundle>(`/cdn/bundles/${bundleId}`);\n return this.convertBundleDates(response);\n }\n\n /**\n * List download bundles with filters and pagination\n *\n * @example\n * ```typescript\n * const { bundles, total } = await cdn.listBundles({\n * projectSlug: 'my-project',\n * status: 'ready',\n * });\n * ```\n */\n async listBundles(request: ListBundlesRequest): Promise<ListBundlesResponse> {\n const params = new URLSearchParams();\n\n params.set(\"projectSlug\", request.projectSlug);\n if (request.status) params.set(\"status\", request.status);\n if (request.search) params.set(\"search\", request.search);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n\n const response = await this.http.get<ListBundlesResponse>(`/cdn/bundles?${params.toString()}`);\n\n return {\n ...response,\n bundles: response.bundles.map((bundle) => this.convertBundleDates(bundle)),\n };\n }\n\n /**\n * Generate a presigned download URL for a bundle\n *\n * @example\n * ```typescript\n * const { downloadUrl, expiresAt } = await cdn.getBundleDownloadUrl({\n * bundleId: 'bundle-id',\n * expiresIn: 3600, // 1 hour\n * });\n * ```\n */\n async getBundleDownloadUrl(request: BundleDownloadUrlRequest): Promise<BundleDownloadUrlResponse> {\n const response = await this.http.post<BundleDownloadUrlResponse>(\n `/cdn/bundles/${request.bundleId}/download`,\n { expiresIn: request.expiresIn },\n );\n\n if (typeof response.expiresAt === \"string\") {\n response.expiresAt = new Date(response.expiresAt);\n }\n\n return response;\n }\n\n /**\n * Delete a download bundle\n */\n async deleteBundle(bundleId: string): Promise<{ success: boolean }> {\n return this.http.deleteWithBody<{ success: boolean }>(`/cdn/bundles/${bundleId}`, { bundleId });\n }\n\n private convertBundleDates(bundle: DownloadBundle): DownloadBundle {\n if (typeof bundle.createdAt === \"string\") {\n bundle.createdAt = new Date(bundle.createdAt);\n }\n if (bundle.completedAt && typeof bundle.completedAt === \"string\") {\n bundle.completedAt = new Date(bundle.completedAt);\n }\n if (bundle.expiresAt && typeof bundle.expiresAt === \"string\") {\n bundle.expiresAt = new Date(bundle.expiresAt);\n }\n return bundle;\n }\n\n // ============================================================================\n // Usage Methods\n // ============================================================================\n\n /**\n * Get current usage stats for the billing period\n *\n * @example\n * ```typescript\n * const usage = await cdn.getUsage({\n * projectSlug: 'my-project',\n * });\n * console.log(`Bandwidth: ${usage.bandwidthFormatted}`);\n * console.log(`Estimated cost: ${usage.estimatedCostFormatted}`);\n * ```\n */\n async getUsage(request: CdnUsageRequest = {}): Promise<CdnUsageResponse> {\n const params = new URLSearchParams();\n if (request.projectSlug) params.set(\"projectSlug\", request.projectSlug);\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.periodStart) {\n const date = request.periodStart instanceof Date ? request.periodStart.toISOString() : request.periodStart;\n params.set(\"periodStart\", date);\n }\n if (request.periodEnd) {\n const date = request.periodEnd instanceof Date ? request.periodEnd.toISOString() : request.periodEnd;\n params.set(\"periodEnd\", date);\n }\n\n const query = params.toString();\n const response = await this.http.get<CdnUsageResponse>(`/cdn/usage${query ? `?${query}` : \"\"}`);\n return this.convertUsageDates(response);\n }\n\n /**\n * Get usage history (time series data for charts)\n *\n * @example\n * ```typescript\n * const history = await cdn.getUsageHistory({\n * projectSlug: 'my-project',\n * days: 30,\n * });\n * console.log(`Total requests: ${history.totals.requests}`);\n * ```\n */\n async getUsageHistory(request: CdnUsageHistoryRequest = {}): Promise<CdnUsageHistoryResponse> {\n const params = new URLSearchParams();\n if (request.projectSlug) params.set(\"projectSlug\", request.projectSlug);\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.days) params.set(\"days\", request.days.toString());\n if (request.granularity) params.set(\"granularity\", request.granularity);\n\n const query = params.toString();\n const response = await this.http.get<CdnUsageHistoryResponse>(`/cdn/usage/history${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n data: response.data.map((point) => this.convertUsageDataPointDates(point)),\n };\n }\n\n /**\n * Get storage breakdown by type or folder\n *\n * @example\n * ```typescript\n * const breakdown = await cdn.getStorageBreakdown({\n * projectSlug: 'my-project',\n * groupBy: 'type',\n * });\n * breakdown.items.forEach(item => {\n * console.log(`${item.key}: ${item.sizeFormatted} (${item.percentage}%)`);\n * });\n * ```\n */\n async getStorageBreakdown(request: CdnStorageBreakdownRequest = {}): Promise<CdnStorageBreakdownResponse> {\n const params = new URLSearchParams();\n if (request.projectSlug) params.set(\"projectSlug\", request.projectSlug);\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.groupBy) params.set(\"groupBy\", request.groupBy);\n\n const query = params.toString();\n return this.http.get<CdnStorageBreakdownResponse>(`/cdn/usage/storage-breakdown${query ? `?${query}` : \"\"}`);\n }\n\n private convertUsageDates(usage: CdnUsageResponse): CdnUsageResponse {\n if (typeof usage.periodStart === \"string\") {\n usage.periodStart = new Date(usage.periodStart);\n }\n if (typeof usage.periodEnd === \"string\") {\n usage.periodEnd = new Date(usage.periodEnd);\n }\n return usage;\n }\n\n private convertUsageDataPointDates(point: CdnUsageDataPoint): CdnUsageDataPoint {\n if (typeof point.timestamp === \"string\") {\n point.timestamp = new Date(point.timestamp);\n }\n return point;\n }\n\n // ============================================================================\n // Additional Folder Methods\n // ============================================================================\n\n /**\n * Get a folder by ID\n *\n * @example\n * ```typescript\n * const folder = await cdn.getFolder('folder-id');\n * console.log(`Folder: ${folder.name}, Assets: ${folder.assetCount}`);\n * ```\n */\n async getFolder(id: string): Promise<Folder> {\n const response = await this.http.get<Folder>(`/cdn/folders/${id}`);\n return this.convertFolderDates(response);\n }\n\n /**\n * Get a folder by its path\n *\n * @example\n * ```typescript\n * const folder = await cdn.getFolderByPath('/images/avatars');\n * ```\n */\n async getFolderByPath(path: string): Promise<Folder> {\n const encodedPath = encodeURIComponent(path);\n const response = await this.http.get<Folder>(`/cdn/folders/path/${encodedPath}`);\n return this.convertFolderDates(response);\n }\n\n /**\n * Update a folder's name\n *\n * @example\n * ```typescript\n * const folder = await cdn.updateFolder({\n * id: 'folder-id',\n * name: 'New Folder Name',\n * });\n * ```\n */\n async updateFolder(request: UpdateFolderRequest): Promise<Folder> {\n const { id, ...data } = request;\n const response = await this.http.patch<Folder>(`/cdn/folders/${id}`, data);\n return this.convertFolderDates(response);\n }\n\n /**\n * List folders with optional filters\n *\n * @example\n * ```typescript\n * const { folders, total } = await cdn.listFolders({\n * parentId: null, // root level\n * limit: 50,\n * });\n * ```\n */\n async listFolders(request: ListFoldersRequest = {}): Promise<ListFoldersResponse> {\n const params = new URLSearchParams();\n if (request.parentId !== undefined) params.set(\"parentId\", request.parentId ?? \"\");\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.search) params.set(\"search\", request.search);\n\n const query = params.toString();\n const response = await this.http.get<ListFoldersResponse>(`/cdn/folders${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n folders: response.folders.map((folder) => this.convertFolderListItemDates(folder)),\n };\n }\n\n /**\n * Move a folder to a new parent\n *\n * @example\n * ```typescript\n * await cdn.moveFolder({\n * id: 'folder-id',\n * newParentId: 'new-parent-id', // or null for root\n * });\n * ```\n */\n async moveFolder(request: MoveFolderRequest): Promise<MoveFolderResponse> {\n return this.http.post<MoveFolderResponse>(\"/cdn/folders/move\", request);\n }\n\n private convertFolderListItemDates(folder: FolderListItem): FolderListItem {\n if (typeof folder.createdAt === \"string\") {\n folder.createdAt = new Date(folder.createdAt);\n }\n return folder;\n }\n\n // ============================================================================\n // Additional Video Methods\n // ============================================================================\n\n /**\n * List all thumbnails for a video asset\n *\n * @example\n * ```typescript\n * const { thumbnails } = await cdn.listThumbnails('video-asset-id');\n * thumbnails.forEach(thumb => {\n * console.log(`${thumb.timestamp}s: ${thumb.url}`);\n * });\n * ```\n */\n async listThumbnails(assetId: string): Promise<ListThumbnailsResponse> {\n const response = await this.http.get<ListThumbnailsResponse>(`/cdn/video/${assetId}/thumbnails`);\n return response;\n }\n\n // ============================================================================\n // Additional Private Files Methods\n // ============================================================================\n\n /**\n * Move private files to a different folder\n *\n * @example\n * ```typescript\n * const result = await cdn.movePrivateFiles({\n * fileIds: ['file-1', 'file-2'],\n * folder: '/confidential/archive',\n * });\n * console.log(`Moved ${result.movedCount} files`);\n * ```\n */\n async movePrivateFiles(request: MovePrivateFilesRequest): Promise<MovePrivateFilesResponse> {\n return this.http.post<MovePrivateFilesResponse>(\"/cdn/private/move\", request);\n }\n\n // ============================================================================\n // Video Merge Methods\n // ============================================================================\n\n /**\n * Create a merge job to combine multiple videos/images with optional audio overlay\n *\n * Merge jobs combine multiple assets (videos, images) in sequence and can\n * optionally overlay an audio track. Images require a duration to be specified.\n *\n * @example\n * ```typescript\n * const job = await cdn.createMergeJob({\n * projectSlug: 'my-project',\n * inputs: [\n * { assetId: 'intro-video-id' },\n * { assetId: 'image-id', duration: 5 }, // Show image for 5 seconds\n * { assetId: 'main-video-id', startTime: 10, endTime: 60 }, // Trim to 50 seconds\n * ],\n * audioTrack: {\n * assetId: 'background-music-id',\n * loop: true,\n * fadeIn: 2,\n * fadeOut: 3,\n * },\n * output: {\n * format: 'mp4',\n * quality: '1080p',\n * filename: 'final-video.mp4',\n * },\n * webhookUrl: 'https://your-app.com/webhook',\n * });\n * console.log(`Merge job started: ${job.id}`);\n * ```\n */\n async createMergeJob(request: CreateMergeJobRequest): Promise<MergeJob> {\n const response = await this.http.post<MergeJob>(\"/cdn/video/merge\", request);\n return this.convertMergeJobDates(response);\n }\n\n /**\n * Get a merge job by ID with output asset details\n *\n * @example\n * ```typescript\n * const job = await cdn.getMergeJob('job-id');\n * if (job.status === 'completed' && job.outputAsset) {\n * console.log(`Output video: ${job.outputAsset.cdnUrl}`);\n * }\n * ```\n */\n async getMergeJob(jobId: string): Promise<MergeJobWithOutput> {\n const response = await this.http.get<MergeJobWithOutput>(`/cdn/video/merge/${jobId}`);\n return this.convertMergeJobWithOutputDates(response);\n }\n\n /**\n * List merge jobs with optional filters\n *\n * @example\n * ```typescript\n * const { jobs, total, hasMore } = await cdn.listMergeJobs({\n * projectSlug: 'my-project',\n * status: 'completed',\n * limit: 20,\n * });\n * ```\n */\n async listMergeJobs(request: ListMergeJobsRequest): Promise<ListMergeJobsResponse> {\n const params = new URLSearchParams();\n params.set(\"projectSlug\", request.projectSlug);\n if (request.status) params.set(\"status\", request.status);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n\n const response = await this.http.get<ListMergeJobsResponse>(`/cdn/video/merge?${params.toString()}`);\n return {\n ...response,\n jobs: response.jobs.map((job) => this.convertMergeJobDates(job)),\n };\n }\n\n /**\n * Cancel a pending or processing merge job\n *\n * @example\n * ```typescript\n * await cdn.cancelMergeJob('job-id');\n * console.log('Merge job cancelled');\n * ```\n */\n async cancelMergeJob(jobId: string): Promise<{ success: boolean }> {\n return this.http.post<{ success: boolean }>(`/cdn/video/merge/${jobId}/cancel`, {});\n }\n\n private convertMergeJobDates(job: MergeJob): MergeJob {\n if (typeof job.createdAt === \"string\") {\n job.createdAt = new Date(job.createdAt);\n }\n if (job.updatedAt && typeof job.updatedAt === \"string\") {\n job.updatedAt = new Date(job.updatedAt);\n }\n if (job.startedAt && typeof job.startedAt === \"string\") {\n job.startedAt = new Date(job.startedAt);\n }\n if (job.completedAt && typeof job.completedAt === \"string\") {\n job.completedAt = new Date(job.completedAt);\n }\n return job;\n }\n\n private convertMergeJobWithOutputDates(job: MergeJobWithOutput): MergeJobWithOutput {\n return this.convertMergeJobDates(job) as MergeJobWithOutput;\n }\n}\n","/**\n * Stack0 Screenshots Client\n * Capture high-quality screenshots of any webpage\n */\n\nimport { HttpClient, type HttpClientConfig } from \"../lib/http-client\";\nimport type {\n CreateBatchResponse,\n GetBatchJobRequest,\n ListBatchJobsRequest,\n CreateScheduleResponse,\n GetScheduleRequest,\n ListSchedulesRequest,\n} from \"../lib/shared-types\";\nimport type {\n Screenshot,\n CreateScreenshotRequest,\n CreateScreenshotResponse,\n GetScreenshotRequest,\n ListScreenshotsRequest,\n ListScreenshotsResponse,\n BatchScreenshotJob,\n CreateBatchScreenshotsRequest,\n ScreenshotBatchJobsResponse,\n ScreenshotSchedule,\n CreateScreenshotScheduleRequest,\n UpdateScreenshotScheduleRequest,\n ScreenshotSchedulesResponse,\n} from \"./types\";\n\nexport class Screenshots {\n private http: HttpClient;\n\n constructor(config: HttpClientConfig) {\n this.http = new HttpClient(config);\n }\n\n // ==========================================================================\n // SCREENSHOTS\n // ==========================================================================\n\n /**\n * Capture a screenshot of a URL\n *\n * @example\n * ```typescript\n * const { id, status } = await screenshots.capture({\n * url: 'https://example.com',\n * format: 'png',\n * fullPage: true,\n * deviceType: 'desktop',\n * });\n *\n * // Poll for completion\n * const screenshot = await screenshots.get({ id });\n * console.log(screenshot.imageUrl);\n * ```\n */\n async capture(request: CreateScreenshotRequest): Promise<CreateScreenshotResponse> {\n return this.http.post<CreateScreenshotResponse>(\"/webdata/screenshots\", request);\n }\n\n /**\n * Get a screenshot by ID\n *\n * @example\n * ```typescript\n * const screenshot = await screenshots.get({ id: 'screenshot-id' });\n * if (screenshot.status === 'completed') {\n * console.log(screenshot.imageUrl);\n * }\n * ```\n */\n async get(request: GetScreenshotRequest): Promise<Screenshot> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/screenshots/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<Screenshot>(path);\n return this.convertDates(response);\n }\n\n /**\n * List screenshots with pagination and filters\n *\n * @example\n * ```typescript\n * const { items, nextCursor } = await screenshots.list({\n * status: 'completed',\n * limit: 20,\n * });\n * ```\n */\n async list(request: ListScreenshotsRequest = {}): Promise<ListScreenshotsResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n if (request.status) params.set(\"status\", request.status);\n if (request.url) params.set(\"url\", request.url);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ListScreenshotsResponse>(`/webdata/screenshots${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertDates(item)),\n };\n }\n\n /**\n * Delete a screenshot\n *\n * @example\n * ```typescript\n * await screenshots.delete({ id: 'screenshot-id' });\n * ```\n */\n async delete(request: GetScreenshotRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.deleteWithBody<{ success: boolean }>(\n `/webdata/screenshots/${request.id}${query ? `?${query}` : \"\"}`,\n {\n id: request.id,\n environment: request.environment,\n projectId: request.projectId,\n },\n );\n }\n\n /**\n * Capture a screenshot and wait for completion\n *\n * @example\n * ```typescript\n * const screenshot = await screenshots.captureAndWait({\n * url: 'https://example.com',\n * format: 'png',\n * });\n * console.log(screenshot.imageUrl);\n * ```\n */\n async captureAndWait(\n request: CreateScreenshotRequest,\n options: { pollInterval?: number; timeout?: number } = {},\n ): Promise<Screenshot> {\n const { pollInterval = 1000, timeout = 60000 } = options;\n const startTime = Date.now();\n\n const { id } = await this.capture(request);\n\n while (Date.now() - startTime < timeout) {\n const screenshot = await this.get({\n id,\n environment: request.environment,\n projectId: request.projectId,\n });\n\n if (screenshot.status === \"completed\" || screenshot.status === \"failed\") {\n if (screenshot.status === \"failed\") {\n throw new Error(screenshot.error || \"Screenshot failed\");\n }\n return screenshot;\n }\n\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n }\n\n throw new Error(\"Screenshot timed out\");\n }\n\n // ==========================================================================\n // BATCH JOBS\n // ==========================================================================\n\n /**\n * Create a batch screenshot job for multiple URLs\n *\n * @example\n * ```typescript\n * const { id, totalUrls } = await screenshots.batch({\n * urls: [\n * 'https://example.com',\n * 'https://example.org',\n * ],\n * config: { format: 'png', fullPage: true },\n * });\n *\n * // Poll for completion\n * const job = await screenshots.getBatchJob({ id });\n * console.log(`Progress: ${job.processedUrls}/${job.totalUrls}`);\n * ```\n */\n async batch(request: CreateBatchScreenshotsRequest): Promise<CreateBatchResponse> {\n return this.http.post<CreateBatchResponse>(\"/webdata/batch/screenshots\", request);\n }\n\n /**\n * Get a batch job by ID\n */\n async getBatchJob(request: GetBatchJobRequest): Promise<BatchScreenshotJob> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/batch/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<BatchScreenshotJob>(path);\n return this.convertBatchJobDates(response);\n }\n\n /**\n * List batch jobs with pagination and filters\n */\n async listBatchJobs(request: ListBatchJobsRequest = {}): Promise<ScreenshotBatchJobsResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n if (request.status) params.set(\"status\", request.status);\n params.set(\"type\", \"screenshot\");\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ScreenshotBatchJobsResponse>(`/webdata/batch${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertBatchJobDates(item)),\n };\n }\n\n /**\n * Cancel a batch job\n */\n async cancelBatchJob(request: GetBatchJobRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.post<{ success: boolean }>(`/webdata/batch/${request.id}/cancel${query ? `?${query}` : \"\"}`, {});\n }\n\n /**\n * Create a batch screenshot job and wait for completion\n */\n async batchAndWait(\n request: CreateBatchScreenshotsRequest,\n options: { pollInterval?: number; timeout?: number } = {},\n ): Promise<BatchScreenshotJob> {\n const { pollInterval = 2000, timeout = 300000 } = options;\n const startTime = Date.now();\n\n const { id } = await this.batch(request);\n\n while (Date.now() - startTime < timeout) {\n const job = await this.getBatchJob({\n id,\n environment: request.environment,\n projectId: request.projectId,\n });\n\n if (job.status === \"completed\" || job.status === \"failed\" || job.status === \"cancelled\") {\n return job;\n }\n\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n }\n\n throw new Error(\"Batch job timed out\");\n }\n\n // ==========================================================================\n // SCHEDULES\n // ==========================================================================\n\n /**\n * Create a scheduled screenshot job\n *\n * @example\n * ```typescript\n * const { id } = await screenshots.createSchedule({\n * name: 'Daily homepage screenshot',\n * url: 'https://example.com',\n * frequency: 'daily',\n * config: { format: 'png', fullPage: true },\n * });\n * ```\n */\n async createSchedule(request: CreateScreenshotScheduleRequest): Promise<CreateScheduleResponse> {\n return this.http.post<CreateScheduleResponse>(\"/webdata/schedules\", {\n ...request,\n type: \"screenshot\",\n });\n }\n\n /**\n * Update a schedule\n */\n async updateSchedule(request: UpdateScreenshotScheduleRequest): Promise<{ success: boolean }> {\n const { id, environment, projectId, ...data } = request;\n\n const params = new URLSearchParams();\n if (environment) params.set(\"environment\", environment);\n if (projectId) params.set(\"projectId\", projectId);\n\n const query = params.toString();\n return this.http.post<{ success: boolean }>(`/webdata/schedules/${id}${query ? `?${query}` : \"\"}`, data);\n }\n\n /**\n * Get a schedule by ID\n */\n async getSchedule(request: GetScheduleRequest): Promise<ScreenshotSchedule> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/schedules/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<ScreenshotSchedule>(path);\n return this.convertScheduleDates(response);\n }\n\n /**\n * List schedules with pagination and filters\n */\n async listSchedules(request: ListSchedulesRequest = {}): Promise<ScreenshotSchedulesResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n params.set(\"type\", \"screenshot\");\n if (request.isActive !== undefined) params.set(\"isActive\", request.isActive.toString());\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ScreenshotSchedulesResponse>(`/webdata/schedules${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertScheduleDates(item)),\n };\n }\n\n /**\n * Delete a schedule\n */\n async deleteSchedule(request: GetScheduleRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.deleteWithBody<{ success: boolean }>(\n `/webdata/schedules/${request.id}${query ? `?${query}` : \"\"}`,\n {\n id: request.id,\n environment: request.environment,\n projectId: request.projectId,\n },\n );\n }\n\n /**\n * Toggle a schedule on or off\n */\n async toggleSchedule(request: GetScheduleRequest): Promise<{ isActive: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.post<{ isActive: boolean }>(\n `/webdata/schedules/${request.id}/toggle${query ? `?${query}` : \"\"}`,\n {},\n );\n }\n\n // ==========================================================================\n // HELPERS\n // ==========================================================================\n\n private convertDates(screenshot: Screenshot): Screenshot {\n if (typeof screenshot.createdAt === \"string\") {\n screenshot.createdAt = new Date(screenshot.createdAt);\n }\n if (screenshot.completedAt && typeof screenshot.completedAt === \"string\") {\n screenshot.completedAt = new Date(screenshot.completedAt);\n }\n return screenshot;\n }\n\n private convertBatchJobDates(job: BatchScreenshotJob): BatchScreenshotJob {\n if (typeof job.createdAt === \"string\") {\n job.createdAt = new Date(job.createdAt);\n }\n if (job.startedAt && typeof job.startedAt === \"string\") {\n job.startedAt = new Date(job.startedAt);\n }\n if (job.completedAt && typeof job.completedAt === \"string\") {\n job.completedAt = new Date(job.completedAt);\n }\n return job;\n }\n\n private convertScheduleDates(schedule: ScreenshotSchedule): ScreenshotSchedule {\n if (typeof schedule.createdAt === \"string\") {\n schedule.createdAt = new Date(schedule.createdAt);\n }\n if (typeof schedule.updatedAt === \"string\") {\n schedule.updatedAt = new Date(schedule.updatedAt);\n }\n if (schedule.lastRunAt && typeof schedule.lastRunAt === \"string\") {\n schedule.lastRunAt = new Date(schedule.lastRunAt);\n }\n if (schedule.nextRunAt && typeof schedule.nextRunAt === \"string\") {\n schedule.nextRunAt = new Date(schedule.nextRunAt);\n }\n return schedule;\n }\n}\n","/**\n * Stack0 AI Extraction Client\n * Extract structured data from any webpage using AI\n */\n\nimport { HttpClient, type HttpClientConfig } from \"../lib/http-client\";\nimport type {\n CreateBatchResponse,\n GetBatchJobRequest,\n ListBatchJobsRequest,\n CreateScheduleResponse,\n GetScheduleRequest,\n ListSchedulesRequest,\n} from \"../lib/shared-types\";\nimport type {\n ExtractionResult,\n CreateExtractionRequest,\n CreateExtractionResponse,\n GetExtractionRequest,\n ListExtractionsRequest,\n ListExtractionsResponse,\n BatchExtractionJob,\n CreateBatchExtractionsRequest,\n ExtractionBatchJobsResponse,\n ExtractionSchedule,\n CreateExtractionScheduleRequest,\n UpdateExtractionScheduleRequest,\n ExtractionSchedulesResponse,\n ExtractionUsage,\n GetUsageRequest,\n GetDailyUsageResponse,\n} from \"./types\";\n\nexport class Extraction {\n private http: HttpClient;\n\n constructor(config: HttpClientConfig) {\n this.http = new HttpClient(config);\n }\n\n // ==========================================================================\n // EXTRACTIONS\n // ==========================================================================\n\n /**\n * Extract content from a URL\n *\n * @example\n * ```typescript\n * const { id, status } = await extraction.extract({\n * url: 'https://example.com/article',\n * mode: 'markdown',\n * includeMetadata: true,\n * });\n *\n * // Poll for completion\n * const result = await extraction.get({ id });\n * console.log(result.markdown);\n * ```\n */\n async extract(request: CreateExtractionRequest): Promise<CreateExtractionResponse> {\n return this.http.post<CreateExtractionResponse>(\"/webdata/extractions\", request);\n }\n\n /**\n * Get an extraction by ID\n *\n * @example\n * ```typescript\n * const extraction = await extraction.get({ id: 'extraction-id' });\n * if (extraction.status === 'completed') {\n * console.log(extraction.markdown);\n * console.log(extraction.pageMetadata);\n * }\n * ```\n */\n async get(request: GetExtractionRequest): Promise<ExtractionResult> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/extractions/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<ExtractionResult>(path);\n return this.convertDates(response);\n }\n\n /**\n * List extractions with pagination and filters\n *\n * @example\n * ```typescript\n * const { items, nextCursor } = await extraction.list({\n * status: 'completed',\n * limit: 20,\n * });\n * ```\n */\n async list(request: ListExtractionsRequest = {}): Promise<ListExtractionsResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n if (request.status) params.set(\"status\", request.status);\n if (request.url) params.set(\"url\", request.url);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ListExtractionsResponse>(`/webdata/extractions${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertDates(item)),\n };\n }\n\n /**\n * Delete an extraction\n *\n * @example\n * ```typescript\n * await extraction.delete({ id: 'extraction-id' });\n * ```\n */\n async delete(request: GetExtractionRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.deleteWithBody<{ success: boolean }>(\n `/webdata/extractions/${request.id}${query ? `?${query}` : \"\"}`,\n {\n id: request.id,\n environment: request.environment,\n projectId: request.projectId,\n },\n );\n }\n\n /**\n * Extract content and wait for completion\n *\n * @example\n * ```typescript\n * const extraction = await extraction.extractAndWait({\n * url: 'https://example.com/article',\n * mode: 'markdown',\n * });\n * console.log(extraction.markdown);\n * ```\n */\n async extractAndWait(\n request: CreateExtractionRequest,\n options: { pollInterval?: number; timeout?: number } = {},\n ): Promise<ExtractionResult> {\n const { pollInterval = 1000, timeout = 60000 } = options;\n const startTime = Date.now();\n\n const { id } = await this.extract(request);\n\n while (Date.now() - startTime < timeout) {\n const extraction = await this.get({\n id,\n environment: request.environment,\n projectId: request.projectId,\n });\n\n if (extraction.status === \"completed\" || extraction.status === \"failed\") {\n if (extraction.status === \"failed\") {\n throw new Error(extraction.error || \"Extraction failed\");\n }\n return extraction;\n }\n\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n }\n\n throw new Error(\"Extraction timed out\");\n }\n\n // ==========================================================================\n // BATCH JOBS\n // ==========================================================================\n\n /**\n * Create a batch extraction job for multiple URLs\n *\n * @example\n * ```typescript\n * const { id, totalUrls } = await extraction.batch({\n * urls: [\n * 'https://example.com/article1',\n * 'https://example.com/article2',\n * ],\n * config: { mode: 'markdown' },\n * });\n * ```\n */\n async batch(request: CreateBatchExtractionsRequest): Promise<CreateBatchResponse> {\n return this.http.post<CreateBatchResponse>(\"/webdata/batch/extractions\", request);\n }\n\n /**\n * Get a batch job by ID\n */\n async getBatchJob(request: GetBatchJobRequest): Promise<BatchExtractionJob> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/batch/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<BatchExtractionJob>(path);\n return this.convertBatchJobDates(response);\n }\n\n /**\n * List batch jobs with pagination and filters\n */\n async listBatchJobs(request: ListBatchJobsRequest = {}): Promise<ExtractionBatchJobsResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n if (request.status) params.set(\"status\", request.status);\n params.set(\"type\", \"extraction\");\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ExtractionBatchJobsResponse>(`/webdata/batch${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertBatchJobDates(item)),\n };\n }\n\n /**\n * Cancel a batch job\n */\n async cancelBatchJob(request: GetBatchJobRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.post<{ success: boolean }>(`/webdata/batch/${request.id}/cancel${query ? `?${query}` : \"\"}`, {});\n }\n\n /**\n * Create a batch extraction job and wait for completion\n */\n async batchAndWait(\n request: CreateBatchExtractionsRequest,\n options: { pollInterval?: number; timeout?: number } = {},\n ): Promise<BatchExtractionJob> {\n const { pollInterval = 2000, timeout = 300000 } = options;\n const startTime = Date.now();\n\n const { id } = await this.batch(request);\n\n while (Date.now() - startTime < timeout) {\n const job = await this.getBatchJob({\n id,\n environment: request.environment,\n projectId: request.projectId,\n });\n\n if (job.status === \"completed\" || job.status === \"failed\" || job.status === \"cancelled\") {\n return job;\n }\n\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n }\n\n throw new Error(\"Batch job timed out\");\n }\n\n // ==========================================================================\n // SCHEDULES\n // ==========================================================================\n\n /**\n * Create a scheduled extraction job\n *\n * @example\n * ```typescript\n * const { id } = await extraction.createSchedule({\n * name: 'Daily price monitoring',\n * url: 'https://competitor.com/pricing',\n * frequency: 'daily',\n * config: { mode: 'schema', schema: { ... } },\n * });\n * ```\n */\n async createSchedule(request: CreateExtractionScheduleRequest): Promise<CreateScheduleResponse> {\n return this.http.post<CreateScheduleResponse>(\"/webdata/schedules\", {\n ...request,\n type: \"extraction\",\n });\n }\n\n /**\n * Update a schedule\n */\n async updateSchedule(request: UpdateExtractionScheduleRequest): Promise<{ success: boolean }> {\n const { id, environment, projectId, ...data } = request;\n\n const params = new URLSearchParams();\n if (environment) params.set(\"environment\", environment);\n if (projectId) params.set(\"projectId\", projectId);\n\n const query = params.toString();\n return this.http.post<{ success: boolean }>(`/webdata/schedules/${id}${query ? `?${query}` : \"\"}`, data);\n }\n\n /**\n * Get a schedule by ID\n */\n async getSchedule(request: GetScheduleRequest): Promise<ExtractionSchedule> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/schedules/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<ExtractionSchedule>(path);\n return this.convertScheduleDates(response);\n }\n\n /**\n * List schedules with pagination and filters\n */\n async listSchedules(request: ListSchedulesRequest = {}): Promise<ExtractionSchedulesResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n params.set(\"type\", \"extraction\");\n if (request.isActive !== undefined) params.set(\"isActive\", request.isActive.toString());\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ExtractionSchedulesResponse>(`/webdata/schedules${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertScheduleDates(item)),\n };\n }\n\n /**\n * Delete a schedule\n */\n async deleteSchedule(request: GetScheduleRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.deleteWithBody<{ success: boolean }>(\n `/webdata/schedules/${request.id}${query ? `?${query}` : \"\"}`,\n {\n id: request.id,\n environment: request.environment,\n projectId: request.projectId,\n },\n );\n }\n\n /**\n * Toggle a schedule on or off\n */\n async toggleSchedule(request: GetScheduleRequest): Promise<{ isActive: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.post<{ isActive: boolean }>(\n `/webdata/schedules/${request.id}/toggle${query ? `?${query}` : \"\"}`,\n {},\n );\n }\n\n // ==========================================================================\n // USAGE\n // ==========================================================================\n\n /**\n * Get usage statistics\n *\n * @example\n * ```typescript\n * const usage = await extraction.getUsage({\n * periodStart: '2024-01-01T00:00:00Z',\n * periodEnd: '2024-01-31T23:59:59Z',\n * });\n * console.log(`Extractions: ${usage.extractionsTotal}`);\n * console.log(`Tokens used: ${usage.extractionTokensUsed}`);\n * ```\n */\n async getUsage(request: GetUsageRequest = {}): Promise<ExtractionUsage> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.periodStart) params.set(\"periodStart\", request.periodStart);\n if (request.periodEnd) params.set(\"periodEnd\", request.periodEnd);\n\n const query = params.toString();\n const response = await this.http.get<ExtractionUsage>(`/webdata/usage${query ? `?${query}` : \"\"}`);\n\n return this.convertUsageDates(response);\n }\n\n /**\n * Get daily usage breakdown\n *\n * @example\n * ```typescript\n * const { days } = await extraction.getUsageDaily({\n * periodStart: '2024-01-01T00:00:00Z',\n * periodEnd: '2024-01-31T23:59:59Z',\n * });\n * days.forEach(day => {\n * console.log(`${day.date}: ${day.screenshots} screenshots, ${day.extractions} extractions`);\n * });\n * ```\n */\n async getUsageDaily(request: GetUsageRequest = {}): Promise<GetDailyUsageResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.periodStart) params.set(\"periodStart\", request.periodStart);\n if (request.periodEnd) params.set(\"periodEnd\", request.periodEnd);\n\n const query = params.toString();\n return this.http.get<GetDailyUsageResponse>(`/webdata/usage/daily${query ? `?${query}` : \"\"}`);\n }\n\n // ==========================================================================\n // HELPERS\n // ==========================================================================\n\n private convertDates(extraction: ExtractionResult): ExtractionResult {\n if (typeof extraction.createdAt === \"string\") {\n extraction.createdAt = new Date(extraction.createdAt);\n }\n if (extraction.completedAt && typeof extraction.completedAt === \"string\") {\n extraction.completedAt = new Date(extraction.completedAt);\n }\n return extraction;\n }\n\n private convertBatchJobDates(job: BatchExtractionJob): BatchExtractionJob {\n if (typeof job.createdAt === \"string\") {\n job.createdAt = new Date(job.createdAt);\n }\n if (job.startedAt && typeof job.startedAt === \"string\") {\n job.startedAt = new Date(job.startedAt);\n }\n if (job.completedAt && typeof job.completedAt === \"string\") {\n job.completedAt = new Date(job.completedAt);\n }\n return job;\n }\n\n private convertScheduleDates(schedule: ExtractionSchedule): ExtractionSchedule {\n if (typeof schedule.createdAt === \"string\") {\n schedule.createdAt = new Date(schedule.createdAt);\n }\n if (typeof schedule.updatedAt === \"string\") {\n schedule.updatedAt = new Date(schedule.updatedAt);\n }\n if (schedule.lastRunAt && typeof schedule.lastRunAt === \"string\") {\n schedule.lastRunAt = new Date(schedule.lastRunAt);\n }\n if (schedule.nextRunAt && typeof schedule.nextRunAt === \"string\") {\n schedule.nextRunAt = new Date(schedule.nextRunAt);\n }\n return schedule;\n }\n\n private convertUsageDates(usage: ExtractionUsage): ExtractionUsage {\n if (typeof usage.periodStart === \"string\") {\n usage.periodStart = new Date(usage.periodStart);\n }\n if (typeof usage.periodEnd === \"string\") {\n usage.periodEnd = new Date(usage.periodEnd);\n }\n return usage;\n }\n}\n","/**\n * Stack0 Webdata Client\n * Capture screenshots and extract data from web pages\n */\n\nimport { HttpClient, type HttpClientConfig } from \"../lib/http-client\";\nimport type {\n Screenshot,\n CreateScreenshotRequest,\n CreateScreenshotResponse,\n GetScreenshotRequest,\n ListScreenshotsRequest,\n ListScreenshotsResponse,\n Extraction,\n CreateExtractionRequest,\n CreateExtractionResponse,\n GetExtractionRequest,\n ListExtractionsRequest,\n ListExtractionsResponse,\n Schedule,\n CreateScheduleRequest,\n CreateScheduleResponse,\n UpdateScheduleRequest,\n GetScheduleRequest,\n ListSchedulesRequest,\n ListSchedulesResponse,\n Usage,\n GetUsageRequest,\n BatchJob,\n CreateBatchScreenshotsRequest,\n CreateBatchExtractionsRequest,\n CreateBatchResponse,\n GetBatchJobRequest,\n ListBatchJobsRequest,\n ListBatchJobsResponse,\n} from \"./types\";\n\nexport class Webdata {\n private http: HttpClient;\n\n constructor(config: HttpClientConfig) {\n this.http = new HttpClient(config);\n }\n\n // ==========================================================================\n // SCREENSHOTS\n // ==========================================================================\n\n /**\n * Capture a screenshot of a URL\n *\n * @example\n * ```typescript\n * const { id, status } = await webdata.screenshot({\n * url: 'https://example.com',\n * format: 'png',\n * fullPage: true,\n * deviceType: 'desktop',\n * });\n *\n * // Poll for completion\n * const screenshot = await webdata.getScreenshot({ id });\n * console.log(screenshot.imageUrl);\n * ```\n */\n async screenshot(request: CreateScreenshotRequest): Promise<CreateScreenshotResponse> {\n return this.http.post<CreateScreenshotResponse>(\"/webdata/screenshots\", request);\n }\n\n /**\n * Get a screenshot by ID\n *\n * @example\n * ```typescript\n * const screenshot = await webdata.getScreenshot({ id: 'screenshot-id' });\n * if (screenshot.status === 'completed') {\n * console.log(screenshot.imageUrl);\n * }\n * ```\n */\n async getScreenshot(request: GetScreenshotRequest): Promise<Screenshot> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/screenshots/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<Screenshot>(path);\n return this.convertScreenshotDates(response);\n }\n\n /**\n * List screenshots with pagination and filters\n *\n * @example\n * ```typescript\n * const { items, nextCursor } = await webdata.listScreenshots({\n * status: 'completed',\n * limit: 20,\n * });\n * ```\n */\n async listScreenshots(request: ListScreenshotsRequest = {}): Promise<ListScreenshotsResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n if (request.status) params.set(\"status\", request.status);\n if (request.url) params.set(\"url\", request.url);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ListScreenshotsResponse>(`/webdata/screenshots${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertScreenshotDates(item)),\n };\n }\n\n /**\n * Delete a screenshot\n *\n * @example\n * ```typescript\n * await webdata.deleteScreenshot({ id: 'screenshot-id' });\n * ```\n */\n async deleteScreenshot(request: GetScreenshotRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.deleteWithBody<{ success: boolean }>(\n `/webdata/screenshots/${request.id}${query ? `?${query}` : \"\"}`,\n {\n id: request.id,\n environment: request.environment,\n projectId: request.projectId,\n },\n );\n }\n\n /**\n * Capture a screenshot and wait for completion\n *\n * @example\n * ```typescript\n * const screenshot = await webdata.screenshotAndWait({\n * url: 'https://example.com',\n * format: 'png',\n * });\n * console.log(screenshot.imageUrl);\n * ```\n */\n async screenshotAndWait(\n request: CreateScreenshotRequest,\n options: { pollInterval?: number; timeout?: number } = {},\n ): Promise<Screenshot> {\n const { pollInterval = 1000, timeout = 60000 } = options;\n const startTime = Date.now();\n\n const { id } = await this.screenshot(request);\n\n while (Date.now() - startTime < timeout) {\n const screenshot = await this.getScreenshot({\n id,\n environment: request.environment,\n projectId: request.projectId,\n });\n\n if (screenshot.status === \"completed\" || screenshot.status === \"failed\") {\n if (screenshot.status === \"failed\") {\n throw new Error(screenshot.error || \"Screenshot failed\");\n }\n return screenshot;\n }\n\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n }\n\n throw new Error(\"Screenshot timed out\");\n }\n\n // ==========================================================================\n // EXTRACTIONS\n // ==========================================================================\n\n /**\n * Extract content from a URL\n *\n * @example\n * ```typescript\n * const { id, status } = await webdata.extract({\n * url: 'https://example.com/article',\n * mode: 'markdown',\n * includeMetadata: true,\n * });\n *\n * // Poll for completion\n * const extraction = await webdata.getExtraction({ id });\n * console.log(extraction.markdown);\n * ```\n */\n async extract(request: CreateExtractionRequest): Promise<CreateExtractionResponse> {\n return this.http.post<CreateExtractionResponse>(\"/webdata/extractions\", request);\n }\n\n /**\n * Get an extraction by ID\n *\n * @example\n * ```typescript\n * const extraction = await webdata.getExtraction({ id: 'extraction-id' });\n * if (extraction.status === 'completed') {\n * console.log(extraction.markdown);\n * console.log(extraction.pageMetadata);\n * }\n * ```\n */\n async getExtraction(request: GetExtractionRequest): Promise<Extraction> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/extractions/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<Extraction>(path);\n return this.convertExtractionDates(response);\n }\n\n /**\n * List extractions with pagination and filters\n *\n * @example\n * ```typescript\n * const { items, nextCursor } = await webdata.listExtractions({\n * status: 'completed',\n * limit: 20,\n * });\n * ```\n */\n async listExtractions(request: ListExtractionsRequest = {}): Promise<ListExtractionsResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n if (request.status) params.set(\"status\", request.status);\n if (request.url) params.set(\"url\", request.url);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ListExtractionsResponse>(`/webdata/extractions${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertExtractionDates(item)),\n };\n }\n\n /**\n * Delete an extraction\n *\n * @example\n * ```typescript\n * await webdata.deleteExtraction({ id: 'extraction-id' });\n * ```\n */\n async deleteExtraction(request: GetExtractionRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.deleteWithBody<{ success: boolean }>(\n `/webdata/extractions/${request.id}${query ? `?${query}` : \"\"}`,\n {\n id: request.id,\n environment: request.environment,\n projectId: request.projectId,\n },\n );\n }\n\n /**\n * Extract content and wait for completion\n *\n * @example\n * ```typescript\n * const extraction = await webdata.extractAndWait({\n * url: 'https://example.com/article',\n * mode: 'markdown',\n * });\n * console.log(extraction.markdown);\n * ```\n */\n async extractAndWait(\n request: CreateExtractionRequest,\n options: { pollInterval?: number; timeout?: number } = {},\n ): Promise<Extraction> {\n const { pollInterval = 1000, timeout = 60000 } = options;\n const startTime = Date.now();\n\n const { id } = await this.extract(request);\n\n while (Date.now() - startTime < timeout) {\n const extraction = await this.getExtraction({\n id,\n environment: request.environment,\n projectId: request.projectId,\n });\n\n if (extraction.status === \"completed\" || extraction.status === \"failed\") {\n if (extraction.status === \"failed\") {\n throw new Error(extraction.error || \"Extraction failed\");\n }\n return extraction;\n }\n\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n }\n\n throw new Error(\"Extraction timed out\");\n }\n\n // ==========================================================================\n // SCHEDULES\n // ==========================================================================\n\n /**\n * Create a scheduled screenshot or extraction job\n *\n * @example\n * ```typescript\n * const { id } = await webdata.createSchedule({\n * name: 'Daily homepage screenshot',\n * url: 'https://example.com',\n * type: 'screenshot',\n * frequency: 'daily',\n * config: { format: 'png', fullPage: true },\n * });\n * ```\n */\n async createSchedule(request: CreateScheduleRequest): Promise<CreateScheduleResponse> {\n return this.http.post<CreateScheduleResponse>(\"/webdata/schedules\", request);\n }\n\n /**\n * Update a schedule\n *\n * @example\n * ```typescript\n * await webdata.updateSchedule({\n * id: 'schedule-id',\n * frequency: 'weekly',\n * isActive: false,\n * });\n * ```\n */\n async updateSchedule(request: UpdateScheduleRequest): Promise<{ success: boolean }> {\n const { id, environment, projectId, ...data } = request;\n\n const params = new URLSearchParams();\n if (environment) params.set(\"environment\", environment);\n if (projectId) params.set(\"projectId\", projectId);\n\n const query = params.toString();\n return this.http.patch<{ success: boolean }>(`/webdata/schedules/${id}${query ? `?${query}` : \"\"}`, data);\n }\n\n /**\n * Get a schedule by ID\n *\n * @example\n * ```typescript\n * const schedule = await webdata.getSchedule({ id: 'schedule-id' });\n * console.log(schedule.nextRunAt);\n * ```\n */\n async getSchedule(request: GetScheduleRequest): Promise<Schedule> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/schedules/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<Schedule>(path);\n return this.convertScheduleDates(response);\n }\n\n /**\n * List schedules with pagination and filters\n *\n * @example\n * ```typescript\n * const { items, nextCursor } = await webdata.listSchedules({\n * type: 'screenshot',\n * isActive: true,\n * });\n * ```\n */\n async listSchedules(request: ListSchedulesRequest = {}): Promise<ListSchedulesResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n if (request.type) params.set(\"type\", request.type);\n if (request.isActive !== undefined) params.set(\"isActive\", request.isActive.toString());\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ListSchedulesResponse>(`/webdata/schedules${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertScheduleDates(item)),\n };\n }\n\n /**\n * Delete a schedule\n *\n * @example\n * ```typescript\n * await webdata.deleteSchedule({ id: 'schedule-id' });\n * ```\n */\n async deleteSchedule(request: GetScheduleRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.deleteWithBody<{ success: boolean }>(\n `/webdata/schedules/${request.id}${query ? `?${query}` : \"\"}`,\n {\n id: request.id,\n environment: request.environment,\n projectId: request.projectId,\n },\n );\n }\n\n /**\n * Toggle a schedule on or off\n *\n * @example\n * ```typescript\n * const { isActive } = await webdata.toggleSchedule({ id: 'schedule-id' });\n * console.log(`Schedule is now ${isActive ? 'active' : 'paused'}`);\n * ```\n */\n async toggleSchedule(request: GetScheduleRequest): Promise<{ isActive: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.post<{ isActive: boolean }>(\n `/webdata/schedules/${request.id}/toggle${query ? `?${query}` : \"\"}`,\n {},\n );\n }\n\n // ==========================================================================\n // USAGE\n // ==========================================================================\n\n /**\n * Get usage statistics\n *\n * @example\n * ```typescript\n * const usage = await webdata.getUsage({\n * periodStart: '2024-01-01T00:00:00Z',\n * periodEnd: '2024-01-31T23:59:59Z',\n * });\n * console.log(`Screenshots: ${usage.screenshotsTotal}`);\n * console.log(`Extractions: ${usage.extractionsTotal}`);\n * ```\n */\n async getUsage(request: GetUsageRequest = {}): Promise<Usage> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.periodStart) params.set(\"periodStart\", request.periodStart);\n if (request.periodEnd) params.set(\"periodEnd\", request.periodEnd);\n\n const query = params.toString();\n const response = await this.http.get<Usage>(`/webdata/usage${query ? `?${query}` : \"\"}`);\n\n return this.convertUsageDates(response);\n }\n\n // ==========================================================================\n // BATCH JOBS\n // ==========================================================================\n\n /**\n * Create a batch screenshot job for multiple URLs\n *\n * @example\n * ```typescript\n * const { id, totalUrls } = await webdata.batchScreenshots({\n * urls: [\n * 'https://example.com',\n * 'https://example.org',\n * ],\n * config: { format: 'png', fullPage: true },\n * });\n *\n * // Poll for completion\n * const job = await webdata.getBatchJob({ id });\n * console.log(`Progress: ${job.processedUrls}/${job.totalUrls}`);\n * ```\n */\n async batchScreenshots(request: CreateBatchScreenshotsRequest): Promise<CreateBatchResponse> {\n return this.http.post<CreateBatchResponse>(\"/webdata/batch/screenshots\", request);\n }\n\n /**\n * Create a batch extraction job for multiple URLs\n *\n * @example\n * ```typescript\n * const { id, totalUrls } = await webdata.batchExtractions({\n * urls: [\n * 'https://example.com/article1',\n * 'https://example.com/article2',\n * ],\n * config: { mode: 'markdown' },\n * });\n * ```\n */\n async batchExtractions(request: CreateBatchExtractionsRequest): Promise<CreateBatchResponse> {\n return this.http.post<CreateBatchResponse>(\"/webdata/batch/extractions\", request);\n }\n\n /**\n * Get a batch job by ID\n *\n * @example\n * ```typescript\n * const job = await webdata.getBatchJob({ id: 'batch-id' });\n * console.log(`Status: ${job.status}`);\n * console.log(`Progress: ${job.processedUrls}/${job.totalUrls}`);\n * ```\n */\n async getBatchJob(request: GetBatchJobRequest): Promise<BatchJob> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/batch/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<BatchJob>(path);\n return this.convertBatchJobDates(response);\n }\n\n /**\n * List batch jobs with pagination and filters\n *\n * @example\n * ```typescript\n * const { items, nextCursor } = await webdata.listBatchJobs({\n * status: 'completed',\n * type: 'screenshot',\n * limit: 20,\n * });\n * ```\n */\n async listBatchJobs(request: ListBatchJobsRequest = {}): Promise<ListBatchJobsResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n if (request.status) params.set(\"status\", request.status);\n if (request.type) params.set(\"type\", request.type);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ListBatchJobsResponse>(`/webdata/batch${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertBatchJobDates(item)),\n };\n }\n\n /**\n * Cancel a batch job\n *\n * @example\n * ```typescript\n * await webdata.cancelBatchJob({ id: 'batch-id' });\n * ```\n */\n async cancelBatchJob(request: GetBatchJobRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.post<{ success: boolean }>(`/webdata/batch/${request.id}/cancel${query ? `?${query}` : \"\"}`, {});\n }\n\n /**\n * Create a batch screenshot job and wait for completion\n *\n * @example\n * ```typescript\n * const job = await webdata.batchScreenshotsAndWait({\n * urls: ['https://example.com', 'https://example.org'],\n * config: { format: 'png' },\n * });\n * console.log(`Completed: ${job.successfulUrls} successful, ${job.failedUrls} failed`);\n * ```\n */\n async batchScreenshotsAndWait(\n request: CreateBatchScreenshotsRequest,\n options: { pollInterval?: number; timeout?: number } = {},\n ): Promise<BatchJob> {\n const { pollInterval = 2000, timeout = 300000 } = options;\n const startTime = Date.now();\n\n const { id } = await this.batchScreenshots(request);\n\n while (Date.now() - startTime < timeout) {\n const job = await this.getBatchJob({\n id,\n environment: request.environment,\n projectId: request.projectId,\n });\n\n if (job.status === \"completed\" || job.status === \"failed\" || job.status === \"cancelled\") {\n return job;\n }\n\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n }\n\n throw new Error(\"Batch job timed out\");\n }\n\n /**\n * Create a batch extraction job and wait for completion\n *\n * @example\n * ```typescript\n * const job = await webdata.batchExtractionsAndWait({\n * urls: ['https://example.com/article1', 'https://example.com/article2'],\n * config: { mode: 'markdown' },\n * });\n * console.log(`Completed: ${job.successfulUrls} successful`);\n * ```\n */\n async batchExtractionsAndWait(\n request: CreateBatchExtractionsRequest,\n options: { pollInterval?: number; timeout?: number } = {},\n ): Promise<BatchJob> {\n const { pollInterval = 2000, timeout = 300000 } = options;\n const startTime = Date.now();\n\n const { id } = await this.batchExtractions(request);\n\n while (Date.now() - startTime < timeout) {\n const job = await this.getBatchJob({\n id,\n environment: request.environment,\n projectId: request.projectId,\n });\n\n if (job.status === \"completed\" || job.status === \"failed\" || job.status === \"cancelled\") {\n return job;\n }\n\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n }\n\n throw new Error(\"Batch job timed out\");\n }\n\n // ==========================================================================\n // HELPERS\n // ==========================================================================\n\n private convertScreenshotDates(screenshot: Screenshot): Screenshot {\n if (typeof screenshot.createdAt === \"string\") {\n screenshot.createdAt = new Date(screenshot.createdAt);\n }\n if (screenshot.completedAt && typeof screenshot.completedAt === \"string\") {\n screenshot.completedAt = new Date(screenshot.completedAt);\n }\n return screenshot;\n }\n\n private convertExtractionDates(extraction: Extraction): Extraction {\n if (typeof extraction.createdAt === \"string\") {\n extraction.createdAt = new Date(extraction.createdAt);\n }\n if (extraction.completedAt && typeof extraction.completedAt === \"string\") {\n extraction.completedAt = new Date(extraction.completedAt);\n }\n return extraction;\n }\n\n private convertScheduleDates(schedule: Schedule): Schedule {\n if (typeof schedule.createdAt === \"string\") {\n schedule.createdAt = new Date(schedule.createdAt);\n }\n if (typeof schedule.updatedAt === \"string\") {\n schedule.updatedAt = new Date(schedule.updatedAt);\n }\n if (schedule.lastRunAt && typeof schedule.lastRunAt === \"string\") {\n schedule.lastRunAt = new Date(schedule.lastRunAt);\n }\n if (schedule.nextRunAt && typeof schedule.nextRunAt === \"string\") {\n schedule.nextRunAt = new Date(schedule.nextRunAt);\n }\n return schedule;\n }\n\n private convertUsageDates(usage: Usage): Usage {\n if (typeof usage.periodStart === \"string\") {\n usage.periodStart = new Date(usage.periodStart);\n }\n if (typeof usage.periodEnd === \"string\") {\n usage.periodEnd = new Date(usage.periodEnd);\n }\n return usage;\n }\n\n private convertBatchJobDates(job: BatchJob): BatchJob {\n if (typeof job.createdAt === \"string\") {\n job.createdAt = new Date(job.createdAt);\n }\n if (job.startedAt && typeof job.startedAt === \"string\") {\n job.startedAt = new Date(job.startedAt);\n }\n if (job.completedAt && typeof job.completedAt === \"string\") {\n job.completedAt = new Date(job.completedAt);\n }\n return job;\n }\n}\n","/**\n * Stack0 Integrations Client\n * Unified API for third-party integrations\n */\n\nimport { HttpClient, type HttpClientConfig } from \"../lib/http-client\";\nimport type {\n Connector,\n Connection,\n ConnectorCategory,\n ListOptions,\n PaginatedResult,\n // CRM\n Contact,\n CreateContactInput,\n UpdateContactInput,\n Company,\n CreateCompanyInput,\n UpdateCompanyInput,\n Deal,\n CreateDealInput,\n UpdateDealInput,\n // Storage\n File,\n IntegrationFolder,\n CreateFolderInput,\n UploadFileInput,\n // Communication\n Channel,\n Message,\n SendMessageInput,\n CommunicationUser,\n // Productivity\n Document,\n CreateDocumentInput,\n UpdateDocumentInput,\n Table,\n TableRow,\n CreateTableRowInput,\n UpdateTableRowInput,\n // Passthrough\n PassthroughRequest,\n // OAuth & Connections\n InitiateOAuthRequest,\n InitiateOAuthResponse,\n CompleteOAuthRequest,\n CompleteOAuthResponse,\n ReconnectConnectionRequest,\n ReconnectConnectionResponse,\n UpdateConnectionRequest,\n UpdateConnectionResponse,\n IntegrationStatsRequest,\n IntegrationStatsResponse,\n ListConnectionsRequest,\n ListConnectionsResponse,\n ConnectionDetails,\n // Logs\n ListLogsRequest,\n ListLogsResponse,\n ApiLog,\n} from \"./types\";\n\n/**\n * CRM operations client\n */\nclass CRM {\n private http: HttpClient;\n\n constructor(http: HttpClient) {\n this.http = http;\n }\n\n // Contacts\n async listContacts(\n connectionId: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<Contact>> {\n const params = new URLSearchParams({ connectionId });\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n if (options?.sortBy) params.set(\"sortBy\", options.sortBy);\n if (options?.sortOrder) params.set(\"sortOrder\", options.sortOrder);\n return this.http.get(`/integrations/crm/contacts?${params}`);\n }\n\n async getContact(connectionId: string, id: string): Promise<Contact> {\n return this.http.get(`/integrations/crm/contacts/${id}?connectionId=${connectionId}`);\n }\n\n async createContact(connectionId: string, data: CreateContactInput): Promise<Contact> {\n return this.http.post(\"/integrations/crm/contacts\", { connectionId, data });\n }\n\n async updateContact(connectionId: string, id: string, data: UpdateContactInput): Promise<Contact> {\n return this.http.patch(`/integrations/crm/contacts/${id}`, { connectionId, data });\n }\n\n async deleteContact(connectionId: string, id: string): Promise<{ success: boolean }> {\n return this.http.delete(`/integrations/crm/contacts/${id}?connectionId=${connectionId}`);\n }\n\n // Companies\n async listCompanies(\n connectionId: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<Company>> {\n const params = new URLSearchParams({ connectionId });\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n if (options?.sortBy) params.set(\"sortBy\", options.sortBy);\n if (options?.sortOrder) params.set(\"sortOrder\", options.sortOrder);\n return this.http.get(`/integrations/crm/companies?${params}`);\n }\n\n async getCompany(connectionId: string, id: string): Promise<Company> {\n return this.http.get(`/integrations/crm/companies/${id}?connectionId=${connectionId}`);\n }\n\n async createCompany(connectionId: string, data: CreateCompanyInput): Promise<Company> {\n return this.http.post(\"/integrations/crm/companies\", { connectionId, data });\n }\n\n async updateCompany(connectionId: string, id: string, data: UpdateCompanyInput): Promise<Company> {\n return this.http.patch(`/integrations/crm/companies/${id}`, { connectionId, data });\n }\n\n async deleteCompany(connectionId: string, id: string): Promise<{ success: boolean }> {\n return this.http.delete(`/integrations/crm/companies/${id}?connectionId=${connectionId}`);\n }\n\n // Deals\n async listDeals(\n connectionId: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<Deal>> {\n const params = new URLSearchParams({ connectionId });\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n if (options?.sortBy) params.set(\"sortBy\", options.sortBy);\n if (options?.sortOrder) params.set(\"sortOrder\", options.sortOrder);\n return this.http.get(`/integrations/crm/deals?${params}`);\n }\n\n async getDeal(connectionId: string, id: string): Promise<Deal> {\n return this.http.get(`/integrations/crm/deals/${id}?connectionId=${connectionId}`);\n }\n\n async createDeal(connectionId: string, data: CreateDealInput): Promise<Deal> {\n return this.http.post(\"/integrations/crm/deals\", { connectionId, data });\n }\n\n async updateDeal(connectionId: string, id: string, data: UpdateDealInput): Promise<Deal> {\n return this.http.patch(`/integrations/crm/deals/${id}`, { connectionId, data });\n }\n\n async deleteDeal(connectionId: string, id: string): Promise<{ success: boolean }> {\n return this.http.delete(`/integrations/crm/deals/${id}?connectionId=${connectionId}`);\n }\n}\n\n/**\n * Storage operations client\n */\nclass Storage {\n private http: HttpClient;\n\n constructor(http: HttpClient) {\n this.http = http;\n }\n\n // Files\n async listFiles(\n connectionId: string,\n folderId?: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<File>> {\n const params = new URLSearchParams({ connectionId });\n if (folderId) params.set(\"folderId\", folderId);\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n return this.http.get(`/integrations/storage/files?${params}`);\n }\n\n async getFile(connectionId: string, id: string): Promise<File> {\n return this.http.get(`/integrations/storage/files/${id}?connectionId=${connectionId}`);\n }\n\n async uploadFile(connectionId: string, input: UploadFileInput): Promise<File> {\n // Convert data to base64 for JSON transport\n const base64Data =\n input.data instanceof ArrayBuffer\n ? btoa(String.fromCharCode(...new Uint8Array(input.data)))\n : btoa(String.fromCharCode(...input.data));\n\n return this.http.post(\"/integrations/storage/files\", {\n connectionId,\n name: input.name,\n mimeType: input.mimeType,\n data: base64Data,\n folderId: input.folderId,\n });\n }\n\n async deleteFile(connectionId: string, id: string): Promise<{ success: boolean }> {\n return this.http.delete(`/integrations/storage/files/${id}?connectionId=${connectionId}`);\n }\n\n async downloadFile(\n connectionId: string,\n id: string,\n ): Promise<{ data: ArrayBuffer; mimeType: string; filename: string }> {\n const response = await this.http.get<{ data: string; mimeType: string; filename: string }>(\n `/integrations/storage/files/${id}/download?connectionId=${connectionId}`,\n );\n // Decode base64 to ArrayBuffer\n const binaryString = atob(response.data);\n const bytes = new Uint8Array(binaryString.length);\n for (let i = 0; i < binaryString.length; i++) {\n bytes[i] = binaryString.charCodeAt(i);\n }\n return {\n data: bytes.buffer,\n mimeType: response.mimeType,\n filename: response.filename,\n };\n }\n\n // Folders\n async listFolders(\n connectionId: string,\n parentId?: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<IntegrationFolder>> {\n const params = new URLSearchParams({ connectionId });\n if (parentId) params.set(\"parentId\", parentId);\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n return this.http.get(`/integrations/storage/folders?${params}`);\n }\n\n async getFolder(connectionId: string, id: string): Promise<IntegrationFolder> {\n return this.http.get(`/integrations/storage/folders/${id}?connectionId=${connectionId}`);\n }\n\n async createFolder(connectionId: string, data: CreateFolderInput): Promise<IntegrationFolder> {\n return this.http.post(\"/integrations/storage/folders\", { connectionId, ...data });\n }\n\n async deleteFolder(connectionId: string, id: string): Promise<{ success: boolean }> {\n return this.http.delete(`/integrations/storage/folders/${id}?connectionId=${connectionId}`);\n }\n}\n\n/**\n * Communication operations client\n */\nclass Communication {\n private http: HttpClient;\n\n constructor(http: HttpClient) {\n this.http = http;\n }\n\n // Channels\n async listChannels(\n connectionId: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<Channel>> {\n const params = new URLSearchParams({ connectionId });\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n return this.http.get(`/integrations/communication/channels?${params}`);\n }\n\n async getChannel(connectionId: string, id: string): Promise<Channel> {\n return this.http.get(`/integrations/communication/channels/${id}?connectionId=${connectionId}`);\n }\n\n // Messages\n async listMessages(\n connectionId: string,\n channelId: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<Message>> {\n const params = new URLSearchParams({ connectionId, channelId });\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n return this.http.get(`/integrations/communication/messages?${params}`);\n }\n\n async sendMessage(connectionId: string, input: SendMessageInput): Promise<Message> {\n return this.http.post(\"/integrations/communication/messages\", { connectionId, ...input });\n }\n\n // Users\n async listUsers(\n connectionId: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<CommunicationUser>> {\n const params = new URLSearchParams({ connectionId });\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n return this.http.get(`/integrations/communication/users?${params}`);\n }\n}\n\n/**\n * Productivity operations client\n */\nclass Productivity {\n private http: HttpClient;\n\n constructor(http: HttpClient) {\n this.http = http;\n }\n\n // Documents\n async listDocuments(\n connectionId: string,\n parentId?: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<Document>> {\n const params = new URLSearchParams({ connectionId });\n if (parentId) params.set(\"parentId\", parentId);\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n return this.http.get(`/integrations/productivity/documents?${params}`);\n }\n\n async getDocument(connectionId: string, id: string): Promise<Document> {\n return this.http.get(`/integrations/productivity/documents/${id}?connectionId=${connectionId}`);\n }\n\n async createDocument(connectionId: string, data: CreateDocumentInput): Promise<Document> {\n return this.http.post(\"/integrations/productivity/documents\", { connectionId, ...data });\n }\n\n async updateDocument(connectionId: string, id: string, data: UpdateDocumentInput): Promise<Document> {\n return this.http.patch(`/integrations/productivity/documents/${id}`, { connectionId, ...data });\n }\n\n // Tables\n async listTables(\n connectionId: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<Table>> {\n const params = new URLSearchParams({ connectionId });\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n return this.http.get(`/integrations/productivity/tables?${params}`);\n }\n\n async getTable(connectionId: string, id: string): Promise<Table> {\n return this.http.get(`/integrations/productivity/tables/${id}?connectionId=${connectionId}`);\n }\n\n // Table Rows\n async listTableRows(\n connectionId: string,\n tableId: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<TableRow>> {\n const params = new URLSearchParams({ connectionId });\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n return this.http.get(`/integrations/productivity/tables/${tableId}/rows?${params}`);\n }\n\n async getTableRow(connectionId: string, tableId: string, rowId: string): Promise<TableRow> {\n return this.http.get(\n `/integrations/productivity/tables/${tableId}/rows/${rowId}?connectionId=${connectionId}`,\n );\n }\n\n async createTableRow(connectionId: string, tableId: string, data: CreateTableRowInput): Promise<TableRow> {\n return this.http.post(`/integrations/productivity/tables/${tableId}/rows`, {\n connectionId,\n ...data,\n });\n }\n\n async updateTableRow(\n connectionId: string,\n tableId: string,\n rowId: string,\n data: UpdateTableRowInput,\n ): Promise<TableRow> {\n return this.http.patch(`/integrations/productivity/tables/${tableId}/rows/${rowId}`, {\n connectionId,\n ...data,\n });\n }\n\n async deleteTableRow(\n connectionId: string,\n tableId: string,\n rowId: string,\n ): Promise<{ success: boolean }> {\n return this.http.delete(\n `/integrations/productivity/tables/${tableId}/rows/${rowId}?connectionId=${connectionId}`,\n );\n }\n}\n\n/**\n * Stack0 Integrations SDK Client\n *\n * @example\n * ```typescript\n * import { Integrations } from '@stack0/sdk';\n *\n * const integrations = new Integrations({ apiKey: 'stack0_...' });\n *\n * // List connectors\n * const connectors = await integrations.listConnectors();\n *\n * // List contacts from a CRM connection\n * const contacts = await integrations.crm.listContacts('conn_123');\n *\n * // Create a contact\n * const contact = await integrations.crm.createContact('conn_123', {\n * firstName: 'John',\n * lastName: 'Doe',\n * email: 'john@example.com',\n * });\n *\n * // Send a message via Slack\n * await integrations.communication.sendMessage('conn_456', {\n * channelId: 'C123',\n * content: 'Hello from Stack0!',\n * });\n *\n * // Upload a file to Google Drive\n * await integrations.storage.uploadFile('conn_789', {\n * name: 'report.pdf',\n * mimeType: 'application/pdf',\n * data: fileBuffer,\n * });\n * ```\n */\nexport class Integrations {\n private http: HttpClient;\n\n public crm: CRM;\n public storage: Storage;\n public communication: Communication;\n public productivity: Productivity;\n\n constructor(config: HttpClientConfig) {\n this.http = new HttpClient(config);\n\n this.crm = new CRM(this.http);\n this.storage = new Storage(this.http);\n this.communication = new Communication(this.http);\n this.productivity = new Productivity(this.http);\n }\n\n // ============================================================================\n // CONNECTORS\n // ============================================================================\n\n /**\n * List all available connectors\n */\n async listConnectors(category?: ConnectorCategory): Promise<Connector[]> {\n const params = category ? `?category=${category}` : \"\";\n return this.http.get(`/integrations/connectors${params}`);\n }\n\n /**\n * Get a specific connector\n */\n async getConnector(slug: string): Promise<Connector> {\n return this.http.get(`/integrations/connectors/${slug}`);\n }\n\n // ============================================================================\n // CONNECTIONS\n // ============================================================================\n\n /**\n * List all connections\n *\n * @example\n * ```typescript\n * const { connections } = await integrations.listConnections({\n * environment: 'production',\n * status: 'connected',\n * });\n * ```\n */\n async listConnections(request?: ListConnectionsRequest): Promise<ListConnectionsResponse> {\n const params = new URLSearchParams();\n if (request?.projectId) params.set(\"projectId\", request.projectId);\n if (request?.environment) params.set(\"environment\", request.environment);\n if (request?.connectorSlug) params.set(\"connectorSlug\", request.connectorSlug);\n if (request?.status) params.set(\"status\", request.status);\n if (request?.limit) params.set(\"limit\", request.limit.toString());\n const queryString = params.toString();\n\n const response = await this.http.get<ListConnectionsResponse>(\n `/integrations/connections${queryString ? `?${queryString}` : \"\"}`,\n );\n return {\n ...response,\n connections: response.connections.map((c) => this.convertConnectionDates(c)),\n };\n }\n\n /**\n * Get a specific connection\n */\n async getConnection(connectionId: string): Promise<ConnectionDetails> {\n const response = await this.http.get<ConnectionDetails>(`/integrations/connections/${connectionId}`);\n return this.convertConnectionDetailsDates(response);\n }\n\n /**\n * Initiate OAuth flow for a connector\n *\n * @example\n * ```typescript\n * const { authUrl, connectionId, state } = await integrations.initiateOAuth({\n * connectorSlug: 'hubspot',\n * redirectUrl: 'https://yourapp.com/oauth/callback',\n * name: 'My HubSpot Connection',\n * });\n * // Redirect user to authUrl\n * ```\n */\n async initiateOAuth(request: InitiateOAuthRequest): Promise<InitiateOAuthResponse> {\n return this.http.post<InitiateOAuthResponse>(\"/integrations/connections/oauth/initiate\", request);\n }\n\n /**\n * Complete OAuth flow with callback data\n *\n * @example\n * ```typescript\n * const result = await integrations.completeOAuth({\n * code: 'auth_code_from_callback',\n * state: 'state_from_initiate',\n * redirectUrl: 'https://yourapp.com/oauth/callback',\n * });\n * console.log(`Connected to: ${result.externalAccountName}`);\n * ```\n */\n async completeOAuth(request: CompleteOAuthRequest): Promise<CompleteOAuthResponse> {\n return this.http.post<CompleteOAuthResponse>(\"/integrations/connections/oauth/callback\", request);\n }\n\n /**\n * Update a connection\n */\n async updateConnection(request: UpdateConnectionRequest): Promise<UpdateConnectionResponse> {\n const { connectionId, ...data } = request;\n return this.http.patch<UpdateConnectionResponse>(`/integrations/connections/${connectionId}`, data);\n }\n\n /**\n * Delete a connection\n */\n async deleteConnection(connectionId: string): Promise<{ success: boolean }> {\n return this.http.delete(`/integrations/connections/${connectionId}`);\n }\n\n /**\n * Reconnect an expired or errored connection\n *\n * @example\n * ```typescript\n * const { authUrl, state } = await integrations.reconnectConnection({\n * connectionId: 'conn_123',\n * redirectUrl: 'https://yourapp.com/oauth/callback',\n * });\n * // Redirect user to authUrl\n * ```\n */\n async reconnectConnection(request: ReconnectConnectionRequest): Promise<ReconnectConnectionResponse> {\n return this.http.post<ReconnectConnectionResponse>(\n `/integrations/connections/${request.connectionId}/reconnect`,\n { redirectUrl: request.redirectUrl },\n );\n }\n\n /**\n * Get integration statistics\n *\n * @example\n * ```typescript\n * const stats = await integrations.getStats({ environment: 'production' });\n * console.log(`Active connections: ${stats.activeConnections}`);\n * console.log(`API calls last 30 days: ${stats.apiCallsLast30Days}`);\n * ```\n */\n async getStats(request?: IntegrationStatsRequest): Promise<IntegrationStatsResponse> {\n const params = new URLSearchParams();\n if (request?.environment) params.set(\"environment\", request.environment);\n const queryString = params.toString();\n return this.http.get<IntegrationStatsResponse>(\n `/integrations/connections/stats${queryString ? `?${queryString}` : \"\"}`,\n );\n }\n\n // ============================================================================\n // LOGS\n // ============================================================================\n\n /**\n * List API logs\n *\n * @example\n * ```typescript\n * const { logs } = await integrations.listLogs({\n * connectionId: 'conn_123',\n * limit: 50,\n * });\n * ```\n */\n async listLogs(request?: ListLogsRequest): Promise<ListLogsResponse> {\n const params = new URLSearchParams();\n if (request?.connectionId) params.set(\"connectionId\", request.connectionId);\n if (request?.connectorSlug) params.set(\"connectorSlug\", request.connectorSlug);\n if (request?.statusCode) params.set(\"statusCode\", request.statusCode.toString());\n if (request?.method) params.set(\"method\", request.method);\n if (request?.search) params.set(\"search\", request.search);\n if (request?.limit) params.set(\"limit\", request.limit.toString());\n if (request?.cursor) params.set(\"cursor\", request.cursor);\n const queryString = params.toString();\n\n const response = await this.http.get<ListLogsResponse>(\n `/integrations/logs${queryString ? `?${queryString}` : \"\"}`,\n );\n return {\n ...response,\n logs: response.logs.map((log) => this.convertLogDates(log)),\n };\n }\n\n // ============================================================================\n // PASSTHROUGH\n // ============================================================================\n\n /**\n * Make a raw passthrough request to the provider API\n */\n async passthrough(request: PassthroughRequest): Promise<unknown> {\n return this.http.post(\"/integrations/passthrough\", request);\n }\n\n // ============================================================================\n // Date Conversion Helpers\n // ============================================================================\n\n private convertConnectionDates<T extends { connectedAt?: Date | null; lastUsedAt?: Date | null; createdAt?: Date }>(\n connection: T,\n ): T {\n if (connection.connectedAt && typeof connection.connectedAt === \"string\") {\n connection.connectedAt = new Date(connection.connectedAt);\n }\n if (connection.lastUsedAt && typeof connection.lastUsedAt === \"string\") {\n connection.lastUsedAt = new Date(connection.lastUsedAt);\n }\n if (connection.createdAt && typeof connection.createdAt === \"string\") {\n connection.createdAt = new Date(connection.createdAt);\n }\n return connection;\n }\n\n private convertConnectionDetailsDates(connection: ConnectionDetails): ConnectionDetails {\n if (connection.connectedAt && typeof connection.connectedAt === \"string\") {\n connection.connectedAt = new Date(connection.connectedAt);\n }\n if (connection.lastUsedAt && typeof connection.lastUsedAt === \"string\") {\n connection.lastUsedAt = new Date(connection.lastUsedAt);\n }\n if (connection.lastErrorAt && typeof connection.lastErrorAt === \"string\") {\n connection.lastErrorAt = new Date(connection.lastErrorAt);\n }\n if (connection.createdAt && typeof connection.createdAt === \"string\") {\n connection.createdAt = new Date(connection.createdAt);\n }\n if (connection.updatedAt && typeof connection.updatedAt === \"string\") {\n connection.updatedAt = new Date(connection.updatedAt);\n }\n return connection;\n }\n\n private convertLogDates(log: ApiLog): ApiLog {\n if (typeof log.createdAt === \"string\") {\n log.createdAt = new Date(log.createdAt);\n }\n return log;\n }\n}\n","/**\n * Stack0 Marketing Client\n * Discover trends, generate content opportunities, and manage marketing content\n */\n\nimport { HttpClient, type HttpClientConfig } from \"../lib/http-client\";\nimport type {\n Trend,\n DiscoverTrendsRequest,\n DiscoverTrendsResponse,\n ListTrendsRequest,\n ListTrendsResponse,\n UpdateTrendStatusRequest,\n UpdateTrendStatusResponse,\n Opportunity,\n GenerateOpportunitiesRequest,\n GenerateOpportunitiesResponse,\n ListOpportunitiesRequest,\n ListOpportunitiesResponse,\n DismissOpportunityRequest,\n Content,\n CreateContentRequest,\n ListContentRequest,\n ListContentResponse,\n UpdateContentRequest,\n ApproveContentRequest,\n RejectContentRequest,\n Script,\n CreateScriptRequest,\n ListScriptsRequest,\n ListScriptsResponse,\n UpdateScriptRequest,\n CreateScriptVersionRequest,\n DeleteScriptResponse,\n AnalyticsOverviewRequest,\n AnalyticsOverviewResponse,\n ContentPerformanceRequest,\n ContentPerformanceResponse,\n TrendAnalyticsRequest,\n TrendAnalyticsResponse,\n OpportunityConversionRequest,\n OpportunityConversionResponse,\n CalendarEntry,\n ScheduleContentRequest,\n ListCalendarEntriesRequest,\n UpdateCalendarEntryRequest,\n CancelCalendarEntryResponse,\n MarkPublishedRequest,\n AssetJob,\n CreateAssetJobRequest,\n ListAssetJobsRequest,\n UpdateAssetJobStatusRequest,\n MarketingSettings,\n GetSettingsRequest,\n UpdateSettingsRequest,\n UpdateSettingsResponse,\n MarketingUsage,\n GetCurrentUsageRequest,\n CurrentUsageResponse,\n GetUsageHistoryRequest,\n GetTotalUsageRequest,\n TotalUsageResponse,\n RecordUsageRequest,\n} from \"./types\";\n\nexport class Marketing {\n private http: HttpClient;\n\n constructor(config: HttpClientConfig) {\n this.http = new HttpClient(config);\n }\n\n // ============================================================================\n // Trends\n // ============================================================================\n\n /**\n * Discover new trends from all sources\n *\n * @example\n * ```typescript\n * const { trendsDiscovered, trends } = await marketing.discoverTrends({\n * projectSlug: 'my-project',\n * environment: 'production',\n * });\n * console.log(`Discovered ${trendsDiscovered} new trends`);\n * ```\n */\n async discoverTrends(request: DiscoverTrendsRequest): Promise<DiscoverTrendsResponse> {\n return this.http.post<DiscoverTrendsResponse>(\"/marketing/trends/discover\", request);\n }\n\n /**\n * List trends for a project\n *\n * @example\n * ```typescript\n * const trends = await marketing.listTrends({\n * projectSlug: 'my-project',\n * environment: 'production',\n * limit: 20,\n * });\n * ```\n */\n async listTrends(request: ListTrendsRequest): Promise<Trend[]> {\n return this.http.get<Trend[]>(\n `/marketing/trends?${new URLSearchParams({\n projectSlug: request.projectSlug,\n environment: request.environment,\n ...(request.status && { status: request.status }),\n ...(request.limit && { limit: request.limit.toString() }),\n }).toString()}`,\n );\n }\n\n /**\n * Get a single trend by ID\n */\n async getTrend(trendId: string): Promise<Trend> {\n const response = await this.http.get<Trend>(`/marketing/trends/${trendId}`);\n return this.convertTrendDates(response);\n }\n\n /**\n * Update trend status\n *\n * @example\n * ```typescript\n * await marketing.updateTrendStatus({\n * trendId: 'trend-id',\n * status: 'active',\n * });\n * ```\n */\n async updateTrendStatus(request: UpdateTrendStatusRequest): Promise<UpdateTrendStatusResponse> {\n return this.http.patch<UpdateTrendStatusResponse>(`/marketing/trends/${request.trendId}/status`, {\n status: request.status,\n });\n }\n\n // ============================================================================\n // Opportunities\n // ============================================================================\n\n /**\n * Generate content opportunities from active trends\n *\n * @example\n * ```typescript\n * const { opportunitiesGenerated, opportunities } = await marketing.generateOpportunities({\n * projectSlug: 'my-project',\n * environment: 'production',\n * });\n * console.log(`Generated ${opportunitiesGenerated} new content ideas`);\n * ```\n */\n async generateOpportunities(request: GenerateOpportunitiesRequest): Promise<GenerateOpportunitiesResponse> {\n return this.http.post<GenerateOpportunitiesResponse>(\"/marketing/opportunities/generate\", request);\n }\n\n /**\n * List opportunities for a project\n *\n * @example\n * ```typescript\n * const opportunities = await marketing.listOpportunities({\n * projectSlug: 'my-project',\n * environment: 'production',\n * status: 'pending',\n * limit: 20,\n * });\n * ```\n */\n async listOpportunities(request: ListOpportunitiesRequest): Promise<Opportunity[]> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n environment: request.environment,\n ...(request.status && { status: request.status }),\n ...(request.limit && { limit: request.limit.toString() }),\n });\n\n return this.http.get<Opportunity[]>(`/marketing/opportunities?${params.toString()}`);\n }\n\n /**\n * Get a single opportunity by ID\n */\n async getOpportunity(opportunityId: string): Promise<Opportunity> {\n const response = await this.http.get<Opportunity>(`/marketing/opportunities/${opportunityId}`);\n return this.convertOpportunityDates(response);\n }\n\n /**\n * Dismiss an opportunity\n *\n * @example\n * ```typescript\n * await marketing.dismissOpportunity({ opportunityId: 'opp-id' });\n * ```\n */\n async dismissOpportunity(request: DismissOpportunityRequest): Promise<{ success: boolean }> {\n return this.http.post<{ success: boolean }>(`/marketing/opportunities/${request.opportunityId}/dismiss`, {});\n }\n\n // ============================================================================\n // Content\n // ============================================================================\n\n /**\n * Create new marketing content\n *\n * @example\n * ```typescript\n * const content = await marketing.createContent({\n * projectSlug: 'my-project',\n * environment: 'production',\n * contentType: 'tiktok_slideshow',\n * title: 'How AI is Changing Marketing',\n * opportunityId: 'opp-id',\n * });\n * ```\n */\n async createContent(request: CreateContentRequest): Promise<Content> {\n const response = await this.http.post<Content>(\"/marketing/content\", request);\n return this.convertContentDates(response);\n }\n\n /**\n * List content with filters\n *\n * @example\n * ```typescript\n * const content = await marketing.listContent({\n * projectSlug: 'my-project',\n * environment: 'production',\n * status: 'published',\n * limit: 20,\n * });\n * ```\n */\n async listContent(request: ListContentRequest): Promise<Content[]> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n environment: request.environment,\n ...(request.status && { status: request.status }),\n ...(request.contentType && { contentType: request.contentType }),\n ...(request.approvalStatus && { approvalStatus: request.approvalStatus }),\n ...(request.limit && { limit: request.limit.toString() }),\n ...(request.offset && { offset: request.offset.toString() }),\n });\n\n const response = await this.http.get<Content[]>(`/marketing/content?${params.toString()}`);\n return response.map((c) => this.convertContentDates(c));\n }\n\n /**\n * Get a single content by ID\n */\n async getContent(contentId: string): Promise<Content> {\n const response = await this.http.get<Content>(`/marketing/content/${contentId}`);\n return this.convertContentDates(response);\n }\n\n /**\n * Update content\n *\n * @example\n * ```typescript\n * const updated = await marketing.updateContent({\n * contentId: 'content-id',\n * title: 'Updated Title',\n * status: 'published',\n * });\n * ```\n */\n async updateContent(request: UpdateContentRequest): Promise<Content> {\n const { contentId, ...data } = request;\n const response = await this.http.patch<Content>(`/marketing/content/${contentId}`, data);\n return this.convertContentDates(response);\n }\n\n /**\n * Approve content for publishing\n *\n * @example\n * ```typescript\n * await marketing.approveContent({\n * contentId: 'content-id',\n * reviewNotes: 'Looks great!',\n * });\n * ```\n */\n async approveContent(request: ApproveContentRequest): Promise<Content> {\n const response = await this.http.post<Content>(`/marketing/content/${request.contentId}/approve`, request);\n return this.convertContentDates(response);\n }\n\n /**\n * Reject content\n *\n * @example\n * ```typescript\n * await marketing.rejectContent({\n * contentId: 'content-id',\n * reviewNotes: 'Needs revisions',\n * });\n * ```\n */\n async rejectContent(request: RejectContentRequest): Promise<Content> {\n const response = await this.http.post<Content>(`/marketing/content/${request.contentId}/reject`, request);\n return this.convertContentDates(response);\n }\n\n /**\n * Delete content\n */\n async deleteContent(contentId: string): Promise<{ success: boolean }> {\n return this.http.deleteWithBody<{ success: boolean }>(`/marketing/content/${contentId}`, { contentId });\n }\n\n // ============================================================================\n // Scripts\n // ============================================================================\n\n /**\n * Create a new script\n *\n * @example\n * ```typescript\n * const script = await marketing.createScript({\n * projectSlug: 'my-project',\n * environment: 'production',\n * hook: 'Are you ready to see the future?',\n * slides: [\n * { order: 0, text: 'AI is changing everything', voiceoverText: 'AI is transforming how we work', duration: 3 },\n * ],\n * cta: 'Follow for more insights!',\n * });\n * ```\n */\n async createScript(request: CreateScriptRequest): Promise<Script> {\n const response = await this.http.post<Script>(\"/marketing/scripts\", request);\n return this.convertScriptDates(response);\n }\n\n /**\n * List scripts\n */\n async listScripts(request: ListScriptsRequest): Promise<Script[]> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n environment: request.environment,\n ...(request.contentId && { contentId: request.contentId }),\n ...(request.limit && { limit: request.limit.toString() }),\n });\n\n const response = await this.http.get<Script[]>(`/marketing/scripts?${params.toString()}`);\n return response.map((s) => this.convertScriptDates(s));\n }\n\n /**\n * Get a single script by ID\n */\n async getScript(scriptId: string): Promise<Script> {\n const response = await this.http.get<Script>(`/marketing/scripts/${scriptId}`);\n return this.convertScriptDates(response);\n }\n\n /**\n * Update a script\n *\n * @example\n * ```typescript\n * const updated = await marketing.updateScript({\n * scriptId: 'script-id',\n * hook: 'Updated hook line',\n * cta: 'New call to action!',\n * });\n * ```\n */\n async updateScript(request: UpdateScriptRequest): Promise<Script> {\n const { scriptId, ...data } = request;\n const response = await this.http.patch<Script>(`/marketing/scripts/${scriptId}`, data);\n return this.convertScriptDates(response);\n }\n\n /**\n * Create a new version of a script\n *\n * @example\n * ```typescript\n * const newVersion = await marketing.createScriptVersion({\n * scriptId: 'script-id',\n * hook: 'Updated hook for v2',\n * slides: [...],\n * cta: 'Updated CTA',\n * });\n * ```\n */\n async createScriptVersion(request: CreateScriptVersionRequest): Promise<Script> {\n const { scriptId, ...data } = request;\n const response = await this.http.post<Script>(`/marketing/scripts/${scriptId}/versions`, data);\n return this.convertScriptDates(response);\n }\n\n /**\n * Get all versions of a script\n */\n async getScriptVersions(scriptId: string): Promise<Script[]> {\n const response = await this.http.get<Script[]>(`/marketing/scripts/${scriptId}/versions`);\n return response.map((s) => this.convertScriptDates(s));\n }\n\n /**\n * Delete a script\n */\n async deleteScript(scriptId: string): Promise<DeleteScriptResponse> {\n return this.http.delete<DeleteScriptResponse>(`/marketing/scripts/${scriptId}`);\n }\n\n // ============================================================================\n // Analytics\n // ============================================================================\n\n /**\n * Get analytics overview\n *\n * @example\n * ```typescript\n * const analytics = await marketing.getAnalyticsOverview({\n * projectSlug: 'my-project',\n * environment: 'production',\n * });\n * console.log(`Total content: ${analytics.totalContent}`);\n * console.log(`Total views: ${analytics.engagement.views}`);\n * ```\n */\n async getAnalyticsOverview(request: AnalyticsOverviewRequest): Promise<AnalyticsOverviewResponse> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n environment: request.environment,\n ...(request.startDate && { startDate: request.startDate.toISOString() }),\n ...(request.endDate && { endDate: request.endDate.toISOString() }),\n });\n\n return this.http.get<AnalyticsOverviewResponse>(`/marketing/analytics/overview?${params.toString()}`);\n }\n\n /**\n * Get content performance metrics\n *\n * @example\n * ```typescript\n * const topContent = await marketing.getContentPerformance({\n * projectSlug: 'my-project',\n * environment: 'production',\n * contentType: 'tiktok_slideshow',\n * limit: 10,\n * });\n * ```\n */\n async getContentPerformance(request: ContentPerformanceRequest): Promise<ContentPerformanceResponse> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n environment: request.environment,\n ...(request.contentType && { contentType: request.contentType }),\n ...(request.limit && { limit: request.limit.toString() }),\n });\n\n return this.http.get<ContentPerformanceResponse>(`/marketing/analytics/performance?${params.toString()}`);\n }\n\n /**\n * Get trend discovery analytics\n *\n * @example\n * ```typescript\n * const trendStats = await marketing.getTrendAnalytics({\n * projectSlug: 'my-project',\n * environment: 'production',\n * });\n * console.log(`Total trends: ${trendStats.totalTrends}`);\n * ```\n */\n async getTrendAnalytics(request: TrendAnalyticsRequest): Promise<TrendAnalyticsResponse> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n ...(request.environment && { environment: request.environment }),\n ...(request.startDate && { startDate: request.startDate.toISOString() }),\n ...(request.endDate && { endDate: request.endDate.toISOString() }),\n });\n\n return this.http.get<TrendAnalyticsResponse>(`/marketing/analytics/trends?${params.toString()}`);\n }\n\n /**\n * Get opportunity conversion analytics\n *\n * @example\n * ```typescript\n * const conversion = await marketing.getOpportunityConversion({\n * projectSlug: 'my-project',\n * environment: 'production',\n * });\n * console.log(`Conversion rate: ${conversion.conversionRate}%`);\n * ```\n */\n async getOpportunityConversion(request: OpportunityConversionRequest): Promise<OpportunityConversionResponse> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n ...(request.environment && { environment: request.environment }),\n ...(request.startDate && { startDate: request.startDate.toISOString() }),\n ...(request.endDate && { endDate: request.endDate.toISOString() }),\n });\n\n return this.http.get<OpportunityConversionResponse>(`/marketing/analytics/conversion?${params.toString()}`);\n }\n\n // ============================================================================\n // Calendar\n // ============================================================================\n\n /**\n * Schedule content for publishing\n *\n * @example\n * ```typescript\n * const entry = await marketing.scheduleContent({\n * projectSlug: 'my-project',\n * contentId: 'content-id',\n * scheduledFor: new Date('2024-12-25T10:00:00Z'),\n * autoPublish: true,\n * });\n * ```\n */\n async scheduleContent(request: ScheduleContentRequest): Promise<CalendarEntry> {\n const response = await this.http.post<CalendarEntry>(\"/marketing/calendar/schedule\", {\n ...request,\n scheduledFor: request.scheduledFor.toISOString(),\n });\n return this.convertCalendarEntryDates(response);\n }\n\n /**\n * List scheduled content\n *\n * @example\n * ```typescript\n * const entries = await marketing.listCalendarEntries({\n * projectSlug: 'my-project',\n * startDate: new Date('2024-12-01'),\n * endDate: new Date('2024-12-31'),\n * });\n * ```\n */\n async listCalendarEntries(request: ListCalendarEntriesRequest): Promise<CalendarEntry[]> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n ...(request.environment && { environment: request.environment }),\n ...(request.startDate && { startDate: request.startDate.toISOString() }),\n ...(request.endDate && { endDate: request.endDate.toISOString() }),\n ...(request.limit && { limit: request.limit.toString() }),\n ...(request.offset && { offset: request.offset.toString() }),\n });\n\n const response = await this.http.get<CalendarEntry[]>(`/marketing/calendar?${params.toString()}`);\n return response.map((e) => this.convertCalendarEntryDates(e));\n }\n\n /**\n * Get a single calendar entry by ID\n */\n async getCalendarEntry(entryId: string): Promise<CalendarEntry> {\n const response = await this.http.get<CalendarEntry>(`/marketing/calendar/${entryId}`);\n return this.convertCalendarEntryDates(response);\n }\n\n /**\n * Update a calendar entry\n *\n * @example\n * ```typescript\n * const updated = await marketing.updateCalendarEntry({\n * entryId: 'entry-id',\n * scheduledFor: new Date('2024-12-26T10:00:00Z'),\n * });\n * ```\n */\n async updateCalendarEntry(request: UpdateCalendarEntryRequest): Promise<CalendarEntry> {\n const { entryId, ...data } = request;\n const response = await this.http.patch<CalendarEntry>(`/marketing/calendar/${entryId}`, {\n ...data,\n ...(data.scheduledFor && { scheduledFor: data.scheduledFor.toISOString() }),\n });\n return this.convertCalendarEntryDates(response);\n }\n\n /**\n * Cancel a scheduled calendar entry\n */\n async cancelCalendarEntry(entryId: string): Promise<CancelCalendarEntryResponse> {\n return this.http.post<CancelCalendarEntryResponse>(`/marketing/calendar/${entryId}/cancel`, {});\n }\n\n /**\n * Mark content as published\n */\n async markContentPublished(request: MarkPublishedRequest): Promise<CalendarEntry> {\n const response = await this.http.post<CalendarEntry>(`/marketing/calendar/${request.entryId}/published`, {\n ...(request.publishedAt && { publishedAt: request.publishedAt.toISOString() }),\n });\n return this.convertCalendarEntryDates(response);\n }\n\n // ============================================================================\n // Assets (Asset Jobs)\n // ============================================================================\n\n /**\n * Create an asset generation job\n *\n * @example\n * ```typescript\n * const job = await marketing.createAssetJob({\n * projectSlug: 'my-project',\n * contentId: 'content-id',\n * jobType: 'slide_generation',\n * input: { style: 'modern' },\n * });\n * ```\n */\n async createAssetJob(request: CreateAssetJobRequest): Promise<AssetJob> {\n const response = await this.http.post<AssetJob>(\"/marketing/assets/jobs\", request);\n return this.convertAssetJobDates(response);\n }\n\n /**\n * List asset jobs\n *\n * @example\n * ```typescript\n * const jobs = await marketing.listAssetJobs({\n * projectSlug: 'my-project',\n * status: 'processing',\n * });\n * ```\n */\n async listAssetJobs(request: ListAssetJobsRequest): Promise<AssetJob[]> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n ...(request.contentId && { contentId: request.contentId }),\n ...(request.status && { status: request.status }),\n ...(request.jobType && { jobType: request.jobType }),\n ...(request.limit && { limit: request.limit.toString() }),\n ...(request.offset && { offset: request.offset.toString() }),\n });\n\n const response = await this.http.get<AssetJob[]>(`/marketing/assets/jobs?${params.toString()}`);\n return response.map((j) => this.convertAssetJobDates(j));\n }\n\n /**\n * Get an asset job by ID\n */\n async getAssetJob(jobId: string): Promise<AssetJob> {\n const response = await this.http.get<AssetJob>(`/marketing/assets/jobs/${jobId}`);\n return this.convertAssetJobDates(response);\n }\n\n /**\n * Update asset job status\n */\n async updateAssetJobStatus(request: UpdateAssetJobStatusRequest): Promise<AssetJob> {\n const { jobId, ...data } = request;\n const response = await this.http.patch<AssetJob>(`/marketing/assets/jobs/${jobId}/status`, data);\n return this.convertAssetJobDates(response);\n }\n\n /**\n * Retry a failed asset job\n */\n async retryAssetJob(jobId: string): Promise<AssetJob> {\n const response = await this.http.post<AssetJob>(`/marketing/assets/jobs/${jobId}/retry`, {});\n return this.convertAssetJobDates(response);\n }\n\n /**\n * Cancel an asset job\n */\n async cancelAssetJob(jobId: string): Promise<AssetJob> {\n const response = await this.http.post<AssetJob>(`/marketing/assets/jobs/${jobId}/cancel`, {});\n return this.convertAssetJobDates(response);\n }\n\n // ============================================================================\n // Settings\n // ============================================================================\n\n /**\n * Get marketing settings for a project\n *\n * @example\n * ```typescript\n * const settings = await marketing.getSettings({\n * projectSlug: 'my-project',\n * environment: 'production',\n * });\n * console.log(`Brand voice: ${settings.brandVoice}`);\n * ```\n */\n async getSettings(request: GetSettingsRequest): Promise<MarketingSettings> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n ...(request.environment && { environment: request.environment }),\n });\n\n return this.http.get<MarketingSettings>(`/marketing/settings?${params.toString()}`);\n }\n\n /**\n * Update marketing settings\n *\n * @example\n * ```typescript\n * await marketing.updateSettings({\n * projectSlug: 'my-project',\n * brandVoice: 'Professional yet approachable',\n * monitoredKeywords: ['AI', 'startup', 'tech'],\n * });\n * ```\n */\n async updateSettings(request: UpdateSettingsRequest): Promise<UpdateSettingsResponse> {\n return this.http.post<UpdateSettingsResponse>(\"/marketing/settings\", request);\n }\n\n // ============================================================================\n // Usage\n // ============================================================================\n\n /**\n * Get current period usage\n *\n * @example\n * ```typescript\n * const usage = await marketing.getCurrentUsage({\n * projectSlug: 'my-project',\n * environment: 'production',\n * });\n * console.log(`AI tokens used: ${usage.aiTokensUsed}`);\n * ```\n */\n async getCurrentUsage(request: GetCurrentUsageRequest): Promise<CurrentUsageResponse> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n ...(request.environment && { environment: request.environment }),\n });\n\n const response = await this.http.get<CurrentUsageResponse>(`/marketing/usage/current?${params.toString()}`);\n return this.convertUsageDates(response);\n }\n\n /**\n * Get usage history\n *\n * @example\n * ```typescript\n * const history = await marketing.getUsageHistory({\n * projectSlug: 'my-project',\n * limit: 6, // Last 6 months\n * });\n * ```\n */\n async getUsageHistory(request: GetUsageHistoryRequest): Promise<MarketingUsage[]> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n ...(request.environment && { environment: request.environment }),\n ...(request.startDate && { startDate: request.startDate.toISOString() }),\n ...(request.endDate && { endDate: request.endDate.toISOString() }),\n ...(request.limit && { limit: request.limit.toString() }),\n });\n\n const response = await this.http.get<MarketingUsage[]>(`/marketing/usage/history?${params.toString()}`);\n return response.map((u) => this.convertMarketingUsageDates(u));\n }\n\n /**\n * Get total usage across all periods\n *\n * @example\n * ```typescript\n * const totals = await marketing.getTotalUsage({\n * projectSlug: 'my-project',\n * startDate: new Date('2024-01-01'),\n * });\n * console.log(`Total content generated: ${totals.contentGenerated}`);\n * ```\n */\n async getTotalUsage(request: GetTotalUsageRequest): Promise<TotalUsageResponse> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n ...(request.environment && { environment: request.environment }),\n ...(request.startDate && { startDate: request.startDate.toISOString() }),\n ...(request.endDate && { endDate: request.endDate.toISOString() }),\n });\n\n return this.http.get<TotalUsageResponse>(`/marketing/usage/total?${params.toString()}`);\n }\n\n /**\n * Record usage (typically called internally)\n */\n async recordUsage(request: RecordUsageRequest): Promise<MarketingUsage> {\n const response = await this.http.post<MarketingUsage>(\"/marketing/usage/record\", request);\n return this.convertMarketingUsageDates(response);\n }\n\n // ============================================================================\n // Date Conversion Helpers\n // ============================================================================\n\n private convertTrendDates(trend: Trend): Trend {\n if (typeof trend.firstSeenAt === \"string\") {\n trend.firstSeenAt = new Date(trend.firstSeenAt);\n }\n if (typeof trend.lastUpdatedAt === \"string\") {\n trend.lastUpdatedAt = new Date(trend.lastUpdatedAt);\n }\n if (trend.expiresAt && typeof trend.expiresAt === \"string\") {\n trend.expiresAt = new Date(trend.expiresAt);\n }\n if (typeof trend.createdAt === \"string\") {\n trend.createdAt = new Date(trend.createdAt);\n }\n return trend;\n }\n\n private convertOpportunityDates(opp: Opportunity): Opportunity {\n if (typeof opp.createdAt === \"string\") {\n opp.createdAt = new Date(opp.createdAt);\n }\n if (opp.expiresAt && typeof opp.expiresAt === \"string\") {\n opp.expiresAt = new Date(opp.expiresAt);\n }\n if (opp.usedAt && typeof opp.usedAt === \"string\") {\n opp.usedAt = new Date(opp.usedAt);\n }\n return opp;\n }\n\n private convertContentDates(content: Content): Content {\n if (typeof content.createdAt === \"string\") {\n content.createdAt = new Date(content.createdAt);\n }\n if (content.updatedAt && typeof content.updatedAt === \"string\") {\n content.updatedAt = new Date(content.updatedAt);\n }\n if (content.reviewedAt && typeof content.reviewedAt === \"string\") {\n content.reviewedAt = new Date(content.reviewedAt);\n }\n if (content.publishedAt && typeof content.publishedAt === \"string\") {\n content.publishedAt = new Date(content.publishedAt);\n }\n return content;\n }\n\n private convertScriptDates(script: Script): Script {\n if (typeof script.createdAt === \"string\") {\n script.createdAt = new Date(script.createdAt);\n }\n return script;\n }\n\n private convertCalendarEntryDates(entry: CalendarEntry): CalendarEntry {\n if (typeof entry.scheduledFor === \"string\") {\n entry.scheduledFor = new Date(entry.scheduledFor);\n }\n if (typeof entry.createdAt === \"string\") {\n entry.createdAt = new Date(entry.createdAt);\n }\n if (entry.updatedAt && typeof entry.updatedAt === \"string\") {\n entry.updatedAt = new Date(entry.updatedAt);\n }\n if (entry.publishedAt && typeof entry.publishedAt === \"string\") {\n entry.publishedAt = new Date(entry.publishedAt);\n }\n return entry;\n }\n\n private convertAssetJobDates(job: AssetJob): AssetJob {\n if (typeof job.createdAt === \"string\") {\n job.createdAt = new Date(job.createdAt);\n }\n if (job.startedAt && typeof job.startedAt === \"string\") {\n job.startedAt = new Date(job.startedAt);\n }\n if (job.completedAt && typeof job.completedAt === \"string\") {\n job.completedAt = new Date(job.completedAt);\n }\n return job;\n }\n\n private convertUsageDates(usage: CurrentUsageResponse): CurrentUsageResponse {\n if (typeof usage.periodStart === \"string\") {\n usage.periodStart = new Date(usage.periodStart);\n }\n if (typeof usage.periodEnd === \"string\") {\n usage.periodEnd = new Date(usage.periodEnd);\n }\n return usage;\n }\n\n private convertMarketingUsageDates(usage: MarketingUsage): MarketingUsage {\n if (typeof usage.periodStart === \"string\") {\n usage.periodStart = new Date(usage.periodStart);\n }\n if (typeof usage.periodEnd === \"string\") {\n usage.periodEnd = new Date(usage.periodEnd);\n }\n if (typeof usage.createdAt === \"string\") {\n usage.createdAt = new Date(usage.createdAt);\n }\n if (usage.updatedAt && typeof usage.updatedAt === \"string\") {\n usage.updatedAt = new Date(usage.updatedAt);\n }\n return usage;\n }\n}\n","/**\n * Stack0 SDK\n * Official SDK for Stack0 services\n *\n * @example\n * ```typescript\n * import { Stack0 } from '@stack0/sdk';\n *\n * const stack0 = new Stack0({ apiKey: 'stack0_...' });\n *\n * // Send an email\n * await stack0.mail.send({\n * from: 'noreply@example.com',\n * to: 'user@example.com',\n * subject: 'Hello',\n * html: '<p>World</p>',\n * });\n *\n * // Upload a file to CDN\n * const asset = await stack0.cdn.upload({\n * projectSlug: 'my-project',\n * file: fileBuffer,\n * filename: 'image.jpg',\n * mimeType: 'image/jpeg',\n * });\n *\n * // Capture a screenshot\n * const screenshot = await stack0.screenshots.captureAndWait({\n * url: 'https://example.com',\n * format: 'png',\n * fullPage: true,\n * });\n *\n * // Extract content from a page\n * const extraction = await stack0.extraction.extractAndWait({\n * url: 'https://example.com/article',\n * mode: 'markdown',\n * });\n *\n * // List contacts from a connected CRM\n * const contacts = await stack0.integrations.crm.listContacts('conn_123');\n *\n * // Send a Slack message\n * await stack0.integrations.communication.sendMessage('conn_456', {\n * channelId: 'C123',\n * content: 'Hello from Stack0!',\n * });\n *\n * // Discover trends and generate content ideas\n * const { trendsDiscovered, trends } = await stack0.marketing.discoverTrends({\n * projectSlug: 'my-project',\n * environment: 'production',\n * });\n * ```\n */\n\nimport { Mail } from \"./mail/client\";\nimport { CDN } from \"./cdn/client\";\nimport { Screenshots } from \"./screenshots/client\";\nimport { Extraction } from \"./extraction/client\";\nimport { Webdata } from \"./webdata/client\";\nimport { Integrations } from \"./integrations/client\";\nimport { Marketing } from \"./marketing/client\";\nimport type { HttpClientConfig } from \"./lib/http-client\";\n\nexport interface Stack0Config extends HttpClientConfig {\n apiKey: string;\n baseUrl?: string;\n /**\n * CDN base URL for image transformations (e.g., 'https://cdn.yourproject.stack0.dev')\n * When provided, transform URLs are generated client-side without API calls\n */\n cdnUrl?: string;\n}\n\n/**\n * Main Stack0 SDK class\n * Provides access to all Stack0 services\n */\nexport class Stack0 {\n public mail: Mail;\n public cdn: CDN;\n public screenshots: Screenshots;\n public extraction: Extraction;\n public integrations: Integrations;\n public marketing: Marketing;\n\n /**\n * @deprecated Use `screenshots` and `extraction` instead. Will be removed in a future version.\n */\n public webdata: Webdata;\n\n constructor(config: Stack0Config) {\n const clientConfig = {\n apiKey: config.apiKey,\n baseUrl: config.baseUrl,\n };\n\n // Initialize clients\n this.mail = new Mail(clientConfig);\n this.cdn = new CDN(clientConfig, config.cdnUrl);\n this.screenshots = new Screenshots(clientConfig);\n this.extraction = new Extraction(clientConfig);\n this.integrations = new Integrations(clientConfig);\n this.marketing = new Marketing(clientConfig);\n\n // Keep webdata for backward compatibility\n this.webdata = new Webdata(clientConfig);\n }\n}\n\n// Export sub-modules\nexport * from \"./mail\";\nexport * from \"./cdn\";\nexport * from \"./screenshots\";\nexport * from \"./extraction\";\nexport * from \"./integrations\";\nexport * from \"./marketing\";\n\n// Export shared types\nexport * from \"./lib/shared-types\";\n\n// Re-export webdata client only (types are available from screenshots/extraction)\nexport { Webdata } from \"./webdata/client\";\n\n// Default export\nexport default Stack0;\n"]}
1
+ {"version":3,"sources":["../src/lib/http-client.ts","../src/mail/audiences.ts","../src/mail/campaigns.ts","../src/mail/contacts.ts","../src/mail/domains.ts","../src/mail/events.ts","../src/mail/sequences.ts","../src/mail/templates.ts","../src/mail/client.ts","../src/cdn/client.ts","../src/screenshots/client.ts","../src/extraction/client.ts","../src/webdata/client.ts","../src/integrations/client.ts","../src/marketing/client.ts","../src/index.ts"],"names":[],"mappings":"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","file":"index.js","sourcesContent":["/**\n * HTTP client for Stack0 API\n * Handles authentication, request/response formatting, and error handling\n */\n\nexport interface HttpClientConfig {\n apiKey: string;\n baseUrl?: string;\n}\n\nexport class HttpClient {\n private apiKey: string;\n private baseUrl: string;\n\n constructor(config: HttpClientConfig) {\n this.apiKey = config.apiKey;\n this.baseUrl = config.baseUrl || \"https://api.stack0.dev/v1\";\n }\n\n private getHeaders(includeContentType = true): Record<string, string> {\n const headers: Record<string, string> = {\n Authorization: `Bearer ${this.apiKey}`,\n };\n if (includeContentType) {\n headers[\"Content-Type\"] = \"application/json\";\n }\n return headers;\n }\n\n async request<T>(method: string, path: string, body?: unknown): Promise<T> {\n const url = `${this.baseUrl}${path}`;\n const bodyString = body === undefined ? undefined : JSON.stringify(body);\n const hasBody = bodyString !== undefined;\n\n try {\n const response = await fetch(url, {\n method,\n headers: this.getHeaders(hasBody),\n body: hasBody ? bodyString : undefined,\n });\n\n if (!response.ok) {\n await this.handleErrorResponse(response);\n }\n\n const data = await response.json();\n return data as T;\n } catch (error) {\n if (error instanceof Error && \"statusCode\" in error) {\n throw error; // Re-throw our custom errors\n }\n throw this.createError(\"Network error\", error);\n }\n }\n\n private async handleErrorResponse(response: Response): Promise<never> {\n let errorBody: { message: string } | undefined;\n try {\n errorBody = (await response.json()) as { message: string };\n } catch {\n errorBody = { message: response.statusText };\n }\n\n const error = new Error(errorBody?.message || `HTTP ${response.status}`) as Error & {\n statusCode: number;\n code: string;\n response: unknown;\n };\n error.statusCode = response.status;\n error.code = (errorBody as unknown as { code: string } | undefined)?.code ?? \"\";\n error.response = errorBody;\n throw error;\n }\n\n private createError(message: string, cause?: unknown): Error {\n const error = new Error(message) as Error & { cause: unknown };\n error.cause = cause;\n return error;\n }\n\n async get<T>(path: string): Promise<T> {\n return this.request<T>(\"GET\", path);\n }\n\n async post<T>(path: string, body: unknown): Promise<T> {\n return this.request<T>(\"POST\", path, body);\n }\n\n async put<T>(path: string, body: unknown): Promise<T> {\n return this.request<T>(\"PUT\", path, body);\n }\n\n async delete<T>(path: string): Promise<T> {\n return this.request<T>(\"DELETE\", path);\n }\n\n async deleteWithBody<T>(path: string, body: unknown): Promise<T> {\n return this.request<T>(\"DELETE\", path, body);\n }\n\n async patch<T>(path: string, body: unknown): Promise<T> {\n return this.request<T>(\"PATCH\", path, body);\n }\n}\n","/**\n * Audiences client for Stack0 Mail API\n */\n\nimport type { HttpClient } from \"../lib/http-client\";\nimport type {\n AddContactsToAudienceRequest,\n AddContactsToAudienceResponse,\n Audience,\n AudienceContact,\n CreateAudienceRequest,\n DeleteAudienceResponse,\n ListAudienceContactsRequest,\n ListAudienceContactsResponse,\n ListAudiencesRequest,\n ListAudiencesResponse,\n RemoveContactsFromAudienceRequest,\n RemoveContactsFromAudienceResponse,\n UpdateAudienceRequest,\n} from \"./types\";\n\nexport class Audiences {\n constructor(private http: HttpClient) {}\n\n /**\n * List all audiences\n */\n async list(request: ListAudiencesRequest = {}): Promise<ListAudiencesResponse> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.search) params.set(\"search\", request.search);\n\n const query = params.toString();\n return this.http.get<ListAudiencesResponse>(`/mail/audiences${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Get an audience by ID\n */\n async get(id: string): Promise<Audience> {\n return this.http.get<Audience>(`/mail/audiences/${id}`);\n }\n\n /**\n * Create a new audience\n */\n async create(request: CreateAudienceRequest): Promise<Audience> {\n return this.http.post<Audience>(\"/mail/audiences\", request);\n }\n\n /**\n * Update an audience\n */\n async update(request: UpdateAudienceRequest): Promise<Audience> {\n const { id, ...data } = request;\n return this.http.put<Audience>(`/mail/audiences/${id}`, data);\n }\n\n /**\n * Delete an audience\n */\n async delete(id: string): Promise<DeleteAudienceResponse> {\n return this.http.delete<DeleteAudienceResponse>(`/mail/audiences/${id}`);\n }\n\n /**\n * List contacts in an audience\n */\n async listContacts(request: ListAudienceContactsRequest): Promise<ListAudienceContactsResponse> {\n const { id, ...params } = request;\n const searchParams = new URLSearchParams();\n if (params.environment) searchParams.set(\"environment\", params.environment);\n if (params.limit) searchParams.set(\"limit\", params.limit.toString());\n if (params.offset) searchParams.set(\"offset\", params.offset.toString());\n if (params.search) searchParams.set(\"search\", params.search);\n if (params.status) searchParams.set(\"status\", params.status);\n\n const query = searchParams.toString();\n return this.http.get<ListAudienceContactsResponse>(`/mail/audiences/${id}/contacts${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Add contacts to an audience\n */\n async addContacts(request: AddContactsToAudienceRequest): Promise<AddContactsToAudienceResponse> {\n const { id, contactIds } = request;\n return this.http.post<AddContactsToAudienceResponse>(`/mail/audiences/${id}/contacts`, { contactIds });\n }\n\n /**\n * Remove contacts from an audience\n */\n async removeContacts(request: RemoveContactsFromAudienceRequest): Promise<RemoveContactsFromAudienceResponse> {\n const { id, contactIds } = request;\n return this.http.deleteWithBody<RemoveContactsFromAudienceResponse>(`/mail/audiences/${id}/contacts`, {\n contactIds,\n });\n }\n}\n","/**\n * Campaigns client for Stack0 Mail API\n */\n\nimport type { HttpClient } from \"../lib/http-client\";\nimport type {\n Campaign,\n CampaignStatsResponse,\n CancelCampaignResponse,\n CreateCampaignRequest,\n DeleteCampaignResponse,\n ListCampaignsRequest,\n ListCampaignsResponse,\n PauseCampaignResponse,\n SendCampaignRequest,\n SendCampaignResponse,\n UpdateCampaignRequest,\n} from \"./types\";\n\nexport class Campaigns {\n constructor(private http: HttpClient) {}\n\n /**\n * List all campaigns\n */\n async list(request: ListCampaignsRequest = {}): Promise<ListCampaignsResponse> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.search) params.set(\"search\", request.search);\n if (request.status) params.set(\"status\", request.status);\n\n const query = params.toString();\n return this.http.get<ListCampaignsResponse>(`/mail/campaigns${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Get a campaign by ID\n */\n async get(id: string): Promise<Campaign> {\n return this.http.get<Campaign>(`/mail/campaigns/${id}`);\n }\n\n /**\n * Create a new campaign\n */\n async create(request: CreateCampaignRequest): Promise<Campaign> {\n return this.http.post<Campaign>(\"/mail/campaigns\", request);\n }\n\n /**\n * Update a campaign\n */\n async update(request: UpdateCampaignRequest): Promise<Campaign> {\n const { id, ...data } = request;\n return this.http.put<Campaign>(`/mail/campaigns/${id}`, data);\n }\n\n /**\n * Delete a campaign\n */\n async delete(id: string): Promise<DeleteCampaignResponse> {\n return this.http.delete<DeleteCampaignResponse>(`/mail/campaigns/${id}`);\n }\n\n /**\n * Send a campaign\n */\n async send(request: SendCampaignRequest): Promise<SendCampaignResponse> {\n const { id, ...data } = request;\n return this.http.post<SendCampaignResponse>(`/mail/campaigns/${id}/send`, data);\n }\n\n /**\n * Pause a sending campaign\n */\n async pause(id: string): Promise<PauseCampaignResponse> {\n return this.http.post<PauseCampaignResponse>(`/mail/campaigns/${id}/pause`, {});\n }\n\n /**\n * Cancel a campaign\n */\n async cancel(id: string): Promise<CancelCampaignResponse> {\n return this.http.post<CancelCampaignResponse>(`/mail/campaigns/${id}/cancel`, {});\n }\n\n /**\n * Duplicate a campaign\n */\n async duplicate(id: string): Promise<Campaign> {\n return this.http.post<Campaign>(`/mail/campaigns/${id}/duplicate`, {});\n }\n\n /**\n * Get campaign statistics\n */\n async getStats(id: string): Promise<CampaignStatsResponse> {\n return this.http.get<CampaignStatsResponse>(`/mail/campaigns/${id}/stats`);\n }\n}\n","/**\n * Contacts client for Stack0 Mail API\n */\n\nimport type { HttpClient } from \"../lib/http-client\";\nimport type {\n MailContact,\n CreateContactRequest,\n DeleteContactResponse,\n ImportContactsRequest,\n ImportContactsResponse,\n ListContactsRequest,\n ListContactsResponse,\n UpdateContactRequest,\n} from \"./types\";\n\nexport class Contacts {\n constructor(private http: HttpClient) {}\n\n /**\n * List all contacts\n */\n async list(request: ListContactsRequest = {}): Promise<ListContactsResponse> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.search) params.set(\"search\", request.search);\n if (request.status) params.set(\"status\", request.status);\n\n const query = params.toString();\n return this.http.get<ListContactsResponse>(`/mail/contacts${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Get a contact by ID\n */\n async get(id: string): Promise<MailContact> {\n return this.http.get<MailContact>(`/mail/contacts/${id}`);\n }\n\n /**\n * Create a new contact\n */\n async create(request: CreateContactRequest): Promise<MailContact> {\n return this.http.post<MailContact>(\"/mail/contacts\", request);\n }\n\n /**\n * Update a contact\n */\n async update(request: UpdateContactRequest): Promise<MailContact> {\n const { id, ...data } = request;\n return this.http.put<MailContact>(`/mail/contacts/${id}`, data);\n }\n\n /**\n * Delete a contact\n */\n async delete(id: string): Promise<DeleteContactResponse> {\n return this.http.delete<DeleteContactResponse>(`/mail/contacts/${id}`);\n }\n\n /**\n * Import contacts in bulk\n */\n async import(request: ImportContactsRequest): Promise<ImportContactsResponse> {\n return this.http.post<ImportContactsResponse>(\"/mail/contacts/import\", request);\n }\n}\n","/**\n * Domains client for Stack0 Mail API\n */\n\nimport type { HttpClient } from \"../lib/http-client\";\nimport type {\n AddDomainRequest,\n AddDomainResponse,\n DeleteDomainResponse,\n Domain,\n GetDnsRecordsResponse,\n ListDomainsRequest,\n ListDomainsResponse,\n SetDefaultDomainResponse,\n VerifyDomainResponse,\n} from \"./types\";\n\nexport class Domains {\n constructor(private http: HttpClient) {}\n\n /**\n * List all domains for the organization\n */\n async list(request: ListDomainsRequest): Promise<ListDomainsResponse> {\n const params = new URLSearchParams();\n params.set(\"projectSlug\", request.projectSlug);\n if (request.environment) params.set(\"environment\", request.environment);\n\n return this.http.get<ListDomainsResponse>(`/mail/domains?${params.toString()}`);\n }\n\n /**\n * Add a new domain\n */\n async add(request: AddDomainRequest): Promise<AddDomainResponse> {\n return this.http.post<AddDomainResponse>(\"/mail/domains\", request);\n }\n\n /**\n * Get DNS records for a domain\n */\n async getDnsRecords(domainId: string): Promise<GetDnsRecordsResponse> {\n return this.http.get<GetDnsRecordsResponse>(`/mail/domains/${domainId}/dns`);\n }\n\n /**\n * Verify a domain\n */\n async verify(domainId: string): Promise<VerifyDomainResponse> {\n return this.http.post<VerifyDomainResponse>(`/mail/domains/${domainId}/verify`, {});\n }\n\n /**\n * Delete a domain\n */\n async delete(domainId: string): Promise<DeleteDomainResponse> {\n return this.http.delete<DeleteDomainResponse>(`/mail/domains/${domainId}`);\n }\n\n /**\n * Set a domain as the default\n */\n async setDefault(domainId: string): Promise<SetDefaultDomainResponse> {\n return this.http.post<SetDefaultDomainResponse>(`/mail/domains/${domainId}/default`, {});\n }\n}\n","/**\n * Events client for Stack0 Mail API\n */\n\nimport type { HttpClient } from \"../lib/http-client\";\nimport type {\n BatchTrackEventsRequest,\n BatchTrackEventsResponse,\n CreateEventRequest,\n DeleteEventResponse,\n EventAnalyticsResponse,\n ListEventOccurrencesRequest,\n ListEventOccurrencesResponse,\n ListEventsRequest,\n ListEventsResponse,\n MailEvent,\n TrackEventRequest,\n TrackEventResponse,\n UpdateEventRequest,\n} from \"./types\";\n\nexport class Events {\n constructor(private http: HttpClient) {}\n\n // ============================================================================\n // EVENT DEFINITIONS\n // ============================================================================\n\n /**\n * List all event definitions\n */\n async list(request: ListEventsRequest = {}): Promise<ListEventsResponse> {\n const params = new URLSearchParams();\n if (request.projectSlug) params.set(\"projectSlug\", request.projectSlug);\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.search) params.set(\"search\", request.search);\n\n const query = params.toString();\n return this.http.get<ListEventsResponse>(`/mail/events${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Get an event definition by ID\n */\n async get(id: string): Promise<MailEvent> {\n return this.http.get<MailEvent>(`/mail/events/${id}`);\n }\n\n /**\n * Create a new event definition\n */\n async create(request: CreateEventRequest): Promise<MailEvent> {\n return this.http.post<MailEvent>(\"/mail/events\", request);\n }\n\n /**\n * Update an event definition\n */\n async update(request: UpdateEventRequest): Promise<MailEvent> {\n const { id, ...data } = request;\n return this.http.put<MailEvent>(`/mail/events/${id}`, data);\n }\n\n /**\n * Delete an event definition\n */\n async delete(id: string): Promise<DeleteEventResponse> {\n return this.http.delete<DeleteEventResponse>(`/mail/events/${id}`);\n }\n\n // ============================================================================\n // EVENT TRACKING\n // ============================================================================\n\n /**\n * Track a single event\n * This can trigger email sequences configured to listen for this event\n */\n async track(request: TrackEventRequest): Promise<TrackEventResponse> {\n return this.http.post<TrackEventResponse>(\"/mail/events/track\", request);\n }\n\n /**\n * Track multiple events in a batch (max 100)\n */\n async trackBatch(request: BatchTrackEventsRequest): Promise<BatchTrackEventsResponse> {\n return this.http.post<BatchTrackEventsResponse>(\"/mail/events/track/batch\", request);\n }\n\n // ============================================================================\n // EVENT OCCURRENCES\n // ============================================================================\n\n /**\n * List event occurrences\n */\n async listOccurrences(request: ListEventOccurrencesRequest = {}): Promise<ListEventOccurrencesResponse> {\n const params = new URLSearchParams();\n if (request.eventId) params.set(\"eventId\", request.eventId);\n if (request.contactId) params.set(\"contactId\", request.contactId);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.startDate) {\n params.set(\"startDate\", request.startDate instanceof Date ? request.startDate.toISOString() : request.startDate);\n }\n if (request.endDate) {\n params.set(\"endDate\", request.endDate instanceof Date ? request.endDate.toISOString() : request.endDate);\n }\n\n const query = params.toString();\n return this.http.get<ListEventOccurrencesResponse>(`/mail/events/occurrences${query ? `?${query}` : \"\"}`);\n }\n\n // ============================================================================\n // ANALYTICS\n // ============================================================================\n\n /**\n * Get analytics for an event\n */\n async getAnalytics(id: string): Promise<EventAnalyticsResponse> {\n return this.http.get<EventAnalyticsResponse>(`/mail/events/analytics/${id}`);\n }\n}\n","/**\n * Sequences client for Stack0 Mail API\n */\n\nimport type { HttpClient } from \"../lib/http-client\";\nimport type {\n AddContactToSequenceRequest,\n ArchiveSequenceResponse,\n CreateConnectionRequest,\n CreateNodeRequest,\n CreateSequenceRequest,\n DeleteConnectionResponse,\n DeleteNodeResponse,\n DeleteSequenceResponse,\n ListSequenceEntriesRequest,\n ListSequenceEntriesResponse,\n ListSequencesRequest,\n ListSequencesResponse,\n PauseSequenceResponse,\n PublishSequenceResponse,\n RemoveContactFromSequenceRequest,\n RemoveContactFromSequenceResponse,\n ResumeSequenceResponse,\n Sequence,\n SequenceAnalyticsResponse,\n SequenceConnection,\n SequenceEntry,\n SequenceNode,\n SequenceWithNodes,\n SetNodeBranchRequest,\n SetNodeEmailRequest,\n SetNodeExperimentRequest,\n SetNodeFilterRequest,\n SetNodeTimerRequest,\n UpdateNodePositionRequest,\n UpdateNodeRequest,\n UpdateSequenceRequest,\n} from \"./types\";\n\nexport class Sequences {\n constructor(private http: HttpClient) {}\n\n // ============================================================================\n // SEQUENCE CRUD\n // ============================================================================\n\n /**\n * List all sequences\n */\n async list(request: ListSequencesRequest = {}): Promise<ListSequencesResponse> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.search) params.set(\"search\", request.search);\n if (request.status) params.set(\"status\", request.status);\n if (request.triggerType) params.set(\"triggerType\", request.triggerType);\n\n const query = params.toString();\n return this.http.get<ListSequencesResponse>(`/mail/sequences${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Get a sequence by ID with all nodes and connections\n */\n async get(id: string): Promise<SequenceWithNodes> {\n return this.http.get<SequenceWithNodes>(`/mail/sequences/${id}`);\n }\n\n /**\n * Create a new sequence\n */\n async create(request: CreateSequenceRequest): Promise<Sequence> {\n return this.http.post<Sequence>(\"/mail/sequences\", request);\n }\n\n /**\n * Update a sequence\n */\n async update(request: UpdateSequenceRequest): Promise<Sequence> {\n const { id, ...data } = request;\n return this.http.put<Sequence>(`/mail/sequences/${id}`, data);\n }\n\n /**\n * Delete a sequence\n */\n async delete(id: string): Promise<DeleteSequenceResponse> {\n return this.http.delete<DeleteSequenceResponse>(`/mail/sequences/${id}`);\n }\n\n // ============================================================================\n // SEQUENCE LIFECYCLE\n // ============================================================================\n\n /**\n * Publish (activate) a sequence\n */\n async publish(id: string): Promise<PublishSequenceResponse> {\n return this.http.post<PublishSequenceResponse>(`/mail/sequences/${id}/publish`, {});\n }\n\n /**\n * Pause an active sequence\n */\n async pause(id: string): Promise<PauseSequenceResponse> {\n return this.http.post<PauseSequenceResponse>(`/mail/sequences/${id}/pause`, {});\n }\n\n /**\n * Resume a paused sequence\n */\n async resume(id: string): Promise<ResumeSequenceResponse> {\n return this.http.post<ResumeSequenceResponse>(`/mail/sequences/${id}/resume`, {});\n }\n\n /**\n * Archive a sequence\n */\n async archive(id: string): Promise<ArchiveSequenceResponse> {\n return this.http.post<ArchiveSequenceResponse>(`/mail/sequences/${id}/archive`, {});\n }\n\n /**\n * Duplicate a sequence\n */\n async duplicate(id: string, name?: string): Promise<Sequence> {\n return this.http.post<Sequence>(`/mail/sequences/${id}/duplicate`, { name });\n }\n\n // ============================================================================\n // NODE MANAGEMENT\n // ============================================================================\n\n /**\n * Create a new node in a sequence\n */\n async createNode(request: CreateNodeRequest): Promise<SequenceNode> {\n const { id, ...data } = request;\n return this.http.post<SequenceNode>(`/mail/sequences/${id}/nodes`, data);\n }\n\n /**\n * Update a node\n */\n async updateNode(request: UpdateNodeRequest): Promise<SequenceNode> {\n const { id, nodeId, ...data } = request;\n return this.http.put<SequenceNode>(`/mail/sequences/${id}/nodes/${nodeId}`, data);\n }\n\n /**\n * Update node position (for visual editor)\n */\n async updateNodePosition(request: UpdateNodePositionRequest): Promise<SequenceNode> {\n const { id, nodeId, positionX, positionY } = request;\n return this.http.put<SequenceNode>(`/mail/sequences/${id}/nodes/${nodeId}/position`, { positionX, positionY });\n }\n\n /**\n * Delete a node\n */\n async deleteNode(sequenceId: string, nodeId: string): Promise<DeleteNodeResponse> {\n return this.http.delete<DeleteNodeResponse>(`/mail/sequences/${sequenceId}/nodes/${nodeId}`);\n }\n\n // ============================================================================\n // NODE CONFIGURATIONS\n // ============================================================================\n\n /**\n * Set email node content\n */\n async setNodeEmail(sequenceId: string, request: SetNodeEmailRequest): Promise<SequenceNode> {\n const { nodeId, ...data } = request;\n return this.http.put<SequenceNode>(`/mail/sequences/${sequenceId}/nodes/${nodeId}/email`, data);\n }\n\n /**\n * Set timer node configuration\n */\n async setNodeTimer(sequenceId: string, request: SetNodeTimerRequest): Promise<SequenceNode> {\n const { nodeId, ...data } = request;\n return this.http.put<SequenceNode>(`/mail/sequences/${sequenceId}/nodes/${nodeId}/timer`, data);\n }\n\n /**\n * Set filter node configuration\n */\n async setNodeFilter(sequenceId: string, request: SetNodeFilterRequest): Promise<SequenceNode> {\n const { nodeId, ...data } = request;\n return this.http.put<SequenceNode>(`/mail/sequences/${sequenceId}/nodes/${nodeId}/filter`, data);\n }\n\n /**\n * Set branch node configuration\n */\n async setNodeBranch(sequenceId: string, request: SetNodeBranchRequest): Promise<SequenceNode> {\n const { nodeId, ...data } = request;\n return this.http.put<SequenceNode>(`/mail/sequences/${sequenceId}/nodes/${nodeId}/branch`, data);\n }\n\n /**\n * Set experiment node configuration\n */\n async setNodeExperiment(sequenceId: string, request: SetNodeExperimentRequest): Promise<SequenceNode> {\n const { nodeId, ...data } = request;\n return this.http.put<SequenceNode>(`/mail/sequences/${sequenceId}/nodes/${nodeId}/experiment`, data);\n }\n\n // ============================================================================\n // CONNECTIONS\n // ============================================================================\n\n /**\n * Create a connection between nodes\n */\n async createConnection(request: CreateConnectionRequest): Promise<SequenceConnection> {\n const { id, ...data } = request;\n return this.http.post<SequenceConnection>(`/mail/sequences/${id}/connections`, data);\n }\n\n /**\n * Delete a connection\n */\n async deleteConnection(sequenceId: string, connectionId: string): Promise<DeleteConnectionResponse> {\n return this.http.delete<DeleteConnectionResponse>(`/mail/sequences/${sequenceId}/connections/${connectionId}`);\n }\n\n // ============================================================================\n // SEQUENCE ENTRIES (CONTACTS IN SEQUENCE)\n // ============================================================================\n\n /**\n * List contacts in a sequence\n */\n async listEntries(request: ListSequenceEntriesRequest): Promise<ListSequenceEntriesResponse> {\n const { id, ...params } = request;\n const searchParams = new URLSearchParams();\n if (params.limit) searchParams.set(\"limit\", params.limit.toString());\n if (params.offset) searchParams.set(\"offset\", params.offset.toString());\n if (params.status) searchParams.set(\"status\", params.status);\n\n const query = searchParams.toString();\n return this.http.get<ListSequenceEntriesResponse>(`/mail/sequences/${id}/entries${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Add a contact to a sequence\n */\n async addContact(request: AddContactToSequenceRequest): Promise<SequenceEntry> {\n const { id, contactId } = request;\n return this.http.post<SequenceEntry>(`/mail/sequences/${id}/add-contact`, { contactId });\n }\n\n /**\n * Remove a contact from a sequence\n */\n async removeContact(request: RemoveContactFromSequenceRequest): Promise<RemoveContactFromSequenceResponse> {\n const { id, entryId, reason } = request;\n return this.http.post<RemoveContactFromSequenceResponse>(`/mail/sequences/${id}/remove-contact`, {\n entryId,\n reason,\n });\n }\n\n // ============================================================================\n // ANALYTICS\n // ============================================================================\n\n /**\n * Get sequence analytics\n */\n async getAnalytics(id: string): Promise<SequenceAnalyticsResponse> {\n return this.http.get<SequenceAnalyticsResponse>(`/mail/sequences/${id}/analytics`);\n }\n}\n","/**\n * Templates client for Stack0 Mail API\n */\n\nimport type { HttpClient } from \"../lib/http-client\";\nimport type {\n CreateTemplateRequest,\n DeleteTemplateResponse,\n ListTemplatesRequest,\n ListTemplatesResponse,\n PreviewTemplateRequest,\n PreviewTemplateResponse,\n Template,\n UpdateTemplateRequest,\n} from \"./types\";\n\nexport class Templates {\n constructor(private http: HttpClient) {}\n\n /**\n * List all templates\n */\n async list(request: ListTemplatesRequest = {}): Promise<ListTemplatesResponse> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.isActive !== undefined) params.set(\"isActive\", request.isActive.toString());\n if (request.search) params.set(\"search\", request.search);\n\n const query = params.toString();\n return this.http.get<ListTemplatesResponse>(`/mail/templates${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Get a template by ID\n */\n async get(id: string): Promise<Template> {\n return this.http.get<Template>(`/mail/templates/${id}`);\n }\n\n /**\n * Get a template by slug\n */\n async getBySlug(slug: string): Promise<Template> {\n return this.http.get<Template>(`/mail/templates/slug/${slug}`);\n }\n\n /**\n * Create a new template\n */\n async create(request: CreateTemplateRequest): Promise<Template> {\n return this.http.post<Template>(\"/mail/templates\", request);\n }\n\n /**\n * Update a template\n */\n async update(request: UpdateTemplateRequest): Promise<Template> {\n const { id, ...data } = request;\n return this.http.put<Template>(`/mail/templates/${id}`, data);\n }\n\n /**\n * Delete a template\n */\n async delete(id: string): Promise<DeleteTemplateResponse> {\n return this.http.delete<DeleteTemplateResponse>(`/mail/templates/${id}`);\n }\n\n /**\n * Preview a template with variables\n */\n async preview(request: PreviewTemplateRequest): Promise<PreviewTemplateResponse> {\n const { id, variables } = request;\n return this.http.post<PreviewTemplateResponse>(`/mail/templates/${id}/preview`, { variables });\n }\n}\n","/**\n * Stack0 Mail Client\n * Complete email API with support for transactional emails, campaigns, sequences, and more\n */\n\nimport { HttpClient, type HttpClientConfig } from \"../lib/http-client\";\nimport { Audiences } from \"./audiences\";\nimport { Campaigns } from \"./campaigns\";\nimport { Contacts } from \"./contacts\";\nimport { Domains } from \"./domains\";\nimport { Events } from \"./events\";\nimport { Sequences } from \"./sequences\";\nimport { Templates } from \"./templates\";\nimport type {\n CancelEmailResponse,\n EmailAnalyticsResponse,\n GetEmailResponse,\n HourlyAnalyticsResponse,\n ListEmailsRequest,\n ListEmailsResponse,\n ListSendersRequest,\n ListSendersResponse,\n ResendEmailResponse,\n SendBatchEmailRequest,\n SendBatchEmailResponse,\n SendBroadcastEmailRequest,\n SendBroadcastEmailResponse,\n SendEmailRequest,\n SendEmailResponse,\n TimeSeriesAnalyticsRequest,\n TimeSeriesAnalyticsResponse,\n} from \"./types\";\n\nexport class Mail {\n private http: HttpClient;\n\n /** Manage sending domains */\n readonly domains: Domains;\n\n /** Manage email templates */\n readonly templates: Templates;\n\n /** Manage contact audiences/lists */\n readonly audiences: Audiences;\n\n /** Manage contacts */\n readonly contacts: Contacts;\n\n /** Manage email campaigns */\n readonly campaigns: Campaigns;\n\n /** Manage automated email sequences */\n readonly sequences: Sequences;\n\n /** Track and manage custom events */\n readonly events: Events;\n\n constructor(config: HttpClientConfig) {\n this.http = new HttpClient(config);\n\n // Initialize sub-clients\n this.domains = new Domains(this.http);\n this.templates = new Templates(this.http);\n this.audiences = new Audiences(this.http);\n this.contacts = new Contacts(this.http);\n this.campaigns = new Campaigns(this.http);\n this.sequences = new Sequences(this.http);\n this.events = new Events(this.http);\n }\n\n // ============================================================================\n // TRANSACTIONAL EMAILS\n // ============================================================================\n\n /**\n * Send a single email\n *\n * @example\n * ```typescript\n * const result = await mail.send({\n * from: 'noreply@example.com',\n * to: 'user@example.com',\n * subject: 'Hello World',\n * html: '<p>Welcome!</p>',\n * });\n * ```\n */\n async send(request: SendEmailRequest): Promise<SendEmailResponse> {\n return this.http.post<SendEmailResponse>(\"/mail/send\", request);\n }\n\n /**\n * Send multiple emails in a batch (up to 100)\n * Each email can have different content and recipients\n *\n * @example\n * ```typescript\n * const result = await mail.sendBatch({\n * emails: [\n * { from: 'noreply@example.com', to: 'user1@example.com', subject: 'Hello', html: '<p>Hi User 1</p>' },\n * { from: 'noreply@example.com', to: 'user2@example.com', subject: 'Hello', html: '<p>Hi User 2</p>' },\n * ]\n * });\n * ```\n */\n async sendBatch(request: SendBatchEmailRequest): Promise<SendBatchEmailResponse> {\n return this.http.post<SendBatchEmailResponse>(\"/mail/send/batch\", request);\n }\n\n /**\n * Send a broadcast email (same content to multiple recipients, up to 1000)\n *\n * @example\n * ```typescript\n * const result = await mail.sendBroadcast({\n * from: 'noreply@example.com',\n * to: ['user1@example.com', 'user2@example.com', 'user3@example.com'],\n * subject: 'Newsletter',\n * html: '<p>Our latest updates...</p>',\n * });\n * ```\n */\n async sendBroadcast(request: SendBroadcastEmailRequest): Promise<SendBroadcastEmailResponse> {\n return this.http.post<SendBroadcastEmailResponse>(\"/mail/send/broadcast\", request);\n }\n\n /**\n * Get email details by ID\n *\n * @example\n * ```typescript\n * const email = await mail.get('email-id');\n * console.log(email.status); // 'delivered'\n * ```\n */\n async get(id: string): Promise<GetEmailResponse> {\n return this.http.get<GetEmailResponse>(`/mail/${id}`);\n }\n\n /**\n * List emails with optional filters\n *\n * @example\n * ```typescript\n * const result = await mail.list({\n * status: 'delivered',\n * limit: 50,\n * });\n * ```\n */\n async list(request: ListEmailsRequest = {}): Promise<ListEmailsResponse> {\n const params = new URLSearchParams();\n if (request.projectSlug) params.set(\"projectSlug\", request.projectSlug);\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.status) params.set(\"status\", request.status);\n if (request.from) params.set(\"from\", request.from);\n if (request.to) params.set(\"to\", request.to);\n if (request.subject) params.set(\"subject\", request.subject);\n if (request.tag) params.set(\"tag\", request.tag);\n if (request.startDate) {\n params.set(\"startDate\", request.startDate instanceof Date ? request.startDate.toISOString() : request.startDate);\n }\n if (request.endDate) {\n params.set(\"endDate\", request.endDate instanceof Date ? request.endDate.toISOString() : request.endDate);\n }\n if (request.sortBy) params.set(\"sortBy\", request.sortBy);\n if (request.sortOrder) params.set(\"sortOrder\", request.sortOrder);\n\n const query = params.toString();\n return this.http.get<ListEmailsResponse>(`/mail${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Resend a previously sent email\n */\n async resend(id: string): Promise<ResendEmailResponse> {\n return this.http.post<ResendEmailResponse>(`/mail/${id}/resend`, {});\n }\n\n /**\n * Cancel a scheduled email\n */\n async cancel(id: string): Promise<CancelEmailResponse> {\n return this.http.post<CancelEmailResponse>(`/mail/${id}/cancel`, {});\n }\n\n // ============================================================================\n // ANALYTICS\n // ============================================================================\n\n /**\n * Get overall email analytics\n */\n async getAnalytics(): Promise<EmailAnalyticsResponse> {\n return this.http.get<EmailAnalyticsResponse>(\"/mail/analytics\");\n }\n\n /**\n * Get time series analytics (daily breakdown)\n */\n async getTimeSeriesAnalytics(request: TimeSeriesAnalyticsRequest = {}): Promise<TimeSeriesAnalyticsResponse> {\n const params = new URLSearchParams();\n if (request.days) params.set(\"days\", request.days.toString());\n\n const query = params.toString();\n return this.http.get<TimeSeriesAnalyticsResponse>(`/mail/analytics/timeseries${query ? `?${query}` : \"\"}`);\n }\n\n /**\n * Get hourly analytics\n */\n async getHourlyAnalytics(): Promise<HourlyAnalyticsResponse> {\n return this.http.get<HourlyAnalyticsResponse>(\"/mail/analytics/hourly\");\n }\n\n /**\n * List unique senders with their statistics\n */\n async listSenders(request: ListSendersRequest = {}): Promise<ListSendersResponse> {\n const params = new URLSearchParams();\n if (request.projectSlug) params.set(\"projectSlug\", request.projectSlug);\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.search) params.set(\"search\", request.search);\n\n const query = params.toString();\n return this.http.get<ListSendersResponse>(`/mail/senders${query ? `?${query}` : \"\"}`);\n }\n}\n","/**\n * Stack0 CDN Client\n * Upload, manage, and transform assets\n */\n\nimport { HttpClient, type HttpClientConfig } from \"../lib/http-client\";\nimport type {\n Asset,\n UploadUrlRequest,\n UploadUrlResponse,\n UpdateAssetRequest,\n DeleteAssetsResponse,\n ListAssetsRequest,\n ListAssetsResponse,\n MoveAssetsRequest,\n MoveAssetsResponse,\n TransformOptions,\n GetFolderTreeRequest,\n FolderTreeNode,\n CreateFolderRequest,\n Folder,\n TranscodeVideoRequest,\n TranscodeJob,\n ListJobsRequest,\n ListJobsResponse,\n StreamingUrls,\n ThumbnailRequest,\n ThumbnailResponse,\n RegenerateThumbnailRequest,\n RegenerateThumbnailResponse,\n ExtractAudioRequest,\n ExtractAudioResponse,\n // Private Files\n PrivateFile,\n PrivateUploadUrlRequest,\n PrivateUploadUrlResponse,\n PrivateDownloadUrlRequest,\n PrivateDownloadUrlResponse,\n ListPrivateFilesRequest,\n ListPrivateFilesResponse,\n UpdatePrivateFileRequest,\n MovePrivateFilesRequest,\n MovePrivateFilesResponse,\n // Bundles\n DownloadBundle,\n CreateBundleRequest,\n CreateBundleResponse,\n ListBundlesRequest,\n ListBundlesResponse,\n BundleDownloadUrlRequest,\n BundleDownloadUrlResponse,\n // Usage\n CdnUsageRequest,\n CdnUsageResponse,\n CdnUsageHistoryRequest,\n CdnUsageHistoryResponse,\n CdnUsageDataPoint,\n CdnStorageBreakdownRequest,\n CdnStorageBreakdownResponse,\n // Additional Folder Types\n UpdateFolderRequest,\n ListFoldersRequest,\n ListFoldersResponse,\n FolderListItem,\n MoveFolderRequest,\n MoveFolderResponse,\n // Additional Video Types\n VideoThumbnail,\n ListThumbnailsResponse,\n // Video Merge Types\n CreateMergeJobRequest,\n MergeJob,\n MergeJobWithOutput,\n ListMergeJobsRequest,\n ListMergeJobsResponse,\n // Image Watermark Types\n ImageWatermarkConfig,\n} from \"./types\";\n\n// Allowed widths that match the CloudFront url-rewriter configuration\nconst ALLOWED_WIDTHS = [256, 384, 640, 750, 828, 1080, 1200, 1920, 2048, 3840];\n\nexport class CDN {\n private http: HttpClient;\n private cdnUrl?: string;\n\n constructor(config: HttpClientConfig, cdnUrl?: string) {\n this.http = new HttpClient(config);\n this.cdnUrl = cdnUrl;\n }\n\n /**\n * Generate a presigned URL for uploading a file\n *\n * @example\n * ```typescript\n * const { uploadUrl, assetId } = await cdn.getUploadUrl({\n * projectSlug: 'my-project',\n * filename: 'image.jpg',\n * mimeType: 'image/jpeg',\n * size: 1024 * 1024,\n * });\n *\n * // Upload file to the presigned URL\n * await fetch(uploadUrl, {\n * method: 'PUT',\n * body: file,\n * headers: { 'Content-Type': 'image/jpeg' },\n * });\n *\n * // Confirm the upload\n * const asset = await cdn.confirmUpload(assetId);\n * ```\n */\n async getUploadUrl(request: UploadUrlRequest): Promise<UploadUrlResponse> {\n const response = await this.http.post<UploadUrlResponse>(\"/cdn/upload\", request);\n\n if (typeof response.expiresAt === \"string\") {\n response.expiresAt = new Date(response.expiresAt);\n }\n\n return response;\n }\n\n /**\n * Confirm that an upload has completed\n */\n async confirmUpload(assetId: string): Promise<Asset> {\n const response = await this.http.post<Asset>(`/cdn/upload/${assetId}/confirm`, {});\n return this.convertAssetDates(response);\n }\n\n /**\n * Upload a file directly (handles presigned URL flow automatically)\n *\n * @example\n * ```typescript\n * const asset = await cdn.upload({\n * projectSlug: 'my-project',\n * file: fileBuffer,\n * filename: 'image.jpg',\n * mimeType: 'image/jpeg',\n * });\n *\n * // With watermark\n * const watermarkedAsset = await cdn.upload({\n * projectSlug: 'my-project',\n * file: fileBuffer,\n * filename: 'photo.jpg',\n * mimeType: 'image/jpeg',\n * watermark: {\n * assetId: 'logo-asset-id', // or url: 'https://example.com/logo.png'\n * position: 'bottom-right',\n * opacity: 50,\n * sizingMode: 'relative',\n * width: 15, // 15% of image width\n * },\n * });\n * ```\n */\n async upload(options: {\n projectSlug: string;\n file: Blob | Buffer | ArrayBuffer;\n filename: string;\n mimeType: string;\n folder?: string;\n metadata?: Record<string, unknown>;\n /** Watermark configuration for images (applied during upload processing) */\n watermark?: ImageWatermarkConfig;\n }): Promise<Asset> {\n const { projectSlug, file, filename, mimeType, folder, metadata, watermark } = options;\n\n // Get file size\n let size: number;\n if (file instanceof Blob) {\n size = file.size;\n } else if (file instanceof ArrayBuffer) {\n size = file.byteLength;\n } else {\n // Buffer\n size = (file as Buffer).length;\n }\n\n // Get presigned URL\n const { uploadUrl, assetId } = await this.getUploadUrl({\n projectSlug,\n filename,\n mimeType,\n size,\n folder,\n metadata,\n watermark,\n });\n\n // Upload file\n const uploadResponse = await fetch(uploadUrl, {\n method: \"PUT\",\n body: file,\n headers: {\n \"Content-Type\": mimeType,\n },\n });\n\n if (!uploadResponse.ok) {\n throw new Error(`Upload failed: ${uploadResponse.statusText}`);\n }\n\n // Confirm upload\n return this.confirmUpload(assetId);\n }\n\n /**\n * Get an asset by ID\n *\n * @example\n * ```typescript\n * const asset = await cdn.get('asset-id');\n * console.log(asset.cdnUrl);\n * ```\n */\n async get(id: string): Promise<Asset> {\n const response = await this.http.get<Asset>(`/cdn/assets/${id}`);\n return this.convertAssetDates(response);\n }\n\n /**\n * Update asset metadata\n *\n * @example\n * ```typescript\n * const asset = await cdn.update({\n * id: 'asset-id',\n * alt: 'A beautiful sunset',\n * tags: ['nature', 'sunset'],\n * });\n * ```\n */\n async update(request: UpdateAssetRequest): Promise<Asset> {\n const { id, ...data } = request;\n const response = await this.http.patch<Asset>(`/cdn/assets/${id}`, data);\n return this.convertAssetDates(response);\n }\n\n /**\n * Delete an asset\n *\n * @example\n * ```typescript\n * await cdn.delete('asset-id');\n * ```\n */\n async delete(id: string): Promise<{ success: boolean }> {\n // NOTE: Our OpenAPI adapter parses JSON bodies for non-GET methods.\n // Some Fastify setups will throw if Content-Type is JSON but the body is empty.\n // Sending the id in the body keeps this endpoint compatible across adapters.\n return this.http.deleteWithBody<{ success: boolean }>(`/cdn/assets/${id}`, { id });\n }\n\n /**\n * Delete multiple assets\n *\n * @example\n * ```typescript\n * const result = await cdn.deleteMany(['asset-1', 'asset-2']);\n * console.log(`Deleted ${result.deletedCount} assets`);\n * ```\n */\n async deleteMany(ids: string[]): Promise<DeleteAssetsResponse> {\n return this.http.post<DeleteAssetsResponse>(\"/cdn/assets/delete\", { ids });\n }\n\n /**\n * List assets with filters and pagination\n *\n * @example\n * ```typescript\n * const { assets, total, hasMore } = await cdn.list({\n * projectSlug: 'my-project',\n * type: 'image',\n * limit: 20,\n * });\n * ```\n */\n async list(request: ListAssetsRequest): Promise<ListAssetsResponse> {\n const params = new URLSearchParams();\n\n params.set(\"projectSlug\", request.projectSlug);\n if (request.folder !== undefined) params.set(\"folder\", request.folder ?? \"\");\n if (request.type) params.set(\"type\", request.type);\n if (request.status) params.set(\"status\", request.status);\n if (request.search) params.set(\"search\", request.search);\n if (request.tags) params.set(\"tags\", request.tags.join(\",\"));\n if (request.sortBy) params.set(\"sortBy\", request.sortBy);\n if (request.sortOrder) params.set(\"sortOrder\", request.sortOrder);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n\n const response = await this.http.get<ListAssetsResponse>(`/cdn/assets?${params.toString()}`);\n\n return {\n ...response,\n assets: response.assets.map((asset) => this.convertAssetDates(asset)),\n };\n }\n\n /**\n * Move assets to a different folder\n *\n * @example\n * ```typescript\n * await cdn.move({\n * assetIds: ['asset-1', 'asset-2'],\n * folder: '/images/archive',\n * });\n * ```\n */\n async move(request: MoveAssetsRequest): Promise<MoveAssetsResponse> {\n return this.http.post<MoveAssetsResponse>(\"/cdn/assets/move\", request);\n }\n\n /**\n * Get a transformed image URL (client-side, no API call)\n *\n * @example\n * ```typescript\n * // Using asset's cdnUrl directly\n * const url = cdn.getTransformUrl(asset.cdnUrl, {\n * width: 800,\n * height: 600,\n * fit: 'cover',\n * format: 'webp',\n * quality: 80,\n * });\n *\n * // Or using cdnUrl from SDK config + s3Key\n * const url = cdn.getTransformUrl(asset.s3Key, { width: 400 });\n * ```\n */\n getTransformUrl(assetUrlOrS3Key: string, options: TransformOptions): string {\n // Determine base URL\n let baseUrl: string;\n if (assetUrlOrS3Key.startsWith(\"http://\") || assetUrlOrS3Key.startsWith(\"https://\")) {\n // It's already a full URL - extract base and path\n const url = new URL(assetUrlOrS3Key);\n baseUrl = `${url.protocol}//${url.host}${url.pathname}`;\n } else if (this.cdnUrl) {\n // It's an s3Key, use configured CDN URL\n const cdnBase = this.cdnUrl.endsWith(\"/\") ? this.cdnUrl.slice(0, -1) : this.cdnUrl;\n baseUrl = `${cdnBase}/${assetUrlOrS3Key}`;\n } else {\n throw new Error(\"getTransformUrl requires either a full URL or cdnUrl to be configured in Stack0 options\");\n }\n\n // Build query string\n const params = this.buildTransformQuery(options);\n if (!params) {\n return baseUrl;\n }\n return `${baseUrl}?${params}`;\n }\n\n /**\n * Build transform query parameters\n */\n private buildTransformQuery(options: TransformOptions): string {\n const params = new URLSearchParams();\n\n if (options.format) params.set(\"f\", options.format);\n if (options.quality !== undefined) params.set(\"q\", options.quality.toString());\n\n if (options.width !== undefined) {\n // Snap to nearest allowed width for better caching\n const width = this.getNearestWidth(options.width);\n params.set(\"w\", width.toString());\n }\n if (options.height !== undefined) params.set(\"h\", options.height.toString());\n if (options.fit) params.set(\"fit\", options.fit);\n if (options.crop) params.set(\"crop\", options.crop);\n if (options.cropX !== undefined) params.set(\"crop-x\", options.cropX.toString());\n if (options.cropY !== undefined) params.set(\"crop-y\", options.cropY.toString());\n if (options.cropWidth !== undefined) params.set(\"crop-w\", options.cropWidth.toString());\n if (options.cropHeight !== undefined) params.set(\"crop-h\", options.cropHeight.toString());\n if (options.blur !== undefined) params.set(\"blur\", options.blur.toString());\n if (options.sharpen !== undefined) params.set(\"sharpen\", options.sharpen.toString());\n if (options.brightness !== undefined) params.set(\"brightness\", options.brightness.toString());\n if (options.saturation !== undefined) params.set(\"saturation\", options.saturation.toString());\n if (options.grayscale) params.set(\"grayscale\", \"true\");\n if (options.rotate !== undefined) params.set(\"rotate\", options.rotate.toString());\n if (options.flip) params.set(\"flip\", \"y\");\n if (options.flop) params.set(\"flop\", \"x\");\n\n return params.toString();\n }\n\n /**\n * Find the nearest allowed width for optimal caching\n */\n private getNearestWidth(width: number): number {\n return ALLOWED_WIDTHS.reduce((prev, curr) => (Math.abs(curr - width) < Math.abs(prev - width) ? curr : prev));\n }\n\n /**\n * Get folder tree for navigation\n *\n * @example\n * ```typescript\n * const tree = await cdn.getFolderTree({\n * projectSlug: 'my-project',\n * maxDepth: 3,\n * });\n * ```\n */\n async getFolderTree(request: GetFolderTreeRequest): Promise<FolderTreeNode[]> {\n const params = new URLSearchParams();\n params.set(\"projectSlug\", request.projectSlug);\n if (request.maxDepth) params.set(\"maxDepth\", request.maxDepth.toString());\n\n const response = await this.http.get<{ tree: FolderTreeNode[] }>(`/cdn/folders/tree?${params.toString()}`);\n return response.tree;\n }\n\n /**\n * Create a new folder\n *\n * @example\n * ```typescript\n * const folder = await cdn.createFolder({\n * projectSlug: 'my-project',\n * name: 'images',\n * });\n * ```\n */\n async createFolder(request: CreateFolderRequest): Promise<Folder> {\n const response = await this.http.post<Folder>(\"/cdn/folders\", request);\n return this.convertFolderDates(response);\n }\n\n /**\n * Delete a folder\n *\n * @example\n * ```typescript\n * await cdn.deleteFolder('folder-id');\n * ```\n */\n async deleteFolder(id: string, deleteContents = false): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (deleteContents) params.set(\"deleteContents\", \"true\");\n\n return this.http.deleteWithBody<{ success: boolean }>(`/cdn/folders/${id}?${params.toString()}`, {\n id,\n deleteContents,\n });\n }\n\n private convertAssetDates(asset: Asset): Asset {\n if (typeof asset.createdAt === \"string\") {\n asset.createdAt = new Date(asset.createdAt);\n }\n if (asset.updatedAt && typeof asset.updatedAt === \"string\") {\n asset.updatedAt = new Date(asset.updatedAt);\n }\n return asset;\n }\n\n private convertFolderDates(folder: Folder): Folder {\n if (typeof folder.createdAt === \"string\") {\n folder.createdAt = new Date(folder.createdAt);\n }\n if (folder.updatedAt && typeof folder.updatedAt === \"string\") {\n folder.updatedAt = new Date(folder.updatedAt);\n }\n return folder;\n }\n\n // ============================================================================\n // Video Transcoding Methods\n // ============================================================================\n\n /**\n * Start a video transcoding job\n *\n * @example\n * ```typescript\n * const job = await cdn.transcode({\n * projectSlug: 'my-project',\n * assetId: 'video-asset-id',\n * outputFormat: 'hls',\n * variants: [\n * { quality: '720p', codec: 'h264' },\n * { quality: '1080p', codec: 'h264' },\n * ],\n * webhookUrl: 'https://your-app.com/webhook',\n * });\n * console.log(`Job started: ${job.id}`);\n * ```\n */\n async transcode(request: TranscodeVideoRequest): Promise<TranscodeJob> {\n const response = await this.http.post<TranscodeJob>(\"/cdn/video/transcode\", request);\n return this.convertJobDates(response);\n }\n\n /**\n * Get a transcoding job by ID\n *\n * @example\n * ```typescript\n * const job = await cdn.getJob('job-id');\n * console.log(`Status: ${job.status}, Progress: ${job.progress}%`);\n * ```\n */\n async getJob(jobId: string): Promise<TranscodeJob> {\n const response = await this.http.get<TranscodeJob>(`/cdn/video/jobs/${jobId}`);\n return this.convertJobDates(response);\n }\n\n /**\n * List transcoding jobs with filters\n *\n * @example\n * ```typescript\n * const { jobs, total } = await cdn.listJobs({\n * projectSlug: 'my-project',\n * status: 'processing',\n * limit: 20,\n * });\n * ```\n */\n async listJobs(request: ListJobsRequest): Promise<ListJobsResponse> {\n const params = new URLSearchParams();\n params.set(\"projectSlug\", request.projectSlug);\n if (request.assetId) params.set(\"assetId\", request.assetId);\n if (request.status) params.set(\"status\", request.status);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n\n const response = await this.http.get<ListJobsResponse>(`/cdn/video/jobs?${params.toString()}`);\n return {\n ...response,\n jobs: response.jobs.map((job) => this.convertJobDates(job)),\n };\n }\n\n /**\n * Cancel a pending or processing transcoding job\n *\n * @example\n * ```typescript\n * await cdn.cancelJob('job-id');\n * ```\n */\n async cancelJob(jobId: string): Promise<{ success: boolean }> {\n return this.http.post<{ success: boolean }>(`/cdn/video/jobs/${jobId}/cancel`, {});\n }\n\n /**\n * Get streaming URLs for a transcoded video\n *\n * @example\n * ```typescript\n * const urls = await cdn.getStreamingUrls('asset-id');\n * console.log(`HLS URL: ${urls.hlsUrl}`);\n * console.log(`MP4 720p: ${urls.mp4Urls.find(u => u.quality === '720p')?.url}`);\n * ```\n */\n async getStreamingUrls(assetId: string): Promise<StreamingUrls> {\n return this.http.get<StreamingUrls>(`/cdn/video/stream/${assetId}`);\n }\n\n /**\n * Generate a thumbnail from a video at a specific timestamp\n *\n * @example\n * ```typescript\n * const thumbnail = await cdn.getThumbnail({\n * assetId: 'video-asset-id',\n * timestamp: 10.5, // 10.5 seconds into the video\n * width: 320,\n * format: 'webp',\n * });\n * console.log(`Thumbnail URL: ${thumbnail.url}`);\n * ```\n */\n async getThumbnail(request: ThumbnailRequest): Promise<ThumbnailResponse> {\n const params = new URLSearchParams();\n params.set(\"timestamp\", request.timestamp.toString());\n if (request.width) params.set(\"width\", request.width.toString());\n if (request.format) params.set(\"format\", request.format);\n\n return this.http.get<ThumbnailResponse>(`/cdn/video/thumbnail/${request.assetId}?${params.toString()}`);\n }\n\n /**\n * Regenerate a thumbnail for a video (force regeneration even if one exists)\n *\n * Useful for retrying failed thumbnail generation or regenerating with different settings.\n *\n * @example\n * ```typescript\n * const result = await cdn.regenerateThumbnail({\n * assetId: 'video-asset-id',\n * timestamp: 5, // 5 seconds into the video\n * width: 1280,\n * format: 'jpg',\n * });\n * console.log(`Thumbnail regeneration queued: ${result.status}`);\n * ```\n */\n async regenerateThumbnail(request: RegenerateThumbnailRequest): Promise<RegenerateThumbnailResponse> {\n return this.http.post<RegenerateThumbnailResponse>(\"/cdn/video/thumbnail/regenerate\", request);\n }\n\n /**\n * Extract audio from a video file\n *\n * @example\n * ```typescript\n * const { jobId } = await cdn.extractAudio({\n * projectSlug: 'my-project',\n * assetId: 'video-asset-id',\n * format: 'mp3',\n * bitrate: 192,\n * });\n * ```\n */\n async extractAudio(request: ExtractAudioRequest): Promise<ExtractAudioResponse> {\n return this.http.post<ExtractAudioResponse>(\"/cdn/video/extract-audio\", request);\n }\n\n private convertJobDates(job: TranscodeJob): TranscodeJob {\n if (typeof job.createdAt === \"string\") {\n job.createdAt = new Date(job.createdAt);\n }\n if (job.startedAt && typeof job.startedAt === \"string\") {\n job.startedAt = new Date(job.startedAt);\n }\n if (job.completedAt && typeof job.completedAt === \"string\") {\n job.completedAt = new Date(job.completedAt);\n }\n return job;\n }\n\n // ============================================================================\n // Private Files Methods\n // ============================================================================\n\n /**\n * Generate a presigned URL for uploading a private file\n *\n * Private files are stored securely and can only be accessed through\n * authorized download links with configurable expiration.\n *\n * @example\n * ```typescript\n * const { uploadUrl, fileId } = await cdn.getPrivateUploadUrl({\n * projectSlug: 'my-project',\n * filename: 'confidential.pdf',\n * mimeType: 'application/pdf',\n * size: 1024 * 1024,\n * });\n *\n * // Upload file to the presigned URL\n * await fetch(uploadUrl, {\n * method: 'PUT',\n * body: file,\n * headers: { 'Content-Type': 'application/pdf' },\n * });\n *\n * // Confirm the upload\n * const privateFile = await cdn.confirmPrivateUpload(fileId);\n * ```\n */\n async getPrivateUploadUrl(request: PrivateUploadUrlRequest): Promise<PrivateUploadUrlResponse> {\n const response = await this.http.post<PrivateUploadUrlResponse>(\"/cdn/private/upload\", request);\n\n if (typeof response.expiresAt === \"string\") {\n response.expiresAt = new Date(response.expiresAt);\n }\n\n return response;\n }\n\n /**\n * Confirm that a private file upload has completed\n */\n async confirmPrivateUpload(fileId: string): Promise<PrivateFile> {\n const response = await this.http.post<PrivateFile>(`/cdn/private/upload/${fileId}/confirm`, {});\n return this.convertPrivateFileDates(response);\n }\n\n /**\n * Upload a private file directly (handles presigned URL flow automatically)\n *\n * @example\n * ```typescript\n * const privateFile = await cdn.uploadPrivate({\n * projectSlug: 'my-project',\n * file: fileBuffer,\n * filename: 'confidential.pdf',\n * mimeType: 'application/pdf',\n * });\n * ```\n */\n async uploadPrivate(options: {\n projectSlug: string;\n file: Blob | Buffer | ArrayBuffer;\n filename: string;\n mimeType: string;\n folder?: string;\n description?: string;\n metadata?: Record<string, unknown>;\n }): Promise<PrivateFile> {\n const { projectSlug, file, filename, mimeType, folder, description, metadata } = options;\n\n // Get file size\n let size: number;\n if (file instanceof Blob) {\n size = file.size;\n } else if (file instanceof ArrayBuffer) {\n size = file.byteLength;\n } else {\n size = (file as Buffer).length;\n }\n\n // Get presigned URL\n const { uploadUrl, fileId } = await this.getPrivateUploadUrl({\n projectSlug,\n filename,\n mimeType,\n size,\n folder,\n description,\n metadata,\n });\n\n // Upload file\n const uploadResponse = await fetch(uploadUrl, {\n method: \"PUT\",\n body: file,\n headers: {\n \"Content-Type\": mimeType,\n },\n });\n\n if (!uploadResponse.ok) {\n throw new Error(`Upload failed: ${uploadResponse.statusText}`);\n }\n\n // Confirm upload\n return this.confirmPrivateUpload(fileId);\n }\n\n /**\n * Generate a presigned download URL for a private file\n *\n * @example\n * ```typescript\n * const { downloadUrl, expiresAt } = await cdn.getPrivateDownloadUrl({\n * fileId: 'file-id',\n * expiresIn: 86400, // 24 hours\n * });\n * ```\n */\n async getPrivateDownloadUrl(request: PrivateDownloadUrlRequest): Promise<PrivateDownloadUrlResponse> {\n const response = await this.http.post<PrivateDownloadUrlResponse>(`/cdn/private/${request.fileId}/download`, {\n expiresIn: request.expiresIn,\n });\n\n if (typeof response.expiresAt === \"string\") {\n response.expiresAt = new Date(response.expiresAt);\n }\n\n return response;\n }\n\n /**\n * Get a private file by ID\n */\n async getPrivateFile(fileId: string): Promise<PrivateFile> {\n const response = await this.http.get<PrivateFile>(`/cdn/private/${fileId}`);\n return this.convertPrivateFileDates(response);\n }\n\n /**\n * Update a private file's metadata\n */\n async updatePrivateFile(request: UpdatePrivateFileRequest): Promise<PrivateFile> {\n const { fileId, ...data } = request;\n const response = await this.http.patch<PrivateFile>(`/cdn/private/${fileId}`, data);\n return this.convertPrivateFileDates(response);\n }\n\n /**\n * Delete a private file\n */\n async deletePrivateFile(fileId: string): Promise<{ success: boolean }> {\n return this.http.deleteWithBody<{ success: boolean }>(`/cdn/private/${fileId}`, { fileId });\n }\n\n /**\n * Delete multiple private files\n */\n async deletePrivateFiles(fileIds: string[]): Promise<{ success: boolean; deletedCount: number }> {\n return this.http.post<{ success: boolean; deletedCount: number }>(\"/cdn/private/delete\", { fileIds });\n }\n\n /**\n * List private files with filters and pagination\n *\n * @example\n * ```typescript\n * const { files, total, hasMore } = await cdn.listPrivateFiles({\n * projectSlug: 'my-project',\n * limit: 20,\n * });\n * ```\n */\n async listPrivateFiles(request: ListPrivateFilesRequest): Promise<ListPrivateFilesResponse> {\n const params = new URLSearchParams();\n\n params.set(\"projectSlug\", request.projectSlug);\n if (request.folder !== undefined) params.set(\"folder\", request.folder ?? \"\");\n if (request.status) params.set(\"status\", request.status);\n if (request.search) params.set(\"search\", request.search);\n if (request.sortBy) params.set(\"sortBy\", request.sortBy);\n if (request.sortOrder) params.set(\"sortOrder\", request.sortOrder);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n\n const response = await this.http.get<ListPrivateFilesResponse>(`/cdn/private?${params.toString()}`);\n\n return {\n ...response,\n files: response.files.map((file) => this.convertPrivateFileDates(file)),\n };\n }\n\n private convertPrivateFileDates(file: PrivateFile): PrivateFile {\n if (typeof file.createdAt === \"string\") {\n file.createdAt = new Date(file.createdAt);\n }\n if (file.updatedAt && typeof file.updatedAt === \"string\") {\n file.updatedAt = new Date(file.updatedAt);\n }\n return file;\n }\n\n // ============================================================================\n // Download Bundle Methods\n // ============================================================================\n\n /**\n * Create a download bundle from assets and/or private files\n *\n * The bundle will be created asynchronously. Check the status using getBundle().\n *\n * @example\n * ```typescript\n * const { bundle } = await cdn.createBundle({\n * projectSlug: 'my-project',\n * name: 'Project Assets - Dec 2024',\n * assetIds: ['asset-1', 'asset-2'],\n * privateFileIds: ['file-1', 'file-2'],\n * expiresIn: 86400, // 24 hours\n * });\n * console.log(`Bundle ${bundle.id} status: ${bundle.status}`);\n * ```\n */\n async createBundle(request: CreateBundleRequest): Promise<CreateBundleResponse> {\n const response = await this.http.post<CreateBundleResponse>(\"/cdn/bundles\", request);\n return {\n bundle: this.convertBundleDates(response.bundle),\n };\n }\n\n /**\n * Get a download bundle by ID\n */\n async getBundle(bundleId: string): Promise<DownloadBundle> {\n const response = await this.http.get<DownloadBundle>(`/cdn/bundles/${bundleId}`);\n return this.convertBundleDates(response);\n }\n\n /**\n * List download bundles with filters and pagination\n *\n * @example\n * ```typescript\n * const { bundles, total } = await cdn.listBundles({\n * projectSlug: 'my-project',\n * status: 'ready',\n * });\n * ```\n */\n async listBundles(request: ListBundlesRequest): Promise<ListBundlesResponse> {\n const params = new URLSearchParams();\n\n params.set(\"projectSlug\", request.projectSlug);\n if (request.status) params.set(\"status\", request.status);\n if (request.search) params.set(\"search\", request.search);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n\n const response = await this.http.get<ListBundlesResponse>(`/cdn/bundles?${params.toString()}`);\n\n return {\n ...response,\n bundles: response.bundles.map((bundle) => this.convertBundleDates(bundle)),\n };\n }\n\n /**\n * Generate a presigned download URL for a bundle\n *\n * @example\n * ```typescript\n * const { downloadUrl, expiresAt } = await cdn.getBundleDownloadUrl({\n * bundleId: 'bundle-id',\n * expiresIn: 3600, // 1 hour\n * });\n * ```\n */\n async getBundleDownloadUrl(request: BundleDownloadUrlRequest): Promise<BundleDownloadUrlResponse> {\n const response = await this.http.post<BundleDownloadUrlResponse>(`/cdn/bundles/${request.bundleId}/download`, {\n expiresIn: request.expiresIn,\n });\n\n if (typeof response.expiresAt === \"string\") {\n response.expiresAt = new Date(response.expiresAt);\n }\n\n return response;\n }\n\n /**\n * Delete a download bundle\n */\n async deleteBundle(bundleId: string): Promise<{ success: boolean }> {\n return this.http.deleteWithBody<{ success: boolean }>(`/cdn/bundles/${bundleId}`, { bundleId });\n }\n\n private convertBundleDates(bundle: DownloadBundle): DownloadBundle {\n if (typeof bundle.createdAt === \"string\") {\n bundle.createdAt = new Date(bundle.createdAt);\n }\n if (bundle.completedAt && typeof bundle.completedAt === \"string\") {\n bundle.completedAt = new Date(bundle.completedAt);\n }\n if (bundle.expiresAt && typeof bundle.expiresAt === \"string\") {\n bundle.expiresAt = new Date(bundle.expiresAt);\n }\n return bundle;\n }\n\n // ============================================================================\n // Usage Methods\n // ============================================================================\n\n /**\n * Get current usage stats for the billing period\n *\n * @example\n * ```typescript\n * const usage = await cdn.getUsage({\n * projectSlug: 'my-project',\n * });\n * console.log(`Bandwidth: ${usage.bandwidthFormatted}`);\n * console.log(`Estimated cost: ${usage.estimatedCostFormatted}`);\n * ```\n */\n async getUsage(request: CdnUsageRequest = {}): Promise<CdnUsageResponse> {\n const params = new URLSearchParams();\n if (request.projectSlug) params.set(\"projectSlug\", request.projectSlug);\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.periodStart) {\n const date = request.periodStart instanceof Date ? request.periodStart.toISOString() : request.periodStart;\n params.set(\"periodStart\", date);\n }\n if (request.periodEnd) {\n const date = request.periodEnd instanceof Date ? request.periodEnd.toISOString() : request.periodEnd;\n params.set(\"periodEnd\", date);\n }\n\n const query = params.toString();\n const response = await this.http.get<CdnUsageResponse>(`/cdn/usage${query ? `?${query}` : \"\"}`);\n return this.convertUsageDates(response);\n }\n\n /**\n * Get usage history (time series data for charts)\n *\n * @example\n * ```typescript\n * const history = await cdn.getUsageHistory({\n * projectSlug: 'my-project',\n * days: 30,\n * });\n * console.log(`Total requests: ${history.totals.requests}`);\n * ```\n */\n async getUsageHistory(request: CdnUsageHistoryRequest = {}): Promise<CdnUsageHistoryResponse> {\n const params = new URLSearchParams();\n if (request.projectSlug) params.set(\"projectSlug\", request.projectSlug);\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.days) params.set(\"days\", request.days.toString());\n if (request.granularity) params.set(\"granularity\", request.granularity);\n\n const query = params.toString();\n const response = await this.http.get<CdnUsageHistoryResponse>(`/cdn/usage/history${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n data: response.data.map((point) => this.convertUsageDataPointDates(point)),\n };\n }\n\n /**\n * Get storage breakdown by type or folder\n *\n * @example\n * ```typescript\n * const breakdown = await cdn.getStorageBreakdown({\n * projectSlug: 'my-project',\n * groupBy: 'type',\n * });\n * breakdown.items.forEach(item => {\n * console.log(`${item.key}: ${item.sizeFormatted} (${item.percentage}%)`);\n * });\n * ```\n */\n async getStorageBreakdown(request: CdnStorageBreakdownRequest = {}): Promise<CdnStorageBreakdownResponse> {\n const params = new URLSearchParams();\n if (request.projectSlug) params.set(\"projectSlug\", request.projectSlug);\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.groupBy) params.set(\"groupBy\", request.groupBy);\n\n const query = params.toString();\n return this.http.get<CdnStorageBreakdownResponse>(`/cdn/usage/storage-breakdown${query ? `?${query}` : \"\"}`);\n }\n\n private convertUsageDates(usage: CdnUsageResponse): CdnUsageResponse {\n if (typeof usage.periodStart === \"string\") {\n usage.periodStart = new Date(usage.periodStart);\n }\n if (typeof usage.periodEnd === \"string\") {\n usage.periodEnd = new Date(usage.periodEnd);\n }\n return usage;\n }\n\n private convertUsageDataPointDates(point: CdnUsageDataPoint): CdnUsageDataPoint {\n if (typeof point.timestamp === \"string\") {\n point.timestamp = new Date(point.timestamp);\n }\n return point;\n }\n\n // ============================================================================\n // Additional Folder Methods\n // ============================================================================\n\n /**\n * Get a folder by ID\n *\n * @example\n * ```typescript\n * const folder = await cdn.getFolder('folder-id');\n * console.log(`Folder: ${folder.name}, Assets: ${folder.assetCount}`);\n * ```\n */\n async getFolder(id: string): Promise<Folder> {\n const response = await this.http.get<Folder>(`/cdn/folders/${id}`);\n return this.convertFolderDates(response);\n }\n\n /**\n * Get a folder by its path\n *\n * @example\n * ```typescript\n * const folder = await cdn.getFolderByPath('/images/avatars');\n * ```\n */\n async getFolderByPath(path: string): Promise<Folder> {\n const encodedPath = encodeURIComponent(path);\n const response = await this.http.get<Folder>(`/cdn/folders/path/${encodedPath}`);\n return this.convertFolderDates(response);\n }\n\n /**\n * Update a folder's name\n *\n * @example\n * ```typescript\n * const folder = await cdn.updateFolder({\n * id: 'folder-id',\n * name: 'New Folder Name',\n * });\n * ```\n */\n async updateFolder(request: UpdateFolderRequest): Promise<Folder> {\n const { id, ...data } = request;\n const response = await this.http.patch<Folder>(`/cdn/folders/${id}`, data);\n return this.convertFolderDates(response);\n }\n\n /**\n * List folders with optional filters\n *\n * @example\n * ```typescript\n * const { folders, total } = await cdn.listFolders({\n * parentId: null, // root level\n * limit: 50,\n * });\n * ```\n */\n async listFolders(request: ListFoldersRequest = {}): Promise<ListFoldersResponse> {\n const params = new URLSearchParams();\n if (request.parentId !== undefined) params.set(\"parentId\", request.parentId ?? \"\");\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n if (request.search) params.set(\"search\", request.search);\n\n const query = params.toString();\n const response = await this.http.get<ListFoldersResponse>(`/cdn/folders${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n folders: response.folders.map((folder) => this.convertFolderListItemDates(folder)),\n };\n }\n\n /**\n * Move a folder to a new parent\n *\n * @example\n * ```typescript\n * await cdn.moveFolder({\n * id: 'folder-id',\n * newParentId: 'new-parent-id', // or null for root\n * });\n * ```\n */\n async moveFolder(request: MoveFolderRequest): Promise<MoveFolderResponse> {\n return this.http.post<MoveFolderResponse>(\"/cdn/folders/move\", request);\n }\n\n private convertFolderListItemDates(folder: FolderListItem): FolderListItem {\n if (typeof folder.createdAt === \"string\") {\n folder.createdAt = new Date(folder.createdAt);\n }\n return folder;\n }\n\n // ============================================================================\n // Additional Video Methods\n // ============================================================================\n\n /**\n * List all thumbnails for a video asset\n *\n * @example\n * ```typescript\n * const { thumbnails } = await cdn.listThumbnails('video-asset-id');\n * thumbnails.forEach(thumb => {\n * console.log(`${thumb.timestamp}s: ${thumb.url}`);\n * });\n * ```\n */\n async listThumbnails(assetId: string): Promise<ListThumbnailsResponse> {\n const response = await this.http.get<ListThumbnailsResponse>(`/cdn/video/${assetId}/thumbnails`);\n return response;\n }\n\n // ============================================================================\n // Additional Private Files Methods\n // ============================================================================\n\n /**\n * Move private files to a different folder\n *\n * @example\n * ```typescript\n * const result = await cdn.movePrivateFiles({\n * fileIds: ['file-1', 'file-2'],\n * folder: '/confidential/archive',\n * });\n * console.log(`Moved ${result.movedCount} files`);\n * ```\n */\n async movePrivateFiles(request: MovePrivateFilesRequest): Promise<MovePrivateFilesResponse> {\n return this.http.post<MovePrivateFilesResponse>(\"/cdn/private/move\", request);\n }\n\n // ============================================================================\n // Video Merge Methods\n // ============================================================================\n\n /**\n * Create a merge job to combine multiple videos/images with optional audio overlay\n *\n * Merge jobs combine multiple assets (videos, images) in sequence and can\n * optionally overlay an audio track. Images require a duration to be specified.\n *\n * @example\n * ```typescript\n * const job = await cdn.createMergeJob({\n * projectSlug: 'my-project',\n * inputs: [\n * { assetId: 'intro-video-id' },\n * { assetId: 'image-id', duration: 5 }, // Show image for 5 seconds\n * { assetId: 'main-video-id', startTime: 10, endTime: 60 }, // Trim to 50 seconds\n * ],\n * audioTrack: {\n * assetId: 'background-music-id',\n * loop: true,\n * fadeIn: 2,\n * fadeOut: 3,\n * },\n * output: {\n * format: 'mp4',\n * quality: '1080p',\n * filename: 'final-video.mp4',\n * },\n * webhookUrl: 'https://your-app.com/webhook',\n * });\n * console.log(`Merge job started: ${job.id}`);\n * ```\n */\n async createMergeJob(request: CreateMergeJobRequest): Promise<MergeJob> {\n const response = await this.http.post<MergeJob>(\"/cdn/video/merge\", request);\n return this.convertMergeJobDates(response);\n }\n\n /**\n * Get a merge job by ID with output asset details\n *\n * @example\n * ```typescript\n * const job = await cdn.getMergeJob('job-id');\n * if (job.status === 'completed' && job.outputAsset) {\n * console.log(`Output video: ${job.outputAsset.cdnUrl}`);\n * }\n * ```\n */\n async getMergeJob(jobId: string): Promise<MergeJobWithOutput> {\n const response = await this.http.get<MergeJobWithOutput>(`/cdn/video/merge/${jobId}`);\n return this.convertMergeJobWithOutputDates(response);\n }\n\n /**\n * List merge jobs with optional filters\n *\n * @example\n * ```typescript\n * const { jobs, total, hasMore } = await cdn.listMergeJobs({\n * projectSlug: 'my-project',\n * status: 'completed',\n * limit: 20,\n * });\n * ```\n */\n async listMergeJobs(request: ListMergeJobsRequest): Promise<ListMergeJobsResponse> {\n const params = new URLSearchParams();\n params.set(\"projectSlug\", request.projectSlug);\n if (request.status) params.set(\"status\", request.status);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.offset) params.set(\"offset\", request.offset.toString());\n\n const response = await this.http.get<ListMergeJobsResponse>(`/cdn/video/merge?${params.toString()}`);\n return {\n ...response,\n jobs: response.jobs.map((job) => this.convertMergeJobDates(job)),\n };\n }\n\n /**\n * Cancel a pending or processing merge job\n *\n * @example\n * ```typescript\n * await cdn.cancelMergeJob('job-id');\n * console.log('Merge job cancelled');\n * ```\n */\n async cancelMergeJob(jobId: string): Promise<{ success: boolean }> {\n return this.http.post<{ success: boolean }>(`/cdn/video/merge/${jobId}/cancel`, {});\n }\n\n private convertMergeJobDates(job: MergeJob): MergeJob {\n if (typeof job.createdAt === \"string\") {\n job.createdAt = new Date(job.createdAt);\n }\n if (job.updatedAt && typeof job.updatedAt === \"string\") {\n job.updatedAt = new Date(job.updatedAt);\n }\n if (job.startedAt && typeof job.startedAt === \"string\") {\n job.startedAt = new Date(job.startedAt);\n }\n if (job.completedAt && typeof job.completedAt === \"string\") {\n job.completedAt = new Date(job.completedAt);\n }\n return job;\n }\n\n private convertMergeJobWithOutputDates(job: MergeJobWithOutput): MergeJobWithOutput {\n return this.convertMergeJobDates(job) as MergeJobWithOutput;\n }\n}\n","/**\n * Stack0 Screenshots Client\n * Capture high-quality screenshots of any webpage\n */\n\nimport { HttpClient, type HttpClientConfig } from \"../lib/http-client\";\nimport type {\n CreateBatchResponse,\n GetBatchJobRequest,\n ListBatchJobsRequest,\n CreateScheduleResponse,\n GetScheduleRequest,\n ListSchedulesRequest,\n} from \"../lib/shared-types\";\nimport type {\n Screenshot,\n CreateScreenshotRequest,\n CreateScreenshotResponse,\n GetScreenshotRequest,\n ListScreenshotsRequest,\n ListScreenshotsResponse,\n BatchScreenshotJob,\n CreateBatchScreenshotsRequest,\n ScreenshotBatchJobsResponse,\n ScreenshotSchedule,\n CreateScreenshotScheduleRequest,\n UpdateScreenshotScheduleRequest,\n ScreenshotSchedulesResponse,\n} from \"./types\";\n\nexport class Screenshots {\n private http: HttpClient;\n\n constructor(config: HttpClientConfig) {\n this.http = new HttpClient(config);\n }\n\n // ==========================================================================\n // SCREENSHOTS\n // ==========================================================================\n\n /**\n * Capture a screenshot of a URL\n *\n * @example\n * ```typescript\n * const { id, status } = await screenshots.capture({\n * url: 'https://example.com',\n * format: 'png',\n * fullPage: true,\n * deviceType: 'desktop',\n * });\n *\n * // Poll for completion\n * const screenshot = await screenshots.get({ id });\n * console.log(screenshot.imageUrl);\n * ```\n */\n async capture(request: CreateScreenshotRequest): Promise<CreateScreenshotResponse> {\n return this.http.post<CreateScreenshotResponse>(\"/webdata/screenshots\", request);\n }\n\n /**\n * Get a screenshot by ID\n *\n * @example\n * ```typescript\n * const screenshot = await screenshots.get({ id: 'screenshot-id' });\n * if (screenshot.status === 'completed') {\n * console.log(screenshot.imageUrl);\n * }\n * ```\n */\n async get(request: GetScreenshotRequest): Promise<Screenshot> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/screenshots/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<Screenshot>(path);\n return this.convertDates(response);\n }\n\n /**\n * List screenshots with pagination and filters\n *\n * @example\n * ```typescript\n * const { items, nextCursor } = await screenshots.list({\n * status: 'completed',\n * limit: 20,\n * });\n * ```\n */\n async list(request: ListScreenshotsRequest = {}): Promise<ListScreenshotsResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n if (request.status) params.set(\"status\", request.status);\n if (request.url) params.set(\"url\", request.url);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ListScreenshotsResponse>(`/webdata/screenshots${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertDates(item)),\n };\n }\n\n /**\n * Delete a screenshot\n *\n * @example\n * ```typescript\n * await screenshots.delete({ id: 'screenshot-id' });\n * ```\n */\n async delete(request: GetScreenshotRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.deleteWithBody<{ success: boolean }>(\n `/webdata/screenshots/${request.id}${query ? `?${query}` : \"\"}`,\n {\n id: request.id,\n environment: request.environment,\n projectId: request.projectId,\n },\n );\n }\n\n /**\n * Capture a screenshot and wait for completion\n *\n * @example\n * ```typescript\n * const screenshot = await screenshots.captureAndWait({\n * url: 'https://example.com',\n * format: 'png',\n * });\n * console.log(screenshot.imageUrl);\n * ```\n */\n async captureAndWait(\n request: CreateScreenshotRequest,\n options: { pollInterval?: number; timeout?: number } = {},\n ): Promise<Screenshot> {\n const { pollInterval = 1000, timeout = 60000 } = options;\n const startTime = Date.now();\n\n const { id } = await this.capture(request);\n\n while (Date.now() - startTime < timeout) {\n const screenshot = await this.get({\n id,\n environment: request.environment,\n projectId: request.projectId,\n });\n\n if (screenshot.status === \"completed\" || screenshot.status === \"failed\") {\n if (screenshot.status === \"failed\") {\n throw new Error(screenshot.error || \"Screenshot failed\");\n }\n return screenshot;\n }\n\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n }\n\n throw new Error(\"Screenshot timed out\");\n }\n\n // ==========================================================================\n // BATCH JOBS\n // ==========================================================================\n\n /**\n * Create a batch screenshot job for multiple URLs\n *\n * @example\n * ```typescript\n * const { id, totalUrls } = await screenshots.batch({\n * urls: [\n * 'https://example.com',\n * 'https://example.org',\n * ],\n * config: { format: 'png', fullPage: true },\n * });\n *\n * // Poll for completion\n * const job = await screenshots.getBatchJob({ id });\n * console.log(`Progress: ${job.processedUrls}/${job.totalUrls}`);\n * ```\n */\n async batch(request: CreateBatchScreenshotsRequest): Promise<CreateBatchResponse> {\n return this.http.post<CreateBatchResponse>(\"/webdata/batch/screenshots\", request);\n }\n\n /**\n * Get a batch job by ID\n */\n async getBatchJob(request: GetBatchJobRequest): Promise<BatchScreenshotJob> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/batch/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<BatchScreenshotJob>(path);\n return this.convertBatchJobDates(response);\n }\n\n /**\n * List batch jobs with pagination and filters\n */\n async listBatchJobs(request: ListBatchJobsRequest = {}): Promise<ScreenshotBatchJobsResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n if (request.status) params.set(\"status\", request.status);\n params.set(\"type\", \"screenshot\");\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ScreenshotBatchJobsResponse>(`/webdata/batch${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertBatchJobDates(item)),\n };\n }\n\n /**\n * Cancel a batch job\n */\n async cancelBatchJob(request: GetBatchJobRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.post<{ success: boolean }>(`/webdata/batch/${request.id}/cancel${query ? `?${query}` : \"\"}`, {});\n }\n\n /**\n * Create a batch screenshot job and wait for completion\n */\n async batchAndWait(\n request: CreateBatchScreenshotsRequest,\n options: { pollInterval?: number; timeout?: number } = {},\n ): Promise<BatchScreenshotJob> {\n const { pollInterval = 2000, timeout = 300000 } = options;\n const startTime = Date.now();\n\n const { id } = await this.batch(request);\n\n while (Date.now() - startTime < timeout) {\n const job = await this.getBatchJob({\n id,\n environment: request.environment,\n projectId: request.projectId,\n });\n\n if (job.status === \"completed\" || job.status === \"failed\" || job.status === \"cancelled\") {\n return job;\n }\n\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n }\n\n throw new Error(\"Batch job timed out\");\n }\n\n // ==========================================================================\n // SCHEDULES\n // ==========================================================================\n\n /**\n * Create a scheduled screenshot job\n *\n * @example\n * ```typescript\n * const { id } = await screenshots.createSchedule({\n * name: 'Daily homepage screenshot',\n * url: 'https://example.com',\n * frequency: 'daily',\n * config: { format: 'png', fullPage: true },\n * });\n * ```\n */\n async createSchedule(request: CreateScreenshotScheduleRequest): Promise<CreateScheduleResponse> {\n return this.http.post<CreateScheduleResponse>(\"/webdata/schedules\", {\n ...request,\n type: \"screenshot\",\n });\n }\n\n /**\n * Update a schedule\n */\n async updateSchedule(request: UpdateScreenshotScheduleRequest): Promise<{ success: boolean }> {\n const { id, environment, projectId, ...data } = request;\n\n const params = new URLSearchParams();\n if (environment) params.set(\"environment\", environment);\n if (projectId) params.set(\"projectId\", projectId);\n\n const query = params.toString();\n return this.http.post<{ success: boolean }>(`/webdata/schedules/${id}${query ? `?${query}` : \"\"}`, data);\n }\n\n /**\n * Get a schedule by ID\n */\n async getSchedule(request: GetScheduleRequest): Promise<ScreenshotSchedule> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/schedules/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<ScreenshotSchedule>(path);\n return this.convertScheduleDates(response);\n }\n\n /**\n * List schedules with pagination and filters\n */\n async listSchedules(request: ListSchedulesRequest = {}): Promise<ScreenshotSchedulesResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n params.set(\"type\", \"screenshot\");\n if (request.isActive !== undefined) params.set(\"isActive\", request.isActive.toString());\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ScreenshotSchedulesResponse>(`/webdata/schedules${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertScheduleDates(item)),\n };\n }\n\n /**\n * Delete a schedule\n */\n async deleteSchedule(request: GetScheduleRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.deleteWithBody<{ success: boolean }>(\n `/webdata/schedules/${request.id}${query ? `?${query}` : \"\"}`,\n {\n id: request.id,\n environment: request.environment,\n projectId: request.projectId,\n },\n );\n }\n\n /**\n * Toggle a schedule on or off\n */\n async toggleSchedule(request: GetScheduleRequest): Promise<{ isActive: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.post<{ isActive: boolean }>(\n `/webdata/schedules/${request.id}/toggle${query ? `?${query}` : \"\"}`,\n {},\n );\n }\n\n // ==========================================================================\n // HELPERS\n // ==========================================================================\n\n private convertDates(screenshot: Screenshot): Screenshot {\n if (typeof screenshot.createdAt === \"string\") {\n screenshot.createdAt = new Date(screenshot.createdAt);\n }\n if (screenshot.completedAt && typeof screenshot.completedAt === \"string\") {\n screenshot.completedAt = new Date(screenshot.completedAt);\n }\n return screenshot;\n }\n\n private convertBatchJobDates(job: BatchScreenshotJob): BatchScreenshotJob {\n if (typeof job.createdAt === \"string\") {\n job.createdAt = new Date(job.createdAt);\n }\n if (job.startedAt && typeof job.startedAt === \"string\") {\n job.startedAt = new Date(job.startedAt);\n }\n if (job.completedAt && typeof job.completedAt === \"string\") {\n job.completedAt = new Date(job.completedAt);\n }\n return job;\n }\n\n private convertScheduleDates(schedule: ScreenshotSchedule): ScreenshotSchedule {\n if (typeof schedule.createdAt === \"string\") {\n schedule.createdAt = new Date(schedule.createdAt);\n }\n if (typeof schedule.updatedAt === \"string\") {\n schedule.updatedAt = new Date(schedule.updatedAt);\n }\n if (schedule.lastRunAt && typeof schedule.lastRunAt === \"string\") {\n schedule.lastRunAt = new Date(schedule.lastRunAt);\n }\n if (schedule.nextRunAt && typeof schedule.nextRunAt === \"string\") {\n schedule.nextRunAt = new Date(schedule.nextRunAt);\n }\n return schedule;\n }\n}\n","/**\n * Stack0 AI Extraction Client\n * Extract structured data from any webpage using AI\n */\n\nimport { HttpClient, type HttpClientConfig } from \"../lib/http-client\";\nimport type {\n CreateBatchResponse,\n GetBatchJobRequest,\n ListBatchJobsRequest,\n CreateScheduleResponse,\n GetScheduleRequest,\n ListSchedulesRequest,\n} from \"../lib/shared-types\";\nimport type {\n ExtractionResult,\n CreateExtractionRequest,\n CreateExtractionResponse,\n GetExtractionRequest,\n ListExtractionsRequest,\n ListExtractionsResponse,\n BatchExtractionJob,\n CreateBatchExtractionsRequest,\n ExtractionBatchJobsResponse,\n ExtractionSchedule,\n CreateExtractionScheduleRequest,\n UpdateExtractionScheduleRequest,\n ExtractionSchedulesResponse,\n ExtractionUsage,\n GetUsageRequest,\n GetDailyUsageResponse,\n} from \"./types\";\n\nexport class Extraction {\n private http: HttpClient;\n\n constructor(config: HttpClientConfig) {\n this.http = new HttpClient(config);\n }\n\n // ==========================================================================\n // EXTRACTIONS\n // ==========================================================================\n\n /**\n * Extract content from a URL\n *\n * @example\n * ```typescript\n * const { id, status } = await extraction.extract({\n * url: 'https://example.com/article',\n * mode: 'markdown',\n * includeMetadata: true,\n * });\n *\n * // Poll for completion\n * const result = await extraction.get({ id });\n * console.log(result.markdown);\n * ```\n */\n async extract(request: CreateExtractionRequest): Promise<CreateExtractionResponse> {\n return this.http.post<CreateExtractionResponse>(\"/webdata/extractions\", request);\n }\n\n /**\n * Get an extraction by ID\n *\n * @example\n * ```typescript\n * const extraction = await extraction.get({ id: 'extraction-id' });\n * if (extraction.status === 'completed') {\n * console.log(extraction.markdown);\n * console.log(extraction.pageMetadata);\n * }\n * ```\n */\n async get(request: GetExtractionRequest): Promise<ExtractionResult> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/extractions/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<ExtractionResult>(path);\n return this.convertDates(response);\n }\n\n /**\n * List extractions with pagination and filters\n *\n * @example\n * ```typescript\n * const { items, nextCursor } = await extraction.list({\n * status: 'completed',\n * limit: 20,\n * });\n * ```\n */\n async list(request: ListExtractionsRequest = {}): Promise<ListExtractionsResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n if (request.status) params.set(\"status\", request.status);\n if (request.url) params.set(\"url\", request.url);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ListExtractionsResponse>(`/webdata/extractions${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertDates(item)),\n };\n }\n\n /**\n * Delete an extraction\n *\n * @example\n * ```typescript\n * await extraction.delete({ id: 'extraction-id' });\n * ```\n */\n async delete(request: GetExtractionRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.deleteWithBody<{ success: boolean }>(\n `/webdata/extractions/${request.id}${query ? `?${query}` : \"\"}`,\n {\n id: request.id,\n environment: request.environment,\n projectId: request.projectId,\n },\n );\n }\n\n /**\n * Extract content and wait for completion\n *\n * @example\n * ```typescript\n * const extraction = await extraction.extractAndWait({\n * url: 'https://example.com/article',\n * mode: 'markdown',\n * });\n * console.log(extraction.markdown);\n * ```\n */\n async extractAndWait(\n request: CreateExtractionRequest,\n options: { pollInterval?: number; timeout?: number } = {},\n ): Promise<ExtractionResult> {\n const { pollInterval = 1000, timeout = 60000 } = options;\n const startTime = Date.now();\n\n const { id } = await this.extract(request);\n\n while (Date.now() - startTime < timeout) {\n const extraction = await this.get({\n id,\n environment: request.environment,\n projectId: request.projectId,\n });\n\n if (extraction.status === \"completed\" || extraction.status === \"failed\") {\n if (extraction.status === \"failed\") {\n throw new Error(extraction.error || \"Extraction failed\");\n }\n return extraction;\n }\n\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n }\n\n throw new Error(\"Extraction timed out\");\n }\n\n // ==========================================================================\n // BATCH JOBS\n // ==========================================================================\n\n /**\n * Create a batch extraction job for multiple URLs\n *\n * @example\n * ```typescript\n * const { id, totalUrls } = await extraction.batch({\n * urls: [\n * 'https://example.com/article1',\n * 'https://example.com/article2',\n * ],\n * config: { mode: 'markdown' },\n * });\n * ```\n */\n async batch(request: CreateBatchExtractionsRequest): Promise<CreateBatchResponse> {\n return this.http.post<CreateBatchResponse>(\"/webdata/batch/extractions\", request);\n }\n\n /**\n * Get a batch job by ID\n */\n async getBatchJob(request: GetBatchJobRequest): Promise<BatchExtractionJob> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/batch/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<BatchExtractionJob>(path);\n return this.convertBatchJobDates(response);\n }\n\n /**\n * List batch jobs with pagination and filters\n */\n async listBatchJobs(request: ListBatchJobsRequest = {}): Promise<ExtractionBatchJobsResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n if (request.status) params.set(\"status\", request.status);\n params.set(\"type\", \"extraction\");\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ExtractionBatchJobsResponse>(`/webdata/batch${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertBatchJobDates(item)),\n };\n }\n\n /**\n * Cancel a batch job\n */\n async cancelBatchJob(request: GetBatchJobRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.post<{ success: boolean }>(`/webdata/batch/${request.id}/cancel${query ? `?${query}` : \"\"}`, {});\n }\n\n /**\n * Create a batch extraction job and wait for completion\n */\n async batchAndWait(\n request: CreateBatchExtractionsRequest,\n options: { pollInterval?: number; timeout?: number } = {},\n ): Promise<BatchExtractionJob> {\n const { pollInterval = 2000, timeout = 300000 } = options;\n const startTime = Date.now();\n\n const { id } = await this.batch(request);\n\n while (Date.now() - startTime < timeout) {\n const job = await this.getBatchJob({\n id,\n environment: request.environment,\n projectId: request.projectId,\n });\n\n if (job.status === \"completed\" || job.status === \"failed\" || job.status === \"cancelled\") {\n return job;\n }\n\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n }\n\n throw new Error(\"Batch job timed out\");\n }\n\n // ==========================================================================\n // SCHEDULES\n // ==========================================================================\n\n /**\n * Create a scheduled extraction job\n *\n * @example\n * ```typescript\n * const { id } = await extraction.createSchedule({\n * name: 'Daily price monitoring',\n * url: 'https://competitor.com/pricing',\n * frequency: 'daily',\n * config: { mode: 'schema', schema: { ... } },\n * });\n * ```\n */\n async createSchedule(request: CreateExtractionScheduleRequest): Promise<CreateScheduleResponse> {\n return this.http.post<CreateScheduleResponse>(\"/webdata/schedules\", {\n ...request,\n type: \"extraction\",\n });\n }\n\n /**\n * Update a schedule\n */\n async updateSchedule(request: UpdateExtractionScheduleRequest): Promise<{ success: boolean }> {\n const { id, environment, projectId, ...data } = request;\n\n const params = new URLSearchParams();\n if (environment) params.set(\"environment\", environment);\n if (projectId) params.set(\"projectId\", projectId);\n\n const query = params.toString();\n return this.http.post<{ success: boolean }>(`/webdata/schedules/${id}${query ? `?${query}` : \"\"}`, data);\n }\n\n /**\n * Get a schedule by ID\n */\n async getSchedule(request: GetScheduleRequest): Promise<ExtractionSchedule> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/schedules/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<ExtractionSchedule>(path);\n return this.convertScheduleDates(response);\n }\n\n /**\n * List schedules with pagination and filters\n */\n async listSchedules(request: ListSchedulesRequest = {}): Promise<ExtractionSchedulesResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n params.set(\"type\", \"extraction\");\n if (request.isActive !== undefined) params.set(\"isActive\", request.isActive.toString());\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ExtractionSchedulesResponse>(`/webdata/schedules${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertScheduleDates(item)),\n };\n }\n\n /**\n * Delete a schedule\n */\n async deleteSchedule(request: GetScheduleRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.deleteWithBody<{ success: boolean }>(\n `/webdata/schedules/${request.id}${query ? `?${query}` : \"\"}`,\n {\n id: request.id,\n environment: request.environment,\n projectId: request.projectId,\n },\n );\n }\n\n /**\n * Toggle a schedule on or off\n */\n async toggleSchedule(request: GetScheduleRequest): Promise<{ isActive: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.post<{ isActive: boolean }>(\n `/webdata/schedules/${request.id}/toggle${query ? `?${query}` : \"\"}`,\n {},\n );\n }\n\n // ==========================================================================\n // USAGE\n // ==========================================================================\n\n /**\n * Get usage statistics\n *\n * @example\n * ```typescript\n * const usage = await extraction.getUsage({\n * periodStart: '2024-01-01T00:00:00Z',\n * periodEnd: '2024-01-31T23:59:59Z',\n * });\n * console.log(`Extractions: ${usage.extractionsTotal}`);\n * console.log(`Tokens used: ${usage.extractionTokensUsed}`);\n * ```\n */\n async getUsage(request: GetUsageRequest = {}): Promise<ExtractionUsage> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.periodStart) params.set(\"periodStart\", request.periodStart);\n if (request.periodEnd) params.set(\"periodEnd\", request.periodEnd);\n\n const query = params.toString();\n const response = await this.http.get<ExtractionUsage>(`/webdata/usage${query ? `?${query}` : \"\"}`);\n\n return this.convertUsageDates(response);\n }\n\n /**\n * Get daily usage breakdown\n *\n * @example\n * ```typescript\n * const { days } = await extraction.getUsageDaily({\n * periodStart: '2024-01-01T00:00:00Z',\n * periodEnd: '2024-01-31T23:59:59Z',\n * });\n * days.forEach(day => {\n * console.log(`${day.date}: ${day.screenshots} screenshots, ${day.extractions} extractions`);\n * });\n * ```\n */\n async getUsageDaily(request: GetUsageRequest = {}): Promise<GetDailyUsageResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.periodStart) params.set(\"periodStart\", request.periodStart);\n if (request.periodEnd) params.set(\"periodEnd\", request.periodEnd);\n\n const query = params.toString();\n return this.http.get<GetDailyUsageResponse>(`/webdata/usage/daily${query ? `?${query}` : \"\"}`);\n }\n\n // ==========================================================================\n // HELPERS\n // ==========================================================================\n\n private convertDates(extraction: ExtractionResult): ExtractionResult {\n if (typeof extraction.createdAt === \"string\") {\n extraction.createdAt = new Date(extraction.createdAt);\n }\n if (extraction.completedAt && typeof extraction.completedAt === \"string\") {\n extraction.completedAt = new Date(extraction.completedAt);\n }\n return extraction;\n }\n\n private convertBatchJobDates(job: BatchExtractionJob): BatchExtractionJob {\n if (typeof job.createdAt === \"string\") {\n job.createdAt = new Date(job.createdAt);\n }\n if (job.startedAt && typeof job.startedAt === \"string\") {\n job.startedAt = new Date(job.startedAt);\n }\n if (job.completedAt && typeof job.completedAt === \"string\") {\n job.completedAt = new Date(job.completedAt);\n }\n return job;\n }\n\n private convertScheduleDates(schedule: ExtractionSchedule): ExtractionSchedule {\n if (typeof schedule.createdAt === \"string\") {\n schedule.createdAt = new Date(schedule.createdAt);\n }\n if (typeof schedule.updatedAt === \"string\") {\n schedule.updatedAt = new Date(schedule.updatedAt);\n }\n if (schedule.lastRunAt && typeof schedule.lastRunAt === \"string\") {\n schedule.lastRunAt = new Date(schedule.lastRunAt);\n }\n if (schedule.nextRunAt && typeof schedule.nextRunAt === \"string\") {\n schedule.nextRunAt = new Date(schedule.nextRunAt);\n }\n return schedule;\n }\n\n private convertUsageDates(usage: ExtractionUsage): ExtractionUsage {\n if (typeof usage.periodStart === \"string\") {\n usage.periodStart = new Date(usage.periodStart);\n }\n if (typeof usage.periodEnd === \"string\") {\n usage.periodEnd = new Date(usage.periodEnd);\n }\n return usage;\n }\n}\n","/**\n * Stack0 Webdata Client\n * Capture screenshots and extract data from web pages\n */\n\nimport { HttpClient, type HttpClientConfig } from \"../lib/http-client\";\nimport type {\n Screenshot,\n CreateScreenshotRequest,\n CreateScreenshotResponse,\n GetScreenshotRequest,\n ListScreenshotsRequest,\n ListScreenshotsResponse,\n Extraction,\n CreateExtractionRequest,\n CreateExtractionResponse,\n GetExtractionRequest,\n ListExtractionsRequest,\n ListExtractionsResponse,\n Schedule,\n CreateScheduleRequest,\n CreateScheduleResponse,\n UpdateScheduleRequest,\n GetScheduleRequest,\n ListSchedulesRequest,\n ListSchedulesResponse,\n Usage,\n GetUsageRequest,\n BatchJob,\n CreateBatchScreenshotsRequest,\n CreateBatchExtractionsRequest,\n CreateBatchResponse,\n GetBatchJobRequest,\n ListBatchJobsRequest,\n ListBatchJobsResponse,\n} from \"./types\";\n\nexport class Webdata {\n private http: HttpClient;\n\n constructor(config: HttpClientConfig) {\n this.http = new HttpClient(config);\n }\n\n // ==========================================================================\n // SCREENSHOTS\n // ==========================================================================\n\n /**\n * Capture a screenshot of a URL\n *\n * @example\n * ```typescript\n * const { id, status } = await webdata.screenshot({\n * url: 'https://example.com',\n * format: 'png',\n * fullPage: true,\n * deviceType: 'desktop',\n * });\n *\n * // Poll for completion\n * const screenshot = await webdata.getScreenshot({ id });\n * console.log(screenshot.imageUrl);\n * ```\n */\n async screenshot(request: CreateScreenshotRequest): Promise<CreateScreenshotResponse> {\n return this.http.post<CreateScreenshotResponse>(\"/webdata/screenshots\", request);\n }\n\n /**\n * Get a screenshot by ID\n *\n * @example\n * ```typescript\n * const screenshot = await webdata.getScreenshot({ id: 'screenshot-id' });\n * if (screenshot.status === 'completed') {\n * console.log(screenshot.imageUrl);\n * }\n * ```\n */\n async getScreenshot(request: GetScreenshotRequest): Promise<Screenshot> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/screenshots/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<Screenshot>(path);\n return this.convertScreenshotDates(response);\n }\n\n /**\n * List screenshots with pagination and filters\n *\n * @example\n * ```typescript\n * const { items, nextCursor } = await webdata.listScreenshots({\n * status: 'completed',\n * limit: 20,\n * });\n * ```\n */\n async listScreenshots(request: ListScreenshotsRequest = {}): Promise<ListScreenshotsResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n if (request.status) params.set(\"status\", request.status);\n if (request.url) params.set(\"url\", request.url);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ListScreenshotsResponse>(`/webdata/screenshots${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertScreenshotDates(item)),\n };\n }\n\n /**\n * Delete a screenshot\n *\n * @example\n * ```typescript\n * await webdata.deleteScreenshot({ id: 'screenshot-id' });\n * ```\n */\n async deleteScreenshot(request: GetScreenshotRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.deleteWithBody<{ success: boolean }>(\n `/webdata/screenshots/${request.id}${query ? `?${query}` : \"\"}`,\n {\n id: request.id,\n environment: request.environment,\n projectId: request.projectId,\n },\n );\n }\n\n /**\n * Capture a screenshot and wait for completion\n *\n * @example\n * ```typescript\n * const screenshot = await webdata.screenshotAndWait({\n * url: 'https://example.com',\n * format: 'png',\n * });\n * console.log(screenshot.imageUrl);\n * ```\n */\n async screenshotAndWait(\n request: CreateScreenshotRequest,\n options: { pollInterval?: number; timeout?: number } = {},\n ): Promise<Screenshot> {\n const { pollInterval = 1000, timeout = 60000 } = options;\n const startTime = Date.now();\n\n const { id } = await this.screenshot(request);\n\n while (Date.now() - startTime < timeout) {\n const screenshot = await this.getScreenshot({\n id,\n environment: request.environment,\n projectId: request.projectId,\n });\n\n if (screenshot.status === \"completed\" || screenshot.status === \"failed\") {\n if (screenshot.status === \"failed\") {\n throw new Error(screenshot.error || \"Screenshot failed\");\n }\n return screenshot;\n }\n\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n }\n\n throw new Error(\"Screenshot timed out\");\n }\n\n // ==========================================================================\n // EXTRACTIONS\n // ==========================================================================\n\n /**\n * Extract content from a URL\n *\n * @example\n * ```typescript\n * const { id, status } = await webdata.extract({\n * url: 'https://example.com/article',\n * mode: 'markdown',\n * includeMetadata: true,\n * });\n *\n * // Poll for completion\n * const extraction = await webdata.getExtraction({ id });\n * console.log(extraction.markdown);\n * ```\n */\n async extract(request: CreateExtractionRequest): Promise<CreateExtractionResponse> {\n return this.http.post<CreateExtractionResponse>(\"/webdata/extractions\", request);\n }\n\n /**\n * Get an extraction by ID\n *\n * @example\n * ```typescript\n * const extraction = await webdata.getExtraction({ id: 'extraction-id' });\n * if (extraction.status === 'completed') {\n * console.log(extraction.markdown);\n * console.log(extraction.pageMetadata);\n * }\n * ```\n */\n async getExtraction(request: GetExtractionRequest): Promise<Extraction> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/extractions/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<Extraction>(path);\n return this.convertExtractionDates(response);\n }\n\n /**\n * List extractions with pagination and filters\n *\n * @example\n * ```typescript\n * const { items, nextCursor } = await webdata.listExtractions({\n * status: 'completed',\n * limit: 20,\n * });\n * ```\n */\n async listExtractions(request: ListExtractionsRequest = {}): Promise<ListExtractionsResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n if (request.status) params.set(\"status\", request.status);\n if (request.url) params.set(\"url\", request.url);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ListExtractionsResponse>(`/webdata/extractions${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertExtractionDates(item)),\n };\n }\n\n /**\n * Delete an extraction\n *\n * @example\n * ```typescript\n * await webdata.deleteExtraction({ id: 'extraction-id' });\n * ```\n */\n async deleteExtraction(request: GetExtractionRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.deleteWithBody<{ success: boolean }>(\n `/webdata/extractions/${request.id}${query ? `?${query}` : \"\"}`,\n {\n id: request.id,\n environment: request.environment,\n projectId: request.projectId,\n },\n );\n }\n\n /**\n * Extract content and wait for completion\n *\n * @example\n * ```typescript\n * const extraction = await webdata.extractAndWait({\n * url: 'https://example.com/article',\n * mode: 'markdown',\n * });\n * console.log(extraction.markdown);\n * ```\n */\n async extractAndWait(\n request: CreateExtractionRequest,\n options: { pollInterval?: number; timeout?: number } = {},\n ): Promise<Extraction> {\n const { pollInterval = 1000, timeout = 60000 } = options;\n const startTime = Date.now();\n\n const { id } = await this.extract(request);\n\n while (Date.now() - startTime < timeout) {\n const extraction = await this.getExtraction({\n id,\n environment: request.environment,\n projectId: request.projectId,\n });\n\n if (extraction.status === \"completed\" || extraction.status === \"failed\") {\n if (extraction.status === \"failed\") {\n throw new Error(extraction.error || \"Extraction failed\");\n }\n return extraction;\n }\n\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n }\n\n throw new Error(\"Extraction timed out\");\n }\n\n // ==========================================================================\n // SCHEDULES\n // ==========================================================================\n\n /**\n * Create a scheduled screenshot or extraction job\n *\n * @example\n * ```typescript\n * const { id } = await webdata.createSchedule({\n * name: 'Daily homepage screenshot',\n * url: 'https://example.com',\n * type: 'screenshot',\n * frequency: 'daily',\n * config: { format: 'png', fullPage: true },\n * });\n * ```\n */\n async createSchedule(request: CreateScheduleRequest): Promise<CreateScheduleResponse> {\n return this.http.post<CreateScheduleResponse>(\"/webdata/schedules\", request);\n }\n\n /**\n * Update a schedule\n *\n * @example\n * ```typescript\n * await webdata.updateSchedule({\n * id: 'schedule-id',\n * frequency: 'weekly',\n * isActive: false,\n * });\n * ```\n */\n async updateSchedule(request: UpdateScheduleRequest): Promise<{ success: boolean }> {\n const { id, environment, projectId, ...data } = request;\n\n const params = new URLSearchParams();\n if (environment) params.set(\"environment\", environment);\n if (projectId) params.set(\"projectId\", projectId);\n\n const query = params.toString();\n return this.http.patch<{ success: boolean }>(`/webdata/schedules/${id}${query ? `?${query}` : \"\"}`, data);\n }\n\n /**\n * Get a schedule by ID\n *\n * @example\n * ```typescript\n * const schedule = await webdata.getSchedule({ id: 'schedule-id' });\n * console.log(schedule.nextRunAt);\n * ```\n */\n async getSchedule(request: GetScheduleRequest): Promise<Schedule> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/schedules/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<Schedule>(path);\n return this.convertScheduleDates(response);\n }\n\n /**\n * List schedules with pagination and filters\n *\n * @example\n * ```typescript\n * const { items, nextCursor } = await webdata.listSchedules({\n * type: 'screenshot',\n * isActive: true,\n * });\n * ```\n */\n async listSchedules(request: ListSchedulesRequest = {}): Promise<ListSchedulesResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n if (request.type) params.set(\"type\", request.type);\n if (request.isActive !== undefined) params.set(\"isActive\", request.isActive.toString());\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ListSchedulesResponse>(`/webdata/schedules${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertScheduleDates(item)),\n };\n }\n\n /**\n * Delete a schedule\n *\n * @example\n * ```typescript\n * await webdata.deleteSchedule({ id: 'schedule-id' });\n * ```\n */\n async deleteSchedule(request: GetScheduleRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.deleteWithBody<{ success: boolean }>(\n `/webdata/schedules/${request.id}${query ? `?${query}` : \"\"}`,\n {\n id: request.id,\n environment: request.environment,\n projectId: request.projectId,\n },\n );\n }\n\n /**\n * Toggle a schedule on or off\n *\n * @example\n * ```typescript\n * const { isActive } = await webdata.toggleSchedule({ id: 'schedule-id' });\n * console.log(`Schedule is now ${isActive ? 'active' : 'paused'}`);\n * ```\n */\n async toggleSchedule(request: GetScheduleRequest): Promise<{ isActive: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.post<{ isActive: boolean }>(\n `/webdata/schedules/${request.id}/toggle${query ? `?${query}` : \"\"}`,\n {},\n );\n }\n\n // ==========================================================================\n // USAGE\n // ==========================================================================\n\n /**\n * Get usage statistics\n *\n * @example\n * ```typescript\n * const usage = await webdata.getUsage({\n * periodStart: '2024-01-01T00:00:00Z',\n * periodEnd: '2024-01-31T23:59:59Z',\n * });\n * console.log(`Screenshots: ${usage.screenshotsTotal}`);\n * console.log(`Extractions: ${usage.extractionsTotal}`);\n * ```\n */\n async getUsage(request: GetUsageRequest = {}): Promise<Usage> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.periodStart) params.set(\"periodStart\", request.periodStart);\n if (request.periodEnd) params.set(\"periodEnd\", request.periodEnd);\n\n const query = params.toString();\n const response = await this.http.get<Usage>(`/webdata/usage${query ? `?${query}` : \"\"}`);\n\n return this.convertUsageDates(response);\n }\n\n // ==========================================================================\n // BATCH JOBS\n // ==========================================================================\n\n /**\n * Create a batch screenshot job for multiple URLs\n *\n * @example\n * ```typescript\n * const { id, totalUrls } = await webdata.batchScreenshots({\n * urls: [\n * 'https://example.com',\n * 'https://example.org',\n * ],\n * config: { format: 'png', fullPage: true },\n * });\n *\n * // Poll for completion\n * const job = await webdata.getBatchJob({ id });\n * console.log(`Progress: ${job.processedUrls}/${job.totalUrls}`);\n * ```\n */\n async batchScreenshots(request: CreateBatchScreenshotsRequest): Promise<CreateBatchResponse> {\n return this.http.post<CreateBatchResponse>(\"/webdata/batch/screenshots\", request);\n }\n\n /**\n * Create a batch extraction job for multiple URLs\n *\n * @example\n * ```typescript\n * const { id, totalUrls } = await webdata.batchExtractions({\n * urls: [\n * 'https://example.com/article1',\n * 'https://example.com/article2',\n * ],\n * config: { mode: 'markdown' },\n * });\n * ```\n */\n async batchExtractions(request: CreateBatchExtractionsRequest): Promise<CreateBatchResponse> {\n return this.http.post<CreateBatchResponse>(\"/webdata/batch/extractions\", request);\n }\n\n /**\n * Get a batch job by ID\n *\n * @example\n * ```typescript\n * const job = await webdata.getBatchJob({ id: 'batch-id' });\n * console.log(`Status: ${job.status}`);\n * console.log(`Progress: ${job.processedUrls}/${job.totalUrls}`);\n * ```\n */\n async getBatchJob(request: GetBatchJobRequest): Promise<BatchJob> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n const path = `/webdata/batch/${request.id}${query ? `?${query}` : \"\"}`;\n\n const response = await this.http.get<BatchJob>(path);\n return this.convertBatchJobDates(response);\n }\n\n /**\n * List batch jobs with pagination and filters\n *\n * @example\n * ```typescript\n * const { items, nextCursor } = await webdata.listBatchJobs({\n * status: 'completed',\n * type: 'screenshot',\n * limit: 20,\n * });\n * ```\n */\n async listBatchJobs(request: ListBatchJobsRequest = {}): Promise<ListBatchJobsResponse> {\n const params = new URLSearchParams();\n\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n if (request.status) params.set(\"status\", request.status);\n if (request.type) params.set(\"type\", request.type);\n if (request.limit) params.set(\"limit\", request.limit.toString());\n if (request.cursor) params.set(\"cursor\", request.cursor);\n\n const query = params.toString();\n const response = await this.http.get<ListBatchJobsResponse>(`/webdata/batch${query ? `?${query}` : \"\"}`);\n\n return {\n ...response,\n items: response.items.map((item) => this.convertBatchJobDates(item)),\n };\n }\n\n /**\n * Cancel a batch job\n *\n * @example\n * ```typescript\n * await webdata.cancelBatchJob({ id: 'batch-id' });\n * ```\n */\n async cancelBatchJob(request: GetBatchJobRequest): Promise<{ success: boolean }> {\n const params = new URLSearchParams();\n if (request.environment) params.set(\"environment\", request.environment);\n if (request.projectId) params.set(\"projectId\", request.projectId);\n\n const query = params.toString();\n return this.http.post<{ success: boolean }>(`/webdata/batch/${request.id}/cancel${query ? `?${query}` : \"\"}`, {});\n }\n\n /**\n * Create a batch screenshot job and wait for completion\n *\n * @example\n * ```typescript\n * const job = await webdata.batchScreenshotsAndWait({\n * urls: ['https://example.com', 'https://example.org'],\n * config: { format: 'png' },\n * });\n * console.log(`Completed: ${job.successfulUrls} successful, ${job.failedUrls} failed`);\n * ```\n */\n async batchScreenshotsAndWait(\n request: CreateBatchScreenshotsRequest,\n options: { pollInterval?: number; timeout?: number } = {},\n ): Promise<BatchJob> {\n const { pollInterval = 2000, timeout = 300000 } = options;\n const startTime = Date.now();\n\n const { id } = await this.batchScreenshots(request);\n\n while (Date.now() - startTime < timeout) {\n const job = await this.getBatchJob({\n id,\n environment: request.environment,\n projectId: request.projectId,\n });\n\n if (job.status === \"completed\" || job.status === \"failed\" || job.status === \"cancelled\") {\n return job;\n }\n\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n }\n\n throw new Error(\"Batch job timed out\");\n }\n\n /**\n * Create a batch extraction job and wait for completion\n *\n * @example\n * ```typescript\n * const job = await webdata.batchExtractionsAndWait({\n * urls: ['https://example.com/article1', 'https://example.com/article2'],\n * config: { mode: 'markdown' },\n * });\n * console.log(`Completed: ${job.successfulUrls} successful`);\n * ```\n */\n async batchExtractionsAndWait(\n request: CreateBatchExtractionsRequest,\n options: { pollInterval?: number; timeout?: number } = {},\n ): Promise<BatchJob> {\n const { pollInterval = 2000, timeout = 300000 } = options;\n const startTime = Date.now();\n\n const { id } = await this.batchExtractions(request);\n\n while (Date.now() - startTime < timeout) {\n const job = await this.getBatchJob({\n id,\n environment: request.environment,\n projectId: request.projectId,\n });\n\n if (job.status === \"completed\" || job.status === \"failed\" || job.status === \"cancelled\") {\n return job;\n }\n\n await new Promise((resolve) => setTimeout(resolve, pollInterval));\n }\n\n throw new Error(\"Batch job timed out\");\n }\n\n // ==========================================================================\n // HELPERS\n // ==========================================================================\n\n private convertScreenshotDates(screenshot: Screenshot): Screenshot {\n if (typeof screenshot.createdAt === \"string\") {\n screenshot.createdAt = new Date(screenshot.createdAt);\n }\n if (screenshot.completedAt && typeof screenshot.completedAt === \"string\") {\n screenshot.completedAt = new Date(screenshot.completedAt);\n }\n return screenshot;\n }\n\n private convertExtractionDates(extraction: Extraction): Extraction {\n if (typeof extraction.createdAt === \"string\") {\n extraction.createdAt = new Date(extraction.createdAt);\n }\n if (extraction.completedAt && typeof extraction.completedAt === \"string\") {\n extraction.completedAt = new Date(extraction.completedAt);\n }\n return extraction;\n }\n\n private convertScheduleDates(schedule: Schedule): Schedule {\n if (typeof schedule.createdAt === \"string\") {\n schedule.createdAt = new Date(schedule.createdAt);\n }\n if (typeof schedule.updatedAt === \"string\") {\n schedule.updatedAt = new Date(schedule.updatedAt);\n }\n if (schedule.lastRunAt && typeof schedule.lastRunAt === \"string\") {\n schedule.lastRunAt = new Date(schedule.lastRunAt);\n }\n if (schedule.nextRunAt && typeof schedule.nextRunAt === \"string\") {\n schedule.nextRunAt = new Date(schedule.nextRunAt);\n }\n return schedule;\n }\n\n private convertUsageDates(usage: Usage): Usage {\n if (typeof usage.periodStart === \"string\") {\n usage.periodStart = new Date(usage.periodStart);\n }\n if (typeof usage.periodEnd === \"string\") {\n usage.periodEnd = new Date(usage.periodEnd);\n }\n return usage;\n }\n\n private convertBatchJobDates(job: BatchJob): BatchJob {\n if (typeof job.createdAt === \"string\") {\n job.createdAt = new Date(job.createdAt);\n }\n if (job.startedAt && typeof job.startedAt === \"string\") {\n job.startedAt = new Date(job.startedAt);\n }\n if (job.completedAt && typeof job.completedAt === \"string\") {\n job.completedAt = new Date(job.completedAt);\n }\n return job;\n }\n}\n","/**\n * Stack0 Integrations Client\n * Unified API for third-party integrations\n */\n\nimport { HttpClient, type HttpClientConfig } from \"../lib/http-client\";\nimport type {\n Connector,\n Connection,\n ConnectorCategory,\n ListOptions,\n PaginatedResult,\n // CRM\n Contact,\n CreateContactInput,\n UpdateContactInput,\n Company,\n CreateCompanyInput,\n UpdateCompanyInput,\n Deal,\n CreateDealInput,\n UpdateDealInput,\n // Storage\n File,\n IntegrationFolder,\n CreateFolderInput,\n UploadFileInput,\n // Communication\n Channel,\n Message,\n SendMessageInput,\n CommunicationUser,\n // Productivity\n Document,\n CreateDocumentInput,\n UpdateDocumentInput,\n Table,\n TableRow,\n CreateTableRowInput,\n UpdateTableRowInput,\n // Passthrough\n PassthroughRequest,\n // OAuth & Connections\n InitiateOAuthRequest,\n InitiateOAuthResponse,\n CompleteOAuthRequest,\n CompleteOAuthResponse,\n ReconnectConnectionRequest,\n ReconnectConnectionResponse,\n UpdateConnectionRequest,\n UpdateConnectionResponse,\n IntegrationStatsRequest,\n IntegrationStatsResponse,\n ListConnectionsRequest,\n ListConnectionsResponse,\n ConnectionDetails,\n // Logs\n ListLogsRequest,\n ListLogsResponse,\n ApiLog,\n} from \"./types\";\n\n/**\n * CRM operations client\n */\nclass CRM {\n private http: HttpClient;\n\n constructor(http: HttpClient) {\n this.http = http;\n }\n\n // Contacts\n async listContacts(\n connectionId: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<Contact>> {\n const params = new URLSearchParams({ connectionId });\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n if (options?.sortBy) params.set(\"sortBy\", options.sortBy);\n if (options?.sortOrder) params.set(\"sortOrder\", options.sortOrder);\n return this.http.get(`/integrations/crm/contacts?${params}`);\n }\n\n async getContact(connectionId: string, id: string): Promise<Contact> {\n return this.http.get(`/integrations/crm/contacts/${id}?connectionId=${connectionId}`);\n }\n\n async createContact(connectionId: string, data: CreateContactInput): Promise<Contact> {\n return this.http.post(\"/integrations/crm/contacts\", { connectionId, data });\n }\n\n async updateContact(connectionId: string, id: string, data: UpdateContactInput): Promise<Contact> {\n return this.http.patch(`/integrations/crm/contacts/${id}`, { connectionId, data });\n }\n\n async deleteContact(connectionId: string, id: string): Promise<{ success: boolean }> {\n return this.http.delete(`/integrations/crm/contacts/${id}?connectionId=${connectionId}`);\n }\n\n // Companies\n async listCompanies(\n connectionId: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<Company>> {\n const params = new URLSearchParams({ connectionId });\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n if (options?.sortBy) params.set(\"sortBy\", options.sortBy);\n if (options?.sortOrder) params.set(\"sortOrder\", options.sortOrder);\n return this.http.get(`/integrations/crm/companies?${params}`);\n }\n\n async getCompany(connectionId: string, id: string): Promise<Company> {\n return this.http.get(`/integrations/crm/companies/${id}?connectionId=${connectionId}`);\n }\n\n async createCompany(connectionId: string, data: CreateCompanyInput): Promise<Company> {\n return this.http.post(\"/integrations/crm/companies\", { connectionId, data });\n }\n\n async updateCompany(connectionId: string, id: string, data: UpdateCompanyInput): Promise<Company> {\n return this.http.patch(`/integrations/crm/companies/${id}`, { connectionId, data });\n }\n\n async deleteCompany(connectionId: string, id: string): Promise<{ success: boolean }> {\n return this.http.delete(`/integrations/crm/companies/${id}?connectionId=${connectionId}`);\n }\n\n // Deals\n async listDeals(\n connectionId: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<Deal>> {\n const params = new URLSearchParams({ connectionId });\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n if (options?.sortBy) params.set(\"sortBy\", options.sortBy);\n if (options?.sortOrder) params.set(\"sortOrder\", options.sortOrder);\n return this.http.get(`/integrations/crm/deals?${params}`);\n }\n\n async getDeal(connectionId: string, id: string): Promise<Deal> {\n return this.http.get(`/integrations/crm/deals/${id}?connectionId=${connectionId}`);\n }\n\n async createDeal(connectionId: string, data: CreateDealInput): Promise<Deal> {\n return this.http.post(\"/integrations/crm/deals\", { connectionId, data });\n }\n\n async updateDeal(connectionId: string, id: string, data: UpdateDealInput): Promise<Deal> {\n return this.http.patch(`/integrations/crm/deals/${id}`, { connectionId, data });\n }\n\n async deleteDeal(connectionId: string, id: string): Promise<{ success: boolean }> {\n return this.http.delete(`/integrations/crm/deals/${id}?connectionId=${connectionId}`);\n }\n}\n\n/**\n * Storage operations client\n */\nclass Storage {\n private http: HttpClient;\n\n constructor(http: HttpClient) {\n this.http = http;\n }\n\n // Files\n async listFiles(\n connectionId: string,\n folderId?: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<File>> {\n const params = new URLSearchParams({ connectionId });\n if (folderId) params.set(\"folderId\", folderId);\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n return this.http.get(`/integrations/storage/files?${params}`);\n }\n\n async getFile(connectionId: string, id: string): Promise<File> {\n return this.http.get(`/integrations/storage/files/${id}?connectionId=${connectionId}`);\n }\n\n async uploadFile(connectionId: string, input: UploadFileInput): Promise<File> {\n // Convert data to base64 for JSON transport\n const base64Data =\n input.data instanceof ArrayBuffer\n ? btoa(String.fromCharCode(...new Uint8Array(input.data)))\n : btoa(String.fromCharCode(...input.data));\n\n return this.http.post(\"/integrations/storage/files\", {\n connectionId,\n name: input.name,\n mimeType: input.mimeType,\n data: base64Data,\n folderId: input.folderId,\n });\n }\n\n async deleteFile(connectionId: string, id: string): Promise<{ success: boolean }> {\n return this.http.delete(`/integrations/storage/files/${id}?connectionId=${connectionId}`);\n }\n\n async downloadFile(\n connectionId: string,\n id: string,\n ): Promise<{ data: ArrayBuffer; mimeType: string; filename: string }> {\n const response = await this.http.get<{ data: string; mimeType: string; filename: string }>(\n `/integrations/storage/files/${id}/download?connectionId=${connectionId}`,\n );\n // Decode base64 to ArrayBuffer\n const binaryString = atob(response.data);\n const bytes = new Uint8Array(binaryString.length);\n for (let i = 0; i < binaryString.length; i++) {\n bytes[i] = binaryString.charCodeAt(i);\n }\n return {\n data: bytes.buffer,\n mimeType: response.mimeType,\n filename: response.filename,\n };\n }\n\n // Folders\n async listFolders(\n connectionId: string,\n parentId?: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<IntegrationFolder>> {\n const params = new URLSearchParams({ connectionId });\n if (parentId) params.set(\"parentId\", parentId);\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n return this.http.get(`/integrations/storage/folders?${params}`);\n }\n\n async getFolder(connectionId: string, id: string): Promise<IntegrationFolder> {\n return this.http.get(`/integrations/storage/folders/${id}?connectionId=${connectionId}`);\n }\n\n async createFolder(connectionId: string, data: CreateFolderInput): Promise<IntegrationFolder> {\n return this.http.post(\"/integrations/storage/folders\", { connectionId, ...data });\n }\n\n async deleteFolder(connectionId: string, id: string): Promise<{ success: boolean }> {\n return this.http.delete(`/integrations/storage/folders/${id}?connectionId=${connectionId}`);\n }\n}\n\n/**\n * Communication operations client\n */\nclass Communication {\n private http: HttpClient;\n\n constructor(http: HttpClient) {\n this.http = http;\n }\n\n // Channels\n async listChannels(\n connectionId: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<Channel>> {\n const params = new URLSearchParams({ connectionId });\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n return this.http.get(`/integrations/communication/channels?${params}`);\n }\n\n async getChannel(connectionId: string, id: string): Promise<Channel> {\n return this.http.get(`/integrations/communication/channels/${id}?connectionId=${connectionId}`);\n }\n\n // Messages\n async listMessages(\n connectionId: string,\n channelId: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<Message>> {\n const params = new URLSearchParams({ connectionId, channelId });\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n return this.http.get(`/integrations/communication/messages?${params}`);\n }\n\n async sendMessage(connectionId: string, input: SendMessageInput): Promise<Message> {\n return this.http.post(\"/integrations/communication/messages\", { connectionId, ...input });\n }\n\n // Users\n async listUsers(\n connectionId: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<CommunicationUser>> {\n const params = new URLSearchParams({ connectionId });\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n return this.http.get(`/integrations/communication/users?${params}`);\n }\n}\n\n/**\n * Productivity operations client\n */\nclass Productivity {\n private http: HttpClient;\n\n constructor(http: HttpClient) {\n this.http = http;\n }\n\n // Documents\n async listDocuments(\n connectionId: string,\n parentId?: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<Document>> {\n const params = new URLSearchParams({ connectionId });\n if (parentId) params.set(\"parentId\", parentId);\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n return this.http.get(`/integrations/productivity/documents?${params}`);\n }\n\n async getDocument(connectionId: string, id: string): Promise<Document> {\n return this.http.get(`/integrations/productivity/documents/${id}?connectionId=${connectionId}`);\n }\n\n async createDocument(connectionId: string, data: CreateDocumentInput): Promise<Document> {\n return this.http.post(\"/integrations/productivity/documents\", { connectionId, ...data });\n }\n\n async updateDocument(connectionId: string, id: string, data: UpdateDocumentInput): Promise<Document> {\n return this.http.patch(`/integrations/productivity/documents/${id}`, { connectionId, ...data });\n }\n\n // Tables\n async listTables(\n connectionId: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<Table>> {\n const params = new URLSearchParams({ connectionId });\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n return this.http.get(`/integrations/productivity/tables?${params}`);\n }\n\n async getTable(connectionId: string, id: string): Promise<Table> {\n return this.http.get(`/integrations/productivity/tables/${id}?connectionId=${connectionId}`);\n }\n\n // Table Rows\n async listTableRows(\n connectionId: string,\n tableId: string,\n options?: ListOptions,\n ): Promise<PaginatedResult<TableRow>> {\n const params = new URLSearchParams({ connectionId });\n if (options?.cursor) params.set(\"cursor\", options.cursor);\n if (options?.limit) params.set(\"limit\", String(options.limit));\n return this.http.get(`/integrations/productivity/tables/${tableId}/rows?${params}`);\n }\n\n async getTableRow(connectionId: string, tableId: string, rowId: string): Promise<TableRow> {\n return this.http.get(\n `/integrations/productivity/tables/${tableId}/rows/${rowId}?connectionId=${connectionId}`,\n );\n }\n\n async createTableRow(connectionId: string, tableId: string, data: CreateTableRowInput): Promise<TableRow> {\n return this.http.post(`/integrations/productivity/tables/${tableId}/rows`, {\n connectionId,\n ...data,\n });\n }\n\n async updateTableRow(\n connectionId: string,\n tableId: string,\n rowId: string,\n data: UpdateTableRowInput,\n ): Promise<TableRow> {\n return this.http.patch(`/integrations/productivity/tables/${tableId}/rows/${rowId}`, {\n connectionId,\n ...data,\n });\n }\n\n async deleteTableRow(\n connectionId: string,\n tableId: string,\n rowId: string,\n ): Promise<{ success: boolean }> {\n return this.http.delete(\n `/integrations/productivity/tables/${tableId}/rows/${rowId}?connectionId=${connectionId}`,\n );\n }\n}\n\n/**\n * Stack0 Integrations SDK Client\n *\n * @example\n * ```typescript\n * import { Integrations } from '@stack0/sdk';\n *\n * const integrations = new Integrations({ apiKey: 'stack0_...' });\n *\n * // List connectors\n * const connectors = await integrations.listConnectors();\n *\n * // List contacts from a CRM connection\n * const contacts = await integrations.crm.listContacts('conn_123');\n *\n * // Create a contact\n * const contact = await integrations.crm.createContact('conn_123', {\n * firstName: 'John',\n * lastName: 'Doe',\n * email: 'john@example.com',\n * });\n *\n * // Send a message via Slack\n * await integrations.communication.sendMessage('conn_456', {\n * channelId: 'C123',\n * content: 'Hello from Stack0!',\n * });\n *\n * // Upload a file to Google Drive\n * await integrations.storage.uploadFile('conn_789', {\n * name: 'report.pdf',\n * mimeType: 'application/pdf',\n * data: fileBuffer,\n * });\n * ```\n */\nexport class Integrations {\n private http: HttpClient;\n\n public crm: CRM;\n public storage: Storage;\n public communication: Communication;\n public productivity: Productivity;\n\n constructor(config: HttpClientConfig) {\n this.http = new HttpClient(config);\n\n this.crm = new CRM(this.http);\n this.storage = new Storage(this.http);\n this.communication = new Communication(this.http);\n this.productivity = new Productivity(this.http);\n }\n\n // ============================================================================\n // CONNECTORS\n // ============================================================================\n\n /**\n * List all available connectors\n */\n async listConnectors(category?: ConnectorCategory): Promise<Connector[]> {\n const params = category ? `?category=${category}` : \"\";\n return this.http.get(`/integrations/connectors${params}`);\n }\n\n /**\n * Get a specific connector\n */\n async getConnector(slug: string): Promise<Connector> {\n return this.http.get(`/integrations/connectors/${slug}`);\n }\n\n // ============================================================================\n // CONNECTIONS\n // ============================================================================\n\n /**\n * List all connections\n *\n * @example\n * ```typescript\n * const { connections } = await integrations.listConnections({\n * environment: 'production',\n * status: 'connected',\n * });\n * ```\n */\n async listConnections(request?: ListConnectionsRequest): Promise<ListConnectionsResponse> {\n const params = new URLSearchParams();\n if (request?.projectId) params.set(\"projectId\", request.projectId);\n if (request?.environment) params.set(\"environment\", request.environment);\n if (request?.connectorSlug) params.set(\"connectorSlug\", request.connectorSlug);\n if (request?.status) params.set(\"status\", request.status);\n if (request?.limit) params.set(\"limit\", request.limit.toString());\n const queryString = params.toString();\n\n const response = await this.http.get<ListConnectionsResponse>(\n `/integrations/connections${queryString ? `?${queryString}` : \"\"}`,\n );\n return {\n ...response,\n connections: response.connections.map((c) => this.convertConnectionDates(c)),\n };\n }\n\n /**\n * Get a specific connection\n */\n async getConnection(connectionId: string): Promise<ConnectionDetails> {\n const response = await this.http.get<ConnectionDetails>(`/integrations/connections/${connectionId}`);\n return this.convertConnectionDetailsDates(response);\n }\n\n /**\n * Initiate OAuth flow for a connector\n *\n * @example\n * ```typescript\n * const { authUrl, connectionId, state } = await integrations.initiateOAuth({\n * connectorSlug: 'hubspot',\n * redirectUrl: 'https://yourapp.com/oauth/callback',\n * name: 'My HubSpot Connection',\n * });\n * // Redirect user to authUrl\n * ```\n */\n async initiateOAuth(request: InitiateOAuthRequest): Promise<InitiateOAuthResponse> {\n return this.http.post<InitiateOAuthResponse>(\"/integrations/connections/oauth/initiate\", request);\n }\n\n /**\n * Complete OAuth flow with callback data\n *\n * @example\n * ```typescript\n * const result = await integrations.completeOAuth({\n * code: 'auth_code_from_callback',\n * state: 'state_from_initiate',\n * redirectUrl: 'https://yourapp.com/oauth/callback',\n * });\n * console.log(`Connected to: ${result.externalAccountName}`);\n * ```\n */\n async completeOAuth(request: CompleteOAuthRequest): Promise<CompleteOAuthResponse> {\n return this.http.post<CompleteOAuthResponse>(\"/integrations/connections/oauth/callback\", request);\n }\n\n /**\n * Update a connection\n */\n async updateConnection(request: UpdateConnectionRequest): Promise<UpdateConnectionResponse> {\n const { connectionId, ...data } = request;\n return this.http.patch<UpdateConnectionResponse>(`/integrations/connections/${connectionId}`, data);\n }\n\n /**\n * Delete a connection\n */\n async deleteConnection(connectionId: string): Promise<{ success: boolean }> {\n return this.http.delete(`/integrations/connections/${connectionId}`);\n }\n\n /**\n * Reconnect an expired or errored connection\n *\n * @example\n * ```typescript\n * const { authUrl, state } = await integrations.reconnectConnection({\n * connectionId: 'conn_123',\n * redirectUrl: 'https://yourapp.com/oauth/callback',\n * });\n * // Redirect user to authUrl\n * ```\n */\n async reconnectConnection(request: ReconnectConnectionRequest): Promise<ReconnectConnectionResponse> {\n return this.http.post<ReconnectConnectionResponse>(\n `/integrations/connections/${request.connectionId}/reconnect`,\n { redirectUrl: request.redirectUrl },\n );\n }\n\n /**\n * Get integration statistics\n *\n * @example\n * ```typescript\n * const stats = await integrations.getStats({ environment: 'production' });\n * console.log(`Active connections: ${stats.activeConnections}`);\n * console.log(`API calls last 30 days: ${stats.apiCallsLast30Days}`);\n * ```\n */\n async getStats(request?: IntegrationStatsRequest): Promise<IntegrationStatsResponse> {\n const params = new URLSearchParams();\n if (request?.environment) params.set(\"environment\", request.environment);\n const queryString = params.toString();\n return this.http.get<IntegrationStatsResponse>(\n `/integrations/connections/stats${queryString ? `?${queryString}` : \"\"}`,\n );\n }\n\n // ============================================================================\n // LOGS\n // ============================================================================\n\n /**\n * List API logs\n *\n * @example\n * ```typescript\n * const { logs } = await integrations.listLogs({\n * connectionId: 'conn_123',\n * limit: 50,\n * });\n * ```\n */\n async listLogs(request?: ListLogsRequest): Promise<ListLogsResponse> {\n const params = new URLSearchParams();\n if (request?.connectionId) params.set(\"connectionId\", request.connectionId);\n if (request?.connectorSlug) params.set(\"connectorSlug\", request.connectorSlug);\n if (request?.statusCode) params.set(\"statusCode\", request.statusCode.toString());\n if (request?.method) params.set(\"method\", request.method);\n if (request?.search) params.set(\"search\", request.search);\n if (request?.limit) params.set(\"limit\", request.limit.toString());\n if (request?.cursor) params.set(\"cursor\", request.cursor);\n const queryString = params.toString();\n\n const response = await this.http.get<ListLogsResponse>(\n `/integrations/logs${queryString ? `?${queryString}` : \"\"}`,\n );\n return {\n ...response,\n logs: response.logs.map((log) => this.convertLogDates(log)),\n };\n }\n\n // ============================================================================\n // PASSTHROUGH\n // ============================================================================\n\n /**\n * Make a raw passthrough request to the provider API\n */\n async passthrough(request: PassthroughRequest): Promise<unknown> {\n return this.http.post(\"/integrations/passthrough\", request);\n }\n\n // ============================================================================\n // Date Conversion Helpers\n // ============================================================================\n\n private convertConnectionDates<T extends { connectedAt?: Date | null; lastUsedAt?: Date | null; createdAt?: Date }>(\n connection: T,\n ): T {\n if (connection.connectedAt && typeof connection.connectedAt === \"string\") {\n connection.connectedAt = new Date(connection.connectedAt);\n }\n if (connection.lastUsedAt && typeof connection.lastUsedAt === \"string\") {\n connection.lastUsedAt = new Date(connection.lastUsedAt);\n }\n if (connection.createdAt && typeof connection.createdAt === \"string\") {\n connection.createdAt = new Date(connection.createdAt);\n }\n return connection;\n }\n\n private convertConnectionDetailsDates(connection: ConnectionDetails): ConnectionDetails {\n if (connection.connectedAt && typeof connection.connectedAt === \"string\") {\n connection.connectedAt = new Date(connection.connectedAt);\n }\n if (connection.lastUsedAt && typeof connection.lastUsedAt === \"string\") {\n connection.lastUsedAt = new Date(connection.lastUsedAt);\n }\n if (connection.lastErrorAt && typeof connection.lastErrorAt === \"string\") {\n connection.lastErrorAt = new Date(connection.lastErrorAt);\n }\n if (connection.createdAt && typeof connection.createdAt === \"string\") {\n connection.createdAt = new Date(connection.createdAt);\n }\n if (connection.updatedAt && typeof connection.updatedAt === \"string\") {\n connection.updatedAt = new Date(connection.updatedAt);\n }\n return connection;\n }\n\n private convertLogDates(log: ApiLog): ApiLog {\n if (typeof log.createdAt === \"string\") {\n log.createdAt = new Date(log.createdAt);\n }\n return log;\n }\n}\n","/**\n * Stack0 Marketing Client\n * Discover trends, generate content opportunities, and manage marketing content\n */\n\nimport { HttpClient, type HttpClientConfig } from \"../lib/http-client\";\nimport type {\n Trend,\n DiscoverTrendsRequest,\n DiscoverTrendsResponse,\n ListTrendsRequest,\n ListTrendsResponse,\n UpdateTrendStatusRequest,\n UpdateTrendStatusResponse,\n Opportunity,\n GenerateOpportunitiesRequest,\n GenerateOpportunitiesResponse,\n ListOpportunitiesRequest,\n ListOpportunitiesResponse,\n DismissOpportunityRequest,\n Content,\n CreateContentRequest,\n ListContentRequest,\n ListContentResponse,\n UpdateContentRequest,\n ApproveContentRequest,\n RejectContentRequest,\n Script,\n CreateScriptRequest,\n ListScriptsRequest,\n ListScriptsResponse,\n UpdateScriptRequest,\n CreateScriptVersionRequest,\n DeleteScriptResponse,\n AnalyticsOverviewRequest,\n AnalyticsOverviewResponse,\n ContentPerformanceRequest,\n ContentPerformanceResponse,\n TrendAnalyticsRequest,\n TrendAnalyticsResponse,\n OpportunityConversionRequest,\n OpportunityConversionResponse,\n CalendarEntry,\n ScheduleContentRequest,\n ListCalendarEntriesRequest,\n UpdateCalendarEntryRequest,\n CancelCalendarEntryResponse,\n MarkPublishedRequest,\n AssetJob,\n CreateAssetJobRequest,\n ListAssetJobsRequest,\n UpdateAssetJobStatusRequest,\n MarketingSettings,\n GetSettingsRequest,\n UpdateSettingsRequest,\n UpdateSettingsResponse,\n MarketingUsage,\n GetCurrentUsageRequest,\n CurrentUsageResponse,\n GetUsageHistoryRequest,\n GetTotalUsageRequest,\n TotalUsageResponse,\n RecordUsageRequest,\n} from \"./types\";\n\nexport class Marketing {\n private http: HttpClient;\n\n constructor(config: HttpClientConfig) {\n this.http = new HttpClient(config);\n }\n\n // ============================================================================\n // Trends\n // ============================================================================\n\n /**\n * Discover new trends from all sources\n *\n * @example\n * ```typescript\n * const { trendsDiscovered, trends } = await marketing.discoverTrends({\n * projectSlug: 'my-project',\n * environment: 'production',\n * });\n * console.log(`Discovered ${trendsDiscovered} new trends`);\n * ```\n */\n async discoverTrends(request: DiscoverTrendsRequest): Promise<DiscoverTrendsResponse> {\n return this.http.post<DiscoverTrendsResponse>(\"/marketing/trends/discover\", request);\n }\n\n /**\n * List trends for a project\n *\n * @example\n * ```typescript\n * const trends = await marketing.listTrends({\n * projectSlug: 'my-project',\n * environment: 'production',\n * limit: 20,\n * });\n * ```\n */\n async listTrends(request: ListTrendsRequest): Promise<Trend[]> {\n return this.http.get<Trend[]>(\n `/marketing/trends?${new URLSearchParams({\n projectSlug: request.projectSlug,\n environment: request.environment,\n ...(request.status && { status: request.status }),\n ...(request.limit && { limit: request.limit.toString() }),\n }).toString()}`,\n );\n }\n\n /**\n * Get a single trend by ID\n */\n async getTrend(trendId: string): Promise<Trend> {\n const response = await this.http.get<Trend>(`/marketing/trends/${trendId}`);\n return this.convertTrendDates(response);\n }\n\n /**\n * Update trend status\n *\n * @example\n * ```typescript\n * await marketing.updateTrendStatus({\n * trendId: 'trend-id',\n * status: 'active',\n * });\n * ```\n */\n async updateTrendStatus(request: UpdateTrendStatusRequest): Promise<UpdateTrendStatusResponse> {\n return this.http.patch<UpdateTrendStatusResponse>(`/marketing/trends/${request.trendId}/status`, {\n status: request.status,\n });\n }\n\n // ============================================================================\n // Opportunities\n // ============================================================================\n\n /**\n * Generate content opportunities from active trends\n *\n * @example\n * ```typescript\n * const { opportunitiesGenerated, opportunities } = await marketing.generateOpportunities({\n * projectSlug: 'my-project',\n * environment: 'production',\n * });\n * console.log(`Generated ${opportunitiesGenerated} new content ideas`);\n * ```\n */\n async generateOpportunities(request: GenerateOpportunitiesRequest): Promise<GenerateOpportunitiesResponse> {\n return this.http.post<GenerateOpportunitiesResponse>(\"/marketing/opportunities/generate\", request);\n }\n\n /**\n * List opportunities for a project\n *\n * @example\n * ```typescript\n * const opportunities = await marketing.listOpportunities({\n * projectSlug: 'my-project',\n * environment: 'production',\n * status: 'pending',\n * limit: 20,\n * });\n * ```\n */\n async listOpportunities(request: ListOpportunitiesRequest): Promise<Opportunity[]> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n environment: request.environment,\n ...(request.status && { status: request.status }),\n ...(request.limit && { limit: request.limit.toString() }),\n });\n\n return this.http.get<Opportunity[]>(`/marketing/opportunities?${params.toString()}`);\n }\n\n /**\n * Get a single opportunity by ID\n */\n async getOpportunity(opportunityId: string): Promise<Opportunity> {\n const response = await this.http.get<Opportunity>(`/marketing/opportunities/${opportunityId}`);\n return this.convertOpportunityDates(response);\n }\n\n /**\n * Dismiss an opportunity\n *\n * @example\n * ```typescript\n * await marketing.dismissOpportunity({ opportunityId: 'opp-id' });\n * ```\n */\n async dismissOpportunity(request: DismissOpportunityRequest): Promise<{ success: boolean }> {\n return this.http.post<{ success: boolean }>(`/marketing/opportunities/${request.opportunityId}/dismiss`, {});\n }\n\n // ============================================================================\n // Content\n // ============================================================================\n\n /**\n * Create new marketing content\n *\n * @example\n * ```typescript\n * const content = await marketing.createContent({\n * projectSlug: 'my-project',\n * environment: 'production',\n * contentType: 'tiktok_slideshow',\n * title: 'How AI is Changing Marketing',\n * opportunityId: 'opp-id',\n * });\n * ```\n */\n async createContent(request: CreateContentRequest): Promise<Content> {\n const response = await this.http.post<Content>(\"/marketing/content\", request);\n return this.convertContentDates(response);\n }\n\n /**\n * List content with filters\n *\n * @example\n * ```typescript\n * const content = await marketing.listContent({\n * projectSlug: 'my-project',\n * environment: 'production',\n * status: 'published',\n * limit: 20,\n * });\n * ```\n */\n async listContent(request: ListContentRequest): Promise<Content[]> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n environment: request.environment,\n ...(request.status && { status: request.status }),\n ...(request.contentType && { contentType: request.contentType }),\n ...(request.approvalStatus && { approvalStatus: request.approvalStatus }),\n ...(request.limit && { limit: request.limit.toString() }),\n ...(request.offset && { offset: request.offset.toString() }),\n });\n\n const response = await this.http.get<Content[]>(`/marketing/content?${params.toString()}`);\n return response.map((c) => this.convertContentDates(c));\n }\n\n /**\n * Get a single content by ID\n */\n async getContent(contentId: string): Promise<Content> {\n const response = await this.http.get<Content>(`/marketing/content/${contentId}`);\n return this.convertContentDates(response);\n }\n\n /**\n * Update content\n *\n * @example\n * ```typescript\n * const updated = await marketing.updateContent({\n * contentId: 'content-id',\n * title: 'Updated Title',\n * status: 'published',\n * });\n * ```\n */\n async updateContent(request: UpdateContentRequest): Promise<Content> {\n const { contentId, ...data } = request;\n const response = await this.http.patch<Content>(`/marketing/content/${contentId}`, data);\n return this.convertContentDates(response);\n }\n\n /**\n * Approve content for publishing\n *\n * @example\n * ```typescript\n * await marketing.approveContent({\n * contentId: 'content-id',\n * reviewNotes: 'Looks great!',\n * });\n * ```\n */\n async approveContent(request: ApproveContentRequest): Promise<Content> {\n const response = await this.http.post<Content>(`/marketing/content/${request.contentId}/approve`, request);\n return this.convertContentDates(response);\n }\n\n /**\n * Reject content\n *\n * @example\n * ```typescript\n * await marketing.rejectContent({\n * contentId: 'content-id',\n * reviewNotes: 'Needs revisions',\n * });\n * ```\n */\n async rejectContent(request: RejectContentRequest): Promise<Content> {\n const response = await this.http.post<Content>(`/marketing/content/${request.contentId}/reject`, request);\n return this.convertContentDates(response);\n }\n\n /**\n * Delete content\n */\n async deleteContent(contentId: string): Promise<{ success: boolean }> {\n return this.http.deleteWithBody<{ success: boolean }>(`/marketing/content/${contentId}`, { contentId });\n }\n\n // ============================================================================\n // Scripts\n // ============================================================================\n\n /**\n * Create a new script\n *\n * @example\n * ```typescript\n * const script = await marketing.createScript({\n * projectSlug: 'my-project',\n * environment: 'production',\n * hook: 'Are you ready to see the future?',\n * slides: [\n * { order: 0, text: 'AI is changing everything', voiceoverText: 'AI is transforming how we work', duration: 3 },\n * ],\n * cta: 'Follow for more insights!',\n * });\n * ```\n */\n async createScript(request: CreateScriptRequest): Promise<Script> {\n const response = await this.http.post<Script>(\"/marketing/scripts\", request);\n return this.convertScriptDates(response);\n }\n\n /**\n * List scripts\n */\n async listScripts(request: ListScriptsRequest): Promise<Script[]> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n environment: request.environment,\n ...(request.contentId && { contentId: request.contentId }),\n ...(request.limit && { limit: request.limit.toString() }),\n });\n\n const response = await this.http.get<Script[]>(`/marketing/scripts?${params.toString()}`);\n return response.map((s) => this.convertScriptDates(s));\n }\n\n /**\n * Get a single script by ID\n */\n async getScript(scriptId: string): Promise<Script> {\n const response = await this.http.get<Script>(`/marketing/scripts/${scriptId}`);\n return this.convertScriptDates(response);\n }\n\n /**\n * Update a script\n *\n * @example\n * ```typescript\n * const updated = await marketing.updateScript({\n * scriptId: 'script-id',\n * hook: 'Updated hook line',\n * cta: 'New call to action!',\n * });\n * ```\n */\n async updateScript(request: UpdateScriptRequest): Promise<Script> {\n const { scriptId, ...data } = request;\n const response = await this.http.patch<Script>(`/marketing/scripts/${scriptId}`, data);\n return this.convertScriptDates(response);\n }\n\n /**\n * Create a new version of a script\n *\n * @example\n * ```typescript\n * const newVersion = await marketing.createScriptVersion({\n * scriptId: 'script-id',\n * hook: 'Updated hook for v2',\n * slides: [...],\n * cta: 'Updated CTA',\n * });\n * ```\n */\n async createScriptVersion(request: CreateScriptVersionRequest): Promise<Script> {\n const { scriptId, ...data } = request;\n const response = await this.http.post<Script>(`/marketing/scripts/${scriptId}/versions`, data);\n return this.convertScriptDates(response);\n }\n\n /**\n * Get all versions of a script\n */\n async getScriptVersions(scriptId: string): Promise<Script[]> {\n const response = await this.http.get<Script[]>(`/marketing/scripts/${scriptId}/versions`);\n return response.map((s) => this.convertScriptDates(s));\n }\n\n /**\n * Delete a script\n */\n async deleteScript(scriptId: string): Promise<DeleteScriptResponse> {\n return this.http.delete<DeleteScriptResponse>(`/marketing/scripts/${scriptId}`);\n }\n\n // ============================================================================\n // Analytics\n // ============================================================================\n\n /**\n * Get analytics overview\n *\n * @example\n * ```typescript\n * const analytics = await marketing.getAnalyticsOverview({\n * projectSlug: 'my-project',\n * environment: 'production',\n * });\n * console.log(`Total content: ${analytics.totalContent}`);\n * console.log(`Total views: ${analytics.engagement.views}`);\n * ```\n */\n async getAnalyticsOverview(request: AnalyticsOverviewRequest): Promise<AnalyticsOverviewResponse> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n environment: request.environment,\n ...(request.startDate && { startDate: request.startDate.toISOString() }),\n ...(request.endDate && { endDate: request.endDate.toISOString() }),\n });\n\n return this.http.get<AnalyticsOverviewResponse>(`/marketing/analytics/overview?${params.toString()}`);\n }\n\n /**\n * Get content performance metrics\n *\n * @example\n * ```typescript\n * const topContent = await marketing.getContentPerformance({\n * projectSlug: 'my-project',\n * environment: 'production',\n * contentType: 'tiktok_slideshow',\n * limit: 10,\n * });\n * ```\n */\n async getContentPerformance(request: ContentPerformanceRequest): Promise<ContentPerformanceResponse> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n environment: request.environment,\n ...(request.contentType && { contentType: request.contentType }),\n ...(request.limit && { limit: request.limit.toString() }),\n });\n\n return this.http.get<ContentPerformanceResponse>(`/marketing/analytics/performance?${params.toString()}`);\n }\n\n /**\n * Get trend discovery analytics\n *\n * @example\n * ```typescript\n * const trendStats = await marketing.getTrendAnalytics({\n * projectSlug: 'my-project',\n * environment: 'production',\n * });\n * console.log(`Total trends: ${trendStats.totalTrends}`);\n * ```\n */\n async getTrendAnalytics(request: TrendAnalyticsRequest): Promise<TrendAnalyticsResponse> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n ...(request.environment && { environment: request.environment }),\n ...(request.startDate && { startDate: request.startDate.toISOString() }),\n ...(request.endDate && { endDate: request.endDate.toISOString() }),\n });\n\n return this.http.get<TrendAnalyticsResponse>(`/marketing/analytics/trends?${params.toString()}`);\n }\n\n /**\n * Get opportunity conversion analytics\n *\n * @example\n * ```typescript\n * const conversion = await marketing.getOpportunityConversion({\n * projectSlug: 'my-project',\n * environment: 'production',\n * });\n * console.log(`Conversion rate: ${conversion.conversionRate}%`);\n * ```\n */\n async getOpportunityConversion(request: OpportunityConversionRequest): Promise<OpportunityConversionResponse> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n ...(request.environment && { environment: request.environment }),\n ...(request.startDate && { startDate: request.startDate.toISOString() }),\n ...(request.endDate && { endDate: request.endDate.toISOString() }),\n });\n\n return this.http.get<OpportunityConversionResponse>(`/marketing/analytics/conversion?${params.toString()}`);\n }\n\n // ============================================================================\n // Calendar\n // ============================================================================\n\n /**\n * Schedule content for publishing\n *\n * @example\n * ```typescript\n * const entry = await marketing.scheduleContent({\n * projectSlug: 'my-project',\n * contentId: 'content-id',\n * scheduledFor: new Date('2024-12-25T10:00:00Z'),\n * autoPublish: true,\n * });\n * ```\n */\n async scheduleContent(request: ScheduleContentRequest): Promise<CalendarEntry> {\n const response = await this.http.post<CalendarEntry>(\"/marketing/calendar/schedule\", {\n ...request,\n scheduledFor: request.scheduledFor.toISOString(),\n });\n return this.convertCalendarEntryDates(response);\n }\n\n /**\n * List scheduled content\n *\n * @example\n * ```typescript\n * const entries = await marketing.listCalendarEntries({\n * projectSlug: 'my-project',\n * startDate: new Date('2024-12-01'),\n * endDate: new Date('2024-12-31'),\n * });\n * ```\n */\n async listCalendarEntries(request: ListCalendarEntriesRequest): Promise<CalendarEntry[]> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n ...(request.environment && { environment: request.environment }),\n ...(request.startDate && { startDate: request.startDate.toISOString() }),\n ...(request.endDate && { endDate: request.endDate.toISOString() }),\n ...(request.limit && { limit: request.limit.toString() }),\n ...(request.offset && { offset: request.offset.toString() }),\n });\n\n const response = await this.http.get<CalendarEntry[]>(`/marketing/calendar?${params.toString()}`);\n return response.map((e) => this.convertCalendarEntryDates(e));\n }\n\n /**\n * Get a single calendar entry by ID\n */\n async getCalendarEntry(entryId: string): Promise<CalendarEntry> {\n const response = await this.http.get<CalendarEntry>(`/marketing/calendar/${entryId}`);\n return this.convertCalendarEntryDates(response);\n }\n\n /**\n * Update a calendar entry\n *\n * @example\n * ```typescript\n * const updated = await marketing.updateCalendarEntry({\n * entryId: 'entry-id',\n * scheduledFor: new Date('2024-12-26T10:00:00Z'),\n * });\n * ```\n */\n async updateCalendarEntry(request: UpdateCalendarEntryRequest): Promise<CalendarEntry> {\n const { entryId, ...data } = request;\n const response = await this.http.patch<CalendarEntry>(`/marketing/calendar/${entryId}`, {\n ...data,\n ...(data.scheduledFor && { scheduledFor: data.scheduledFor.toISOString() }),\n });\n return this.convertCalendarEntryDates(response);\n }\n\n /**\n * Cancel a scheduled calendar entry\n */\n async cancelCalendarEntry(entryId: string): Promise<CancelCalendarEntryResponse> {\n return this.http.post<CancelCalendarEntryResponse>(`/marketing/calendar/${entryId}/cancel`, {});\n }\n\n /**\n * Mark content as published\n */\n async markContentPublished(request: MarkPublishedRequest): Promise<CalendarEntry> {\n const response = await this.http.post<CalendarEntry>(`/marketing/calendar/${request.entryId}/published`, {\n ...(request.publishedAt && { publishedAt: request.publishedAt.toISOString() }),\n });\n return this.convertCalendarEntryDates(response);\n }\n\n // ============================================================================\n // Assets (Asset Jobs)\n // ============================================================================\n\n /**\n * Create an asset generation job\n *\n * @example\n * ```typescript\n * const job = await marketing.createAssetJob({\n * projectSlug: 'my-project',\n * contentId: 'content-id',\n * jobType: 'slide_generation',\n * input: { style: 'modern' },\n * });\n * ```\n */\n async createAssetJob(request: CreateAssetJobRequest): Promise<AssetJob> {\n const response = await this.http.post<AssetJob>(\"/marketing/assets/jobs\", request);\n return this.convertAssetJobDates(response);\n }\n\n /**\n * List asset jobs\n *\n * @example\n * ```typescript\n * const jobs = await marketing.listAssetJobs({\n * projectSlug: 'my-project',\n * status: 'processing',\n * });\n * ```\n */\n async listAssetJobs(request: ListAssetJobsRequest): Promise<AssetJob[]> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n ...(request.contentId && { contentId: request.contentId }),\n ...(request.status && { status: request.status }),\n ...(request.jobType && { jobType: request.jobType }),\n ...(request.limit && { limit: request.limit.toString() }),\n ...(request.offset && { offset: request.offset.toString() }),\n });\n\n const response = await this.http.get<AssetJob[]>(`/marketing/assets/jobs?${params.toString()}`);\n return response.map((j) => this.convertAssetJobDates(j));\n }\n\n /**\n * Get an asset job by ID\n */\n async getAssetJob(jobId: string): Promise<AssetJob> {\n const response = await this.http.get<AssetJob>(`/marketing/assets/jobs/${jobId}`);\n return this.convertAssetJobDates(response);\n }\n\n /**\n * Update asset job status\n */\n async updateAssetJobStatus(request: UpdateAssetJobStatusRequest): Promise<AssetJob> {\n const { jobId, ...data } = request;\n const response = await this.http.patch<AssetJob>(`/marketing/assets/jobs/${jobId}/status`, data);\n return this.convertAssetJobDates(response);\n }\n\n /**\n * Retry a failed asset job\n */\n async retryAssetJob(jobId: string): Promise<AssetJob> {\n const response = await this.http.post<AssetJob>(`/marketing/assets/jobs/${jobId}/retry`, {});\n return this.convertAssetJobDates(response);\n }\n\n /**\n * Cancel an asset job\n */\n async cancelAssetJob(jobId: string): Promise<AssetJob> {\n const response = await this.http.post<AssetJob>(`/marketing/assets/jobs/${jobId}/cancel`, {});\n return this.convertAssetJobDates(response);\n }\n\n // ============================================================================\n // Settings\n // ============================================================================\n\n /**\n * Get marketing settings for a project\n *\n * @example\n * ```typescript\n * const settings = await marketing.getSettings({\n * projectSlug: 'my-project',\n * environment: 'production',\n * });\n * console.log(`Brand voice: ${settings.brandVoice}`);\n * ```\n */\n async getSettings(request: GetSettingsRequest): Promise<MarketingSettings> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n ...(request.environment && { environment: request.environment }),\n });\n\n return this.http.get<MarketingSettings>(`/marketing/settings?${params.toString()}`);\n }\n\n /**\n * Update marketing settings\n *\n * @example\n * ```typescript\n * await marketing.updateSettings({\n * projectSlug: 'my-project',\n * brandVoice: 'Professional yet approachable',\n * monitoredKeywords: ['AI', 'startup', 'tech'],\n * });\n * ```\n */\n async updateSettings(request: UpdateSettingsRequest): Promise<UpdateSettingsResponse> {\n return this.http.post<UpdateSettingsResponse>(\"/marketing/settings\", request);\n }\n\n // ============================================================================\n // Usage\n // ============================================================================\n\n /**\n * Get current period usage\n *\n * @example\n * ```typescript\n * const usage = await marketing.getCurrentUsage({\n * projectSlug: 'my-project',\n * environment: 'production',\n * });\n * console.log(`AI tokens used: ${usage.aiTokensUsed}`);\n * ```\n */\n async getCurrentUsage(request: GetCurrentUsageRequest): Promise<CurrentUsageResponse> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n ...(request.environment && { environment: request.environment }),\n });\n\n const response = await this.http.get<CurrentUsageResponse>(`/marketing/usage/current?${params.toString()}`);\n return this.convertUsageDates(response);\n }\n\n /**\n * Get usage history\n *\n * @example\n * ```typescript\n * const history = await marketing.getUsageHistory({\n * projectSlug: 'my-project',\n * limit: 6, // Last 6 months\n * });\n * ```\n */\n async getUsageHistory(request: GetUsageHistoryRequest): Promise<MarketingUsage[]> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n ...(request.environment && { environment: request.environment }),\n ...(request.startDate && { startDate: request.startDate.toISOString() }),\n ...(request.endDate && { endDate: request.endDate.toISOString() }),\n ...(request.limit && { limit: request.limit.toString() }),\n });\n\n const response = await this.http.get<MarketingUsage[]>(`/marketing/usage/history?${params.toString()}`);\n return response.map((u) => this.convertMarketingUsageDates(u));\n }\n\n /**\n * Get total usage across all periods\n *\n * @example\n * ```typescript\n * const totals = await marketing.getTotalUsage({\n * projectSlug: 'my-project',\n * startDate: new Date('2024-01-01'),\n * });\n * console.log(`Total content generated: ${totals.contentGenerated}`);\n * ```\n */\n async getTotalUsage(request: GetTotalUsageRequest): Promise<TotalUsageResponse> {\n const params = new URLSearchParams({\n projectSlug: request.projectSlug,\n ...(request.environment && { environment: request.environment }),\n ...(request.startDate && { startDate: request.startDate.toISOString() }),\n ...(request.endDate && { endDate: request.endDate.toISOString() }),\n });\n\n return this.http.get<TotalUsageResponse>(`/marketing/usage/total?${params.toString()}`);\n }\n\n /**\n * Record usage (typically called internally)\n */\n async recordUsage(request: RecordUsageRequest): Promise<MarketingUsage> {\n const response = await this.http.post<MarketingUsage>(\"/marketing/usage/record\", request);\n return this.convertMarketingUsageDates(response);\n }\n\n // ============================================================================\n // Date Conversion Helpers\n // ============================================================================\n\n private convertTrendDates(trend: Trend): Trend {\n if (typeof trend.firstSeenAt === \"string\") {\n trend.firstSeenAt = new Date(trend.firstSeenAt);\n }\n if (typeof trend.lastUpdatedAt === \"string\") {\n trend.lastUpdatedAt = new Date(trend.lastUpdatedAt);\n }\n if (trend.expiresAt && typeof trend.expiresAt === \"string\") {\n trend.expiresAt = new Date(trend.expiresAt);\n }\n if (typeof trend.createdAt === \"string\") {\n trend.createdAt = new Date(trend.createdAt);\n }\n return trend;\n }\n\n private convertOpportunityDates(opp: Opportunity): Opportunity {\n if (typeof opp.createdAt === \"string\") {\n opp.createdAt = new Date(opp.createdAt);\n }\n if (opp.expiresAt && typeof opp.expiresAt === \"string\") {\n opp.expiresAt = new Date(opp.expiresAt);\n }\n if (opp.usedAt && typeof opp.usedAt === \"string\") {\n opp.usedAt = new Date(opp.usedAt);\n }\n return opp;\n }\n\n private convertContentDates(content: Content): Content {\n if (typeof content.createdAt === \"string\") {\n content.createdAt = new Date(content.createdAt);\n }\n if (content.updatedAt && typeof content.updatedAt === \"string\") {\n content.updatedAt = new Date(content.updatedAt);\n }\n if (content.reviewedAt && typeof content.reviewedAt === \"string\") {\n content.reviewedAt = new Date(content.reviewedAt);\n }\n if (content.publishedAt && typeof content.publishedAt === \"string\") {\n content.publishedAt = new Date(content.publishedAt);\n }\n return content;\n }\n\n private convertScriptDates(script: Script): Script {\n if (typeof script.createdAt === \"string\") {\n script.createdAt = new Date(script.createdAt);\n }\n return script;\n }\n\n private convertCalendarEntryDates(entry: CalendarEntry): CalendarEntry {\n if (typeof entry.scheduledFor === \"string\") {\n entry.scheduledFor = new Date(entry.scheduledFor);\n }\n if (typeof entry.createdAt === \"string\") {\n entry.createdAt = new Date(entry.createdAt);\n }\n if (entry.updatedAt && typeof entry.updatedAt === \"string\") {\n entry.updatedAt = new Date(entry.updatedAt);\n }\n if (entry.publishedAt && typeof entry.publishedAt === \"string\") {\n entry.publishedAt = new Date(entry.publishedAt);\n }\n return entry;\n }\n\n private convertAssetJobDates(job: AssetJob): AssetJob {\n if (typeof job.createdAt === \"string\") {\n job.createdAt = new Date(job.createdAt);\n }\n if (job.startedAt && typeof job.startedAt === \"string\") {\n job.startedAt = new Date(job.startedAt);\n }\n if (job.completedAt && typeof job.completedAt === \"string\") {\n job.completedAt = new Date(job.completedAt);\n }\n return job;\n }\n\n private convertUsageDates(usage: CurrentUsageResponse): CurrentUsageResponse {\n if (typeof usage.periodStart === \"string\") {\n usage.periodStart = new Date(usage.periodStart);\n }\n if (typeof usage.periodEnd === \"string\") {\n usage.periodEnd = new Date(usage.periodEnd);\n }\n return usage;\n }\n\n private convertMarketingUsageDates(usage: MarketingUsage): MarketingUsage {\n if (typeof usage.periodStart === \"string\") {\n usage.periodStart = new Date(usage.periodStart);\n }\n if (typeof usage.periodEnd === \"string\") {\n usage.periodEnd = new Date(usage.periodEnd);\n }\n if (typeof usage.createdAt === \"string\") {\n usage.createdAt = new Date(usage.createdAt);\n }\n if (usage.updatedAt && typeof usage.updatedAt === \"string\") {\n usage.updatedAt = new Date(usage.updatedAt);\n }\n return usage;\n }\n}\n","/**\n * Stack0 SDK\n * Official SDK for Stack0 services\n *\n * @example\n * ```typescript\n * import { Stack0 } from '@stack0/sdk';\n *\n * const stack0 = new Stack0({ apiKey: 'stack0_...' });\n *\n * // Send an email\n * await stack0.mail.send({\n * from: 'noreply@example.com',\n * to: 'user@example.com',\n * subject: 'Hello',\n * html: '<p>World</p>',\n * });\n *\n * // Upload a file to CDN\n * const asset = await stack0.cdn.upload({\n * projectSlug: 'my-project',\n * file: fileBuffer,\n * filename: 'image.jpg',\n * mimeType: 'image/jpeg',\n * });\n *\n * // Capture a screenshot\n * const screenshot = await stack0.screenshots.captureAndWait({\n * url: 'https://example.com',\n * format: 'png',\n * fullPage: true,\n * });\n *\n * // Extract content from a page\n * const extraction = await stack0.extraction.extractAndWait({\n * url: 'https://example.com/article',\n * mode: 'markdown',\n * });\n *\n * // List contacts from a connected CRM\n * const contacts = await stack0.integrations.crm.listContacts('conn_123');\n *\n * // Send a Slack message\n * await stack0.integrations.communication.sendMessage('conn_456', {\n * channelId: 'C123',\n * content: 'Hello from Stack0!',\n * });\n *\n * // Discover trends and generate content ideas\n * const { trendsDiscovered, trends } = await stack0.marketing.discoverTrends({\n * projectSlug: 'my-project',\n * environment: 'production',\n * });\n * ```\n */\n\nimport { Mail } from \"./mail/client\";\nimport { CDN } from \"./cdn/client\";\nimport { Screenshots } from \"./screenshots/client\";\nimport { Extraction } from \"./extraction/client\";\nimport { Webdata } from \"./webdata/client\";\nimport { Integrations } from \"./integrations/client\";\nimport { Marketing } from \"./marketing/client\";\nimport type { HttpClientConfig } from \"./lib/http-client\";\n\nexport interface Stack0Config extends HttpClientConfig {\n apiKey: string;\n baseUrl?: string;\n /**\n * CDN base URL for image transformations (e.g., 'https://cdn.yourproject.stack0.dev')\n * When provided, transform URLs are generated client-side without API calls\n */\n cdnUrl?: string;\n}\n\n/**\n * Main Stack0 SDK class\n * Provides access to all Stack0 services\n */\nexport class Stack0 {\n public mail: Mail;\n public cdn: CDN;\n public screenshots: Screenshots;\n public extraction: Extraction;\n public integrations: Integrations;\n public marketing: Marketing;\n\n /**\n * @deprecated Use `screenshots` and `extraction` instead. Will be removed in a future version.\n */\n public webdata: Webdata;\n\n constructor(config: Stack0Config) {\n const clientConfig = {\n apiKey: config.apiKey,\n baseUrl: config.baseUrl,\n };\n\n // Initialize clients\n this.mail = new Mail(clientConfig);\n this.cdn = new CDN(clientConfig, config.cdnUrl);\n this.screenshots = new Screenshots(clientConfig);\n this.extraction = new Extraction(clientConfig);\n this.integrations = new Integrations(clientConfig);\n this.marketing = new Marketing(clientConfig);\n\n // Keep webdata for backward compatibility\n this.webdata = new Webdata(clientConfig);\n }\n}\n\n// Export sub-modules\nexport * from \"./mail\";\nexport * from \"./cdn\";\nexport * from \"./screenshots\";\nexport * from \"./extraction\";\nexport * from \"./integrations\";\nexport * from \"./marketing\";\n\n// Export shared types\nexport * from \"./lib/shared-types\";\n\n// Re-export webdata client only (types are available from screenshots/extraction)\nexport { Webdata } from \"./webdata/client\";\n\n// Default export\nexport default Stack0;\n"]}