@hoststack.dev/sdk 0.2.0 → 0.3.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/dist/index.cjs +88 -8
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +196 -26
- package/dist/index.d.ts +196 -26
- package/dist/index.js +88 -8
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
package/dist/index.cjs
CHANGED
|
@@ -129,11 +129,21 @@ var DeploysResource = class {
|
|
|
129
129
|
constructor(client) {
|
|
130
130
|
this.client = client;
|
|
131
131
|
}
|
|
132
|
-
/**
|
|
133
|
-
|
|
132
|
+
/**
|
|
133
|
+
* List deploys for a service. Paginated — pass `page` / `perPage` to walk
|
|
134
|
+
* pages. Default page=1, perPage=25, hard cap perPage=100.
|
|
135
|
+
*/
|
|
136
|
+
async list(teamId, serviceId, options) {
|
|
134
137
|
const tid = await this.client.resolveId(teamId, { kind: "team" });
|
|
135
138
|
const sid = await this.client.resolveId(serviceId, { kind: "service", teamId: tid });
|
|
136
|
-
|
|
139
|
+
const params = new URLSearchParams();
|
|
140
|
+
if (options?.page !== void 0) params.set("page", String(options.page));
|
|
141
|
+
if (options?.perPage !== void 0) params.set("perPage", String(options.perPage));
|
|
142
|
+
const qs = params.toString();
|
|
143
|
+
return this.client.request(
|
|
144
|
+
"GET",
|
|
145
|
+
`/api/services/${tid}/${sid}/deploys${qs ? `?${qs}` : ""}`
|
|
146
|
+
);
|
|
137
147
|
}
|
|
138
148
|
/** Get a single deploy by ID. */
|
|
139
149
|
async get(teamId, serviceId, deployId) {
|
|
@@ -174,8 +184,13 @@ var DeploysResource = class {
|
|
|
174
184
|
});
|
|
175
185
|
return this.client.request("POST", `/api/services/${tid}/${sid}/deploys/${did}/rollback`);
|
|
176
186
|
}
|
|
177
|
-
/**
|
|
178
|
-
|
|
187
|
+
/**
|
|
188
|
+
* Get build logs for a deploy.
|
|
189
|
+
*
|
|
190
|
+
* Pagination: pass `afterId` from the previous response's `nextAfterId`
|
|
191
|
+
* to fetch the next page. Per-call cap is 5000; default 500.
|
|
192
|
+
*/
|
|
193
|
+
async getLogs(teamId, serviceId, deployId, options) {
|
|
179
194
|
const tid = await this.client.resolveId(teamId, { kind: "team" });
|
|
180
195
|
const sid = await this.client.resolveId(serviceId, { kind: "service", teamId: tid });
|
|
181
196
|
const did = await this.client.resolveId(deployId, {
|
|
@@ -183,7 +198,15 @@ var DeploysResource = class {
|
|
|
183
198
|
teamId: tid,
|
|
184
199
|
serviceId: sid
|
|
185
200
|
});
|
|
186
|
-
|
|
201
|
+
const params = new URLSearchParams();
|
|
202
|
+
if (options?.search) params.set("search", options.search);
|
|
203
|
+
if (options?.level) params.set("level", options.level);
|
|
204
|
+
if (options?.phase) params.set("phase", options.phase);
|
|
205
|
+
if (options?.limit !== void 0) params.set("limit", String(options.limit));
|
|
206
|
+
if (options?.afterId !== void 0) params.set("afterId", String(options.afterId));
|
|
207
|
+
const qs = params.toString();
|
|
208
|
+
const url = `/api/services/${tid}/${sid}/deploys/${did}/logs${qs ? `?${qs}` : ""}`;
|
|
209
|
+
return this.client.request("GET", url);
|
|
187
210
|
}
|
|
188
211
|
};
|
|
189
212
|
|
|
@@ -462,6 +485,54 @@ var ServicesResource = class {
|
|
|
462
485
|
}
|
|
463
486
|
};
|
|
464
487
|
|
|
488
|
+
// src/resources/volumes.ts
|
|
489
|
+
var VolumesResource = class {
|
|
490
|
+
constructor(client) {
|
|
491
|
+
this.client = client;
|
|
492
|
+
}
|
|
493
|
+
/** List volumes attached to a service. */
|
|
494
|
+
async list(teamId, serviceId) {
|
|
495
|
+
const tid = await this.client.resolveId(teamId, { kind: "team" });
|
|
496
|
+
const sid = await this.client.resolveId(serviceId, { kind: "service", teamId: tid });
|
|
497
|
+
return this.client.request("GET", `/api/services/${tid}/${sid}/volumes`);
|
|
498
|
+
}
|
|
499
|
+
/** Attach a new volume to a service. Triggers provisioning on the host. */
|
|
500
|
+
async create(teamId, serviceId, data) {
|
|
501
|
+
const tid = await this.client.resolveId(teamId, { kind: "team" });
|
|
502
|
+
const sid = await this.client.resolveId(serviceId, { kind: "service", teamId: tid });
|
|
503
|
+
return this.client.request("POST", `/api/services/${tid}/${sid}/volumes`, data);
|
|
504
|
+
}
|
|
505
|
+
/**
|
|
506
|
+
* Update a volume's mountPath or sizeGb. Resizes that take effect on the
|
|
507
|
+
* next deploy; mountPath changes require a redeploy to remount.
|
|
508
|
+
*/
|
|
509
|
+
async update(teamId, serviceId, volumeId, data) {
|
|
510
|
+
const tid = await this.client.resolveId(teamId, { kind: "team" });
|
|
511
|
+
const sid = await this.client.resolveId(serviceId, { kind: "service", teamId: tid });
|
|
512
|
+
const vid = await this.client.resolveId(volumeId, {
|
|
513
|
+
kind: "volume",
|
|
514
|
+
teamId: tid,
|
|
515
|
+
serviceId: sid
|
|
516
|
+
});
|
|
517
|
+
return this.client.request("PATCH", `/api/services/${tid}/${sid}/volumes/${vid}`, data);
|
|
518
|
+
}
|
|
519
|
+
/**
|
|
520
|
+
* Detach and deprovision a volume. The underlying disk is destroyed —
|
|
521
|
+
* back up any data first. Async: the row is marked `deleting` and the
|
|
522
|
+
* agent finalises the removal once it acks.
|
|
523
|
+
*/
|
|
524
|
+
async delete(teamId, serviceId, volumeId) {
|
|
525
|
+
const tid = await this.client.resolveId(teamId, { kind: "team" });
|
|
526
|
+
const sid = await this.client.resolveId(serviceId, { kind: "service", teamId: tid });
|
|
527
|
+
const vid = await this.client.resolveId(volumeId, {
|
|
528
|
+
kind: "volume",
|
|
529
|
+
teamId: tid,
|
|
530
|
+
serviceId: sid
|
|
531
|
+
});
|
|
532
|
+
return this.client.request("DELETE", `/api/services/${tid}/${sid}/volumes/${vid}`);
|
|
533
|
+
}
|
|
534
|
+
};
|
|
535
|
+
|
|
465
536
|
// src/client.ts
|
|
466
537
|
var PREFIX = {
|
|
467
538
|
team: "team_",
|
|
@@ -470,6 +541,7 @@ var PREFIX = {
|
|
|
470
541
|
deploy: "dpl_",
|
|
471
542
|
database: "db_",
|
|
472
543
|
domain: "dom_",
|
|
544
|
+
volume: "vol_",
|
|
473
545
|
envVar: "env_",
|
|
474
546
|
cronExecution: "cjob_"
|
|
475
547
|
};
|
|
@@ -492,6 +564,8 @@ var HostStack = class {
|
|
|
492
564
|
envVars;
|
|
493
565
|
/** Manage cron job executions. */
|
|
494
566
|
cron;
|
|
567
|
+
/** Manage persistent disks attached to services. */
|
|
568
|
+
volumes;
|
|
495
569
|
constructor(options) {
|
|
496
570
|
if (!options.apiKey) {
|
|
497
571
|
throw new Error("apiKey is required");
|
|
@@ -505,6 +579,7 @@ var HostStack = class {
|
|
|
505
579
|
this.domains = new DomainsResource(this);
|
|
506
580
|
this.envVars = new EnvVarsResource(this);
|
|
507
581
|
this.cron = new CronResource(this);
|
|
582
|
+
this.volumes = new VolumesResource(this);
|
|
508
583
|
}
|
|
509
584
|
/**
|
|
510
585
|
* Make an authenticated request to the HostStack API.
|
|
@@ -598,9 +673,9 @@ var HostStack = class {
|
|
|
598
673
|
case "deploy": {
|
|
599
674
|
const r = await this.request(
|
|
600
675
|
"GET",
|
|
601
|
-
`/api/services/${scope.teamId}/${scope.serviceId}/deploys`
|
|
676
|
+
`/api/services/${scope.teamId}/${scope.serviceId}/deploys?perPage=100`
|
|
602
677
|
);
|
|
603
|
-
return r.
|
|
678
|
+
return r.data ?? [];
|
|
604
679
|
}
|
|
605
680
|
case "database": {
|
|
606
681
|
const r = await this.request(
|
|
@@ -623,6 +698,10 @@ var HostStack = class {
|
|
|
623
698
|
);
|
|
624
699
|
return r.envVars ?? [];
|
|
625
700
|
}
|
|
701
|
+
case "volume": {
|
|
702
|
+
const r = await this.request("GET", `/api/services/${scope.teamId}/${scope.serviceId}/volumes`);
|
|
703
|
+
return r.volumes ?? [];
|
|
704
|
+
}
|
|
626
705
|
case "cronExecution": {
|
|
627
706
|
const r = await this.request("GET", `/api/services/${scope.teamId}/${scope.serviceId}/cron-executions`);
|
|
628
707
|
return r.executions ?? [];
|
|
@@ -640,6 +719,7 @@ function cacheScope(scope) {
|
|
|
640
719
|
case "domain":
|
|
641
720
|
return `${scope.kind}:${scope.teamId}`;
|
|
642
721
|
case "deploy":
|
|
722
|
+
case "volume":
|
|
643
723
|
case "envVar":
|
|
644
724
|
case "cronExecution":
|
|
645
725
|
return `${scope.kind}:${scope.teamId}:${scope.serviceId}`;
|
package/dist/index.cjs.map
CHANGED
|
@@ -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 class DeploysResource {\n\tconstructor(private client: HostStack) {}\n\n\t/** List deploys for a service. */\n\tasync list(teamId: IdInput, serviceId: IdInput): Promise<{ deploys: 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('GET', `/api/services/${tid}/${sid}/deploys`);\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/** Get build logs for a deploy. */\n\tasync getLogs(\n\t\tteamId: IdInput,\n\t\tserviceId: IdInput,\n\t\tdeployId: IdInput,\n\t): Promise<{ logs: 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 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}/logs`);\n\t}\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\tconst r = await this.request<{ deploys: Array<{ id: number; publicId: string }> }>(\n\t\t\t\t\t'GET',\n\t\t\t\t\t`/api/services/${scope.teamId}/${scope.serviceId}/deploys`,\n\t\t\t\t);\n\t\t\t\treturn r.deploys ?? [];\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/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 * 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 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 { 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\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| { 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\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.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}\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 '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"]}
|