@stack0/sdk 0.4.0 → 0.5.2

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.
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/lib/http-client.ts","../../src/mail/client.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 * Stack0 Mail Client\n * API compatible with Resend for easy migration\n */\n\nimport { HttpClient, type HttpClientConfig } from \"../lib/http-client\";\nimport type { SendEmailRequest, SendEmailResponse, GetEmailResponse } from \"./types\";\n\nexport class Mail {\n private http: HttpClient;\n\n constructor(config: HttpClientConfig) {\n this.http = new HttpClient(config);\n }\n\n /**\n * Send an 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 const response = await this.http.post<SendEmailResponse>(\"/mail/send\", request);\n\n // Convert date strings to Date objects if needed\n if (typeof response.createdAt === \"string\") {\n response.createdAt = new Date(response.createdAt);\n }\n\n return response;\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 const response = await this.http.get<GetEmailResponse>(`/mail/${id}`);\n\n // Convert date strings to Date objects\n const dateFields = [\"createdAt\", \"sentAt\", \"deliveredAt\", \"openedAt\", \"clickedAt\", \"bouncedAt\"] as const;\n\n for (const field of dateFields) {\n if (response[field] && typeof response[field] === \"string\") {\n (response[field] as unknown as Date) = new Date(response[field] as string);\n }\n }\n\n return response;\n }\n}\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"],"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"]}