@treeseed/sdk 0.1.1

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.
Files changed (63) hide show
  1. package/README.md +565 -0
  2. package/dist/cli-tools.js +44 -0
  3. package/dist/content-store.js +237 -0
  4. package/dist/d1-store.js +549 -0
  5. package/dist/frontmatter.js +33 -0
  6. package/dist/git-runtime.js +67 -0
  7. package/dist/index.js +12 -0
  8. package/dist/model-registry.js +164 -0
  9. package/dist/runtime.js +36 -0
  10. package/dist/scripts/.ts-run-1775616845195-odh4xzphk3l.js +22 -0
  11. package/dist/scripts/.ts-run-1775616848931-9386s6kwrl.js +126 -0
  12. package/dist/scripts/assert-release-tag-version.d.ts +1 -0
  13. package/dist/scripts/assert-release-tag-version.js +23 -0
  14. package/dist/scripts/build-dist.d.ts +1 -0
  15. package/dist/scripts/build-dist.js +114 -0
  16. package/dist/scripts/package-tools.d.ts +15 -0
  17. package/dist/scripts/package-tools.js +76 -0
  18. package/dist/scripts/publish-package.d.ts +1 -0
  19. package/dist/scripts/publish-package.js +20 -0
  20. package/dist/scripts/release-verify.d.ts +1 -0
  21. package/dist/scripts/release-verify.js +49 -0
  22. package/dist/scripts/run-ts.js +45 -0
  23. package/dist/scripts/test-smoke.d.ts +1 -0
  24. package/dist/scripts/test-smoke.js +77 -0
  25. package/dist/sdk-filters.js +77 -0
  26. package/dist/sdk-types.js +24 -0
  27. package/dist/sdk.js +232 -0
  28. package/dist/src/cli-tools.d.ts +3 -0
  29. package/dist/src/content-store.d.ts +24 -0
  30. package/dist/src/d1-store.d.ts +108 -0
  31. package/dist/src/frontmatter.d.ts +6 -0
  32. package/dist/src/git-runtime.d.ts +16 -0
  33. package/dist/src/index.d.ts +6 -0
  34. package/dist/src/model-registry.d.ts +4 -0
  35. package/dist/src/runtime.d.ts +1 -0
  36. package/dist/src/sdk-filters.d.ts +4 -0
  37. package/dist/src/sdk-types.d.ts +285 -0
  38. package/dist/src/sdk.d.ts +109 -0
  39. package/dist/src/stores/cursor-store.d.ts +10 -0
  40. package/dist/src/stores/envelopes.d.ts +116 -0
  41. package/dist/src/stores/helpers.d.ts +12 -0
  42. package/dist/src/stores/lease-store.d.ts +18 -0
  43. package/dist/src/stores/message-store.d.ts +12 -0
  44. package/dist/src/stores/run-store.d.ts +10 -0
  45. package/dist/src/stores/subscription-store.d.ts +9 -0
  46. package/dist/src/types/agents.d.ts +100 -0
  47. package/dist/src/types/cloudflare.d.ts +32 -0
  48. package/dist/src/wrangler-d1.d.ts +25 -0
  49. package/dist/stores/cursor-store.js +158 -0
  50. package/dist/stores/envelopes.js +219 -0
  51. package/dist/stores/helpers.js +42 -0
  52. package/dist/stores/lease-store.js +183 -0
  53. package/dist/stores/message-store.js +249 -0
  54. package/dist/stores/run-store.js +166 -0
  55. package/dist/stores/subscription-store.js +171 -0
  56. package/dist/test/test-fixture.d.ts +1 -0
  57. package/dist/test/utils/envelopes.test.d.ts +1 -0
  58. package/dist/test/utils/sdk.test.d.ts +1 -0
  59. package/dist/types/agents.js +40 -0
  60. package/dist/types/cloudflare.js +0 -0
  61. package/dist/vitest.config.d.ts +2 -0
  62. package/dist/wrangler-d1.js +84 -0
  63. package/package.json +130 -0
@@ -0,0 +1,164 @@
1
+ import path from "node:path";
2
+ import { resolveSdkRepoRoot } from "./runtime.js";
3
+ function contentRoot() {
4
+ return process.env.TREESEED_AGENT_CONTENT_ROOT ? path.resolve(process.env.TREESEED_AGENT_CONTENT_ROOT) : path.resolve(resolveSdkRepoRoot(), "src", "content");
5
+ }
6
+ function buildModelRegistry() {
7
+ const root = contentRoot();
8
+ return {
9
+ page: {
10
+ name: "page",
11
+ aliases: ["pages"],
12
+ storage: "content",
13
+ operations: ["get", "read", "search", "follow", "pick", "create", "update"],
14
+ filterableFields: ["title", "slug", "status", "audience", "updated"],
15
+ sortableFields: ["title", "updated"],
16
+ pickField: "updated",
17
+ contentCollection: "pages",
18
+ contentDir: path.join(root, "pages")
19
+ },
20
+ note: {
21
+ name: "note",
22
+ aliases: ["notes"],
23
+ storage: "content",
24
+ operations: ["get", "read", "search", "follow", "pick", "create", "update"],
25
+ filterableFields: ["title", "status", "author", "tags", "date", "updated"],
26
+ sortableFields: ["title", "date", "updated"],
27
+ pickField: "date",
28
+ contentCollection: "notes",
29
+ contentDir: path.join(root, "notes")
30
+ },
31
+ question: {
32
+ name: "question",
33
+ aliases: ["questions"],
34
+ storage: "content",
35
+ operations: ["get", "read", "search", "follow", "pick", "create", "update"],
36
+ filterableFields: ["title", "status", "tags", "date", "questionType", "relatedObjectives", "relatedBooks"],
37
+ sortableFields: ["title", "date", "updated"],
38
+ pickField: "date",
39
+ contentCollection: "questions",
40
+ contentDir: path.join(root, "questions")
41
+ },
42
+ book: {
43
+ name: "book",
44
+ aliases: ["books"],
45
+ storage: "content",
46
+ operations: ["get", "read", "search", "follow", "pick", "create", "update"],
47
+ filterableFields: ["title", "slug", "tags", "sectionLabel"],
48
+ sortableFields: ["title", "order", "updated"],
49
+ pickField: "order",
50
+ contentCollection: "books",
51
+ contentDir: path.join(root, "books")
52
+ },
53
+ knowledge: {
54
+ name: "knowledge",
55
+ aliases: ["knowledge-base", "docs"],
56
+ storage: "content",
57
+ operations: ["get", "read", "search", "follow", "pick", "create", "update"],
58
+ filterableFields: ["title", "tags", "updated", "slug"],
59
+ sortableFields: ["title", "updated"],
60
+ pickField: "updated",
61
+ contentCollection: "docs",
62
+ contentDir: path.join(root, "knowledge")
63
+ },
64
+ objective: {
65
+ name: "objective",
66
+ aliases: ["objectives"],
67
+ storage: "content",
68
+ operations: ["get", "read", "search", "follow", "pick", "create", "update"],
69
+ filterableFields: ["title", "status", "tags", "date", "timeHorizon", "relatedQuestions", "relatedBooks"],
70
+ sortableFields: ["title", "date", "updated"],
71
+ pickField: "date",
72
+ contentCollection: "objectives",
73
+ contentDir: path.join(root, "objectives")
74
+ },
75
+ person: {
76
+ name: "person",
77
+ aliases: ["people", "persons"],
78
+ storage: "content",
79
+ operations: ["get", "read", "search", "follow", "pick", "create", "update"],
80
+ filterableFields: ["name", "role", "affiliation", "status", "tags"],
81
+ sortableFields: ["name", "updated"],
82
+ pickField: "updated",
83
+ contentCollection: "people",
84
+ contentDir: path.join(root, "people")
85
+ },
86
+ subscription: {
87
+ name: "subscription",
88
+ aliases: ["subscriptions", "subscriber", "subscribers"],
89
+ storage: "d1",
90
+ operations: ["get", "read", "search", "follow", "pick", "create", "update"],
91
+ filterableFields: ["email", "status", "source", "created_at", "updated_at"],
92
+ sortableFields: ["email", "created_at", "updated_at"],
93
+ pickField: "updated_at"
94
+ },
95
+ message: {
96
+ name: "message",
97
+ aliases: ["messages"],
98
+ storage: "d1",
99
+ operations: ["get", "read", "search", "follow", "pick", "create", "update"],
100
+ filterableFields: ["type", "status", "related_model", "related_id", "priority", "available_at"],
101
+ sortableFields: ["priority", "available_at", "created_at", "updated_at"],
102
+ pickField: "available_at"
103
+ },
104
+ agent: {
105
+ name: "agent",
106
+ aliases: ["agents"],
107
+ storage: "content",
108
+ operations: ["get", "read", "search", "follow", "pick", "create", "update"],
109
+ filterableFields: ["slug", "runtimeStatus", "tags", "operator"],
110
+ sortableFields: ["name", "slug", "updated"],
111
+ pickField: "updated",
112
+ contentCollection: "agents",
113
+ contentDir: path.join(root, "agents")
114
+ },
115
+ agent_run: {
116
+ name: "agent_run",
117
+ aliases: ["agent_runs", "run", "runs"],
118
+ storage: "d1",
119
+ operations: ["get", "read", "search", "follow", "create", "update"],
120
+ filterableFields: ["run_id", "agent_slug", "status", "started_at", "finished_at"],
121
+ sortableFields: ["started_at", "finished_at"],
122
+ pickField: "started_at"
123
+ },
124
+ agent_cursor: {
125
+ name: "agent_cursor",
126
+ aliases: ["agent_cursors", "cursor", "cursors"],
127
+ storage: "d1",
128
+ operations: ["get", "read", "search", "follow", "create", "update"],
129
+ filterableFields: ["agent_slug", "cursor_key", "cursor_value", "updated_at"],
130
+ sortableFields: ["updated_at", "agent_slug", "cursor_key"],
131
+ pickField: "updated_at"
132
+ },
133
+ content_lease: {
134
+ name: "content_lease",
135
+ aliases: ["content_leases", "lease", "leases"],
136
+ storage: "d1",
137
+ operations: ["get", "read", "search", "follow", "create", "update"],
138
+ filterableFields: ["model", "item_key", "claimed_by", "lease_expires_at"],
139
+ sortableFields: ["lease_expires_at", "claimed_at"],
140
+ pickField: "lease_expires_at"
141
+ }
142
+ };
143
+ }
144
+ const MODEL_REGISTRY = buildModelRegistry();
145
+ function resolveModelDefinition(model) {
146
+ const registry = buildModelRegistry();
147
+ const directMatch = registry[model];
148
+ if (directMatch) {
149
+ return directMatch;
150
+ }
151
+ const normalized = model.trim().toLowerCase();
152
+ const aliasMatch = Object.values(registry).find(
153
+ (definition) => definition.aliases.includes(normalized) || definition.name === normalized
154
+ );
155
+ if (!aliasMatch) {
156
+ throw new Error(`Unknown SDK model "${model}".`);
157
+ }
158
+ return aliasMatch;
159
+ }
160
+ export {
161
+ MODEL_REGISTRY,
162
+ buildModelRegistry,
163
+ resolveModelDefinition
164
+ };
@@ -0,0 +1,36 @@
1
+ import { existsSync } from "node:fs";
2
+ import path from "node:path";
3
+ function findContentRoot(start) {
4
+ let current = path.resolve(start);
5
+ for (; ; ) {
6
+ if (existsSync(path.join(current, "fixture", "src", "content"))) {
7
+ return path.join(current, "fixture");
8
+ }
9
+ if (existsSync(path.join(current, "src", "content"))) {
10
+ return current;
11
+ }
12
+ if (existsSync(path.join(current, "docs", "src", "content"))) {
13
+ return path.join(current, "docs");
14
+ }
15
+ const parent = path.dirname(current);
16
+ if (parent === current) {
17
+ return null;
18
+ }
19
+ current = parent;
20
+ }
21
+ }
22
+ function resolveSdkRepoRoot(repoRoot) {
23
+ if (repoRoot) {
24
+ return path.resolve(repoRoot);
25
+ }
26
+ if (process.env.TREESEED_SDK_CONTENT_ROOT) {
27
+ return path.resolve(process.env.TREESEED_SDK_CONTENT_ROOT);
28
+ }
29
+ if (process.env.TREESEED_SDK_REPO_ROOT) {
30
+ return path.resolve(process.env.TREESEED_SDK_REPO_ROOT);
31
+ }
32
+ return findContentRoot(process.cwd()) ?? process.cwd();
33
+ }
34
+ export {
35
+ resolveSdkRepoRoot
36
+ };
@@ -0,0 +1,22 @@
1
+ // scripts/publish-package.ts
2
+ import { spawnSync } from "node:child_process";
3
+ import { resolve } from "node:path";
4
+ import { fileURLToPath } from "node:url";
5
+ var packageRoot = resolve(fileURLToPath(new URL("..", import.meta.url)));
6
+ var extraArgs = process.argv.slice(2);
7
+ var npmArgs = ["publish", ".", "--access", "public"];
8
+ if (process.env.GITHUB_ACTIONS === "true") {
9
+ npmArgs.push("--provenance");
10
+ }
11
+ npmArgs.push(...extraArgs);
12
+ var result = spawnSync("npm", npmArgs, {
13
+ cwd: packageRoot,
14
+ stdio: "inherit",
15
+ env: process.env
16
+ });
17
+ if (result.error) {
18
+ console.error(result.error.message);
19
+ process.exit(1);
20
+ }
21
+ process.exit(result.status ?? 1);
22
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsicHVibGlzaC1wYWNrYWdlLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJpbXBvcnQgeyBzcGF3blN5bmMgfSBmcm9tICdub2RlOmNoaWxkX3Byb2Nlc3MnO1xuaW1wb3J0IHsgcmVzb2x2ZSB9IGZyb20gJ25vZGU6cGF0aCc7XG5pbXBvcnQgeyBmaWxlVVJMVG9QYXRoIH0gZnJvbSAnbm9kZTp1cmwnO1xuXG5jb25zdCBwYWNrYWdlUm9vdCA9IHJlc29sdmUoZmlsZVVSTFRvUGF0aChuZXcgVVJMKCcuLicsIGltcG9ydC5tZXRhLnVybCkpKTtcbmNvbnN0IGV4dHJhQXJncyA9IHByb2Nlc3MuYXJndi5zbGljZSgyKTtcblxuY29uc3QgbnBtQXJncyA9IFsncHVibGlzaCcsICcuJywgJy0tYWNjZXNzJywgJ3B1YmxpYyddO1xuXG5pZiAocHJvY2Vzcy5lbnYuR0lUSFVCX0FDVElPTlMgPT09ICd0cnVlJykge1xuXHRucG1BcmdzLnB1c2goJy0tcHJvdmVuYW5jZScpO1xufVxuXG5ucG1BcmdzLnB1c2goLi4uZXh0cmFBcmdzKTtcblxuY29uc3QgcmVzdWx0ID0gc3Bhd25TeW5jKCducG0nLCBucG1BcmdzLCB7XG5cdGN3ZDogcGFja2FnZVJvb3QsXG5cdHN0ZGlvOiAnaW5oZXJpdCcsXG5cdGVudjogcHJvY2Vzcy5lbnYsXG59KTtcblxuaWYgKHJlc3VsdC5lcnJvcikge1xuXHRjb25zb2xlLmVycm9yKHJlc3VsdC5lcnJvci5tZXNzYWdlKTtcblx0cHJvY2Vzcy5leGl0KDEpO1xufVxuXG5wcm9jZXNzLmV4aXQocmVzdWx0LnN0YXR1cyA/PyAxKTtcbiJdLAogICJtYXBwaW5ncyI6ICI7QUFBQSxTQUFTLGlCQUFpQjtBQUMxQixTQUFTLGVBQWU7QUFDeEIsU0FBUyxxQkFBcUI7QUFFOUIsSUFBTSxjQUFjLFFBQVEsY0FBYyxJQUFJLElBQUksTUFBTSxZQUFZLEdBQUcsQ0FBQyxDQUFDO0FBQ3pFLElBQU0sWUFBWSxRQUFRLEtBQUssTUFBTSxDQUFDO0FBRXRDLElBQU0sVUFBVSxDQUFDLFdBQVcsS0FBSyxZQUFZLFFBQVE7QUFFckQsSUFBSSxRQUFRLElBQUksbUJBQW1CLFFBQVE7QUFDMUMsVUFBUSxLQUFLLGNBQWM7QUFDNUI7QUFFQSxRQUFRLEtBQUssR0FBRyxTQUFTO0FBRXpCLElBQU0sU0FBUyxVQUFVLE9BQU8sU0FBUztBQUFBLEVBQ3hDLEtBQUs7QUFBQSxFQUNMLE9BQU87QUFBQSxFQUNQLEtBQUssUUFBUTtBQUNkLENBQUM7QUFFRCxJQUFJLE9BQU8sT0FBTztBQUNqQixVQUFRLE1BQU0sT0FBTyxNQUFNLE9BQU87QUFDbEMsVUFBUSxLQUFLLENBQUM7QUFDZjtBQUVBLFFBQVEsS0FBSyxPQUFPLFVBQVUsQ0FBQzsiLAogICJuYW1lcyI6IFtdCn0K
@@ -0,0 +1,126 @@
1
+ // scripts/build-dist.ts
2
+ import { copyFileSync, existsSync, mkdirSync, readdirSync, readFileSync, rmSync, writeFileSync } from "node:fs";
3
+ import { dirname as dirname2, extname as extname2, join, relative, resolve as resolve2 } from "node:path";
4
+ import { build } from "esbuild";
5
+ import ts from "typescript";
6
+
7
+ // scripts/package-tools.ts
8
+ import { dirname, extname, resolve } from "node:path";
9
+ import { fileURLToPath } from "node:url";
10
+ import { createRequire } from "node:module";
11
+ var require2 = createRequire(import.meta.url);
12
+ var scriptRoot = dirname(fileURLToPath(import.meta.url));
13
+ var packageCandidate = resolve(scriptRoot, "..");
14
+ var packageRoot = packageCandidate.endsWith("/dist") ? resolve(packageCandidate, "..") : packageCandidate;
15
+ var packageScriptRoot = packageCandidate.endsWith("/dist") ? resolve(packageCandidate, "scripts") : resolve(packageRoot, "scripts");
16
+
17
+ // scripts/build-dist.ts
18
+ var srcRoot = resolve2(packageRoot, "src");
19
+ var scriptsRoot = resolve2(packageRoot, "scripts");
20
+ var distRoot = resolve2(packageRoot, "dist");
21
+ var COPY_EXTENSIONS = /* @__PURE__ */ new Set([".d.js", ".json", ".md"]);
22
+ function walkFiles(root) {
23
+ const files = [];
24
+ for (const entry of readdirSync(root, { withFileTypes: true })) {
25
+ const fullPath = join(root, entry.name);
26
+ if (entry.isDirectory()) {
27
+ files.push(...walkFiles(fullPath));
28
+ continue;
29
+ }
30
+ files.push(fullPath);
31
+ }
32
+ return files;
33
+ }
34
+ function ensureDir(filePath) {
35
+ mkdirSync(dirname2(filePath), { recursive: true });
36
+ }
37
+ function rewriteRuntimeSpecifiers(contents) {
38
+ return contents.replace(/(['"`])(\.[^'"`\n]+)\.(mjs|ts)\1/g, "$1$2.js$1");
39
+ }
40
+ async function compileModule(filePath, sourceRoot, outputRoot) {
41
+ const relativePath = relative(sourceRoot, filePath);
42
+ const outputFile = resolve2(outputRoot, relativePath.replace(/\.(mjs|ts)$/u, ".js"));
43
+ ensureDir(outputFile);
44
+ await build({
45
+ entryPoints: [filePath],
46
+ outfile: outputFile,
47
+ platform: "node",
48
+ format: "esm",
49
+ bundle: false,
50
+ logLevel: "silent"
51
+ });
52
+ const builtSource = readFileSync(outputFile, "utf8");
53
+ writeFileSync(outputFile, rewriteRuntimeSpecifiers(builtSource), "utf8");
54
+ }
55
+ function copyAsset(filePath, sourceRoot, outputRoot) {
56
+ const outputFile = resolve2(outputRoot, relative(sourceRoot, filePath));
57
+ ensureDir(outputFile);
58
+ copyFileSync(filePath, outputFile);
59
+ if (outputFile.endsWith(".d.js")) {
60
+ const contents = readFileSync(outputFile, "utf8");
61
+ writeFileSync(outputFile, rewriteRuntimeSpecifiers(contents), "utf8");
62
+ }
63
+ }
64
+ function transpileScript(filePath) {
65
+ const source = readFileSync(filePath, "utf8");
66
+ const relativePath = relative(scriptsRoot, filePath);
67
+ const outputFile = resolve2(distRoot, "scripts", relativePath.replace(/\.(mjs|ts)$/u, ".js"));
68
+ const transformed = extname2(filePath) === ".ts" ? ts.transpileModule(source, {
69
+ compilerOptions: {
70
+ module: ts.ModuleKind.ESNext,
71
+ target: ts.ScriptTarget.ES2022
72
+ }
73
+ }).outputText : source;
74
+ ensureDir(outputFile);
75
+ writeFileSync(outputFile, rewriteRuntimeSpecifiers(transformed), "utf8");
76
+ }
77
+ function emitDeclarations() {
78
+ const configPath = ts.findConfigFile(packageRoot, ts.sys.fileExists, "tsconfig.json");
79
+ if (!configPath) {
80
+ throw new Error("Unable to locate tsconfig.json for declaration build.");
81
+ }
82
+ const configFile = ts.readConfigFile(configPath, ts.sys.readFile);
83
+ const parsed = ts.parseJsonConfigFileContent(configFile.config, ts.sys, packageRoot);
84
+ const program = ts.createProgram({
85
+ rootNames: parsed.fileNames,
86
+ options: {
87
+ ...parsed.options,
88
+ declaration: true,
89
+ emitDeclarationOnly: true,
90
+ declarationDir: distRoot,
91
+ noEmit: false
92
+ }
93
+ });
94
+ const result = program.emit();
95
+ if (result.emitSkipped) {
96
+ const diagnostics = ts.formatDiagnosticsWithColorAndContext(result.diagnostics, {
97
+ getCanonicalFileName: (fileName) => fileName,
98
+ getCurrentDirectory: () => process.cwd(),
99
+ getNewLine: () => "\n"
100
+ });
101
+ throw new Error(`Declaration build failed.
102
+ ${diagnostics}`);
103
+ }
104
+ }
105
+ rmSync(distRoot, { recursive: true, force: true });
106
+ for (const filePath of walkFiles(srcRoot)) {
107
+ const extension = extname2(filePath);
108
+ if (extension === ".ts") {
109
+ await compileModule(filePath, srcRoot, distRoot);
110
+ continue;
111
+ }
112
+ if (COPY_EXTENSIONS.has(extension)) {
113
+ copyAsset(filePath, srcRoot, distRoot);
114
+ }
115
+ }
116
+ for (const filePath of walkFiles(scriptsRoot)) {
117
+ const extension = extname2(filePath);
118
+ if (extension === ".ts" || extension === ".mjs") {
119
+ transpileScript(filePath);
120
+ }
121
+ }
122
+ emitDeclarations();
123
+ if (existsSync(resolve2(packageRoot, "README.md"))) {
124
+ copyFileSync(resolve2(packageRoot, "README.md"), resolve2(distRoot, "..", "README.md"));
125
+ }
126
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["build-dist.ts", "package-tools.ts"],
  "sourcesContent": ["import { copyFileSync, existsSync, mkdirSync, readdirSync, readFileSync, rmSync, writeFileSync } from 'node:fs';\nimport { dirname, extname, join, relative, resolve } from 'node:path';\nimport { build } from 'esbuild';\nimport ts from 'typescript';\nimport { packageRoot } from './package-tools.ts';\n\nconst srcRoot = resolve(packageRoot, 'src');\nconst scriptsRoot = resolve(packageRoot, 'scripts');\nconst distRoot = resolve(packageRoot, 'dist');\n\nconst COPY_EXTENSIONS = new Set(['.d.ts', '.json', '.md']);\n\nfunction walkFiles(root) {\n\tconst files = [];\n\tfor (const entry of readdirSync(root, { withFileTypes: true })) {\n\t\tconst fullPath = join(root, entry.name);\n\t\tif (entry.isDirectory()) {\n\t\t\tfiles.push(...walkFiles(fullPath));\n\t\t\tcontinue;\n\t\t}\n\t\tfiles.push(fullPath);\n\t}\n\treturn files;\n}\n\nfunction ensureDir(filePath) {\n\tmkdirSync(dirname(filePath), { recursive: true });\n}\n\nfunction rewriteRuntimeSpecifiers(contents) {\n\treturn contents.replace(/(['\"`])(\\.[^'\"`\\n]+)\\.(mjs|ts)\\1/g, '$1$2.js$1');\n}\n\nasync function compileModule(filePath, sourceRoot, outputRoot) {\n\tconst relativePath = relative(sourceRoot, filePath);\n\tconst outputFile = resolve(outputRoot, relativePath.replace(/\\.(mjs|ts)$/u, '.js'));\n\tensureDir(outputFile);\n\n\tawait build({\n\t\tentryPoints: [filePath],\n\t\toutfile: outputFile,\n\t\tplatform: 'node',\n\t\tformat: 'esm',\n\t\tbundle: false,\n\t\tlogLevel: 'silent',\n\t});\n\n\tconst builtSource = readFileSync(outputFile, 'utf8');\n\twriteFileSync(outputFile, rewriteRuntimeSpecifiers(builtSource), 'utf8');\n}\n\nfunction copyAsset(filePath, sourceRoot, outputRoot) {\n\tconst outputFile = resolve(outputRoot, relative(sourceRoot, filePath));\n\tensureDir(outputFile);\n\tcopyFileSync(filePath, outputFile);\n\n\tif (outputFile.endsWith('.d.ts')) {\n\t\tconst contents = readFileSync(outputFile, 'utf8');\n\t\twriteFileSync(outputFile, rewriteRuntimeSpecifiers(contents), 'utf8');\n\t}\n}\n\nfunction transpileScript(filePath) {\n\tconst source = readFileSync(filePath, 'utf8');\n\tconst relativePath = relative(scriptsRoot, filePath);\n\tconst outputFile = resolve(distRoot, 'scripts', relativePath.replace(/\\.(mjs|ts)$/u, '.js'));\n\tconst transformed = extname(filePath) === '.ts'\n\t\t? ts.transpileModule(source, {\n\t\t\t\tcompilerOptions: {\n\t\t\t\t\tmodule: ts.ModuleKind.ESNext,\n\t\t\t\t\ttarget: ts.ScriptTarget.ES2022,\n\t\t\t\t},\n\t\t\t}).outputText\n\t\t: source;\n\n\tensureDir(outputFile);\n\twriteFileSync(outputFile, rewriteRuntimeSpecifiers(transformed), 'utf8');\n}\n\nfunction emitDeclarations() {\n\tconst configPath = ts.findConfigFile(packageRoot, ts.sys.fileExists, 'tsconfig.json');\n\tif (!configPath) {\n\t\tthrow new Error('Unable to locate tsconfig.json for declaration build.');\n\t}\n\n\tconst configFile = ts.readConfigFile(configPath, ts.sys.readFile);\n\tconst parsed = ts.parseJsonConfigFileContent(configFile.config, ts.sys, packageRoot);\n\tconst program = ts.createProgram({\n\t\trootNames: parsed.fileNames,\n\t\toptions: {\n\t\t\t...parsed.options,\n\t\t\tdeclaration: true,\n\t\t\temitDeclarationOnly: true,\n\t\t\tdeclarationDir: distRoot,\n\t\t\tnoEmit: false,\n\t\t},\n\t});\n\n\tconst result = program.emit();\n\tif (result.emitSkipped) {\n\t\tconst diagnostics = ts.formatDiagnosticsWithColorAndContext(result.diagnostics, {\n\t\t\tgetCanonicalFileName: (fileName) => fileName,\n\t\t\tgetCurrentDirectory: () => process.cwd(),\n\t\t\tgetNewLine: () => '\\n',\n\t\t});\n\t\tthrow new Error(`Declaration build failed.\\n${diagnostics}`);\n\t}\n}\n\nrmSync(distRoot, { recursive: true, force: true });\n\nfor (const filePath of walkFiles(srcRoot)) {\n\tconst extension = extname(filePath);\n\tif (extension === '.ts') {\n\t\tawait compileModule(filePath, srcRoot, distRoot);\n\t\tcontinue;\n\t}\n\n\tif (COPY_EXTENSIONS.has(extension)) {\n\t\tcopyAsset(filePath, srcRoot, distRoot);\n\t}\n}\n\nfor (const filePath of walkFiles(scriptsRoot)) {\n\tconst extension = extname(filePath);\n\tif (extension === '.ts' || extension === '.mjs') {\n\t\ttranspileScript(filePath);\n\t}\n}\n\nemitDeclarations();\n\nif (existsSync(resolve(packageRoot, 'README.md'))) {\n\tcopyFileSync(resolve(packageRoot, 'README.md'), resolve(distRoot, '..', 'README.md'));\n}\n", "import { readFileSync } from 'node:fs';\nimport { existsSync } from 'node:fs';\nimport { dirname, extname, resolve } from 'node:path';\nimport { fileURLToPath } from 'node:url';\nimport { spawn, spawnSync } from 'node:child_process';\nimport { createRequire } from 'node:module';\n\nconst require = createRequire(import.meta.url);\nconst scriptRoot = dirname(fileURLToPath(import.meta.url));\nconst packageCandidate = resolve(scriptRoot, '..');\n\nexport const packageRoot = packageCandidate.endsWith('/dist')\n\t? resolve(packageCandidate, '..')\n\t: packageCandidate;\nexport const packageScriptRoot = packageCandidate.endsWith('/dist')\n\t? resolve(packageCandidate, 'scripts')\n\t: resolve(packageRoot, 'scripts');\n\nfunction resolvePackageBinary(packageName, binName = packageName) {\n\tconst packageJsonPath = require.resolve(`${packageName}/package.json`);\n\tconst packageJson = JSON.parse(readFileSync(packageJsonPath, 'utf8'));\n\tconst binField = packageJson.bin;\n\tconst relativePath =\n\t\ttypeof binField === 'string'\n\t\t\t? binField\n\t\t\t: binField?.[binName];\n\n\tif (!relativePath) {\n\t\tthrow new Error(`Unable to resolve binary \"${binName}\" from package \"${packageName}\".`);\n\t}\n\n\treturn resolve(dirname(packageJsonPath), relativePath);\n}\n\nexport function resolveAstroBin() {\n\treturn resolvePackageBinary('astro', 'astro');\n}\n\nexport function resolveWranglerBin() {\n\treturn resolvePackageBinary('wrangler', 'wrangler');\n}\n\nexport function createProductionBuildEnv(extraEnv = {}) {\n\treturn {\n\t\tTREESEED_LOCAL_DEV_MODE: 'cloudflare',\n\t\tTREESEED_PUBLIC_FORMS_LOCAL_BYPASS_TURNSTILE: '',\n\t\tTREESEED_FORMS_LOCAL_BYPASS_TURNSTILE: '',\n\t\tTREESEED_FORMS_LOCAL_BYPASS_CLOUDFLARE_GUARDS: '',\n\t\tTREESEED_PUBLIC_DEV_WATCH_RELOAD: '',\n\t\t...extraEnv,\n\t};\n}\n\nexport function packageScriptPath(scriptName) {\n\tif (extname(scriptName)) {\n\t\treturn resolve(packageScriptRoot, scriptName);\n\t}\n\n\tfor (const extension of ['.js', '.ts', '.mjs']) {\n\t\tconst candidate = resolve(packageScriptRoot, `${scriptName}${extension}`);\n\t\tif (existsSync(candidate)) {\n\t\t\treturn candidate;\n\t\t}\n\t}\n\n\tthrow new Error(`Unable to resolve package script \"${scriptName}\".`);\n}\n\nexport function runNodeBinary(binPath, args, options = {}) {\n\tconst result = spawnSync(process.execPath, [binPath, ...args], {\n\t\tstdio: options.stdio ?? 'inherit',\n\t\tcwd: options.cwd ?? process.cwd(),\n\t\tenv: { ...process.env, ...(options.env ?? {}) },\n\t});\n\n\tif (result.status !== 0) {\n\t\tprocess.exit(result.status ?? 1);\n\t}\n}\n\nexport function runNodeScript(scriptPath, args = [], options = {}) {\n\treturn runNodeBinary(scriptPath, args, options);\n}\n\nexport function spawnNodeBinary(binPath, args, options = {}) {\n\treturn spawn(process.execPath, [binPath, ...args], {\n\t\tstdio: options.stdio ?? 'inherit',\n\t\tcwd: options.cwd ?? process.cwd(),\n\t\tenv: { ...process.env, ...(options.env ?? {}) },\n\t\tdetached: options.detached ?? false,\n\t});\n}\n"],
  "mappings": "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",
  "names": ["dirname", "extname", "resolve", "require", "resolve", "dirname", "extname"]
}

@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,23 @@
1
+ import { readFileSync } from 'node:fs';
2
+ import { resolve } from 'node:path';
3
+ import { fileURLToPath } from 'node:url';
4
+ const semverTagPattern = /^\d+\.\d+\.\d+$/;
5
+ const packageRoot = resolve(fileURLToPath(new URL('..', import.meta.url)));
6
+ const packageJsonPath = resolve(packageRoot, 'package.json');
7
+ const packageJson = JSON.parse(readFileSync(packageJsonPath, 'utf8'));
8
+ const packageVersion = packageJson.version;
9
+ const tagName = process.argv[2] || process.env.GITHUB_REF_NAME;
10
+ if (!tagName) {
11
+ console.error('Release tag validation requires a tag name argument or GITHUB_REF_NAME.');
12
+ process.exit(1);
13
+ }
14
+ if (!semverTagPattern.test(tagName)) {
15
+ console.error(`Release tag "${tagName}" must use the "{MAJOR}.{MINOR}.{PATCH}" format, for example "${packageVersion}".`);
16
+ process.exit(1);
17
+ }
18
+ const taggedVersion = tagName;
19
+ if (taggedVersion !== packageVersion) {
20
+ console.error(`Release tag version "${taggedVersion}" does not match @treeseed/sdk version "${packageVersion}".`);
21
+ process.exit(1);
22
+ }
23
+ console.log(`Release tag "${tagName}" matches @treeseed/sdk version "${packageVersion}".`);
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,114 @@
1
+ import { copyFileSync, existsSync, mkdirSync, readdirSync, readFileSync, rmSync, writeFileSync } from 'node:fs';
2
+ import { dirname, extname, join, relative, resolve } from 'node:path';
3
+ import { build } from 'esbuild';
4
+ import ts from 'typescript';
5
+ import { packageRoot } from './package-tools.js';
6
+ const srcRoot = resolve(packageRoot, 'src');
7
+ const scriptsRoot = resolve(packageRoot, 'scripts');
8
+ const distRoot = resolve(packageRoot, 'dist');
9
+ const COPY_EXTENSIONS = new Set(['.d.js', '.json', '.md']);
10
+ function walkFiles(root) {
11
+ const files = [];
12
+ for (const entry of readdirSync(root, { withFileTypes: true })) {
13
+ const fullPath = join(root, entry.name);
14
+ if (entry.isDirectory()) {
15
+ files.push(...walkFiles(fullPath));
16
+ continue;
17
+ }
18
+ files.push(fullPath);
19
+ }
20
+ return files;
21
+ }
22
+ function ensureDir(filePath) {
23
+ mkdirSync(dirname(filePath), { recursive: true });
24
+ }
25
+ function rewriteRuntimeSpecifiers(contents) {
26
+ return contents.replace(/(['"`])(\.[^'"`\n]+)\.(mjs|ts)\1/g, '$1$2.js$1');
27
+ }
28
+ async function compileModule(filePath, sourceRoot, outputRoot) {
29
+ const relativePath = relative(sourceRoot, filePath);
30
+ const outputFile = resolve(outputRoot, relativePath.replace(/\.(mjs|ts)$/u, '.js'));
31
+ ensureDir(outputFile);
32
+ await build({
33
+ entryPoints: [filePath],
34
+ outfile: outputFile,
35
+ platform: 'node',
36
+ format: 'esm',
37
+ bundle: false,
38
+ logLevel: 'silent',
39
+ });
40
+ const builtSource = readFileSync(outputFile, 'utf8');
41
+ writeFileSync(outputFile, rewriteRuntimeSpecifiers(builtSource), 'utf8');
42
+ }
43
+ function copyAsset(filePath, sourceRoot, outputRoot) {
44
+ const outputFile = resolve(outputRoot, relative(sourceRoot, filePath));
45
+ ensureDir(outputFile);
46
+ copyFileSync(filePath, outputFile);
47
+ if (outputFile.endsWith('.d.js')) {
48
+ const contents = readFileSync(outputFile, 'utf8');
49
+ writeFileSync(outputFile, rewriteRuntimeSpecifiers(contents), 'utf8');
50
+ }
51
+ }
52
+ function transpileScript(filePath) {
53
+ const source = readFileSync(filePath, 'utf8');
54
+ const relativePath = relative(scriptsRoot, filePath);
55
+ const outputFile = resolve(distRoot, 'scripts', relativePath.replace(/\.(mjs|ts)$/u, '.js'));
56
+ const transformed = extname(filePath) === '.ts'
57
+ ? ts.transpileModule(source, {
58
+ compilerOptions: {
59
+ module: ts.ModuleKind.ESNext,
60
+ target: ts.ScriptTarget.ES2022,
61
+ },
62
+ }).outputText
63
+ : source;
64
+ ensureDir(outputFile);
65
+ writeFileSync(outputFile, rewriteRuntimeSpecifiers(transformed), 'utf8');
66
+ }
67
+ function emitDeclarations() {
68
+ const configPath = ts.findConfigFile(packageRoot, ts.sys.fileExists, 'tsconfig.json');
69
+ if (!configPath) {
70
+ throw new Error('Unable to locate tsconfig.json for declaration build.');
71
+ }
72
+ const configFile = ts.readConfigFile(configPath, ts.sys.readFile);
73
+ const parsed = ts.parseJsonConfigFileContent(configFile.config, ts.sys, packageRoot);
74
+ const program = ts.createProgram({
75
+ rootNames: parsed.fileNames,
76
+ options: {
77
+ ...parsed.options,
78
+ declaration: true,
79
+ emitDeclarationOnly: true,
80
+ declarationDir: distRoot,
81
+ noEmit: false,
82
+ },
83
+ });
84
+ const result = program.emit();
85
+ if (result.emitSkipped) {
86
+ const diagnostics = ts.formatDiagnosticsWithColorAndContext(result.diagnostics, {
87
+ getCanonicalFileName: (fileName) => fileName,
88
+ getCurrentDirectory: () => process.cwd(),
89
+ getNewLine: () => '\n',
90
+ });
91
+ throw new Error(`Declaration build failed.\n${diagnostics}`);
92
+ }
93
+ }
94
+ rmSync(distRoot, { recursive: true, force: true });
95
+ for (const filePath of walkFiles(srcRoot)) {
96
+ const extension = extname(filePath);
97
+ if (extension === '.ts') {
98
+ await compileModule(filePath, srcRoot, distRoot);
99
+ continue;
100
+ }
101
+ if (COPY_EXTENSIONS.has(extension)) {
102
+ copyAsset(filePath, srcRoot, distRoot);
103
+ }
104
+ }
105
+ for (const filePath of walkFiles(scriptsRoot)) {
106
+ const extension = extname(filePath);
107
+ if (extension === '.ts' || extension === '.mjs') {
108
+ transpileScript(filePath);
109
+ }
110
+ }
111
+ emitDeclarations();
112
+ if (existsSync(resolve(packageRoot, 'README.md'))) {
113
+ copyFileSync(resolve(packageRoot, 'README.md'), resolve(distRoot, '..', 'README.md'));
114
+ }
@@ -0,0 +1,15 @@
1
+ export declare const packageRoot: string;
2
+ export declare const packageScriptRoot: string;
3
+ export declare function resolveAstroBin(): string;
4
+ export declare function resolveWranglerBin(): string;
5
+ export declare function createProductionBuildEnv(extraEnv?: {}): {
6
+ TREESEED_LOCAL_DEV_MODE: string;
7
+ TREESEED_PUBLIC_FORMS_LOCAL_BYPASS_TURNSTILE: string;
8
+ TREESEED_FORMS_LOCAL_BYPASS_TURNSTILE: string;
9
+ TREESEED_FORMS_LOCAL_BYPASS_CLOUDFLARE_GUARDS: string;
10
+ TREESEED_PUBLIC_DEV_WATCH_RELOAD: string;
11
+ };
12
+ export declare function packageScriptPath(scriptName: any): string;
13
+ export declare function runNodeBinary(binPath: any, args: any, options?: {}): void;
14
+ export declare function runNodeScript(scriptPath: any, args?: never[], options?: {}): void;
15
+ export declare function spawnNodeBinary(binPath: any, args: any, options?: {}): import("child_process").ChildProcessWithoutNullStreams;
@@ -0,0 +1,76 @@
1
+ import { readFileSync } from 'node:fs';
2
+ import { existsSync } from 'node:fs';
3
+ import { dirname, extname, resolve } from 'node:path';
4
+ import { fileURLToPath } from 'node:url';
5
+ import { spawn, spawnSync } from 'node:child_process';
6
+ import { createRequire } from 'node:module';
7
+ const require = createRequire(import.meta.url);
8
+ const scriptRoot = dirname(fileURLToPath(import.meta.url));
9
+ const packageCandidate = resolve(scriptRoot, '..');
10
+ export const packageRoot = packageCandidate.endsWith('/dist')
11
+ ? resolve(packageCandidate, '..')
12
+ : packageCandidate;
13
+ export const packageScriptRoot = packageCandidate.endsWith('/dist')
14
+ ? resolve(packageCandidate, 'scripts')
15
+ : resolve(packageRoot, 'scripts');
16
+ function resolvePackageBinary(packageName, binName = packageName) {
17
+ const packageJsonPath = require.resolve(`${packageName}/package.json`);
18
+ const packageJson = JSON.parse(readFileSync(packageJsonPath, 'utf8'));
19
+ const binField = packageJson.bin;
20
+ const relativePath = typeof binField === 'string'
21
+ ? binField
22
+ : binField?.[binName];
23
+ if (!relativePath) {
24
+ throw new Error(`Unable to resolve binary "${binName}" from package "${packageName}".`);
25
+ }
26
+ return resolve(dirname(packageJsonPath), relativePath);
27
+ }
28
+ export function resolveAstroBin() {
29
+ return resolvePackageBinary('astro', 'astro');
30
+ }
31
+ export function resolveWranglerBin() {
32
+ return resolvePackageBinary('wrangler', 'wrangler');
33
+ }
34
+ export function createProductionBuildEnv(extraEnv = {}) {
35
+ return {
36
+ TREESEED_LOCAL_DEV_MODE: 'cloudflare',
37
+ TREESEED_PUBLIC_FORMS_LOCAL_BYPASS_TURNSTILE: '',
38
+ TREESEED_FORMS_LOCAL_BYPASS_TURNSTILE: '',
39
+ TREESEED_FORMS_LOCAL_BYPASS_CLOUDFLARE_GUARDS: '',
40
+ TREESEED_PUBLIC_DEV_WATCH_RELOAD: '',
41
+ ...extraEnv,
42
+ };
43
+ }
44
+ export function packageScriptPath(scriptName) {
45
+ if (extname(scriptName)) {
46
+ return resolve(packageScriptRoot, scriptName);
47
+ }
48
+ for (const extension of ['.js', '.ts', '.mjs']) {
49
+ const candidate = resolve(packageScriptRoot, `${scriptName}${extension}`);
50
+ if (existsSync(candidate)) {
51
+ return candidate;
52
+ }
53
+ }
54
+ throw new Error(`Unable to resolve package script "${scriptName}".`);
55
+ }
56
+ export function runNodeBinary(binPath, args, options = {}) {
57
+ const result = spawnSync(process.execPath, [binPath, ...args], {
58
+ stdio: options.stdio ?? 'inherit',
59
+ cwd: options.cwd ?? process.cwd(),
60
+ env: { ...process.env, ...(options.env ?? {}) },
61
+ });
62
+ if (result.status !== 0) {
63
+ process.exit(result.status ?? 1);
64
+ }
65
+ }
66
+ export function runNodeScript(scriptPath, args = [], options = {}) {
67
+ return runNodeBinary(scriptPath, args, options);
68
+ }
69
+ export function spawnNodeBinary(binPath, args, options = {}) {
70
+ return spawn(process.execPath, [binPath, ...args], {
71
+ stdio: options.stdio ?? 'inherit',
72
+ cwd: options.cwd ?? process.cwd(),
73
+ env: { ...process.env, ...(options.env ?? {}) },
74
+ detached: options.detached ?? false,
75
+ });
76
+ }
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,20 @@
1
+ import { spawnSync } from 'node:child_process';
2
+ import { resolve } from 'node:path';
3
+ import { fileURLToPath } from 'node:url';
4
+ const packageRoot = resolve(fileURLToPath(new URL('..', import.meta.url)));
5
+ const extraArgs = process.argv.slice(2);
6
+ const npmArgs = ['publish', '.', '--access', 'public'];
7
+ if (process.env.GITHUB_ACTIONS === 'true') {
8
+ npmArgs.push('--provenance');
9
+ }
10
+ npmArgs.push(...extraArgs);
11
+ const result = spawnSync('npm', npmArgs, {
12
+ cwd: packageRoot,
13
+ stdio: 'inherit',
14
+ env: process.env,
15
+ });
16
+ if (result.error) {
17
+ console.error(result.error.message);
18
+ process.exit(1);
19
+ }
20
+ process.exit(result.status ?? 1);
@@ -0,0 +1 @@
1
+ export {};