@treeseed/sdk 0.1.1 → 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +20 -8
- package/dist/runtime.js +37 -3
- package/dist/scripts/.ts-run-1775630388025-vnjle0z75a.js +129 -0
- package/dist/scripts/build-dist.js +3 -0
- package/dist/scripts/fixture-tools.d.ts +5 -0
- package/dist/scripts/release-verify.js +1 -0
- package/package.json +3 -1
- package/dist/scripts/.ts-run-1775616848931-9386s6kwrl.js +0 -126
- /package/dist/scripts/{.ts-run-1775616845195-odh4xzphk3l.js → .ts-run-1775630384291-crtqr3izsa.js} +0 -0
package/README.md
CHANGED
|
@@ -354,8 +354,8 @@ You can see that usage in:
|
|
|
354
354
|
|
|
355
355
|
- [`agent/src/agents/kernel/agent-kernel.ts`](/home/adrian/Projects/treeseed/agent/src/agents/kernel/agent-kernel.ts)
|
|
356
356
|
- [`agent/src/agents/kernel/trigger-resolver.ts`](/home/adrian/Projects/treeseed/agent/src/agents/kernel/trigger-resolver.ts)
|
|
357
|
-
- [`
|
|
358
|
-
- [`
|
|
357
|
+
- [`planner.ts`](/home/adrian/Projects/treeseed/core/.fixtures/treeseed-fixtures/sites/working-site/src/agents/planner.ts)
|
|
358
|
+
- [`notifier.ts`](/home/adrian/Projects/treeseed/core/.fixtures/treeseed-fixtures/sites/working-site/src/agents/notifier.ts)
|
|
359
359
|
|
|
360
360
|
Conceptually, `agent_cursor` is the answer to: "Where should this agent continue from next time?"
|
|
361
361
|
|
|
@@ -508,7 +508,7 @@ Content-backed operations need a repository root that contains `src/content`.
|
|
|
508
508
|
3. `TREESEED_SDK_REPO_ROOT`
|
|
509
509
|
4. auto-detection from the current working directory
|
|
510
510
|
|
|
511
|
-
For
|
|
511
|
+
For fixture-driven development, the SDK also recognizes the shared submodule fixture at `.fixtures/treeseed-fixtures/sites/working-site`.
|
|
512
512
|
|
|
513
513
|
Example with an explicit root:
|
|
514
514
|
|
|
@@ -522,6 +522,12 @@ const sdk = new AgentSdk({
|
|
|
522
522
|
|
|
523
523
|
## Local Development
|
|
524
524
|
|
|
525
|
+
Initialize the shared fixtures submodule before running fixture-backed tests:
|
|
526
|
+
|
|
527
|
+
```bash
|
|
528
|
+
git submodule update --init --recursive
|
|
529
|
+
```
|
|
530
|
+
|
|
525
531
|
```bash
|
|
526
532
|
npm ci
|
|
527
533
|
npm run build
|
|
@@ -539,9 +545,7 @@ What each command does:
|
|
|
539
545
|
|
|
540
546
|
## Sample Fixture Site
|
|
541
547
|
|
|
542
|
-
The canonical
|
|
543
|
-
|
|
544
|
-
The SDK package also keeps a mirrored local fixture at `sdk/fixture` so the standalone SDK repository can run its own tests and CI without depending on the larger workspace layout.
|
|
548
|
+
The canonical shared fixture lives in the pinned `treeseed-fixtures` submodule at `.fixtures/treeseed-fixtures/sites/working-site`.
|
|
545
549
|
|
|
546
550
|
It serves three purposes at once:
|
|
547
551
|
|
|
@@ -556,10 +560,18 @@ import path from 'node:path';
|
|
|
556
560
|
import { AgentSdk } from '@treeseed/sdk';
|
|
557
561
|
|
|
558
562
|
const sdk = new AgentSdk({
|
|
559
|
-
repoRoot: path.resolve('
|
|
563
|
+
repoRoot: path.resolve('.fixtures/treeseed-fixtures/sites/working-site'),
|
|
560
564
|
});
|
|
561
565
|
```
|
|
562
566
|
|
|
563
567
|
The fixture includes representative entries for pages, notes, questions, objectives, books, knowledge, people, and agents so local queries behave like a small real site instead of a synthetic stub.
|
|
564
568
|
|
|
565
|
-
|
|
569
|
+
Shared fixture commands:
|
|
570
|
+
|
|
571
|
+
```bash
|
|
572
|
+
npm run fixtures:resolve
|
|
573
|
+
npm run fixtures:check
|
|
574
|
+
```
|
|
575
|
+
|
|
576
|
+
- `fixtures:resolve`: prints the active shared fixture root
|
|
577
|
+
- `fixtures:check`: verifies that the pinned shared fixture is initialized and usable
|
package/dist/runtime.js
CHANGED
|
@@ -1,10 +1,44 @@
|
|
|
1
|
-
import { existsSync } from "node:fs";
|
|
1
|
+
import { existsSync, readFileSync, readdirSync } from "node:fs";
|
|
2
2
|
import path from "node:path";
|
|
3
|
+
const DEFAULT_FIXTURE_ID = "treeseed-working-site";
|
|
4
|
+
function resolveSharedFixtureRoot(start) {
|
|
5
|
+
const fixturesRoot = process.env.TREESEED_FIXTURES_ROOT ? path.resolve(process.env.TREESEED_FIXTURES_ROOT) : path.join(start, ".fixtures", "treeseed-fixtures");
|
|
6
|
+
const requestedFixtureId = process.env.TREESEED_FIXTURE_ID?.trim() || DEFAULT_FIXTURE_ID;
|
|
7
|
+
const directRoot = path.join(fixturesRoot, "sites", "working-site");
|
|
8
|
+
const directManifestPath = path.join(directRoot, "fixture.manifest.json");
|
|
9
|
+
if (existsSync(path.join(directRoot, "src", "content")) && existsSync(directManifestPath)) {
|
|
10
|
+
return directRoot;
|
|
11
|
+
}
|
|
12
|
+
const sitesRoot = path.join(fixturesRoot, "sites");
|
|
13
|
+
if (!existsSync(sitesRoot)) {
|
|
14
|
+
return null;
|
|
15
|
+
}
|
|
16
|
+
for (const entry of readdirSync(sitesRoot, { withFileTypes: true }).filter((item) => item.isDirectory()).map((item) => item.name)) {
|
|
17
|
+
const fixtureRoot = path.join(sitesRoot, entry);
|
|
18
|
+
const manifestPath = path.join(fixtureRoot, "fixture.manifest.json");
|
|
19
|
+
if (!existsSync(manifestPath)) {
|
|
20
|
+
continue;
|
|
21
|
+
}
|
|
22
|
+
try {
|
|
23
|
+
const manifest = JSON.parse(readFileSync(manifestPath, "utf8"));
|
|
24
|
+
if (manifest.id === requestedFixtureId) {
|
|
25
|
+
const root = path.resolve(fixtureRoot, manifest.root ?? ".");
|
|
26
|
+
if (existsSync(path.join(root, "src", "content"))) {
|
|
27
|
+
return root;
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
} catch {
|
|
31
|
+
continue;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
return null;
|
|
35
|
+
}
|
|
3
36
|
function findContentRoot(start) {
|
|
4
37
|
let current = path.resolve(start);
|
|
5
38
|
for (; ; ) {
|
|
6
|
-
|
|
7
|
-
|
|
39
|
+
const sharedFixtureRoot = resolveSharedFixtureRoot(current);
|
|
40
|
+
if (sharedFixtureRoot) {
|
|
41
|
+
return sharedFixtureRoot;
|
|
8
42
|
}
|
|
9
43
|
if (existsSync(path.join(current, "src", "content"))) {
|
|
10
44
|
return current;
|
|
@@ -0,0 +1,129 @@
|
|
|
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
|
+
if (relativePath === "fixture-tools.ts") {
|
|
68
|
+
return;
|
|
69
|
+
}
|
|
70
|
+
const outputFile = resolve2(distRoot, "scripts", relativePath.replace(/\.(mjs|ts)$/u, ".js"));
|
|
71
|
+
const transformed = extname2(filePath) === ".ts" ? ts.transpileModule(source, {
|
|
72
|
+
compilerOptions: {
|
|
73
|
+
module: ts.ModuleKind.ESNext,
|
|
74
|
+
target: ts.ScriptTarget.ES2022
|
|
75
|
+
}
|
|
76
|
+
}).outputText : source;
|
|
77
|
+
ensureDir(outputFile);
|
|
78
|
+
writeFileSync(outputFile, rewriteRuntimeSpecifiers(transformed), "utf8");
|
|
79
|
+
}
|
|
80
|
+
function emitDeclarations() {
|
|
81
|
+
const configPath = ts.findConfigFile(packageRoot, ts.sys.fileExists, "tsconfig.json");
|
|
82
|
+
if (!configPath) {
|
|
83
|
+
throw new Error("Unable to locate tsconfig.json for declaration build.");
|
|
84
|
+
}
|
|
85
|
+
const configFile = ts.readConfigFile(configPath, ts.sys.readFile);
|
|
86
|
+
const parsed = ts.parseJsonConfigFileContent(configFile.config, ts.sys, packageRoot);
|
|
87
|
+
const program = ts.createProgram({
|
|
88
|
+
rootNames: parsed.fileNames,
|
|
89
|
+
options: {
|
|
90
|
+
...parsed.options,
|
|
91
|
+
declaration: true,
|
|
92
|
+
emitDeclarationOnly: true,
|
|
93
|
+
declarationDir: distRoot,
|
|
94
|
+
noEmit: false
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
const result = program.emit();
|
|
98
|
+
if (result.emitSkipped) {
|
|
99
|
+
const diagnostics = ts.formatDiagnosticsWithColorAndContext(result.diagnostics, {
|
|
100
|
+
getCanonicalFileName: (fileName) => fileName,
|
|
101
|
+
getCurrentDirectory: () => process.cwd(),
|
|
102
|
+
getNewLine: () => "\n"
|
|
103
|
+
});
|
|
104
|
+
throw new Error(`Declaration build failed.
|
|
105
|
+
${diagnostics}`);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
rmSync(distRoot, { recursive: true, force: true });
|
|
109
|
+
for (const filePath of walkFiles(srcRoot)) {
|
|
110
|
+
const extension = extname2(filePath);
|
|
111
|
+
if (extension === ".ts") {
|
|
112
|
+
await compileModule(filePath, srcRoot, distRoot);
|
|
113
|
+
continue;
|
|
114
|
+
}
|
|
115
|
+
if (COPY_EXTENSIONS.has(extension)) {
|
|
116
|
+
copyAsset(filePath, srcRoot, distRoot);
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
for (const filePath of walkFiles(scriptsRoot)) {
|
|
120
|
+
const extension = extname2(filePath);
|
|
121
|
+
if (extension === ".ts" || extension === ".mjs") {
|
|
122
|
+
transpileScript(filePath);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
emitDeclarations();
|
|
126
|
+
if (existsSync(resolve2(packageRoot, "README.md"))) {
|
|
127
|
+
copyFileSync(resolve2(packageRoot, "README.md"), resolve2(distRoot, "..", "README.md"));
|
|
128
|
+
}
|
|
129
|
+
//# 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\tif (relativePath === 'fixture-tools.ts') {\n\t\treturn;\n\t}\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"]
}

|
|
@@ -52,6 +52,9 @@ function copyAsset(filePath, sourceRoot, outputRoot) {
|
|
|
52
52
|
function transpileScript(filePath) {
|
|
53
53
|
const source = readFileSync(filePath, 'utf8');
|
|
54
54
|
const relativePath = relative(scriptsRoot, filePath);
|
|
55
|
+
if (relativePath === 'fixture-tools.ts') {
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
55
58
|
const outputFile = resolve(distRoot, 'scripts', relativePath.replace(/\.(mjs|ts)$/u, '.js'));
|
|
56
59
|
const transformed = extname(filePath) === '.ts'
|
|
57
60
|
? ts.transpileModule(source, {
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export declare const DEFAULT_FIXTURE_ID = "treeseed-working-site";
|
|
2
|
+
export declare function resolveFixturesRepoRoot(): string;
|
|
3
|
+
export declare function resolveSharedFixtureRoot(): string | null;
|
|
4
|
+
export declare function requireSharedFixtureRoot(): string;
|
|
5
|
+
export declare function checkSharedFixture(): string;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@treeseed/sdk",
|
|
3
|
-
"version": "0.1.
|
|
3
|
+
"version": "0.1.2",
|
|
4
4
|
"description": "Shared Treeseed SDK for content-backed and D1-backed object models.",
|
|
5
5
|
"license": "AGPL-3.0-only",
|
|
6
6
|
"repository": {
|
|
@@ -34,6 +34,8 @@
|
|
|
34
34
|
"test": "npm run test:unit",
|
|
35
35
|
"test:unit": "vitest run --config ./vitest.config.ts",
|
|
36
36
|
"test:smoke": "node ./scripts/run-ts.mjs ./scripts/test-smoke.ts",
|
|
37
|
+
"fixtures:resolve": "node ./scripts/run-ts.mjs ./scripts/fixture-tools.ts resolve",
|
|
38
|
+
"fixtures:check": "node ./scripts/run-ts.mjs ./scripts/fixture-tools.ts check",
|
|
37
39
|
"verify": "npm run release:verify",
|
|
38
40
|
"release:setup": "npm run setup:ci",
|
|
39
41
|
"release:check-tag": "node ./scripts/run-ts.mjs ./scripts/assert-release-tag-version.ts",
|
|
@@ -1,126 +0,0 @@
|
|
|
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"]
}

|
/package/dist/scripts/{.ts-run-1775616845195-odh4xzphk3l.js → .ts-run-1775630384291-crtqr3izsa.js}
RENAMED
|
File without changes
|