@hoststack.dev/sdk 0.2.1 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -61,7 +61,9 @@ Generate an API key from your [HostStack dashboard → Settings → API Keys](ht
61
61
  | `client.databases` | `list`, `get`, `create`, `update`, `delete`, `suspend`, `resume`, `getCredentials`, `resetPassword` |
62
62
  | `client.domains` | `list`, `add`, `update`, `remove`, `verify` |
63
63
  | `client.envVars` | `list`, `create`, `update`, `delete`, `bulkSet` |
64
+ | `client.environments` | `list`, `get`, `create`, `update`, `delete` |
64
65
  | `client.cron` | `list`, `get`, `trigger` |
66
+ | `client.deploys` | `…`, `promote(teamId, serviceId, deployId, targetEnvId)` — image-based promotion across envs |
65
67
 
66
68
  Every method's first argument is `teamId: number`. Full API reference: **[hoststack.dev/docs/sdk](https://hoststack.dev/docs/sdk)**.
67
69
 
package/dist/index.cjs CHANGED
@@ -184,6 +184,26 @@ var DeploysResource = class {
184
184
  });
185
185
  return this.client.request("POST", `/api/services/${tid}/${sid}/deploys/${did}/rollback`);
186
186
  }
187
+ /**
188
+ * v66 P5: promote a built deploy to a sibling service in another
189
+ * environment. Reuses the source deploy's docker image (no rebuild).
190
+ * If no sibling service exists in the target env yet, the API auto-
191
+ * creates one by cloning the source service's config.
192
+ */
193
+ async promote(teamId, serviceId, deployId, targetEnvironmentId) {
194
+ const tid = await this.client.resolveId(teamId, { kind: "team" });
195
+ const sid = await this.client.resolveId(serviceId, { kind: "service", teamId: tid });
196
+ const did = await this.client.resolveId(deployId, {
197
+ kind: "deploy",
198
+ teamId: tid,
199
+ serviceId: sid
200
+ });
201
+ return this.client.request(
202
+ "POST",
203
+ `/api/services/${tid}/${sid}/deploys/${did}/promote`,
204
+ { targetEnvironmentId }
205
+ );
206
+ }
187
207
  /**
188
208
  * Get build logs for a deploy.
189
209
  *
@@ -245,6 +265,50 @@ var DomainsResource = class {
245
265
  }
246
266
  };
247
267
 
268
+ // src/resources/environments.ts
269
+ var EnvironmentsResource = class {
270
+ constructor(client) {
271
+ this.client = client;
272
+ }
273
+ /** List all environments for a project. */
274
+ async list(teamId, projectId) {
275
+ const tid = await this.client.resolveId(teamId, { kind: "team" });
276
+ const pid = await this.client.resolveId(projectId, { kind: "project", teamId: tid });
277
+ return this.client.request("GET", `/api/environments/${tid}/${pid}`);
278
+ }
279
+ /** Get a single environment by id. */
280
+ async get(teamId, projectId, envId) {
281
+ const tid = await this.client.resolveId(teamId, { kind: "team" });
282
+ const pid = await this.client.resolveId(projectId, { kind: "project", teamId: tid });
283
+ const eid = await this.client.resolveId(envId, { kind: "environment", teamId: tid });
284
+ return this.client.request("GET", `/api/environments/${tid}/${pid}/${eid}`);
285
+ }
286
+ /** Create a new environment in the given project. */
287
+ async create(teamId, projectId, data) {
288
+ const tid = await this.client.resolveId(teamId, { kind: "team" });
289
+ const pid = await this.client.resolveId(projectId, { kind: "project", teamId: tid });
290
+ return this.client.request("POST", `/api/environments/${tid}/${pid}`, data);
291
+ }
292
+ /** Update environment metadata (name, default flag, protected flag). */
293
+ async update(teamId, projectId, envId, data) {
294
+ const tid = await this.client.resolveId(teamId, { kind: "team" });
295
+ const pid = await this.client.resolveId(projectId, { kind: "project", teamId: tid });
296
+ const eid = await this.client.resolveId(envId, { kind: "environment", teamId: tid });
297
+ return this.client.request("PATCH", `/api/environments/${tid}/${pid}/${eid}`, data);
298
+ }
299
+ /**
300
+ * Delete an environment. The API blocks delete when the env still
301
+ * has services or databases attached — destroy them first or move
302
+ * them to another env. Cannot delete the project's default env.
303
+ */
304
+ async delete(teamId, projectId, envId) {
305
+ const tid = await this.client.resolveId(teamId, { kind: "team" });
306
+ const pid = await this.client.resolveId(projectId, { kind: "project", teamId: tid });
307
+ const eid = await this.client.resolveId(envId, { kind: "environment", teamId: tid });
308
+ return this.client.request("DELETE", `/api/environments/${tid}/${pid}/${eid}`);
309
+ }
310
+ };
311
+
248
312
  // src/resources/env-vars.ts
249
313
  var EnvVarsResource = class {
250
314
  constructor(client) {
@@ -335,7 +399,7 @@ async function* streamLogsViaPolling(fetch2, basePath, options = {}) {
335
399
  const buildPath = (lines, since) => {
336
400
  const params = new URLSearchParams();
337
401
  if (options.stream) params.set("stream", options.stream);
338
- if (lines !== void 0) params.set("lines", String(lines));
402
+ if (lines !== void 0) params.set("limit", String(lines));
339
403
  if (since) params.set("since", since);
340
404
  const qs = params.toString();
341
405
  return `${basePath}${qs ? `?${qs}` : ""}`;
@@ -447,14 +511,30 @@ var ServicesResource = class {
447
511
  const sid = await this.client.resolveId(serviceId, { kind: "service", teamId: tid });
448
512
  return this.client.request("PATCH", `/api/services/${tid}/${sid}/config`, data);
449
513
  }
450
- /** Get runtime logs for a service. */
514
+ /**
515
+ * Get runtime logs for a service.
516
+ *
517
+ * `since`/`until` accept either an ISO-8601 timestamp or a short
518
+ * relative offset like `-5m`, `-1h`, `-2d`.
519
+ *
520
+ * `search` does case-insensitive substring filtering server-side
521
+ * (≤100 chars). `countOnly` returns just `{ count: N }` for cheap
522
+ * polling — useful when you want to know "how many error lines in the
523
+ * last 5 minutes" without paying the bytes.
524
+ */
451
525
  async getRuntimeLogs(teamId, serviceId, options) {
452
526
  const tid = await this.client.resolveId(teamId, { kind: "team" });
453
527
  const sid = await this.client.resolveId(serviceId, { kind: "service", teamId: tid });
454
528
  const params = new URLSearchParams();
455
- if (options?.lines) params.set("lines", String(options.lines));
529
+ const lim = options?.limit ?? options?.lines;
530
+ if (lim != null) params.set("limit", String(lim));
456
531
  if (options?.since) params.set("since", options.since);
532
+ if (options?.until) params.set("until", options.until);
457
533
  if (options?.stream) params.set("stream", options.stream);
534
+ if (options?.level) params.set("level", options.level);
535
+ const grep = options?.grep ?? options?.search;
536
+ if (grep) params.set("search", grep);
537
+ if (options?.countOnly) params.set("count_only", "1");
458
538
  const qs = params.toString();
459
539
  return this.client.request(
460
540
  "GET",
@@ -485,6 +565,54 @@ var ServicesResource = class {
485
565
  }
486
566
  };
487
567
 
568
+ // src/resources/volumes.ts
569
+ var VolumesResource = class {
570
+ constructor(client) {
571
+ this.client = client;
572
+ }
573
+ /** List volumes attached to a service. */
574
+ async list(teamId, serviceId) {
575
+ const tid = await this.client.resolveId(teamId, { kind: "team" });
576
+ const sid = await this.client.resolveId(serviceId, { kind: "service", teamId: tid });
577
+ return this.client.request("GET", `/api/services/${tid}/${sid}/volumes`);
578
+ }
579
+ /** Attach a new volume to a service. Triggers provisioning on the host. */
580
+ async create(teamId, serviceId, data) {
581
+ const tid = await this.client.resolveId(teamId, { kind: "team" });
582
+ const sid = await this.client.resolveId(serviceId, { kind: "service", teamId: tid });
583
+ return this.client.request("POST", `/api/services/${tid}/${sid}/volumes`, data);
584
+ }
585
+ /**
586
+ * Update a volume's mountPath or sizeGb. Resizes that take effect on the
587
+ * next deploy; mountPath changes require a redeploy to remount.
588
+ */
589
+ async update(teamId, serviceId, volumeId, data) {
590
+ const tid = await this.client.resolveId(teamId, { kind: "team" });
591
+ const sid = await this.client.resolveId(serviceId, { kind: "service", teamId: tid });
592
+ const vid = await this.client.resolveId(volumeId, {
593
+ kind: "volume",
594
+ teamId: tid,
595
+ serviceId: sid
596
+ });
597
+ return this.client.request("PATCH", `/api/services/${tid}/${sid}/volumes/${vid}`, data);
598
+ }
599
+ /**
600
+ * Detach and deprovision a volume. The underlying disk is destroyed —
601
+ * back up any data first. Async: the row is marked `deleting` and the
602
+ * agent finalises the removal once it acks.
603
+ */
604
+ async delete(teamId, serviceId, volumeId) {
605
+ const tid = await this.client.resolveId(teamId, { kind: "team" });
606
+ const sid = await this.client.resolveId(serviceId, { kind: "service", teamId: tid });
607
+ const vid = await this.client.resolveId(volumeId, {
608
+ kind: "volume",
609
+ teamId: tid,
610
+ serviceId: sid
611
+ });
612
+ return this.client.request("DELETE", `/api/services/${tid}/${sid}/volumes/${vid}`);
613
+ }
614
+ };
615
+
488
616
  // src/client.ts
489
617
  var PREFIX = {
490
618
  team: "team_",
@@ -493,7 +621,9 @@ var PREFIX = {
493
621
  deploy: "dpl_",
494
622
  database: "db_",
495
623
  domain: "dom_",
624
+ volume: "vol_",
496
625
  envVar: "env_",
626
+ environment: "environment_",
497
627
  cronExecution: "cjob_"
498
628
  };
499
629
  var HostStack = class {
@@ -513,8 +643,12 @@ var HostStack = class {
513
643
  domains;
514
644
  /** Manage service environment variables. */
515
645
  envVars;
646
+ /** v66: manage environments (production/staging/development/preview) per project. */
647
+ environments;
516
648
  /** Manage cron job executions. */
517
649
  cron;
650
+ /** Manage persistent disks attached to services. */
651
+ volumes;
518
652
  constructor(options) {
519
653
  if (!options.apiKey) {
520
654
  throw new Error("apiKey is required");
@@ -527,7 +661,9 @@ var HostStack = class {
527
661
  this.databases = new DatabasesResource(this);
528
662
  this.domains = new DomainsResource(this);
529
663
  this.envVars = new EnvVarsResource(this);
664
+ this.environments = new EnvironmentsResource(this);
530
665
  this.cron = new CronResource(this);
666
+ this.volumes = new VolumesResource(this);
531
667
  }
532
668
  /**
533
669
  * Make an authenticated request to the HostStack API.
@@ -646,10 +782,23 @@ var HostStack = class {
646
782
  );
647
783
  return r.envVars ?? [];
648
784
  }
785
+ case "volume": {
786
+ const r = await this.request("GET", `/api/services/${scope.teamId}/${scope.serviceId}/volumes`);
787
+ return r.volumes ?? [];
788
+ }
649
789
  case "cronExecution": {
650
790
  const r = await this.request("GET", `/api/services/${scope.teamId}/${scope.serviceId}/cron-executions`);
651
791
  return r.executions ?? [];
652
792
  }
793
+ case "environment": {
794
+ const projectsRes = await this.request("GET", `/api/projects/${scope.teamId}`);
795
+ const envs = [];
796
+ for (const p of projectsRes.projects ?? []) {
797
+ const r = await this.request("GET", `/api/environments/${scope.teamId}/${p.id}`);
798
+ envs.push(...r.environments ?? []);
799
+ }
800
+ return envs;
801
+ }
653
802
  }
654
803
  }
655
804
  };
@@ -661,8 +810,10 @@ function cacheScope(scope) {
661
810
  case "service":
662
811
  case "database":
663
812
  case "domain":
813
+ case "environment":
664
814
  return `${scope.kind}:${scope.teamId}`;
665
815
  case "deploy":
816
+ case "volume":
666
817
  case "envVar":
667
818
  case "cronExecution":
668
819
  return `${scope.kind}:${scope.teamId}:${scope.serviceId}`;
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/errors.ts","../src/resources/cron.ts","../src/resources/databases.ts","../src/resources/deploys.ts","../src/resources/domains.ts","../src/resources/env-vars.ts","../src/resources/projects.ts","../src/streaming.ts","../src/resources/services.ts","../src/client.ts","../src/pagination.ts"],"names":["fetch"],"mappings":"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","file":"index.cjs","sourcesContent":["export class HostStackError extends Error {\n\tpublic readonly statusCode: number;\n\n\tconstructor(statusCode: number, message: string) {\n\t\tsuper(message);\n\t\tthis.name = 'HostStackError';\n\t\tthis.statusCode = statusCode;\n\t}\n}\n\nexport class AuthenticationError extends HostStackError {\n\tconstructor(message = 'Authentication failed. Check your API key.') {\n\t\tsuper(401, message);\n\t\tthis.name = 'AuthenticationError';\n\t}\n}\n\nexport class NotFoundError extends HostStackError {\n\tconstructor(message = 'Resource not found.') {\n\t\tsuper(404, message);\n\t\tthis.name = 'NotFoundError';\n\t}\n}\n\nexport class RateLimitError extends HostStackError {\n\tconstructor(message = 'Rate limit exceeded. Try again later.') {\n\t\tsuper(429, message);\n\t\tthis.name = 'RateLimitError';\n\t}\n}\n","import type { HostStack, IdInput } from '../client.ts';\nimport type { CronExecution } from '../types.ts';\n\nexport class CronResource {\n\tconstructor(private client: HostStack) {}\n\n\t/** List cron executions for a service. */\n\tasync list(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\toptions?: { limit?: number },\n\t): Promise<{ executions: CronExecution[] }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst params = new URLSearchParams();\n\t\tif (options?.limit) params.set('limit', String(options.limit));\n\t\tconst qs = params.toString();\n\t\treturn this.client.request(\n\t\t\t'GET',\n\t\t\t`/api/services/${tid}/${sid}/cron-executions${qs ? `?${qs}` : ''}`,\n\t\t);\n\t}\n\n\t/** Get a single cron execution by ID. */\n\tasync get(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\texecutionId: IdInput,\n\t): Promise<{ execution: CronExecution }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst eid = await this.client.resolveId(executionId, {\n\t\t\tkind: 'cronExecution',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\treturn this.client.request('GET', `/api/services/${tid}/${sid}/cron-executions/${eid}`);\n\t}\n\n\t/** Trigger an immediate cron execution. */\n\tasync trigger(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t): Promise<{ execution: CronExecution }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('POST', `/api/services/${tid}/${sid}/cron-executions/trigger`);\n\t}\n}\n","import type { HostStack, IdInput } from '../client.ts';\nimport type {\n\tCreateDatabaseInput,\n\tDatabase,\n\tDatabaseCredentials,\n\tUpdateDatabaseInput,\n} from '../types.ts';\n\nexport class DatabasesResource {\n\tconstructor(private client: HostStack) {}\n\n\t/** List all databases for a project. */\n\tasync list(teamId: IdInput, projectId: IdInput): Promise<{ databases: Database[] }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst pid = await this.client.resolveId(projectId, { kind: 'project', teamId: tid });\n\t\treturn this.client.request('GET', `/api/databases/${tid}?projectId=${pid}`);\n\t}\n\n\t/** Get a single database by ID. */\n\tasync get(teamId: IdInput, databaseId: IdInput): Promise<{ database: Database }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(databaseId, { kind: 'database', teamId: tid });\n\t\treturn this.client.request('GET', `/api/databases/${tid}/${did}`);\n\t}\n\n\t/** Create a new database. */\n\tasync create(teamId: IdInput, data: CreateDatabaseInput): Promise<{ database: Database }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\treturn this.client.request('POST', `/api/databases/${tid}`, data);\n\t}\n\n\t/** Update a database. */\n\tasync update(\n\t\tteamId: IdInput,\n\t\tdatabaseId: IdInput,\n\t\tdata: UpdateDatabaseInput,\n\t): Promise<{ database: Database }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(databaseId, { kind: 'database', teamId: tid });\n\t\treturn this.client.request('PATCH', `/api/databases/${tid}/${did}`, data);\n\t}\n\n\t/** Delete a database. */\n\tasync delete(teamId: IdInput, databaseId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(databaseId, { kind: 'database', teamId: tid });\n\t\treturn this.client.request('DELETE', `/api/databases/${tid}/${did}`);\n\t}\n\n\t/** Suspend a database. */\n\tasync suspend(teamId: IdInput, databaseId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(databaseId, { kind: 'database', teamId: tid });\n\t\treturn this.client.request('POST', `/api/databases/${tid}/${did}/suspend`);\n\t}\n\n\t/** Resume a suspended database. */\n\tasync resume(teamId: IdInput, databaseId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(databaseId, { kind: 'database', teamId: tid });\n\t\treturn this.client.request('POST', `/api/databases/${tid}/${did}/resume`);\n\t}\n\n\t/** Get connection credentials. */\n\tasync getCredentials(\n\t\tteamId: IdInput,\n\t\tdatabaseId: IdInput,\n\t): Promise<{ credentials: DatabaseCredentials }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(databaseId, { kind: 'database', teamId: tid });\n\t\treturn this.client.request('GET', `/api/databases/${tid}/${did}/credentials`);\n\t}\n\n\t/** Reset the database password. */\n\tasync resetPassword(teamId: IdInput, databaseId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(databaseId, { kind: 'database', teamId: tid });\n\t\treturn this.client.request('POST', `/api/databases/${tid}/${did}/reset-password`);\n\t}\n}\n","import type { HostStack, IdInput } from '../client.ts';\nimport type { Deploy, TriggerDeployInput } from '../types.ts';\n\nexport interface DeployListResponse {\n\tdata: Deploy[];\n\tpage: number;\n\tperPage: number;\n\ttotal: number;\n\ttotalPages: number;\n}\n\nexport class DeploysResource {\n\tconstructor(private client: HostStack) {}\n\n\t/**\n\t * List deploys for a service. Paginated — pass `page` / `perPage` to walk\n\t * pages. Default page=1, perPage=25, hard cap perPage=100.\n\t */\n\tasync list(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\toptions?: { page?: number; perPage?: number },\n\t): Promise<DeployListResponse> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst params = new URLSearchParams();\n\t\tif (options?.page !== undefined) params.set('page', String(options.page));\n\t\tif (options?.perPage !== undefined) params.set('perPage', String(options.perPage));\n\t\tconst qs = params.toString();\n\t\treturn this.client.request(\n\t\t\t'GET',\n\t\t\t`/api/services/${tid}/${sid}/deploys${qs ? `?${qs}` : ''}`,\n\t\t);\n\t}\n\n\t/** Get a single deploy by ID. */\n\tasync get(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdeployId: IdInput,\n\t): Promise<{ deploy: Deploy }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst did = await this.client.resolveId(deployId, {\n\t\t\tkind: 'deploy',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\treturn this.client.request('GET', `/api/services/${tid}/${sid}/deploys/${did}`);\n\t}\n\n\t/** Trigger a new deploy. */\n\tasync trigger(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdata?: TriggerDeployInput,\n\t): Promise<{ deploy: Deploy }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('POST', `/api/services/${tid}/${sid}/deploys`, data ?? {});\n\t}\n\n\t/** Cancel an in-progress deploy. */\n\tasync cancel(teamId: IdInput, serviceId: IdInput, deployId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst did = await this.client.resolveId(deployId, {\n\t\t\tkind: 'deploy',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\treturn this.client.request('POST', `/api/services/${tid}/${sid}/deploys/${did}/cancel`);\n\t}\n\n\t/** Rollback to a previous deploy. */\n\tasync rollback(teamId: IdInput, serviceId: IdInput, deployId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst did = await this.client.resolveId(deployId, {\n\t\t\tkind: 'deploy',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\treturn this.client.request('POST', `/api/services/${tid}/${sid}/deploys/${did}/rollback`);\n\t}\n\n\t/**\n\t * Get build logs for a deploy.\n\t *\n\t * Pagination: pass `afterId` from the previous response's `nextAfterId`\n\t * to fetch the next page. Per-call cap is 5000; default 500.\n\t */\n\tasync getLogs(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdeployId: IdInput,\n\t\toptions?: {\n\t\t\tsearch?: string;\n\t\t\tlevel?: string;\n\t\t\tphase?: string;\n\t\t\tlimit?: number;\n\t\t\tafterId?: number;\n\t\t},\n\t): Promise<{ logs: DeployLogEntry[]; nextAfterId: number | null }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst did = await this.client.resolveId(deployId, {\n\t\t\tkind: 'deploy',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\tconst params = new URLSearchParams();\n\t\tif (options?.search) params.set('search', options.search);\n\t\tif (options?.level) params.set('level', options.level);\n\t\tif (options?.phase) params.set('phase', options.phase);\n\t\tif (options?.limit !== undefined) params.set('limit', String(options.limit));\n\t\tif (options?.afterId !== undefined) params.set('afterId', String(options.afterId));\n\t\tconst qs = params.toString();\n\t\tconst url = `/api/services/${tid}/${sid}/deploys/${did}/logs${qs ? `?${qs}` : ''}`;\n\t\treturn this.client.request('GET', url);\n\t}\n}\n\nexport interface DeployLogEntry {\n\tid: number;\n\tdeployId: number;\n\ttimestamp: string;\n\tlevel: 'info' | 'warn' | 'error' | 'debug';\n\tphase: string | null;\n\tmessage: string;\n}\n","import type { HostStack, IdInput } from '../client.ts';\nimport type { AddDomainInput, Domain, UpdateDomainInput } from '../types.ts';\n\nexport class DomainsResource {\n\tconstructor(private client: HostStack) {}\n\n\t/** List all domains for the active team. */\n\tasync list(teamId: IdInput): Promise<{ domains: Domain[] }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\treturn this.client.request('GET', `/api/domains/${tid}`);\n\t}\n\n\t/** Add a custom domain. */\n\tasync add(teamId: IdInput, data: AddDomainInput): Promise<{ domain: Domain }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\treturn this.client.request('POST', `/api/domains/${tid}`, data);\n\t}\n\n\t/** Update a domain. */\n\tasync update(\n\t\tteamId: IdInput,\n\t\tdomainId: IdInput,\n\t\tdata: UpdateDomainInput,\n\t): Promise<{ domain: Domain }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(domainId, { kind: 'domain', teamId: tid });\n\t\treturn this.client.request('PATCH', `/api/domains/${tid}/${did}`, data);\n\t}\n\n\t/** Remove a domain. */\n\tasync remove(teamId: IdInput, domainId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(domainId, { kind: 'domain', teamId: tid });\n\t\treturn this.client.request('DELETE', `/api/domains/${tid}/${did}`);\n\t}\n\n\t/** Verify domain DNS configuration. */\n\tasync verify(teamId: IdInput, domainId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(domainId, { kind: 'domain', teamId: tid });\n\t\treturn this.client.request('POST', `/api/domains/${tid}/${did}/verify`);\n\t}\n}\n","import type { HostStack, IdInput } from '../client.ts';\nimport type {\n\tBulkSetEnvVarsInput,\n\tCreateEnvVarInput,\n\tEnvVar,\n\tUpdateEnvVarInput,\n} from '../types.ts';\n\nexport class EnvVarsResource {\n\tconstructor(private client: HostStack) {}\n\n\t/** List all environment variables for a service. */\n\tasync list(teamId: IdInput, serviceId: IdInput): Promise<{ envVars: EnvVar[] }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('GET', `/api/services/${tid}/${sid}/env`);\n\t}\n\n\t/** Create a new environment variable. */\n\tasync create(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdata: CreateEnvVarInput,\n\t): Promise<{ envVar: EnvVar }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('POST', `/api/services/${tid}/${sid}/env`, data);\n\t}\n\n\t/** Update an environment variable. */\n\tasync update(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tenvVarId: IdInput,\n\t\tdata: UpdateEnvVarInput,\n\t): Promise<{ envVar: EnvVar }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst eid = await this.client.resolveId(envVarId, {\n\t\t\tkind: 'envVar',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\treturn this.client.request('PATCH', `/api/services/${tid}/${sid}/env/${eid}`, data);\n\t}\n\n\t/** Delete an environment variable. */\n\tasync delete(teamId: IdInput, serviceId: IdInput, envVarId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst eid = await this.client.resolveId(envVarId, {\n\t\t\tkind: 'envVar',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\treturn this.client.request('DELETE', `/api/services/${tid}/${sid}/env/${eid}`);\n\t}\n\n\t/** Bulk set environment variables (create or update). */\n\tasync bulkSet(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdata: BulkSetEnvVarsInput,\n\t): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('PUT', `/api/services/${tid}/${sid}/env/bulk`, data);\n\t}\n}\n","import type { HostStack, IdInput } from '../client.ts';\nimport type { CreateProjectInput, Project, UpdateProjectInput } from '../types.ts';\n\nexport class ProjectsResource {\n\tconstructor(private client: HostStack) {}\n\n\t/** List all projects for the active team. */\n\tasync list(teamId: IdInput): Promise<{ projects: Project[] }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\treturn this.client.request('GET', `/api/projects/${tid}`);\n\t}\n\n\t/** Get a single project by ID. */\n\tasync get(teamId: IdInput, projectId: IdInput): Promise<{ project: Project }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst pid = await this.client.resolveId(projectId, { kind: 'project', teamId: tid });\n\t\treturn this.client.request('GET', `/api/projects/${tid}/${pid}`);\n\t}\n\n\t/** Create a new project. */\n\tasync create(teamId: IdInput, data: CreateProjectInput): Promise<{ project: Project }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\treturn this.client.request('POST', `/api/projects/${tid}`, data);\n\t}\n\n\t/** Update a project. */\n\tasync update(\n\t\tteamId: IdInput,\n\t\tprojectId: IdInput,\n\t\tdata: UpdateProjectInput,\n\t): Promise<{ project: Project }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst pid = await this.client.resolveId(projectId, { kind: 'project', teamId: tid });\n\t\treturn this.client.request('PATCH', `/api/projects/${tid}/${pid}`, data);\n\t}\n\n\t/** Delete a project. */\n\tasync delete(teamId: IdInput, projectId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst pid = await this.client.resolveId(projectId, { kind: 'project', teamId: tid });\n\t\treturn this.client.request('DELETE', `/api/projects/${tid}/${pid}`);\n\t}\n}\n","export interface LogEntry {\n\ttimestamp: string;\n\tlevel?: string | null;\n\tstream?: string | null;\n\tmessage: string;\n}\n\nexport interface StreamLogsOptions {\n\t/** Filter by stream: 'stdout' or 'stderr'. */\n\tstream?: 'stdout' | 'stderr';\n\t/** Number of historical lines to fetch on first poll (default: 100). */\n\tinitialLines?: number;\n\t/** Poll interval in milliseconds (default: 2000). */\n\tpollInterval?: number;\n\t/** AbortSignal to stop streaming. */\n\tsignal?: AbortSignal;\n}\n\n/**\n * Streams runtime logs for a service by polling the logs REST endpoint.\n * Yields log entries as they appear. Use an AbortController to stop.\n *\n * @example\n * ```ts\n * const ac = new AbortController();\n * for await (const entry of client.services.streamLogs(teamId, serviceId, { signal: ac.signal })) {\n * console.log(entry.message);\n * }\n * ```\n */\nexport async function* streamLogsViaPolling(\n\tfetch: (path: string) => Promise<{ logs: LogEntry[] | string }>,\n\tbasePath: string,\n\toptions: StreamLogsOptions = {},\n): AsyncGenerator<LogEntry> {\n\tconst pollInterval = options.pollInterval ?? 2000;\n\tconst initialLines = options.initialLines ?? 100;\n\n\t// Track seen timestamps to avoid duplicates on first yield\n\tlet lastTimestamp: string | null = null;\n\n\tconst buildPath = (lines?: number, since?: string) => {\n\t\tconst params = new URLSearchParams();\n\t\tif (options.stream) params.set('stream', options.stream);\n\t\tif (lines !== undefined) params.set('lines', String(lines));\n\t\tif (since) params.set('since', since);\n\t\tconst qs = params.toString();\n\t\treturn `${basePath}${qs ? `?${qs}` : ''}`;\n\t};\n\n\t// Initial fetch\n\tconst initialData = await fetch(buildPath(initialLines));\n\tconst initial = normalizeEntries(initialData.logs);\n\tfor (const entry of initial) {\n\t\tyield entry;\n\t\tif (entry.timestamp > (lastTimestamp ?? '')) {\n\t\t\tlastTimestamp = entry.timestamp;\n\t\t}\n\t}\n\n\t// Poll loop\n\twhile (!options.signal?.aborted) {\n\t\tawait sleep(pollInterval, options.signal);\n\t\tif (options.signal?.aborted) break;\n\n\t\tconst sinceTs = lastTimestamp ? new Date(lastTimestamp).toISOString() : undefined;\n\t\tconst data = await fetch(buildPath(undefined, sinceTs)).catch(() => ({ logs: [] }));\n\t\tconst entries = normalizeEntries(data.logs);\n\n\t\tfor (const entry of entries) {\n\t\t\tif (!lastTimestamp || entry.timestamp > lastTimestamp) {\n\t\t\t\tyield entry;\n\t\t\t\tlastTimestamp = entry.timestamp;\n\t\t\t}\n\t\t}\n\t}\n}\n\nfunction normalizeEntries(logs: LogEntry[] | string): LogEntry[] {\n\tif (typeof logs === 'string') {\n\t\tconst lines = logs.split('\\n').filter(Boolean);\n\t\treturn lines.map((line) => ({\n\t\t\ttimestamp: new Date().toISOString(),\n\t\t\tmessage: line,\n\t\t}));\n\t}\n\treturn logs;\n}\n\nfunction sleep(ms: number, signal?: AbortSignal): Promise<void> {\n\treturn new Promise((resolve, reject) => {\n\t\tconst timer = setTimeout(resolve, ms);\n\t\tif (signal) {\n\t\t\tsignal.addEventListener('abort', () => {\n\t\t\t\tclearTimeout(timer);\n\t\t\t\treject(new DOMException('Aborted', 'AbortError'));\n\t\t\t});\n\t\t}\n\t});\n}\n","import type { HostStack, IdInput } from '../client.ts';\nimport { type StreamLogsOptions, streamLogsViaPolling } from '../streaming.ts';\nimport type {\n\tCreateServiceInput,\n\tService,\n\tServiceConfig,\n\tServiceMetrics,\n\tUpdateServiceConfigInput,\n\tUpdateServiceInput,\n} from '../types.ts';\n\ninterface LogEntry {\n\ttimestamp: string;\n\tlevel?: string | null;\n\tstream?: string | null;\n\tmessage: string;\n}\n\nexport class ServicesResource {\n\tconstructor(private client: HostStack) {}\n\n\t/** List all services for the active team. */\n\tasync list(teamId: IdInput): Promise<{ services: Service[] }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\treturn this.client.request('GET', `/api/services/${tid}`);\n\t}\n\n\t/** Get a single service by ID. */\n\tasync get(teamId: IdInput, serviceId: IdInput): Promise<{ service: Service }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('GET', `/api/services/${tid}/${sid}`);\n\t}\n\n\t/** Create a new service. */\n\tasync create(teamId: IdInput, data: CreateServiceInput): Promise<{ service: Service }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\treturn this.client.request('POST', `/api/services/${tid}`, data);\n\t}\n\n\t/** Update a service. */\n\tasync update(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdata: UpdateServiceInput,\n\t): Promise<{ service: Service }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('PATCH', `/api/services/${tid}/${sid}`, data);\n\t}\n\n\t/** Delete a service. */\n\tasync delete(teamId: IdInput, serviceId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('DELETE', `/api/services/${tid}/${sid}`);\n\t}\n\n\t/** Suspend a service. */\n\tasync suspend(teamId: IdInput, serviceId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('POST', `/api/services/${tid}/${sid}/suspend`);\n\t}\n\n\t/** Resume a suspended service. */\n\tasync resume(teamId: IdInput, serviceId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('POST', `/api/services/${tid}/${sid}/resume`);\n\t}\n\n\t/** Get service metrics. */\n\tasync getMetrics(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t): Promise<{ metrics: ServiceMetrics }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('GET', `/api/services/${tid}/${sid}/metrics`);\n\t}\n\n\t/** Get service configuration. */\n\tasync getConfig(teamId: IdInput, serviceId: IdInput): Promise<{ config: ServiceConfig }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('GET', `/api/services/${tid}/${sid}/config`);\n\t}\n\n\t/** Update service configuration. */\n\tasync updateConfig(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdata: UpdateServiceConfigInput,\n\t): Promise<{ config: ServiceConfig }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('PATCH', `/api/services/${tid}/${sid}/config`, data);\n\t}\n\n\t/** Get runtime logs for a service. */\n\tasync getRuntimeLogs(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\toptions?: { lines?: number; since?: string; stream?: 'stdout' | 'stderr' },\n\t): Promise<{ logs: LogEntry[] | string }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst params = new URLSearchParams();\n\t\tif (options?.lines) params.set('lines', String(options.lines));\n\t\tif (options?.since) params.set('since', options.since);\n\t\tif (options?.stream) params.set('stream', options.stream);\n\t\tconst qs = params.toString();\n\t\treturn this.client.request(\n\t\t\t'GET',\n\t\t\t`/api/services/${tid}/${sid}/runtime-logs${qs ? `?${qs}` : ''}`,\n\t\t);\n\t}\n\n\t/**\n\t * Stream runtime logs for a service by polling the logs endpoint.\n\t * Yields log entries as they appear. Use an AbortController to stop.\n\t *\n\t * @example\n\t * ```ts\n\t * const ac = new AbortController();\n\t * for await (const entry of client.services.streamLogs(teamId, serviceId, { signal: ac.signal })) {\n\t * console.log(entry.message);\n\t * }\n\t * ```\n\t */\n\tasync *streamLogs(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\toptions?: StreamLogsOptions,\n\t): AsyncGenerator<LogEntry> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst basePath = `/api/services/${tid}/${sid}/runtime-logs`;\n\t\tyield* streamLogsViaPolling(\n\t\t\t(path) => this.client.request('GET', path),\n\t\t\tbasePath,\n\t\t\toptions,\n\t\t);\n\t}\n}\n","import {\n\tAuthenticationError,\n\tHostStackError,\n\tNotFoundError,\n\tRateLimitError,\n} from './errors.ts';\nimport { CronResource } from './resources/cron.ts';\nimport { DatabasesResource } from './resources/databases.ts';\nimport { DeploysResource } from './resources/deploys.ts';\nimport { DomainsResource } from './resources/domains.ts';\nimport { EnvVarsResource } from './resources/env-vars.ts';\nimport { ProjectsResource } from './resources/projects.ts';\nimport { ServicesResource } from './resources/services.ts';\n\n/** A numeric id or a publicId string (e.g. 42, \"42\", \"svc_abc…\"). */\nexport type IdInput = number | string;\n\nexport interface HostStackOptions {\n\t/** Your HostStack API key (hs_live_... or hs_test_...). */\n\tapiKey: string;\n\t/** Base URL of the HostStack API. Defaults to https://hoststack.dev */\n\tbaseUrl?: string;\n}\n\nconst PREFIX = {\n\tteam: 'team_',\n\tproject: 'prj_',\n\tservice: 'svc_',\n\tdeploy: 'dpl_',\n\tdatabase: 'db_',\n\tdomain: 'dom_',\n\tenvVar: 'env_',\n\tcronExecution: 'cjob_',\n} as const;\n\ntype ResolveScope =\n\t| { kind: 'team' }\n\t| { kind: 'project'; teamId: number }\n\t| { kind: 'service'; teamId: number }\n\t| { kind: 'deploy'; teamId: number; serviceId: number }\n\t| { kind: 'database'; teamId: number }\n\t| { kind: 'domain'; teamId: number }\n\t| { kind: 'envVar'; teamId: number; serviceId: number }\n\t| { kind: 'cronExecution'; teamId: number; serviceId: number };\n\nexport class HostStack {\n\tprivate apiKey: string;\n\tprivate baseUrl: string;\n\n\t// publicId → numeric id, scoped by parent context. Lifetime: client instance.\n\tprivate idCache = new Map<string, number>();\n\n\t/** Manage projects. */\n\tpublic readonly projects: ProjectsResource;\n\t/** Manage services (web, worker, cron). */\n\tpublic readonly services: ServicesResource;\n\t/** Trigger and manage deployments. */\n\tpublic readonly deploys: DeploysResource;\n\t/** Manage databases (Postgres, Redis). */\n\tpublic readonly databases: DatabasesResource;\n\t/** Manage custom domains. */\n\tpublic readonly domains: DomainsResource;\n\t/** Manage service environment variables. */\n\tpublic readonly envVars: EnvVarsResource;\n\t/** Manage cron job executions. */\n\tpublic readonly cron: CronResource;\n\n\tconstructor(options: HostStackOptions) {\n\t\tif (!options.apiKey) {\n\t\t\tthrow new Error('apiKey is required');\n\t\t}\n\n\t\tthis.apiKey = options.apiKey;\n\t\tthis.baseUrl = (options.baseUrl ?? 'https://hoststack.dev').replace(/\\/$/, '');\n\n\t\tthis.projects = new ProjectsResource(this);\n\t\tthis.services = new ServicesResource(this);\n\t\tthis.deploys = new DeploysResource(this);\n\t\tthis.databases = new DatabasesResource(this);\n\t\tthis.domains = new DomainsResource(this);\n\t\tthis.envVars = new EnvVarsResource(this);\n\t\tthis.cron = new CronResource(this);\n\t}\n\n\t/**\n\t * Make an authenticated request to the HostStack API.\n\t * Used internally by resource classes. Can also be used for custom API calls.\n\t */\n\tasync request<T>(method: string, path: string, body?: unknown): Promise<T> {\n\t\tconst url = `${this.baseUrl}${path}`;\n\n\t\tconst headers: Record<string, string> = {\n\t\t\tAuthorization: `Bearer ${this.apiKey}`,\n\t\t};\n\n\t\tif (body !== undefined) {\n\t\t\theaders['Content-Type'] = 'application/json';\n\t\t}\n\n\t\tconst res = await fetch(url, {\n\t\t\tmethod,\n\t\t\theaders,\n\t\t\tbody: body !== undefined ? JSON.stringify(body) : undefined,\n\t\t});\n\n\t\tif (!res.ok) {\n\t\t\tconst data = (await res.json().catch(() => ({ error: 'Unknown error' }))) as {\n\t\t\t\terror?: string;\n\t\t\t};\n\t\t\tconst message = data.error ?? `HTTP ${res.status}`;\n\n\t\t\tswitch (res.status) {\n\t\t\t\tcase 401:\n\t\t\t\t\tthrow new AuthenticationError(message);\n\t\t\t\tcase 404:\n\t\t\t\t\tthrow new NotFoundError(message);\n\t\t\t\tcase 429:\n\t\t\t\t\tthrow new RateLimitError(message);\n\t\t\t\tdefault:\n\t\t\t\t\tthrow new HostStackError(res.status, message);\n\t\t\t}\n\t\t}\n\n\t\t// Handle 204 No Content\n\t\tif (res.status === 204) {\n\t\t\treturn undefined as T;\n\t\t}\n\n\t\treturn res.json() as Promise<T>;\n\t}\n\n\t/**\n\t * Resolve a publicId-or-numeric id input to a numeric database id. Numeric\n\t * inputs short-circuit; publicIds (svc_xyz, dpl_xyz, etc.) are looked up\n\t * via the relevant list endpoint and cached on this client instance.\n\t *\n\t * The API addresses everything by numeric id internally; this resolver lets\n\t * SDK/MCP consumers pass either form interchangeably without burning extra\n\t * round-trips on subsequent calls.\n\t */\n\tasync resolveId(input: IdInput, scope: ResolveScope): Promise<number> {\n\t\tif (typeof input === 'number') return input;\n\t\tif (/^\\d+$/.test(input)) return Number.parseInt(input, 10);\n\n\t\tconst expectedPrefix = PREFIX[scope.kind];\n\t\tif (!input.startsWith(expectedPrefix)) {\n\t\t\tthrow new HostStackError(\n\t\t\t\t400,\n\t\t\t\t`Invalid ${scope.kind} id \"${input}\": expected ${expectedPrefix}xxx or numeric.`,\n\t\t\t);\n\t\t}\n\n\t\tconst cacheKey = `${cacheScope(scope)}:${input}`;\n\t\tconst cached = this.idCache.get(cacheKey);\n\t\tif (cached !== undefined) return cached;\n\n\t\tconst items = await this.fetchForResolution(scope);\n\t\tconst match = items.find((it) => it.publicId === input);\n\t\tif (!match) {\n\t\t\tthrow new NotFoundError(`${scope.kind} ${input} not found`);\n\t\t}\n\t\tthis.idCache.set(cacheKey, match.id);\n\t\treturn match.id;\n\t}\n\n\tprivate async fetchForResolution(\n\t\tscope: ResolveScope,\n\t): Promise<Array<{ id: number; publicId: string }>> {\n\t\tswitch (scope.kind) {\n\t\t\tcase 'team': {\n\t\t\t\tconst r = await this.request<{ teams: Array<{ id: number; publicId: string }> }>(\n\t\t\t\t\t'GET',\n\t\t\t\t\t'/api/teams',\n\t\t\t\t);\n\t\t\t\treturn r.teams ?? [];\n\t\t\t}\n\t\t\tcase 'project': {\n\t\t\t\tconst r = await this.request<{ projects: Array<{ id: number; publicId: string }> }>(\n\t\t\t\t\t'GET',\n\t\t\t\t\t`/api/projects/${scope.teamId}`,\n\t\t\t\t);\n\t\t\t\treturn r.projects ?? [];\n\t\t\t}\n\t\t\tcase 'service': {\n\t\t\t\tconst r = await this.request<{ services: Array<{ id: number; publicId: string }> }>(\n\t\t\t\t\t'GET',\n\t\t\t\t\t`/api/services/${scope.teamId}`,\n\t\t\t\t);\n\t\t\t\treturn r.services ?? [];\n\t\t\t}\n\t\t\tcase 'deploy': {\n\t\t\t\t// Deploys list is paginated and returns `{ data, page, ... }` —\n\t\t\t\t// not the bare `{ deploys: [] }` shape used by other endpoints.\n\t\t\t\t// resolveId only needs the latest pages, but we walk pagination\n\t\t\t\t// so older deploy publicIds still resolve.\n\t\t\t\tconst r = await this.request<{\n\t\t\t\t\tdata: Array<{ id: number; publicId: string }>;\n\t\t\t\t\ttotalPages?: number;\n\t\t\t\t}>(\n\t\t\t\t\t'GET',\n\t\t\t\t\t`/api/services/${scope.teamId}/${scope.serviceId}/deploys?perPage=100`,\n\t\t\t\t);\n\t\t\t\treturn r.data ?? [];\n\t\t\t}\n\t\t\tcase 'database': {\n\t\t\t\tconst r = await this.request<{ databases: Array<{ id: number; publicId: string }> }>(\n\t\t\t\t\t'GET',\n\t\t\t\t\t`/api/databases/${scope.teamId}`,\n\t\t\t\t);\n\t\t\t\treturn r.databases ?? [];\n\t\t\t}\n\t\t\tcase 'domain': {\n\t\t\t\tconst r = await this.request<{ domains: Array<{ id: number; publicId: string }> }>(\n\t\t\t\t\t'GET',\n\t\t\t\t\t`/api/domains/${scope.teamId}`,\n\t\t\t\t);\n\t\t\t\treturn r.domains ?? [];\n\t\t\t}\n\t\t\tcase 'envVar': {\n\t\t\t\tconst r = await this.request<{ envVars: Array<{ id: number; publicId: string }> }>(\n\t\t\t\t\t'GET',\n\t\t\t\t\t`/api/services/${scope.teamId}/${scope.serviceId}/env`,\n\t\t\t\t);\n\t\t\t\treturn r.envVars ?? [];\n\t\t\t}\n\t\t\tcase 'cronExecution': {\n\t\t\t\tconst r = await this.request<{\n\t\t\t\t\texecutions: Array<{ id: number; publicId: string }>;\n\t\t\t\t}>('GET', `/api/services/${scope.teamId}/${scope.serviceId}/cron-executions`);\n\t\t\t\treturn r.executions ?? [];\n\t\t\t}\n\t\t}\n\t}\n}\n\nfunction cacheScope(scope: ResolveScope): string {\n\tswitch (scope.kind) {\n\t\tcase 'team':\n\t\t\treturn 'team';\n\t\tcase 'project':\n\t\tcase 'service':\n\t\tcase 'database':\n\t\tcase 'domain':\n\t\t\treturn `${scope.kind}:${scope.teamId}`;\n\t\tcase 'deploy':\n\t\tcase 'envVar':\n\t\tcase 'cronExecution':\n\t\t\treturn `${scope.kind}:${scope.teamId}:${scope.serviceId}`;\n\t}\n}\n","/**\n * Standard pagination parameters for list requests.\n */\nexport interface PaginationParams {\n\t/** Maximum number of items to return. */\n\tlimit?: number;\n\t/** Number of items to skip. */\n\toffset?: number;\n}\n\n/**\n * A paginated response wrapper.\n */\nexport interface PaginatedResponse<T> {\n\titems: T[];\n\ttotal: number;\n\tlimit: number;\n\toffset: number;\n\thasMore: boolean;\n}\n\n/**\n * Builds a query string from pagination params.\n * Returns an empty string if no params are set.\n */\nexport function buildPaginationQuery(params?: PaginationParams): string {\n\tif (!params) return '';\n\tconst qs = new URLSearchParams();\n\tif (params.limit !== undefined) qs.set('limit', String(params.limit));\n\tif (params.offset !== undefined) qs.set('offset', String(params.offset));\n\tconst str = qs.toString();\n\treturn str ? `?${str}` : '';\n}\n\n/**\n * Wraps a plain array result into a PaginatedResponse.\n * Useful when the API returns a flat array without pagination metadata.\n */\nexport function wrapArray<T>(\n\titems: T[],\n\tparams?: PaginationParams,\n): PaginatedResponse<T> {\n\tconst limit = params?.limit ?? items.length;\n\tconst offset = params?.offset ?? 0;\n\treturn {\n\t\titems,\n\t\ttotal: items.length,\n\t\tlimit,\n\t\toffset,\n\t\thasMore: false,\n\t};\n}\n"]}
1
+ {"version":3,"sources":["../src/errors.ts","../src/resources/cron.ts","../src/resources/databases.ts","../src/resources/deploys.ts","../src/resources/domains.ts","../src/resources/environments.ts","../src/resources/env-vars.ts","../src/resources/projects.ts","../src/streaming.ts","../src/resources/services.ts","../src/resources/volumes.ts","../src/client.ts","../src/pagination.ts"],"names":["fetch"],"mappings":"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","file":"index.cjs","sourcesContent":["export class HostStackError extends Error {\n\tpublic readonly statusCode: number;\n\n\tconstructor(statusCode: number, message: string) {\n\t\tsuper(message);\n\t\tthis.name = 'HostStackError';\n\t\tthis.statusCode = statusCode;\n\t}\n}\n\nexport class AuthenticationError extends HostStackError {\n\tconstructor(message = 'Authentication failed. Check your API key.') {\n\t\tsuper(401, message);\n\t\tthis.name = 'AuthenticationError';\n\t}\n}\n\nexport class NotFoundError extends HostStackError {\n\tconstructor(message = 'Resource not found.') {\n\t\tsuper(404, message);\n\t\tthis.name = 'NotFoundError';\n\t}\n}\n\nexport class RateLimitError extends HostStackError {\n\tconstructor(message = 'Rate limit exceeded. Try again later.') {\n\t\tsuper(429, message);\n\t\tthis.name = 'RateLimitError';\n\t}\n}\n","import type { HostStack, IdInput } from '../client.ts';\nimport type { CronExecution } from '../types.ts';\n\nexport class CronResource {\n\tconstructor(private client: HostStack) {}\n\n\t/** List cron executions for a service. */\n\tasync list(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\toptions?: { limit?: number },\n\t): Promise<{ executions: CronExecution[] }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst params = new URLSearchParams();\n\t\tif (options?.limit) params.set('limit', String(options.limit));\n\t\tconst qs = params.toString();\n\t\treturn this.client.request(\n\t\t\t'GET',\n\t\t\t`/api/services/${tid}/${sid}/cron-executions${qs ? `?${qs}` : ''}`,\n\t\t);\n\t}\n\n\t/** Get a single cron execution by ID. */\n\tasync get(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\texecutionId: IdInput,\n\t): Promise<{ execution: CronExecution }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst eid = await this.client.resolveId(executionId, {\n\t\t\tkind: 'cronExecution',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\treturn this.client.request('GET', `/api/services/${tid}/${sid}/cron-executions/${eid}`);\n\t}\n\n\t/** Trigger an immediate cron execution. */\n\tasync trigger(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t): Promise<{ execution: CronExecution }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('POST', `/api/services/${tid}/${sid}/cron-executions/trigger`);\n\t}\n}\n","import type { HostStack, IdInput } from '../client.ts';\nimport type {\n\tCreateDatabaseInput,\n\tDatabase,\n\tDatabaseCredentials,\n\tUpdateDatabaseInput,\n} from '../types.ts';\n\nexport class DatabasesResource {\n\tconstructor(private client: HostStack) {}\n\n\t/** List all databases for a project. */\n\tasync list(teamId: IdInput, projectId: IdInput): Promise<{ databases: Database[] }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst pid = await this.client.resolveId(projectId, { kind: 'project', teamId: tid });\n\t\treturn this.client.request('GET', `/api/databases/${tid}?projectId=${pid}`);\n\t}\n\n\t/** Get a single database by ID. */\n\tasync get(teamId: IdInput, databaseId: IdInput): Promise<{ database: Database }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(databaseId, { kind: 'database', teamId: tid });\n\t\treturn this.client.request('GET', `/api/databases/${tid}/${did}`);\n\t}\n\n\t/** Create a new database. */\n\tasync create(teamId: IdInput, data: CreateDatabaseInput): Promise<{ database: Database }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\treturn this.client.request('POST', `/api/databases/${tid}`, data);\n\t}\n\n\t/** Update a database. */\n\tasync update(\n\t\tteamId: IdInput,\n\t\tdatabaseId: IdInput,\n\t\tdata: UpdateDatabaseInput,\n\t): Promise<{ database: Database }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(databaseId, { kind: 'database', teamId: tid });\n\t\treturn this.client.request('PATCH', `/api/databases/${tid}/${did}`, data);\n\t}\n\n\t/** Delete a database. */\n\tasync delete(teamId: IdInput, databaseId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(databaseId, { kind: 'database', teamId: tid });\n\t\treturn this.client.request('DELETE', `/api/databases/${tid}/${did}`);\n\t}\n\n\t/** Suspend a database. */\n\tasync suspend(teamId: IdInput, databaseId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(databaseId, { kind: 'database', teamId: tid });\n\t\treturn this.client.request('POST', `/api/databases/${tid}/${did}/suspend`);\n\t}\n\n\t/** Resume a suspended database. */\n\tasync resume(teamId: IdInput, databaseId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(databaseId, { kind: 'database', teamId: tid });\n\t\treturn this.client.request('POST', `/api/databases/${tid}/${did}/resume`);\n\t}\n\n\t/** Get connection credentials. */\n\tasync getCredentials(\n\t\tteamId: IdInput,\n\t\tdatabaseId: IdInput,\n\t): Promise<{ credentials: DatabaseCredentials }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(databaseId, { kind: 'database', teamId: tid });\n\t\treturn this.client.request('GET', `/api/databases/${tid}/${did}/credentials`);\n\t}\n\n\t/** Reset the database password. */\n\tasync resetPassword(teamId: IdInput, databaseId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(databaseId, { kind: 'database', teamId: tid });\n\t\treturn this.client.request('POST', `/api/databases/${tid}/${did}/reset-password`);\n\t}\n}\n","import type { HostStack, IdInput } from '../client.ts';\nimport type { Deploy, TriggerDeployInput } from '../types.ts';\n\nexport interface DeployListResponse {\n\tdata: Deploy[];\n\tpage: number;\n\tperPage: number;\n\ttotal: number;\n\ttotalPages: number;\n}\n\nexport class DeploysResource {\n\tconstructor(private client: HostStack) {}\n\n\t/**\n\t * List deploys for a service. Paginated — pass `page` / `perPage` to walk\n\t * pages. Default page=1, perPage=25, hard cap perPage=100.\n\t */\n\tasync list(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\toptions?: { page?: number; perPage?: number },\n\t): Promise<DeployListResponse> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst params = new URLSearchParams();\n\t\tif (options?.page !== undefined) params.set('page', String(options.page));\n\t\tif (options?.perPage !== undefined) params.set('perPage', String(options.perPage));\n\t\tconst qs = params.toString();\n\t\treturn this.client.request(\n\t\t\t'GET',\n\t\t\t`/api/services/${tid}/${sid}/deploys${qs ? `?${qs}` : ''}`,\n\t\t);\n\t}\n\n\t/** Get a single deploy by ID. */\n\tasync get(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdeployId: IdInput,\n\t): Promise<{ deploy: Deploy }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst did = await this.client.resolveId(deployId, {\n\t\t\tkind: 'deploy',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\treturn this.client.request('GET', `/api/services/${tid}/${sid}/deploys/${did}`);\n\t}\n\n\t/** Trigger a new deploy. */\n\tasync trigger(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdata?: TriggerDeployInput,\n\t): Promise<{ deploy: Deploy }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('POST', `/api/services/${tid}/${sid}/deploys`, data ?? {});\n\t}\n\n\t/** Cancel an in-progress deploy. */\n\tasync cancel(teamId: IdInput, serviceId: IdInput, deployId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst did = await this.client.resolveId(deployId, {\n\t\t\tkind: 'deploy',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\treturn this.client.request('POST', `/api/services/${tid}/${sid}/deploys/${did}/cancel`);\n\t}\n\n\t/** Rollback to a previous deploy. */\n\tasync rollback(teamId: IdInput, serviceId: IdInput, deployId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst did = await this.client.resolveId(deployId, {\n\t\t\tkind: 'deploy',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\treturn this.client.request('POST', `/api/services/${tid}/${sid}/deploys/${did}/rollback`);\n\t}\n\n\t/**\n\t * v66 P5: promote a built deploy to a sibling service in another\n\t * environment. Reuses the source deploy's docker image (no rebuild).\n\t * If no sibling service exists in the target env yet, the API auto-\n\t * creates one by cloning the source service's config.\n\t */\n\tasync promote(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdeployId: IdInput,\n\t\ttargetEnvironmentId: number,\n\t): Promise<{ deploy: Deploy }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst did = await this.client.resolveId(deployId, {\n\t\t\tkind: 'deploy',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\treturn this.client.request(\n\t\t\t'POST',\n\t\t\t`/api/services/${tid}/${sid}/deploys/${did}/promote`,\n\t\t\t{ targetEnvironmentId },\n\t\t);\n\t}\n\n\t/**\n\t * Get build logs for a deploy.\n\t *\n\t * Pagination: pass `afterId` from the previous response's `nextAfterId`\n\t * to fetch the next page. Per-call cap is 5000; default 500.\n\t */\n\tasync getLogs(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdeployId: IdInput,\n\t\toptions?: {\n\t\t\tsearch?: string;\n\t\t\tlevel?: string;\n\t\t\tphase?: string;\n\t\t\tlimit?: number;\n\t\t\tafterId?: number;\n\t\t},\n\t): Promise<{ logs: DeployLogEntry[]; nextAfterId: number | null }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst did = await this.client.resolveId(deployId, {\n\t\t\tkind: 'deploy',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\tconst params = new URLSearchParams();\n\t\tif (options?.search) params.set('search', options.search);\n\t\tif (options?.level) params.set('level', options.level);\n\t\tif (options?.phase) params.set('phase', options.phase);\n\t\tif (options?.limit !== undefined) params.set('limit', String(options.limit));\n\t\tif (options?.afterId !== undefined) params.set('afterId', String(options.afterId));\n\t\tconst qs = params.toString();\n\t\tconst url = `/api/services/${tid}/${sid}/deploys/${did}/logs${qs ? `?${qs}` : ''}`;\n\t\treturn this.client.request('GET', url);\n\t}\n}\n\nexport interface DeployLogEntry {\n\tid: number;\n\tdeployId: number;\n\ttimestamp: string;\n\tlevel: 'info' | 'warn' | 'error' | 'debug';\n\tphase: string | null;\n\tmessage: string;\n}\n","import type { HostStack, IdInput } from '../client.ts';\nimport type { AddDomainInput, Domain, UpdateDomainInput } from '../types.ts';\n\nexport class DomainsResource {\n\tconstructor(private client: HostStack) {}\n\n\t/** List all domains for the active team. */\n\tasync list(teamId: IdInput): Promise<{ domains: Domain[] }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\treturn this.client.request('GET', `/api/domains/${tid}`);\n\t}\n\n\t/** Add a custom domain. */\n\tasync add(teamId: IdInput, data: AddDomainInput): Promise<{ domain: Domain }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\treturn this.client.request('POST', `/api/domains/${tid}`, data);\n\t}\n\n\t/** Update a domain. */\n\tasync update(\n\t\tteamId: IdInput,\n\t\tdomainId: IdInput,\n\t\tdata: UpdateDomainInput,\n\t): Promise<{ domain: Domain }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(domainId, { kind: 'domain', teamId: tid });\n\t\treturn this.client.request('PATCH', `/api/domains/${tid}/${did}`, data);\n\t}\n\n\t/** Remove a domain. */\n\tasync remove(teamId: IdInput, domainId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(domainId, { kind: 'domain', teamId: tid });\n\t\treturn this.client.request('DELETE', `/api/domains/${tid}/${did}`);\n\t}\n\n\t/** Verify domain DNS configuration. */\n\tasync verify(teamId: IdInput, domainId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst did = await this.client.resolveId(domainId, { kind: 'domain', teamId: tid });\n\t\treturn this.client.request('POST', `/api/domains/${tid}/${did}/verify`);\n\t}\n}\n","import type { HostStack, IdInput } from '../client.ts';\n\nexport interface Environment {\n\tid: number;\n\tpublicId: string;\n\tprojectId: number;\n\tname: string;\n\ttype: 'production' | 'staging' | 'development' | 'preview';\n\tisDefault: boolean;\n\tisProtected: boolean;\n\tcreatedAt: string;\n\tupdatedAt: string;\n}\n\nexport interface CreateEnvironmentInput {\n\tname: string;\n\ttype: 'production' | 'staging' | 'development' | 'preview';\n\tisProtected?: boolean;\n}\n\nexport interface UpdateEnvironmentInput {\n\tname?: string;\n\tisDefault?: boolean;\n\tisProtected?: boolean;\n}\n\n/**\n * v66 P5: programmatic env management. Each project has at least a\n * Production env auto-created at project creation; you can add more\n * via `create` and bind services/databases to them via the\n * `environmentId` field on those resources' create inputs.\n *\n * @example\n * ```ts\n * const { environment: staging } = await client.environments.create(\n * teamId,\n * projectId,\n * { name: 'Staging', type: 'staging' }\n * );\n * await client.services.create(teamId, {\n * projectId,\n * environmentId: staging.id,\n * name: 'api',\n * type: 'web_service',\n * // ...\n * });\n * ```\n */\nexport class EnvironmentsResource {\n\tconstructor(private client: HostStack) {}\n\n\t/** List all environments for a project. */\n\tasync list(\n\t\tteamId: IdInput,\n\t\tprojectId: IdInput,\n\t): Promise<{ environments: Environment[] }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst pid = await this.client.resolveId(projectId, { kind: 'project', teamId: tid });\n\t\treturn this.client.request('GET', `/api/environments/${tid}/${pid}`);\n\t}\n\n\t/** Get a single environment by id. */\n\tasync get(\n\t\tteamId: IdInput,\n\t\tprojectId: IdInput,\n\t\tenvId: IdInput,\n\t): Promise<{ environment: Environment }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst pid = await this.client.resolveId(projectId, { kind: 'project', teamId: tid });\n\t\tconst eid = await this.client.resolveId(envId, { kind: 'environment', teamId: tid });\n\t\treturn this.client.request('GET', `/api/environments/${tid}/${pid}/${eid}`);\n\t}\n\n\t/** Create a new environment in the given project. */\n\tasync create(\n\t\tteamId: IdInput,\n\t\tprojectId: IdInput,\n\t\tdata: CreateEnvironmentInput,\n\t): Promise<{ environment: Environment }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst pid = await this.client.resolveId(projectId, { kind: 'project', teamId: tid });\n\t\treturn this.client.request('POST', `/api/environments/${tid}/${pid}`, data);\n\t}\n\n\t/** Update environment metadata (name, default flag, protected flag). */\n\tasync update(\n\t\tteamId: IdInput,\n\t\tprojectId: IdInput,\n\t\tenvId: IdInput,\n\t\tdata: UpdateEnvironmentInput,\n\t): Promise<{ environment: Environment }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst pid = await this.client.resolveId(projectId, { kind: 'project', teamId: tid });\n\t\tconst eid = await this.client.resolveId(envId, { kind: 'environment', teamId: tid });\n\t\treturn this.client.request('PATCH', `/api/environments/${tid}/${pid}/${eid}`, data);\n\t}\n\n\t/**\n\t * Delete an environment. The API blocks delete when the env still\n\t * has services or databases attached — destroy them first or move\n\t * them to another env. Cannot delete the project's default env.\n\t */\n\tasync delete(\n\t\tteamId: IdInput,\n\t\tprojectId: IdInput,\n\t\tenvId: IdInput,\n\t): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst pid = await this.client.resolveId(projectId, { kind: 'project', teamId: tid });\n\t\tconst eid = await this.client.resolveId(envId, { kind: 'environment', teamId: tid });\n\t\treturn this.client.request('DELETE', `/api/environments/${tid}/${pid}/${eid}`);\n\t}\n}\n","import type { HostStack, IdInput } from '../client.ts';\nimport type {\n\tBulkSetEnvVarsInput,\n\tCreateEnvVarInput,\n\tEnvVar,\n\tUpdateEnvVarInput,\n} from '../types.ts';\n\nexport class EnvVarsResource {\n\tconstructor(private client: HostStack) {}\n\n\t/** List all environment variables for a service. */\n\tasync list(teamId: IdInput, serviceId: IdInput): Promise<{ envVars: EnvVar[] }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('GET', `/api/services/${tid}/${sid}/env`);\n\t}\n\n\t/** Create a new environment variable. */\n\tasync create(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdata: CreateEnvVarInput,\n\t): Promise<{ envVar: EnvVar }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('POST', `/api/services/${tid}/${sid}/env`, data);\n\t}\n\n\t/** Update an environment variable. */\n\tasync update(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tenvVarId: IdInput,\n\t\tdata: UpdateEnvVarInput,\n\t): Promise<{ envVar: EnvVar }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst eid = await this.client.resolveId(envVarId, {\n\t\t\tkind: 'envVar',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\treturn this.client.request('PATCH', `/api/services/${tid}/${sid}/env/${eid}`, data);\n\t}\n\n\t/** Delete an environment variable. */\n\tasync delete(teamId: IdInput, serviceId: IdInput, envVarId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst eid = await this.client.resolveId(envVarId, {\n\t\t\tkind: 'envVar',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\treturn this.client.request('DELETE', `/api/services/${tid}/${sid}/env/${eid}`);\n\t}\n\n\t/** Bulk set environment variables (create or update). */\n\tasync bulkSet(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdata: BulkSetEnvVarsInput,\n\t): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('PUT', `/api/services/${tid}/${sid}/env/bulk`, data);\n\t}\n}\n","import type { HostStack, IdInput } from '../client.ts';\nimport type { CreateProjectInput, Project, UpdateProjectInput } from '../types.ts';\n\nexport class ProjectsResource {\n\tconstructor(private client: HostStack) {}\n\n\t/** List all projects for the active team. */\n\tasync list(teamId: IdInput): Promise<{ projects: Project[] }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\treturn this.client.request('GET', `/api/projects/${tid}`);\n\t}\n\n\t/** Get a single project by ID. */\n\tasync get(teamId: IdInput, projectId: IdInput): Promise<{ project: Project }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst pid = await this.client.resolveId(projectId, { kind: 'project', teamId: tid });\n\t\treturn this.client.request('GET', `/api/projects/${tid}/${pid}`);\n\t}\n\n\t/** Create a new project. */\n\tasync create(teamId: IdInput, data: CreateProjectInput): Promise<{ project: Project }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\treturn this.client.request('POST', `/api/projects/${tid}`, data);\n\t}\n\n\t/** Update a project. */\n\tasync update(\n\t\tteamId: IdInput,\n\t\tprojectId: IdInput,\n\t\tdata: UpdateProjectInput,\n\t): Promise<{ project: Project }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst pid = await this.client.resolveId(projectId, { kind: 'project', teamId: tid });\n\t\treturn this.client.request('PATCH', `/api/projects/${tid}/${pid}`, data);\n\t}\n\n\t/** Delete a project. */\n\tasync delete(teamId: IdInput, projectId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst pid = await this.client.resolveId(projectId, { kind: 'project', teamId: tid });\n\t\treturn this.client.request('DELETE', `/api/projects/${tid}/${pid}`);\n\t}\n}\n","export interface LogEntry {\n\ttimestamp: string;\n\tlevel?: string | null;\n\tstream?: string | null;\n\tmessage: string;\n}\n\nexport interface StreamLogsOptions {\n\t/** Filter by stream: 'stdout' or 'stderr'. */\n\tstream?: 'stdout' | 'stderr';\n\t/** Number of historical lines to fetch on first poll (default: 100). */\n\tinitialLines?: number;\n\t/** Poll interval in milliseconds (default: 2000). */\n\tpollInterval?: number;\n\t/** AbortSignal to stop streaming. */\n\tsignal?: AbortSignal;\n}\n\n/**\n * Streams runtime logs for a service by polling the logs REST endpoint.\n * Yields log entries as they appear. Use an AbortController to stop.\n *\n * @example\n * ```ts\n * const ac = new AbortController();\n * for await (const entry of client.services.streamLogs(teamId, serviceId, { signal: ac.signal })) {\n * console.log(entry.message);\n * }\n * ```\n */\nexport async function* streamLogsViaPolling(\n\tfetch: (path: string) => Promise<{ logs: LogEntry[] | string }>,\n\tbasePath: string,\n\toptions: StreamLogsOptions = {},\n): AsyncGenerator<LogEntry> {\n\tconst pollInterval = options.pollInterval ?? 2000;\n\tconst initialLines = options.initialLines ?? 100;\n\n\t// Track seen timestamps to avoid duplicates on first yield\n\tlet lastTimestamp: string | null = null;\n\n\tconst buildPath = (lines?: number, since?: string) => {\n\t\tconst params = new URLSearchParams();\n\t\tif (options.stream) params.set('stream', options.stream);\n\t\t// v63 P5: backend now standardises on `limit` + `since`; we keep the\n\t\t// `lines` SDK alias and pass it as `limit` so old + new wire formats\n\t\t// both work.\n\t\tif (lines !== undefined) params.set('limit', String(lines));\n\t\tif (since) params.set('since', since);\n\t\tconst qs = params.toString();\n\t\treturn `${basePath}${qs ? `?${qs}` : ''}`;\n\t};\n\n\t// Initial fetch\n\tconst initialData = await fetch(buildPath(initialLines));\n\tconst initial = normalizeEntries(initialData.logs);\n\tfor (const entry of initial) {\n\t\tyield entry;\n\t\tif (entry.timestamp > (lastTimestamp ?? '')) {\n\t\t\tlastTimestamp = entry.timestamp;\n\t\t}\n\t}\n\n\t// Poll loop\n\twhile (!options.signal?.aborted) {\n\t\tawait sleep(pollInterval, options.signal);\n\t\tif (options.signal?.aborted) break;\n\n\t\tconst sinceTs = lastTimestamp ? new Date(lastTimestamp).toISOString() : undefined;\n\t\tconst data = await fetch(buildPath(undefined, sinceTs)).catch(() => ({ logs: [] }));\n\t\tconst entries = normalizeEntries(data.logs);\n\n\t\tfor (const entry of entries) {\n\t\t\tif (!lastTimestamp || entry.timestamp > lastTimestamp) {\n\t\t\t\tyield entry;\n\t\t\t\tlastTimestamp = entry.timestamp;\n\t\t\t}\n\t\t}\n\t}\n}\n\nfunction normalizeEntries(logs: LogEntry[] | string): LogEntry[] {\n\tif (typeof logs === 'string') {\n\t\tconst lines = logs.split('\\n').filter(Boolean);\n\t\treturn lines.map((line) => ({\n\t\t\ttimestamp: new Date().toISOString(),\n\t\t\tmessage: line,\n\t\t}));\n\t}\n\treturn logs;\n}\n\nfunction sleep(ms: number, signal?: AbortSignal): Promise<void> {\n\treturn new Promise((resolve, reject) => {\n\t\tconst timer = setTimeout(resolve, ms);\n\t\tif (signal) {\n\t\t\tsignal.addEventListener('abort', () => {\n\t\t\t\tclearTimeout(timer);\n\t\t\t\treject(new DOMException('Aborted', 'AbortError'));\n\t\t\t});\n\t\t}\n\t});\n}\n","import type { HostStack, IdInput } from '../client.ts';\nimport { type StreamLogsOptions, streamLogsViaPolling } from '../streaming.ts';\nimport type {\n\tCreateServiceInput,\n\tService,\n\tServiceConfig,\n\tServiceMetrics,\n\tUpdateServiceConfigInput,\n\tUpdateServiceInput,\n} from '../types.ts';\n\ninterface LogEntry {\n\ttimestamp: string;\n\tlevel?: string | null;\n\tstream?: string | null;\n\tmessage: string;\n}\n\nexport class ServicesResource {\n\tconstructor(private client: HostStack) {}\n\n\t/** List all services for the active team. */\n\tasync list(teamId: IdInput): Promise<{ services: Service[] }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\treturn this.client.request('GET', `/api/services/${tid}`);\n\t}\n\n\t/** Get a single service by ID. */\n\tasync get(teamId: IdInput, serviceId: IdInput): Promise<{ service: Service }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('GET', `/api/services/${tid}/${sid}`);\n\t}\n\n\t/** Create a new service. */\n\tasync create(teamId: IdInput, data: CreateServiceInput): Promise<{ service: Service }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\treturn this.client.request('POST', `/api/services/${tid}`, data);\n\t}\n\n\t/** Update a service. */\n\tasync update(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdata: UpdateServiceInput,\n\t): Promise<{ service: Service }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('PATCH', `/api/services/${tid}/${sid}`, data);\n\t}\n\n\t/** Delete a service. */\n\tasync delete(teamId: IdInput, serviceId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('DELETE', `/api/services/${tid}/${sid}`);\n\t}\n\n\t/** Suspend a service. */\n\tasync suspend(teamId: IdInput, serviceId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('POST', `/api/services/${tid}/${sid}/suspend`);\n\t}\n\n\t/** Resume a suspended service. */\n\tasync resume(teamId: IdInput, serviceId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('POST', `/api/services/${tid}/${sid}/resume`);\n\t}\n\n\t/** Get service metrics. */\n\tasync getMetrics(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t): Promise<{ metrics: ServiceMetrics }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('GET', `/api/services/${tid}/${sid}/metrics`);\n\t}\n\n\t/** Get service configuration. */\n\tasync getConfig(teamId: IdInput, serviceId: IdInput): Promise<{ config: ServiceConfig }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('GET', `/api/services/${tid}/${sid}/config`);\n\t}\n\n\t/** Update service configuration. */\n\tasync updateConfig(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdata: UpdateServiceConfigInput,\n\t): Promise<{ config: ServiceConfig }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('PATCH', `/api/services/${tid}/${sid}/config`, data);\n\t}\n\n\t/**\n\t * Get runtime logs for a service.\n\t *\n\t * `since`/`until` accept either an ISO-8601 timestamp or a short\n\t * relative offset like `-5m`, `-1h`, `-2d`.\n\t *\n\t * `search` does case-insensitive substring filtering server-side\n\t * (≤100 chars). `countOnly` returns just `{ count: N }` for cheap\n\t * polling — useful when you want to know \"how many error lines in the\n\t * last 5 minutes\" without paying the bytes.\n\t */\n\tasync getRuntimeLogs(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\toptions?: {\n\t\t\tlines?: number;\n\t\t\tlimit?: number;\n\t\t\tsince?: string;\n\t\t\tuntil?: string;\n\t\t\tstream?: 'stdout' | 'stderr';\n\t\t\tlevel?: 'stdout' | 'stderr' | 'info' | 'warn' | 'error' | 'debug';\n\t\t\tsearch?: string;\n\t\t\tgrep?: string;\n\t\t\tcountOnly?: boolean;\n\t\t},\n\t): Promise<{ logs: LogEntry[] | string } | { count: number }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst params = new URLSearchParams();\n\t\tconst lim = options?.limit ?? options?.lines;\n\t\tif (lim != null) params.set('limit', String(lim));\n\t\tif (options?.since) params.set('since', options.since);\n\t\tif (options?.until) params.set('until', options.until);\n\t\tif (options?.stream) params.set('stream', options.stream);\n\t\tif (options?.level) params.set('level', options.level);\n\t\tconst grep = options?.grep ?? options?.search;\n\t\tif (grep) params.set('search', grep);\n\t\tif (options?.countOnly) params.set('count_only', '1');\n\t\tconst qs = params.toString();\n\t\treturn this.client.request(\n\t\t\t'GET',\n\t\t\t`/api/services/${tid}/${sid}/runtime-logs${qs ? `?${qs}` : ''}`,\n\t\t);\n\t}\n\n\t/**\n\t * Stream runtime logs for a service by polling the logs endpoint.\n\t * Yields log entries as they appear. Use an AbortController to stop.\n\t *\n\t * @example\n\t * ```ts\n\t * const ac = new AbortController();\n\t * for await (const entry of client.services.streamLogs(teamId, serviceId, { signal: ac.signal })) {\n\t * console.log(entry.message);\n\t * }\n\t * ```\n\t */\n\tasync *streamLogs(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\toptions?: StreamLogsOptions,\n\t): AsyncGenerator<LogEntry> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst basePath = `/api/services/${tid}/${sid}/runtime-logs`;\n\t\tyield* streamLogsViaPolling(\n\t\t\t(path) => this.client.request('GET', path),\n\t\t\tbasePath,\n\t\t\toptions,\n\t\t);\n\t}\n}\n","import type { HostStack, IdInput } from '../client.ts';\nimport type { CreateVolumeInput, UpdateVolumeInput, Volume } from '../types.ts';\n\n/**\n * Manage persistent disks attached to a service.\n *\n * Volumes mount a writable disk into a service's container at the path you\n * choose, surviving redeploys and container restarts. One service can have\n * multiple volumes; each one is identified by a short `name` and a\n * `mountPath`.\n *\n * Renderers porting from render.yaml: a volume here is the same concept as\n * Render's `disk:` block. Use {@link create} to attach one programmatically,\n * or declare it in `hoststack.yaml` for IaC workflows.\n *\n * @example\n * ```ts\n * await client.volumes.create(team, service, {\n * name: 'data',\n * mountPath: '/var/data',\n * sizeGb: 10,\n * });\n * ```\n */\nexport class VolumesResource {\n\tconstructor(private client: HostStack) {}\n\n\t/** List volumes attached to a service. */\n\tasync list(teamId: IdInput, serviceId: IdInput): Promise<{ volumes: Volume[] }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('GET', `/api/services/${tid}/${sid}/volumes`);\n\t}\n\n\t/** Attach a new volume to a service. Triggers provisioning on the host. */\n\tasync create(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdata: CreateVolumeInput,\n\t): Promise<{ volume: Volume }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\treturn this.client.request('POST', `/api/services/${tid}/${sid}/volumes`, data);\n\t}\n\n\t/**\n\t * Update a volume's mountPath or sizeGb. Resizes that take effect on the\n\t * next deploy; mountPath changes require a redeploy to remount.\n\t */\n\tasync update(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tvolumeId: IdInput,\n\t\tdata: UpdateVolumeInput,\n\t): Promise<{ volume: Volume }> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst vid = await this.client.resolveId(volumeId, {\n\t\t\tkind: 'volume',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\treturn this.client.request('PATCH', `/api/services/${tid}/${sid}/volumes/${vid}`, data);\n\t}\n\n\t/**\n\t * Detach and deprovision a volume. The underlying disk is destroyed —\n\t * back up any data first. Async: the row is marked `deleting` and the\n\t * agent finalises the removal once it acks.\n\t */\n\tasync delete(teamId: IdInput, serviceId: IdInput, volumeId: IdInput): Promise<void> {\n\t\tconst tid = await this.client.resolveId(teamId, { kind: 'team' });\n\t\tconst sid = await this.client.resolveId(serviceId, { kind: 'service', teamId: tid });\n\t\tconst vid = await this.client.resolveId(volumeId, {\n\t\t\tkind: 'volume',\n\t\t\tteamId: tid,\n\t\t\tserviceId: sid,\n\t\t});\n\t\treturn this.client.request('DELETE', `/api/services/${tid}/${sid}/volumes/${vid}`);\n\t}\n}\n","import {\n\tAuthenticationError,\n\tHostStackError,\n\tNotFoundError,\n\tRateLimitError,\n} from './errors.ts';\nimport { CronResource } from './resources/cron.ts';\nimport { DatabasesResource } from './resources/databases.ts';\nimport { DeploysResource } from './resources/deploys.ts';\nimport { DomainsResource } from './resources/domains.ts';\nimport { EnvironmentsResource } from './resources/environments.ts';\nimport { EnvVarsResource } from './resources/env-vars.ts';\nimport { ProjectsResource } from './resources/projects.ts';\nimport { ServicesResource } from './resources/services.ts';\nimport { VolumesResource } from './resources/volumes.ts';\n\n/** A numeric id or a publicId string (e.g. 42, \"42\", \"svc_abc…\"). */\nexport type IdInput = number | string;\n\nexport interface HostStackOptions {\n\t/** Your HostStack API key (hs_live_... or hs_test_...). */\n\tapiKey: string;\n\t/** Base URL of the HostStack API. Defaults to https://hoststack.dev */\n\tbaseUrl?: string;\n}\n\nconst PREFIX = {\n\tteam: 'team_',\n\tproject: 'prj_',\n\tservice: 'svc_',\n\tdeploy: 'dpl_',\n\tdatabase: 'db_',\n\tdomain: 'dom_',\n\tvolume: 'vol_',\n\tenvVar: 'env_',\n\tenvironment: 'environment_',\n\tcronExecution: 'cjob_',\n} as const;\n\ntype ResolveScope =\n\t| { kind: 'team' }\n\t| { kind: 'project'; teamId: number }\n\t| { kind: 'service'; teamId: number }\n\t| { kind: 'deploy'; teamId: number; serviceId: number }\n\t| { kind: 'database'; teamId: number }\n\t| { kind: 'domain'; teamId: number }\n\t| { kind: 'volume'; teamId: number; serviceId: number }\n\t| { kind: 'envVar'; teamId: number; serviceId: number }\n\t// v66 P5: env publicIds resolve numeric ids by hitting the project's\n\t// env list. The resource methods that call resolveId for env scope\n\t// only need teamId since the listForProject endpoint validates team\n\t// ownership; we accept publicId from any project the team owns.\n\t| { kind: 'environment'; teamId: number }\n\t| { kind: 'cronExecution'; teamId: number; serviceId: number };\n\nexport class HostStack {\n\tprivate apiKey: string;\n\tprivate baseUrl: string;\n\n\t// publicId → numeric id, scoped by parent context. Lifetime: client instance.\n\tprivate idCache = new Map<string, number>();\n\n\t/** Manage projects. */\n\tpublic readonly projects: ProjectsResource;\n\t/** Manage services (web, worker, cron). */\n\tpublic readonly services: ServicesResource;\n\t/** Trigger and manage deployments. */\n\tpublic readonly deploys: DeploysResource;\n\t/** Manage databases (Postgres, Redis). */\n\tpublic readonly databases: DatabasesResource;\n\t/** Manage custom domains. */\n\tpublic readonly domains: DomainsResource;\n\t/** Manage service environment variables. */\n\tpublic readonly envVars: EnvVarsResource;\n\t/** v66: manage environments (production/staging/development/preview) per project. */\n\tpublic readonly environments: EnvironmentsResource;\n\t/** Manage cron job executions. */\n\tpublic readonly cron: CronResource;\n\t/** Manage persistent disks attached to services. */\n\tpublic readonly volumes: VolumesResource;\n\n\tconstructor(options: HostStackOptions) {\n\t\tif (!options.apiKey) {\n\t\t\tthrow new Error('apiKey is required');\n\t\t}\n\n\t\tthis.apiKey = options.apiKey;\n\t\tthis.baseUrl = (options.baseUrl ?? 'https://hoststack.dev').replace(/\\/$/, '');\n\n\t\tthis.projects = new ProjectsResource(this);\n\t\tthis.services = new ServicesResource(this);\n\t\tthis.deploys = new DeploysResource(this);\n\t\tthis.databases = new DatabasesResource(this);\n\t\tthis.domains = new DomainsResource(this);\n\t\tthis.envVars = new EnvVarsResource(this);\n\t\tthis.environments = new EnvironmentsResource(this);\n\t\tthis.cron = new CronResource(this);\n\t\tthis.volumes = new VolumesResource(this);\n\t}\n\n\t/**\n\t * Make an authenticated request to the HostStack API.\n\t * Used internally by resource classes. Can also be used for custom API calls.\n\t */\n\tasync request<T>(method: string, path: string, body?: unknown): Promise<T> {\n\t\tconst url = `${this.baseUrl}${path}`;\n\n\t\tconst headers: Record<string, string> = {\n\t\t\tAuthorization: `Bearer ${this.apiKey}`,\n\t\t};\n\n\t\tif (body !== undefined) {\n\t\t\theaders['Content-Type'] = 'application/json';\n\t\t}\n\n\t\tconst res = await fetch(url, {\n\t\t\tmethod,\n\t\t\theaders,\n\t\t\tbody: body !== undefined ? JSON.stringify(body) : undefined,\n\t\t});\n\n\t\tif (!res.ok) {\n\t\t\tconst data = (await res.json().catch(() => ({ error: 'Unknown error' }))) as {\n\t\t\t\terror?: string;\n\t\t\t};\n\t\t\tconst message = data.error ?? `HTTP ${res.status}`;\n\n\t\t\tswitch (res.status) {\n\t\t\t\tcase 401:\n\t\t\t\t\tthrow new AuthenticationError(message);\n\t\t\t\tcase 404:\n\t\t\t\t\tthrow new NotFoundError(message);\n\t\t\t\tcase 429:\n\t\t\t\t\tthrow new RateLimitError(message);\n\t\t\t\tdefault:\n\t\t\t\t\tthrow new HostStackError(res.status, message);\n\t\t\t}\n\t\t}\n\n\t\t// Handle 204 No Content\n\t\tif (res.status === 204) {\n\t\t\treturn undefined as T;\n\t\t}\n\n\t\treturn res.json() as Promise<T>;\n\t}\n\n\t/**\n\t * Resolve a publicId-or-numeric id input to a numeric database id. Numeric\n\t * inputs short-circuit; publicIds (svc_xyz, dpl_xyz, etc.) are looked up\n\t * via the relevant list endpoint and cached on this client instance.\n\t *\n\t * The API addresses everything by numeric id internally; this resolver lets\n\t * SDK/MCP consumers pass either form interchangeably without burning extra\n\t * round-trips on subsequent calls.\n\t */\n\tasync resolveId(input: IdInput, scope: ResolveScope): Promise<number> {\n\t\tif (typeof input === 'number') return input;\n\t\tif (/^\\d+$/.test(input)) return Number.parseInt(input, 10);\n\n\t\tconst expectedPrefix = PREFIX[scope.kind];\n\t\tif (!input.startsWith(expectedPrefix)) {\n\t\t\tthrow new HostStackError(\n\t\t\t\t400,\n\t\t\t\t`Invalid ${scope.kind} id \"${input}\": expected ${expectedPrefix}xxx or numeric.`,\n\t\t\t);\n\t\t}\n\n\t\tconst cacheKey = `${cacheScope(scope)}:${input}`;\n\t\tconst cached = this.idCache.get(cacheKey);\n\t\tif (cached !== undefined) return cached;\n\n\t\tconst items = await this.fetchForResolution(scope);\n\t\tconst match = items.find((it) => it.publicId === input);\n\t\tif (!match) {\n\t\t\tthrow new NotFoundError(`${scope.kind} ${input} not found`);\n\t\t}\n\t\tthis.idCache.set(cacheKey, match.id);\n\t\treturn match.id;\n\t}\n\n\tprivate async fetchForResolution(\n\t\tscope: ResolveScope,\n\t): Promise<Array<{ id: number; publicId: string }>> {\n\t\tswitch (scope.kind) {\n\t\t\tcase 'team': {\n\t\t\t\tconst r = await this.request<{ teams: Array<{ id: number; publicId: string }> }>(\n\t\t\t\t\t'GET',\n\t\t\t\t\t'/api/teams',\n\t\t\t\t);\n\t\t\t\treturn r.teams ?? [];\n\t\t\t}\n\t\t\tcase 'project': {\n\t\t\t\tconst r = await this.request<{ projects: Array<{ id: number; publicId: string }> }>(\n\t\t\t\t\t'GET',\n\t\t\t\t\t`/api/projects/${scope.teamId}`,\n\t\t\t\t);\n\t\t\t\treturn r.projects ?? [];\n\t\t\t}\n\t\t\tcase 'service': {\n\t\t\t\tconst r = await this.request<{ services: Array<{ id: number; publicId: string }> }>(\n\t\t\t\t\t'GET',\n\t\t\t\t\t`/api/services/${scope.teamId}`,\n\t\t\t\t);\n\t\t\t\treturn r.services ?? [];\n\t\t\t}\n\t\t\tcase 'deploy': {\n\t\t\t\t// Deploys list is paginated and returns `{ data, page, ... }` —\n\t\t\t\t// not the bare `{ deploys: [] }` shape used by other endpoints.\n\t\t\t\t// resolveId only needs the latest pages, but we walk pagination\n\t\t\t\t// so older deploy publicIds still resolve.\n\t\t\t\tconst r = await this.request<{\n\t\t\t\t\tdata: Array<{ id: number; publicId: string }>;\n\t\t\t\t\ttotalPages?: number;\n\t\t\t\t}>(\n\t\t\t\t\t'GET',\n\t\t\t\t\t`/api/services/${scope.teamId}/${scope.serviceId}/deploys?perPage=100`,\n\t\t\t\t);\n\t\t\t\treturn r.data ?? [];\n\t\t\t}\n\t\t\tcase 'database': {\n\t\t\t\tconst r = await this.request<{ databases: Array<{ id: number; publicId: string }> }>(\n\t\t\t\t\t'GET',\n\t\t\t\t\t`/api/databases/${scope.teamId}`,\n\t\t\t\t);\n\t\t\t\treturn r.databases ?? [];\n\t\t\t}\n\t\t\tcase 'domain': {\n\t\t\t\tconst r = await this.request<{ domains: Array<{ id: number; publicId: string }> }>(\n\t\t\t\t\t'GET',\n\t\t\t\t\t`/api/domains/${scope.teamId}`,\n\t\t\t\t);\n\t\t\t\treturn r.domains ?? [];\n\t\t\t}\n\t\t\tcase 'envVar': {\n\t\t\t\tconst r = await this.request<{ envVars: Array<{ id: number; publicId: string }> }>(\n\t\t\t\t\t'GET',\n\t\t\t\t\t`/api/services/${scope.teamId}/${scope.serviceId}/env`,\n\t\t\t\t);\n\t\t\t\treturn r.envVars ?? [];\n\t\t\t}\n\t\t\tcase 'volume': {\n\t\t\t\tconst r = await this.request<{\n\t\t\t\t\tvolumes: Array<{ id: number; publicId: string }>;\n\t\t\t\t}>('GET', `/api/services/${scope.teamId}/${scope.serviceId}/volumes`);\n\t\t\t\treturn r.volumes ?? [];\n\t\t\t}\n\t\t\tcase 'cronExecution': {\n\t\t\t\tconst r = await this.request<{\n\t\t\t\t\texecutions: Array<{ id: number; publicId: string }>;\n\t\t\t\t}>('GET', `/api/services/${scope.teamId}/${scope.serviceId}/cron-executions`);\n\t\t\t\treturn r.executions ?? [];\n\t\t\t}\n\t\t\tcase 'environment': {\n\t\t\t\t// Walk the team's projects to collect every env. Slightly\n\t\t\t\t// expensive but envs are small in count and the cache\n\t\t\t\t// amortizes subsequent lookups for the same client instance.\n\t\t\t\tconst projectsRes = await this.request<{\n\t\t\t\t\tprojects: Array<{ id: number; publicId: string }>;\n\t\t\t\t}>('GET', `/api/projects/${scope.teamId}`);\n\t\t\t\tconst envs: Array<{ id: number; publicId: string }> = [];\n\t\t\t\tfor (const p of projectsRes.projects ?? []) {\n\t\t\t\t\tconst r = await this.request<{\n\t\t\t\t\t\tenvironments: Array<{ id: number; publicId: string }>;\n\t\t\t\t\t}>('GET', `/api/environments/${scope.teamId}/${p.id}`);\n\t\t\t\t\tenvs.push(...(r.environments ?? []));\n\t\t\t\t}\n\t\t\t\treturn envs;\n\t\t\t}\n\t\t}\n\t}\n}\n\nfunction cacheScope(scope: ResolveScope): string {\n\tswitch (scope.kind) {\n\t\tcase 'team':\n\t\t\treturn 'team';\n\t\tcase 'project':\n\t\tcase 'service':\n\t\tcase 'database':\n\t\tcase 'domain':\n\t\tcase 'environment':\n\t\t\treturn `${scope.kind}:${scope.teamId}`;\n\t\tcase 'deploy':\n\t\tcase 'volume':\n\t\tcase 'envVar':\n\t\tcase 'cronExecution':\n\t\t\treturn `${scope.kind}:${scope.teamId}:${scope.serviceId}`;\n\t}\n}\n","/**\n * Standard pagination parameters for list requests.\n */\nexport interface PaginationParams {\n\t/** Maximum number of items to return. */\n\tlimit?: number;\n\t/** Number of items to skip. */\n\toffset?: number;\n}\n\n/**\n * A paginated response wrapper.\n */\nexport interface PaginatedResponse<T> {\n\titems: T[];\n\ttotal: number;\n\tlimit: number;\n\toffset: number;\n\thasMore: boolean;\n}\n\n/**\n * Builds a query string from pagination params.\n * Returns an empty string if no params are set.\n */\nexport function buildPaginationQuery(params?: PaginationParams): string {\n\tif (!params) return '';\n\tconst qs = new URLSearchParams();\n\tif (params.limit !== undefined) qs.set('limit', String(params.limit));\n\tif (params.offset !== undefined) qs.set('offset', String(params.offset));\n\tconst str = qs.toString();\n\treturn str ? `?${str}` : '';\n}\n\n/**\n * Wraps a plain array result into a PaginatedResponse.\n * Useful when the API returns a flat array without pagination metadata.\n */\nexport function wrapArray<T>(\n\titems: T[],\n\tparams?: PaginationParams,\n): PaginatedResponse<T> {\n\tconst limit = params?.limit ?? items.length;\n\tconst offset = params?.offset ?? 0;\n\treturn {\n\t\titems,\n\t\ttotal: items.length,\n\t\tlimit,\n\t\toffset,\n\t\thasMore: false,\n\t};\n}\n"]}