fastscript 0.1.1 → 2.0.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/CHANGELOG.md +31 -2
- package/LICENSE +33 -21
- package/README.md +568 -59
- package/node_modules/@fastscript/core-private/BOUNDARY.json +15 -0
- package/node_modules/@fastscript/core-private/README.md +5 -0
- package/node_modules/@fastscript/core-private/package.json +34 -0
- package/node_modules/@fastscript/core-private/src/asset-optimizer.mjs +67 -0
- package/node_modules/@fastscript/core-private/src/audit-log.mjs +50 -0
- package/node_modules/@fastscript/core-private/src/auth-flows.mjs +29 -0
- package/node_modules/@fastscript/core-private/src/auth.mjs +115 -0
- package/node_modules/@fastscript/core-private/src/bench.mjs +45 -0
- package/node_modules/@fastscript/core-private/src/build.mjs +670 -0
- package/node_modules/@fastscript/core-private/src/cache.mjs +248 -0
- package/node_modules/@fastscript/core-private/src/check.mjs +22 -0
- package/node_modules/@fastscript/core-private/src/cli.mjs +95 -0
- package/node_modules/@fastscript/core-private/src/compat.mjs +128 -0
- package/node_modules/@fastscript/core-private/src/create.mjs +278 -0
- package/node_modules/@fastscript/core-private/src/csp.mjs +26 -0
- package/node_modules/@fastscript/core-private/src/db-cli.mjs +185 -0
- package/node_modules/@fastscript/core-private/src/db-postgres-collection.mjs +110 -0
- package/node_modules/@fastscript/core-private/src/db-postgres.mjs +40 -0
- package/node_modules/@fastscript/core-private/src/db.mjs +103 -0
- package/node_modules/@fastscript/core-private/src/deploy.mjs +662 -0
- package/node_modules/@fastscript/core-private/src/dev.mjs +5 -0
- package/node_modules/@fastscript/core-private/src/docs-search.mjs +35 -0
- package/node_modules/@fastscript/core-private/src/env.mjs +118 -0
- package/node_modules/@fastscript/core-private/src/export.mjs +83 -0
- package/node_modules/@fastscript/core-private/src/fs-diagnostics.mjs +70 -0
- package/node_modules/@fastscript/core-private/src/fs-error-codes.mjs +141 -0
- package/node_modules/@fastscript/core-private/src/fs-formatter.mjs +66 -0
- package/node_modules/@fastscript/core-private/src/fs-linter.mjs +274 -0
- package/node_modules/@fastscript/core-private/src/fs-normalize.mjs +91 -0
- package/node_modules/@fastscript/core-private/src/fs-parser.mjs +980 -0
- package/node_modules/@fastscript/core-private/src/generated/docs-search-index.mjs +3182 -0
- package/node_modules/@fastscript/core-private/src/i18n.mjs +25 -0
- package/node_modules/@fastscript/core-private/src/interop.mjs +16 -0
- package/node_modules/@fastscript/core-private/src/jobs.mjs +378 -0
- package/node_modules/@fastscript/core-private/src/logger.mjs +27 -0
- package/node_modules/@fastscript/core-private/src/metrics.mjs +45 -0
- package/node_modules/@fastscript/core-private/src/middleware.mjs +14 -0
- package/node_modules/@fastscript/core-private/src/migrate.mjs +81 -0
- package/node_modules/@fastscript/core-private/src/migration-wizard.mjs +16 -0
- package/node_modules/@fastscript/core-private/src/module-loader.mjs +46 -0
- package/node_modules/@fastscript/core-private/src/oauth-providers.mjs +103 -0
- package/node_modules/@fastscript/core-private/src/observability.mjs +21 -0
- package/node_modules/@fastscript/core-private/src/plugins.mjs +194 -0
- package/node_modules/@fastscript/core-private/src/retention.mjs +57 -0
- package/node_modules/@fastscript/core-private/src/routes.mjs +178 -0
- package/node_modules/@fastscript/core-private/src/scheduler.mjs +104 -0
- package/node_modules/@fastscript/core-private/src/security.mjs +233 -0
- package/node_modules/@fastscript/core-private/src/server-runtime.mjs +849 -0
- package/node_modules/@fastscript/core-private/src/serverless-handler.mjs +20 -0
- package/node_modules/@fastscript/core-private/src/session-policy.mjs +38 -0
- package/node_modules/@fastscript/core-private/src/start.mjs +10 -0
- package/node_modules/@fastscript/core-private/src/storage.mjs +155 -0
- package/node_modules/@fastscript/core-private/src/style-primitives.mjs +538 -0
- package/node_modules/@fastscript/core-private/src/style-system.mjs +461 -0
- package/node_modules/@fastscript/core-private/src/tenant.mjs +55 -0
- package/node_modules/@fastscript/core-private/src/typecheck.mjs +1464 -0
- package/node_modules/@fastscript/core-private/src/validate.mjs +22 -0
- package/node_modules/@fastscript/core-private/src/validation.mjs +88 -0
- package/node_modules/@fastscript/core-private/src/webhook.mjs +81 -0
- package/node_modules/@fastscript/core-private/src/worker.mjs +24 -0
- package/package.json +88 -8
- package/src/asset-optimizer.mjs +67 -0
- package/src/audit-log.mjs +50 -0
- package/src/auth.mjs +1 -115
- package/src/bench.mjs +20 -7
- package/src/build.mjs +1 -222
- package/src/cache.mjs +210 -20
- package/src/cli.mjs +29 -5
- package/src/compat.mjs +7 -1
- package/src/create.mjs +65 -11
- package/src/csp.mjs +26 -0
- package/src/db-cli.mjs +158 -18
- package/src/db-postgres-collection.mjs +110 -0
- package/src/deploy.mjs +1 -65
- package/src/docs-search.mjs +35 -0
- package/src/env.mjs +34 -5
- package/src/fs-diagnostics.mjs +70 -0
- package/src/fs-error-codes.mjs +126 -0
- package/src/fs-formatter.mjs +66 -0
- package/src/fs-linter.mjs +274 -0
- package/src/fs-normalize.mjs +17 -26
- package/src/fs-parser.mjs +1 -0
- package/src/generated/docs-search-index.mjs +3220 -0
- package/src/i18n.mjs +25 -0
- package/src/jobs.mjs +283 -32
- package/src/metrics.mjs +45 -0
- package/src/migration-wizard.mjs +16 -0
- package/src/module-loader.mjs +46 -0
- package/src/oauth-providers.mjs +103 -0
- package/src/plugins.mjs +194 -0
- package/src/retention.mjs +57 -0
- package/src/routes.mjs +178 -0
- package/src/scheduler.mjs +104 -0
- package/src/security.mjs +197 -19
- package/src/server-runtime.mjs +1 -339
- package/src/serverless-handler.mjs +20 -0
- package/src/session-policy.mjs +38 -0
- package/src/storage.mjs +1 -56
- package/src/style-system.mjs +461 -0
- package/src/tenant.mjs +55 -0
- package/src/typecheck.mjs +1 -0
- package/src/validate.mjs +5 -1
- package/src/validation.mjs +14 -5
- package/src/webhook.mjs +1 -71
- package/src/worker.mjs +23 -4
package/src/webhook.mjs
CHANGED
|
@@ -1,71 +1 @@
|
|
|
1
|
-
|
|
2
|
-
import { existsSync, mkdirSync, readFileSync, writeFileSync } from "node:fs";
|
|
3
|
-
import { join, resolve } from "node:path";
|
|
4
|
-
|
|
5
|
-
export async function readRawBody(req) {
|
|
6
|
-
const chunks = [];
|
|
7
|
-
for await (const chunk of req) chunks.push(Buffer.from(chunk));
|
|
8
|
-
return Buffer.concat(chunks);
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
export function signPayload(payload, secret, algo = "sha256") {
|
|
12
|
-
const mac = createHmac(algo, secret).update(payload).digest("hex");
|
|
13
|
-
return `${algo}=${mac}`;
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
export function verifySignature(payload, header, secret, algo = "sha256") {
|
|
17
|
-
if (!header || typeof header !== "string") return false;
|
|
18
|
-
const expected = signPayload(payload, secret, algo);
|
|
19
|
-
const a = Buffer.from(expected);
|
|
20
|
-
const b = Buffer.from(header);
|
|
21
|
-
if (a.length !== b.length) return false;
|
|
22
|
-
return timingSafeEqual(a, b);
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
export function isReplay(tsSeconds, maxSkewSec = 300) {
|
|
26
|
-
const ts = Number(tsSeconds);
|
|
27
|
-
if (!Number.isFinite(ts)) return true;
|
|
28
|
-
const now = Math.floor(Date.now() / 1000);
|
|
29
|
-
return Math.abs(now - ts) > maxSkewSec;
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
function replayStore({ dir = ".fastscript", ttlSec = 600 } = {}) {
|
|
33
|
-
const root = resolve(dir);
|
|
34
|
-
mkdirSync(root, { recursive: true });
|
|
35
|
-
const file = join(root, "webhook-replay.json");
|
|
36
|
-
let state = { seen: {} };
|
|
37
|
-
if (existsSync(file)) {
|
|
38
|
-
try { state = JSON.parse(readFileSync(file, "utf8")); } catch {}
|
|
39
|
-
}
|
|
40
|
-
function persist() {
|
|
41
|
-
writeFileSync(file, JSON.stringify(state, null, 2), "utf8");
|
|
42
|
-
}
|
|
43
|
-
return {
|
|
44
|
-
has(id) {
|
|
45
|
-
const now = Date.now();
|
|
46
|
-
for (const [k, exp] of Object.entries(state.seen)) if (exp < now) delete state.seen[k];
|
|
47
|
-
persist();
|
|
48
|
-
return Boolean(state.seen[id]);
|
|
49
|
-
},
|
|
50
|
-
add(id) {
|
|
51
|
-
state.seen[id] = Date.now() + ttlSec * 1000;
|
|
52
|
-
persist();
|
|
53
|
-
},
|
|
54
|
-
};
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
export async function verifyWebhookRequest(req, { secret, signatureHeader = "x-signature", timestampHeader = "x-timestamp", idHeader = "x-event-id", maxSkewSec = 300, replayDir = ".fastscript" } = {}) {
|
|
58
|
-
const raw = await readRawBody(req);
|
|
59
|
-
const sig = req.headers[signatureHeader];
|
|
60
|
-
const ts = req.headers[timestampHeader];
|
|
61
|
-
const eventId = req.headers[idHeader];
|
|
62
|
-
const id = Array.isArray(eventId) ? eventId[0] : eventId;
|
|
63
|
-
if (isReplay(ts, maxSkewSec)) return { ok: false, reason: "replay_window" };
|
|
64
|
-
if (!verifySignature(raw, Array.isArray(sig) ? sig[0] : sig, secret)) return { ok: false, reason: "bad_signature" };
|
|
65
|
-
if (id) {
|
|
66
|
-
const store = replayStore({ dir: replayDir, ttlSec: Math.max(maxSkewSec, 600) });
|
|
67
|
-
if (store.has(id)) return { ok: false, reason: "duplicate_event" };
|
|
68
|
-
store.add(id);
|
|
69
|
-
}
|
|
70
|
-
return { ok: true, raw };
|
|
71
|
-
}
|
|
1
|
+
export * from "@fastscript/core-private/webhook";
|
package/src/worker.mjs
CHANGED
|
@@ -1,5 +1,24 @@
|
|
|
1
|
-
|
|
1
|
+
import { replayDeadLetter, runWorker } from "./jobs.mjs";
|
|
2
2
|
|
|
3
|
-
export async function runWorkerCommand() {
|
|
4
|
-
|
|
5
|
-
|
|
3
|
+
export async function runWorkerCommand(args = []) {
|
|
4
|
+
if (args[0] === "replay-dead-letter") {
|
|
5
|
+
const limitArg = args.indexOf("--limit");
|
|
6
|
+
const nameArg = args.indexOf("--name");
|
|
7
|
+
const limit = limitArg >= 0 ? Number(args[limitArg + 1] || 20) : 20;
|
|
8
|
+
const name = nameArg >= 0 ? args[nameArg + 1] || null : null;
|
|
9
|
+
const replayed = await replayDeadLetter({
|
|
10
|
+
dir: ".fastscript",
|
|
11
|
+
limit,
|
|
12
|
+
name,
|
|
13
|
+
driver: process.env.JOBS_DRIVER || "file",
|
|
14
|
+
});
|
|
15
|
+
console.log(`dead-letter replayed: ${replayed.length}`);
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
await runWorker({
|
|
20
|
+
dir: ".fastscript",
|
|
21
|
+
pollMs: Number(process.env.WORKER_POLL_MS || 350),
|
|
22
|
+
driver: process.env.JOBS_DRIVER || "file",
|
|
23
|
+
});
|
|
24
|
+
}
|