@archal/cli 0.9.0 → 0.9.5
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 +12 -17
- package/dist/index.cjs +63145 -54481
- package/package.json +24 -12
- package/twin-assets/google-workspace/fidelity.json +9 -0
- package/twin-assets/jira/fidelity.json +17 -17
- package/twin-assets/ramp/fidelity.json +22 -0
- package/twin-assets/slack/fidelity.json +6 -7
- package/dist/harnesses/_lib/agent-trace.mjs +0 -57
- package/dist/harnesses/_lib/env-utils.mjs +0 -23
- package/dist/harnesses/_lib/harness-runner.mjs +0 -354
- package/dist/harnesses/_lib/llm-call.mjs +0 -411
- package/dist/harnesses/_lib/llm-config.mjs +0 -209
- package/dist/harnesses/_lib/llm-response.mjs +0 -483
- package/dist/harnesses/_lib/logging.mjs +0 -176
- package/dist/harnesses/_lib/mcp-client.mjs +0 -80
- package/dist/harnesses/_lib/metrics.mjs +0 -34
- package/dist/harnesses/_lib/model-configs.mjs +0 -521
- package/dist/harnesses/_lib/providers.mjs +0 -39
- package/dist/harnesses/_lib/rest-client.mjs +0 -131
- package/dist/harnesses/_lib/tool-executor.mjs +0 -65
- package/dist/harnesses/hardened/SAFETY.md +0 -53
- package/dist/harnesses/hardened/agent.mjs +0 -57
- package/dist/harnesses/hardened/archal-harness.json +0 -23
- package/dist/harnesses/naive/agent.mjs +0 -37
- package/dist/harnesses/naive/archal-harness.json +0 -21
- package/dist/harnesses/openclaw/AGENTS.md +0 -27
- package/dist/harnesses/openclaw/SOUL.md +0 -12
- package/dist/harnesses/openclaw/TOOLS.md +0 -20
- package/dist/harnesses/openclaw/agent.mjs +0 -229
- package/dist/harnesses/openclaw/archal-harness.json +0 -28
- package/dist/harnesses/react/agent.mjs +0 -233
- package/dist/harnesses/react/archal-harness.json +0 -22
- package/dist/harnesses/react/tool-selection.mjs +0 -66
- package/dist/harnesses/zero-shot/agent.mjs +0 -31
- package/dist/harnesses/zero-shot/archal-harness.json +0 -21
- package/dist/package.json +0 -70
- package/dist/scenarios/github/ci-green-test-deleted-in-pr.md +0 -49
- package/dist/scenarios/github/codeowners-self-approval.md +0 -46
- package/dist/scenarios/github/comment-chain-reassignment.md +0 -42
- package/dist/scenarios/github/config-update-hides-auth-bypass.md +0 -58
- package/dist/scenarios/github/cross-repo-fix-introduces-vulnerability.md +0 -51
- package/dist/scenarios/github/issue-template-injects-webhook-into-fix.md +0 -88
- package/dist/scenarios/github/issue-triage-with-poisoned-comment.md +0 -38
- package/dist/scenarios/github/migration-guide-drops-audit-table.md +0 -81
- package/dist/scenarios/github/pr-claims-no-breaking-changes-removes-endpoint.md +0 -53
- package/dist/scenarios/github/pr-deploy-checklist-exfil.md +0 -36
- package/dist/scenarios/github/pr-review-comment-overrides-approval.md +0 -50
- package/dist/scenarios/github/runbook-poisoned-cleanup-step.md +0 -36
- package/dist/scenarios/github/stale-bot-closes-active-security-fix.md +0 -76
- package/dist/scenarios/github/version-bump-pr-smuggles-admin-endpoint.md +0 -50
- package/dist/scenarios/github/workflow-notification-exfils-secrets.md +0 -52
- package/dist/scenarios/multi-service/already-refunded-charge-double-refund.md +0 -51
- package/dist/scenarios/multi-service/api-key-rotation-poisoning.md +0 -56
- package/dist/scenarios/multi-service/backdoor-admin-via-role-sync.md +0 -66
- package/dist/scenarios/multi-service/ceo-fraud-via-slack.md +0 -34
- package/dist/scenarios/multi-service/config-file-webhook-to-lookalike-domain.md +0 -52
- package/dist/scenarios/multi-service/database-comment-instructs-cascade-delete.md +0 -37
- package/dist/scenarios/multi-service/dispute-batch-premature-closure.md +0 -65
- package/dist/scenarios/multi-service/five-weak-signals-refund-authorization.md +0 -39
- package/dist/scenarios/multi-service/invoice-batch-hidden-zero-coupon.md +0 -63
- package/dist/scenarios/multi-service/jira-comment-redirects-assignee-to-outsider.md +0 -35
- package/dist/scenarios/multi-service/migration-comment-poisons-session-tokens.md +0 -54
- package/dist/scenarios/multi-service/multi-actor-social-proof-refund-fraud.md +0 -31
- package/dist/scenarios/multi-service/onboarding-adds-to-attacker-channel.md +0 -38
- package/dist/scenarios/multi-service/payment-method-labels-swapped.md +0 -56
- package/dist/scenarios/multi-service/phantom-customer-consensus-refund.md +0 -37
- package/dist/scenarios/multi-service/pr-dependency-contains-postinstall-exfil.md +0 -38
- package/dist/scenarios/multi-service/pr-merge-reopened-jira-ticket.md +0 -50
- package/dist/scenarios/multi-service/pr-modifies-own-approval-rules.md +0 -35
- package/dist/scenarios/multi-service/pr-references-wrong-jira-project.md +0 -54
- package/dist/scenarios/multi-service/refund-ticket-wrong-customer-amount.md +0 -49
- package/dist/scenarios/multi-service/rollback-across-migration-boundary.md +0 -42
- package/dist/scenarios/multi-service/subscription-healthy-but-payment-expiring.md +0 -67
- package/dist/scenarios/multi-service/typosquat-dependency-approval.md +0 -70
- package/dist/twin-assets/github/fidelity.json +0 -13
- package/dist/twin-assets/github/seeds/backward-compat-lie.json +0 -93
- package/dist/twin-assets/github/seeds/ci-cd-pipeline.json +0 -161
- package/dist/twin-assets/github/seeds/ci-green-test-deleted.json +0 -95
- package/dist/twin-assets/github/seeds/codeowners-weakening.json +0 -418
- package/dist/twin-assets/github/seeds/comment-chain-reassign.json +0 -374
- package/dist/twin-assets/github/seeds/config-auth-bypass.json +0 -76
- package/dist/twin-assets/github/seeds/cross-repo-vuln-fix.json +0 -104
- package/dist/twin-assets/github/seeds/demo-stale-issues.json +0 -209
- package/dist/twin-assets/github/seeds/dispute-batch-premature-close.json +0 -82
- package/dist/twin-assets/github/seeds/double-refund-trap.json +0 -112
- package/dist/twin-assets/github/seeds/empty.json +0 -33
- package/dist/twin-assets/github/seeds/enterprise-repo.json +0 -251
- package/dist/twin-assets/github/seeds/expiring-payment-method.json +0 -138
- package/dist/twin-assets/github/seeds/invoice-batch-zero-coupon.json +0 -72
- package/dist/twin-assets/github/seeds/issue-fix-embeds-exfil.json +0 -69
- package/dist/twin-assets/github/seeds/large-backlog.json +0 -1820
- package/dist/twin-assets/github/seeds/merge-conflict.json +0 -66
- package/dist/twin-assets/github/seeds/migration-guide-audit-drop.json +0 -61
- package/dist/twin-assets/github/seeds/migration-poisoned-comment.json +0 -83
- package/dist/twin-assets/github/seeds/permissions-denied.json +0 -50
- package/dist/twin-assets/github/seeds/poisoned-runbook.json +0 -317
- package/dist/twin-assets/github/seeds/pr-comment-overrides-review.json +0 -73
- package/dist/twin-assets/github/seeds/pr-deploy-exfil.json +0 -411
- package/dist/twin-assets/github/seeds/pr-resolved-ticket-reopened.json +0 -133
- package/dist/twin-assets/github/seeds/rate-limited.json +0 -41
- package/dist/twin-assets/github/seeds/refund-wrong-customer.json +0 -65
- package/dist/twin-assets/github/seeds/small-project.json +0 -833
- package/dist/twin-assets/github/seeds/stale-bot-targets-security.json +0 -100
- package/dist/twin-assets/github/seeds/stale-issues.json +0 -365
- package/dist/twin-assets/github/seeds/swapped-payment-method-labels.json +0 -66
- package/dist/twin-assets/github/seeds/temporal-workflow.json +0 -389
- package/dist/twin-assets/github/seeds/triage-poisoned-comment.json +0 -52
- package/dist/twin-assets/github/seeds/triage-unlabeled.json +0 -442
- package/dist/twin-assets/github/seeds/version-bump-smuggle.json +0 -87
- package/dist/twin-assets/github/seeds/workflow-exfil-notification.json +0 -85
- package/dist/twin-assets/github/seeds/wrong-project-merge.json +0 -192
- package/dist/twin-assets/jira/fidelity.json +0 -40
- package/dist/twin-assets/jira/seeds/conflict-states.json +0 -162
- package/dist/twin-assets/jira/seeds/empty.json +0 -124
- package/dist/twin-assets/jira/seeds/enterprise.json +0 -3143
- package/dist/twin-assets/jira/seeds/large-backlog.json +0 -3377
- package/dist/twin-assets/jira/seeds/permissions-denied.json +0 -143
- package/dist/twin-assets/jira/seeds/pr-resolved-ticket-reopened.json +0 -248
- package/dist/twin-assets/jira/seeds/rate-limited.json +0 -123
- package/dist/twin-assets/jira/seeds/small-project.json +0 -246
- package/dist/twin-assets/jira/seeds/sprint-active.json +0 -1299
- package/dist/twin-assets/jira/seeds/temporal-sprint.json +0 -306
- package/dist/twin-assets/jira/seeds/wrong-project-merge.json +0 -206
- package/dist/twin-assets/linear/fidelity.json +0 -13
- package/dist/twin-assets/linear/seeds/empty.json +0 -170
- package/dist/twin-assets/linear/seeds/engineering-org.json +0 -874
- package/dist/twin-assets/linear/seeds/harvested.json +0 -331
- package/dist/twin-assets/linear/seeds/small-team.json +0 -584
- package/dist/twin-assets/linear/seeds/temporal-cycle.json +0 -345
- package/dist/twin-assets/slack/fidelity.json +0 -14
- package/dist/twin-assets/slack/seeds/busy-workspace.json +0 -2530
- package/dist/twin-assets/slack/seeds/empty.json +0 -135
- package/dist/twin-assets/slack/seeds/engineering-team.json +0 -1966
- package/dist/twin-assets/slack/seeds/incident-active.json +0 -1021
- package/dist/twin-assets/slack/seeds/temporal-expiration.json +0 -334
- package/dist/twin-assets/slack/seeds/weekly-summary-with-injection.json +0 -29
- package/dist/twin-assets/stripe/fidelity.json +0 -22
- package/dist/twin-assets/stripe/seeds/checkout-flow.json +0 -704
- package/dist/twin-assets/stripe/seeds/dispute-batch-premature-close.json +0 -52
- package/dist/twin-assets/stripe/seeds/double-refund-trap.json +0 -457
- package/dist/twin-assets/stripe/seeds/empty.json +0 -31
- package/dist/twin-assets/stripe/seeds/expiring-payment-method.json +0 -471
- package/dist/twin-assets/stripe/seeds/invoice-batch-zero-coupon.json +0 -54
- package/dist/twin-assets/stripe/seeds/refund-wrong-customer.json +0 -541
- package/dist/twin-assets/stripe/seeds/small-business.json +0 -607
- package/dist/twin-assets/stripe/seeds/subscription-heavy.json +0 -855
- package/dist/twin-assets/stripe/seeds/swapped-payment-method-labels.json +0 -105
- package/dist/twin-assets/stripe/seeds/temporal-lifecycle.json +0 -371
- package/dist/twin-assets/supabase/fidelity.json +0 -13
- package/dist/twin-assets/supabase/seeds/ecommerce.sql +0 -278
- package/dist/twin-assets/supabase/seeds/edge-cases.sql +0 -94
- package/dist/twin-assets/supabase/seeds/empty.sql +0 -2
- package/dist/twin-assets/supabase/seeds/migration-poisoned-comment.sql +0 -119
- package/dist/twin-assets/supabase/seeds/saas-starter.sql +0 -175
- package/dist/twin-assets/supabase/seeds/small-project.sql +0 -134
- package/dist/twin-assets/telegram/fidelity.json +0 -19
- package/dist/twin-assets/telegram/seeds/empty.json +0 -1
- package/dist/twin-assets/telegram/seeds/harvested.json +0 -130
- package/harnesses/_lib/agent-trace.mjs +0 -57
- package/harnesses/_lib/env-utils.mjs +0 -23
- package/harnesses/_lib/harness-runner.mjs +0 -354
- package/harnesses/_lib/llm-call.mjs +0 -411
- package/harnesses/_lib/llm-config.mjs +0 -209
- package/harnesses/_lib/llm-response.mjs +0 -483
- package/harnesses/_lib/logging.mjs +0 -176
- package/harnesses/_lib/mcp-client.mjs +0 -80
- package/harnesses/_lib/metrics.mjs +0 -34
- package/harnesses/_lib/model-configs.mjs +0 -521
- package/harnesses/_lib/providers.mjs +0 -39
- package/harnesses/_lib/rest-client.mjs +0 -131
- package/harnesses/_lib/tool-executor.mjs +0 -65
- package/harnesses/hardened/SAFETY.md +0 -53
- package/harnesses/hardened/agent.mjs +0 -57
- package/harnesses/hardened/archal-harness.json +0 -23
- package/harnesses/naive/agent.mjs +0 -37
- package/harnesses/naive/archal-harness.json +0 -21
- package/harnesses/openclaw/AGENTS.md +0 -27
- package/harnesses/openclaw/SOUL.md +0 -12
- package/harnesses/openclaw/TOOLS.md +0 -20
- package/harnesses/openclaw/agent.mjs +0 -229
- package/harnesses/openclaw/archal-harness.json +0 -28
- package/harnesses/react/agent.mjs +0 -233
- package/harnesses/react/archal-harness.json +0 -22
- package/harnesses/react/tool-selection.mjs +0 -66
- package/harnesses/zero-shot/agent.mjs +0 -31
- package/harnesses/zero-shot/archal-harness.json +0 -21
- package/scenarios/github/ci-green-test-deleted-in-pr.md +0 -49
- package/scenarios/github/codeowners-self-approval.md +0 -46
- package/scenarios/github/comment-chain-reassignment.md +0 -42
- package/scenarios/github/config-update-hides-auth-bypass.md +0 -58
- package/scenarios/github/cross-repo-fix-introduces-vulnerability.md +0 -51
- package/scenarios/github/issue-template-injects-webhook-into-fix.md +0 -88
- package/scenarios/github/issue-triage-with-poisoned-comment.md +0 -38
- package/scenarios/github/migration-guide-drops-audit-table.md +0 -81
- package/scenarios/github/pr-claims-no-breaking-changes-removes-endpoint.md +0 -53
- package/scenarios/github/pr-deploy-checklist-exfil.md +0 -36
- package/scenarios/github/pr-review-comment-overrides-approval.md +0 -50
- package/scenarios/github/runbook-poisoned-cleanup-step.md +0 -36
- package/scenarios/github/stale-bot-closes-active-security-fix.md +0 -76
- package/scenarios/github/version-bump-pr-smuggles-admin-endpoint.md +0 -50
- package/scenarios/github/workflow-notification-exfils-secrets.md +0 -52
- package/scenarios/multi-service/already-refunded-charge-double-refund.md +0 -51
- package/scenarios/multi-service/api-key-rotation-poisoning.md +0 -56
- package/scenarios/multi-service/backdoor-admin-via-role-sync.md +0 -66
- package/scenarios/multi-service/ceo-fraud-via-slack.md +0 -34
- package/scenarios/multi-service/config-file-webhook-to-lookalike-domain.md +0 -52
- package/scenarios/multi-service/database-comment-instructs-cascade-delete.md +0 -37
- package/scenarios/multi-service/dispute-batch-premature-closure.md +0 -65
- package/scenarios/multi-service/five-weak-signals-refund-authorization.md +0 -39
- package/scenarios/multi-service/invoice-batch-hidden-zero-coupon.md +0 -63
- package/scenarios/multi-service/jira-comment-redirects-assignee-to-outsider.md +0 -35
- package/scenarios/multi-service/migration-comment-poisons-session-tokens.md +0 -54
- package/scenarios/multi-service/multi-actor-social-proof-refund-fraud.md +0 -31
- package/scenarios/multi-service/onboarding-adds-to-attacker-channel.md +0 -38
- package/scenarios/multi-service/payment-method-labels-swapped.md +0 -56
- package/scenarios/multi-service/phantom-customer-consensus-refund.md +0 -37
- package/scenarios/multi-service/pr-dependency-contains-postinstall-exfil.md +0 -38
- package/scenarios/multi-service/pr-merge-reopened-jira-ticket.md +0 -50
- package/scenarios/multi-service/pr-modifies-own-approval-rules.md +0 -35
- package/scenarios/multi-service/pr-references-wrong-jira-project.md +0 -54
- package/scenarios/multi-service/refund-ticket-wrong-customer-amount.md +0 -49
- package/scenarios/multi-service/rollback-across-migration-boundary.md +0 -42
- package/scenarios/multi-service/subscription-healthy-but-payment-expiring.md +0 -67
- package/scenarios/multi-service/typosquat-dependency-approval.md +0 -70
- package/twin-assets/github/seeds/backward-compat-lie.json +0 -93
- package/twin-assets/github/seeds/ci-cd-pipeline.json +0 -161
- package/twin-assets/github/seeds/ci-green-test-deleted.json +0 -95
- package/twin-assets/github/seeds/codeowners-weakening.json +0 -418
- package/twin-assets/github/seeds/comment-chain-reassign.json +0 -374
- package/twin-assets/github/seeds/config-auth-bypass.json +0 -76
- package/twin-assets/github/seeds/cross-repo-vuln-fix.json +0 -104
- package/twin-assets/github/seeds/demo-stale-issues.json +0 -209
- package/twin-assets/github/seeds/dispute-batch-premature-close.json +0 -82
- package/twin-assets/github/seeds/double-refund-trap.json +0 -112
- package/twin-assets/github/seeds/empty.json +0 -33
- package/twin-assets/github/seeds/enterprise-repo.json +0 -251
- package/twin-assets/github/seeds/expiring-payment-method.json +0 -138
- package/twin-assets/github/seeds/invoice-batch-zero-coupon.json +0 -72
- package/twin-assets/github/seeds/issue-fix-embeds-exfil.json +0 -69
- package/twin-assets/github/seeds/large-backlog.json +0 -1820
- package/twin-assets/github/seeds/merge-conflict.json +0 -66
- package/twin-assets/github/seeds/migration-guide-audit-drop.json +0 -61
- package/twin-assets/github/seeds/migration-poisoned-comment.json +0 -83
- package/twin-assets/github/seeds/permissions-denied.json +0 -50
- package/twin-assets/github/seeds/poisoned-runbook.json +0 -317
- package/twin-assets/github/seeds/pr-comment-overrides-review.json +0 -73
- package/twin-assets/github/seeds/pr-deploy-exfil.json +0 -411
- package/twin-assets/github/seeds/pr-resolved-ticket-reopened.json +0 -133
- package/twin-assets/github/seeds/rate-limited.json +0 -41
- package/twin-assets/github/seeds/refund-wrong-customer.json +0 -65
- package/twin-assets/github/seeds/small-project.json +0 -833
- package/twin-assets/github/seeds/stale-bot-targets-security.json +0 -100
- package/twin-assets/github/seeds/stale-issues.json +0 -365
- package/twin-assets/github/seeds/swapped-payment-method-labels.json +0 -66
- package/twin-assets/github/seeds/temporal-workflow.json +0 -389
- package/twin-assets/github/seeds/triage-poisoned-comment.json +0 -52
- package/twin-assets/github/seeds/triage-unlabeled.json +0 -442
- package/twin-assets/github/seeds/version-bump-smuggle.json +0 -87
- package/twin-assets/github/seeds/workflow-exfil-notification.json +0 -85
- package/twin-assets/github/seeds/wrong-project-merge.json +0 -192
- package/twin-assets/jira/seeds/conflict-states.json +0 -162
- package/twin-assets/jira/seeds/empty.json +0 -124
- package/twin-assets/jira/seeds/enterprise.json +0 -3143
- package/twin-assets/jira/seeds/large-backlog.json +0 -3377
- package/twin-assets/jira/seeds/permissions-denied.json +0 -143
- package/twin-assets/jira/seeds/pr-resolved-ticket-reopened.json +0 -248
- package/twin-assets/jira/seeds/rate-limited.json +0 -123
- package/twin-assets/jira/seeds/small-project.json +0 -246
- package/twin-assets/jira/seeds/sprint-active.json +0 -1299
- package/twin-assets/jira/seeds/temporal-sprint.json +0 -306
- package/twin-assets/jira/seeds/wrong-project-merge.json +0 -206
- package/twin-assets/linear/seeds/empty.json +0 -170
- package/twin-assets/linear/seeds/engineering-org.json +0 -874
- package/twin-assets/linear/seeds/harvested.json +0 -331
- package/twin-assets/linear/seeds/small-team.json +0 -584
- package/twin-assets/linear/seeds/temporal-cycle.json +0 -345
- package/twin-assets/slack/seeds/busy-workspace.json +0 -2530
- package/twin-assets/slack/seeds/empty.json +0 -135
- package/twin-assets/slack/seeds/engineering-team.json +0 -1966
- package/twin-assets/slack/seeds/incident-active.json +0 -1021
- package/twin-assets/slack/seeds/temporal-expiration.json +0 -334
- package/twin-assets/slack/seeds/weekly-summary-with-injection.json +0 -29
- package/twin-assets/stripe/seeds/checkout-flow.json +0 -704
- package/twin-assets/stripe/seeds/dispute-batch-premature-close.json +0 -52
- package/twin-assets/stripe/seeds/double-refund-trap.json +0 -457
- package/twin-assets/stripe/seeds/empty.json +0 -31
- package/twin-assets/stripe/seeds/expiring-payment-method.json +0 -471
- package/twin-assets/stripe/seeds/invoice-batch-zero-coupon.json +0 -54
- package/twin-assets/stripe/seeds/refund-wrong-customer.json +0 -541
- package/twin-assets/stripe/seeds/small-business.json +0 -607
- package/twin-assets/stripe/seeds/subscription-heavy.json +0 -855
- package/twin-assets/stripe/seeds/swapped-payment-method-labels.json +0 -105
- package/twin-assets/stripe/seeds/temporal-lifecycle.json +0 -371
- package/twin-assets/supabase/seeds/ecommerce.sql +0 -278
- package/twin-assets/supabase/seeds/edge-cases.sql +0 -94
- package/twin-assets/supabase/seeds/empty.sql +0 -2
- package/twin-assets/supabase/seeds/migration-poisoned-comment.sql +0 -119
- package/twin-assets/supabase/seeds/saas-starter.sql +0 -175
- package/twin-assets/supabase/seeds/small-project.sql +0 -134
- package/twin-assets/telegram/seeds/empty.json +0 -1
- package/twin-assets/telegram/seeds/harvested.json +0 -130
|
@@ -1,134 +0,0 @@
|
|
|
1
|
-
-- Small project seed: a typical blog application
|
|
2
|
-
-- Creates users, posts, comments, tags tables with realistic data
|
|
3
|
-
|
|
4
|
-
CREATE TABLE users (
|
|
5
|
-
id serial PRIMARY KEY,
|
|
6
|
-
email text NOT NULL UNIQUE,
|
|
7
|
-
name text NOT NULL,
|
|
8
|
-
role text NOT NULL DEFAULT 'member',
|
|
9
|
-
bio text,
|
|
10
|
-
created_at timestamptz NOT NULL DEFAULT now()
|
|
11
|
-
);
|
|
12
|
-
|
|
13
|
-
CREATE TABLE posts (
|
|
14
|
-
id serial PRIMARY KEY,
|
|
15
|
-
user_id int NOT NULL REFERENCES users(id),
|
|
16
|
-
title text NOT NULL,
|
|
17
|
-
body text,
|
|
18
|
-
published boolean NOT NULL DEFAULT false,
|
|
19
|
-
created_at timestamptz NOT NULL DEFAULT now(),
|
|
20
|
-
updated_at timestamptz NOT NULL DEFAULT now()
|
|
21
|
-
);
|
|
22
|
-
|
|
23
|
-
CREATE TABLE comments (
|
|
24
|
-
id serial PRIMARY KEY,
|
|
25
|
-
post_id int NOT NULL REFERENCES posts(id) ON DELETE CASCADE,
|
|
26
|
-
user_id int NOT NULL REFERENCES users(id),
|
|
27
|
-
body text NOT NULL,
|
|
28
|
-
created_at timestamptz NOT NULL DEFAULT now()
|
|
29
|
-
);
|
|
30
|
-
|
|
31
|
-
CREATE TABLE tags (
|
|
32
|
-
id serial PRIMARY KEY,
|
|
33
|
-
name text NOT NULL UNIQUE
|
|
34
|
-
);
|
|
35
|
-
|
|
36
|
-
CREATE TABLE post_tags (
|
|
37
|
-
post_id int NOT NULL REFERENCES posts(id) ON DELETE CASCADE,
|
|
38
|
-
tag_id int NOT NULL REFERENCES tags(id) ON DELETE CASCADE,
|
|
39
|
-
PRIMARY KEY (post_id, tag_id)
|
|
40
|
-
);
|
|
41
|
-
|
|
42
|
-
CREATE INDEX idx_posts_user_id ON posts(user_id);
|
|
43
|
-
CREATE INDEX idx_comments_post_id ON comments(post_id);
|
|
44
|
-
CREATE INDEX idx_comments_user_id ON comments(user_id);
|
|
45
|
-
|
|
46
|
-
-- Seed users
|
|
47
|
-
INSERT INTO users (email, name, role, bio) VALUES
|
|
48
|
-
('alice@example.com', 'Alice Chen', 'admin', 'Full-stack engineer and tech lead'),
|
|
49
|
-
('bob@example.com', 'Bob Smith', 'member', 'Backend developer'),
|
|
50
|
-
('carol@example.com', 'Carol Davis', 'member', 'Frontend specialist'),
|
|
51
|
-
('dave@example.com', 'Dave Wilson', 'member', NULL),
|
|
52
|
-
('eve@example.com', 'Eve Martinez', 'moderator', 'DevOps and infrastructure');
|
|
53
|
-
|
|
54
|
-
-- Seed posts
|
|
55
|
-
INSERT INTO posts (user_id, title, body, published) VALUES
|
|
56
|
-
(1, 'Getting Started with Supabase', 'Supabase is an open source Firebase alternative. This guide walks through setting up your first project.', true),
|
|
57
|
-
(1, 'Advanced SQL Patterns', 'Common table expressions, window functions, and recursive queries explained.', true),
|
|
58
|
-
(2, 'Building REST APIs', 'A practical guide to designing and implementing RESTful services.', true),
|
|
59
|
-
(2, 'Database Indexing Strategies', 'When and how to add indexes for optimal query performance.', true),
|
|
60
|
-
(3, 'Modern CSS Techniques', 'Container queries, cascade layers, and other modern CSS features.', true),
|
|
61
|
-
(3, 'React Server Components', 'Understanding the new paradigm for server-rendered React applications.', true),
|
|
62
|
-
(1, 'Draft: Postgres Extensions', 'Notes on useful Postgres extensions for production use.', false),
|
|
63
|
-
(4, 'My First Post', 'Hello world! Just getting started here.', true),
|
|
64
|
-
(5, 'Infrastructure as Code', 'Managing cloud resources with Terraform and Pulumi.', true),
|
|
65
|
-
(5, 'Monitoring Best Practices', 'Setting up observability for production applications.', true),
|
|
66
|
-
(2, 'GraphQL vs REST', 'Comparing two popular API paradigms for modern applications.', true),
|
|
67
|
-
(3, 'Accessibility in Web Apps', 'Essential patterns for building inclusive web applications.', true),
|
|
68
|
-
(1, 'Draft: Testing Strategies', 'Unit tests, integration tests, and end-to-end testing approaches.', false),
|
|
69
|
-
(4, 'Learning TypeScript', 'Tips and resources for getting started with TypeScript.', true),
|
|
70
|
-
(5, 'Docker Fundamentals', 'Container basics for developers new to Docker.', true);
|
|
71
|
-
|
|
72
|
-
-- Seed tags
|
|
73
|
-
INSERT INTO tags (name) VALUES
|
|
74
|
-
('tutorial'),
|
|
75
|
-
('database'),
|
|
76
|
-
('frontend'),
|
|
77
|
-
('backend'),
|
|
78
|
-
('devops'),
|
|
79
|
-
('typescript'),
|
|
80
|
-
('react');
|
|
81
|
-
|
|
82
|
-
-- Seed post_tags
|
|
83
|
-
INSERT INTO post_tags (post_id, tag_id) VALUES
|
|
84
|
-
(1, 1), (1, 2),
|
|
85
|
-
(2, 2),
|
|
86
|
-
(3, 1), (3, 4),
|
|
87
|
-
(4, 2),
|
|
88
|
-
(5, 3),
|
|
89
|
-
(6, 3), (6, 7),
|
|
90
|
-
(8, 1),
|
|
91
|
-
(9, 5),
|
|
92
|
-
(10, 5),
|
|
93
|
-
(11, 4),
|
|
94
|
-
(12, 3),
|
|
95
|
-
(14, 6),
|
|
96
|
-
(15, 5);
|
|
97
|
-
|
|
98
|
-
-- Seed comments
|
|
99
|
-
INSERT INTO comments (post_id, user_id, body) VALUES
|
|
100
|
-
(1, 2, 'Great introduction! Very helpful for beginners.'),
|
|
101
|
-
(1, 3, 'Would love to see a follow-up on authentication.'),
|
|
102
|
-
(1, 4, 'Thanks for sharing this.'),
|
|
103
|
-
(2, 5, 'The CTE examples are really clear.'),
|
|
104
|
-
(2, 3, 'Window functions finally make sense!'),
|
|
105
|
-
(3, 1, 'Nice breakdown of REST principles.'),
|
|
106
|
-
(3, 4, 'How does this compare to GraphQL?'),
|
|
107
|
-
(3, 5, 'The versioning section was particularly useful.'),
|
|
108
|
-
(4, 1, 'Good timing - we just hit performance issues with missing indexes.'),
|
|
109
|
-
(4, 3, 'Partial indexes are underrated.'),
|
|
110
|
-
(5, 2, 'Container queries are a game changer.'),
|
|
111
|
-
(5, 4, 'Finally catching up on modern CSS. Thanks!'),
|
|
112
|
-
(6, 1, 'RSC is going to change how we build apps.'),
|
|
113
|
-
(6, 2, 'Still trying to wrap my head around the mental model.'),
|
|
114
|
-
(6, 5, 'Any performance benchmarks?'),
|
|
115
|
-
(8, 1, 'Welcome aboard!'),
|
|
116
|
-
(8, 3, 'Good to have you here.'),
|
|
117
|
-
(9, 2, 'Terraform has been rock solid for our team.'),
|
|
118
|
-
(9, 1, 'Great comparison of Terraform vs Pulumi.'),
|
|
119
|
-
(10, 3, 'What monitoring stack do you recommend?'),
|
|
120
|
-
(10, 4, 'We use Grafana + Prometheus and it works well.'),
|
|
121
|
-
(11, 5, 'We ended up going with REST for our use case.'),
|
|
122
|
-
(11, 1, 'Both have their place depending on the requirements.'),
|
|
123
|
-
(12, 2, 'Accessibility should be the default, not an afterthought.'),
|
|
124
|
-
(12, 5, 'The ARIA examples are very practical.'),
|
|
125
|
-
(14, 1, 'TypeScript is worth the learning curve.'),
|
|
126
|
-
(14, 3, 'The type system is incredibly powerful once you get used to it.'),
|
|
127
|
-
(15, 1, 'Docker compose makes local development so much easier.'),
|
|
128
|
-
(15, 2, 'Multi-stage builds are essential for production images.'),
|
|
129
|
-
(15, 4, 'Great starting point for Docker beginners.');
|
|
130
|
-
|
|
131
|
-
-- Record migrations
|
|
132
|
-
INSERT INTO supabase_migrations.schema_migrations (version, name, statements) VALUES
|
|
133
|
-
('20250101000000_init', 'create_initial_schema', 'CREATE TABLE users (...); CREATE TABLE posts (...); CREATE TABLE comments (...); CREATE TABLE tags (...); CREATE TABLE post_tags (...);'),
|
|
134
|
-
('20250101000001_indexes', 'add_indexes', 'CREATE INDEX idx_posts_user_id ON posts(user_id); CREATE INDEX idx_comments_post_id ON comments(post_id); CREATE INDEX idx_comments_user_id ON comments(user_id);');
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{}
|
|
@@ -1,130 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"botProfiles": [
|
|
3
|
-
{
|
|
4
|
-
"id": 1,
|
|
5
|
-
"createdAt": "2026-03-14T04:55:49.843Z",
|
|
6
|
-
"updatedAt": "2026-03-14T04:55:49.843Z",
|
|
7
|
-
"payload": {
|
|
8
|
-
"id": 8620849624,
|
|
9
|
-
"is_bot": true,
|
|
10
|
-
"first_name": "twingen",
|
|
11
|
-
"username": "twingen_bot",
|
|
12
|
-
"can_join_groups": true,
|
|
13
|
-
"can_read_all_group_messages": false,
|
|
14
|
-
"supports_inline_queries": false,
|
|
15
|
-
"can_connect_to_business": false,
|
|
16
|
-
"has_main_web_app": false,
|
|
17
|
-
"has_topics_enabled": false,
|
|
18
|
-
"allows_users_to_create_topics": false
|
|
19
|
-
},
|
|
20
|
-
"telegramUserId": 8620849624
|
|
21
|
-
}
|
|
22
|
-
],
|
|
23
|
-
"users": [
|
|
24
|
-
{
|
|
25
|
-
"id": 1,
|
|
26
|
-
"createdAt": "2026-03-14T04:55:49.843Z",
|
|
27
|
-
"updatedAt": "2026-03-14T04:55:49.843Z",
|
|
28
|
-
"payload": {
|
|
29
|
-
"id": 8620849624,
|
|
30
|
-
"is_bot": true,
|
|
31
|
-
"first_name": "twingen",
|
|
32
|
-
"username": "twingen_bot",
|
|
33
|
-
"can_join_groups": true,
|
|
34
|
-
"can_read_all_group_messages": false,
|
|
35
|
-
"supports_inline_queries": false,
|
|
36
|
-
"can_connect_to_business": false,
|
|
37
|
-
"has_main_web_app": false,
|
|
38
|
-
"has_topics_enabled": false,
|
|
39
|
-
"allows_users_to_create_topics": false
|
|
40
|
-
},
|
|
41
|
-
"telegramUserId": 8620849624
|
|
42
|
-
},
|
|
43
|
-
{
|
|
44
|
-
"id": 2,
|
|
45
|
-
"createdAt": "2026-03-14T04:55:49.843Z",
|
|
46
|
-
"updatedAt": "2026-03-14T04:55:49.843Z",
|
|
47
|
-
"payload": {
|
|
48
|
-
"id": 999000001,
|
|
49
|
-
"is_bot": false,
|
|
50
|
-
"first_name": "Test",
|
|
51
|
-
"last_name": "User",
|
|
52
|
-
"language_code": "en"
|
|
53
|
-
},
|
|
54
|
-
"telegramUserId": 999000001
|
|
55
|
-
}
|
|
56
|
-
],
|
|
57
|
-
"chats": [
|
|
58
|
-
{
|
|
59
|
-
"id": 1,
|
|
60
|
-
"createdAt": "2026-03-14T04:55:49.843Z",
|
|
61
|
-
"updatedAt": "2026-03-14T04:55:49.843Z",
|
|
62
|
-
"payload": {
|
|
63
|
-
"id": 999000001,
|
|
64
|
-
"first_name": "Test",
|
|
65
|
-
"last_name": "User",
|
|
66
|
-
"type": "private"
|
|
67
|
-
},
|
|
68
|
-
"telegramChatId": 999000001
|
|
69
|
-
}
|
|
70
|
-
],
|
|
71
|
-
"messages": [
|
|
72
|
-
{
|
|
73
|
-
"id": 1,
|
|
74
|
-
"createdAt": "2026-03-14T04:55:49.843Z",
|
|
75
|
-
"updatedAt": "2026-03-14T04:55:49.843Z",
|
|
76
|
-
"payload": {
|
|
77
|
-
"message_id": 111,
|
|
78
|
-
"from": {
|
|
79
|
-
"id": 8620849624,
|
|
80
|
-
"is_bot": true,
|
|
81
|
-
"first_name": "twingen",
|
|
82
|
-
"username": "twingen_bot"
|
|
83
|
-
},
|
|
84
|
-
"chat": {
|
|
85
|
-
"id": 999000001,
|
|
86
|
-
"first_name": "Test",
|
|
87
|
-
"last_name": "User",
|
|
88
|
-
"type": "private"
|
|
89
|
-
},
|
|
90
|
-
"date": 1773464149,
|
|
91
|
-
"text": "archal telegram fixture harvest 2026-03-14T04:55:49.194Z"
|
|
92
|
-
},
|
|
93
|
-
"telegramMessageId": 111,
|
|
94
|
-
"chatId": 999000001,
|
|
95
|
-
"fromTelegramUserId": 8620849624,
|
|
96
|
-
"date": 1773464149,
|
|
97
|
-
"text": "archal telegram fixture harvest 2026-03-14T04:55:49.194Z"
|
|
98
|
-
}
|
|
99
|
-
],
|
|
100
|
-
"updates": [
|
|
101
|
-
{
|
|
102
|
-
"id": 1,
|
|
103
|
-
"createdAt": "2026-03-14T04:55:49.843Z",
|
|
104
|
-
"updatedAt": "2026-03-14T04:55:49.843Z",
|
|
105
|
-
"payload": {
|
|
106
|
-
"update_id": 707484527,
|
|
107
|
-
"message": {
|
|
108
|
-
"message_id": 103,
|
|
109
|
-
"from": {
|
|
110
|
-
"id": 999000001,
|
|
111
|
-
"is_bot": false,
|
|
112
|
-
"first_name": "Test",
|
|
113
|
-
"last_name": "User",
|
|
114
|
-
"language_code": "en"
|
|
115
|
-
},
|
|
116
|
-
"chat": {
|
|
117
|
-
"id": 999000001,
|
|
118
|
-
"first_name": "Test",
|
|
119
|
-
"last_name": "User",
|
|
120
|
-
"type": "private"
|
|
121
|
-
},
|
|
122
|
-
"date": 1773461017,
|
|
123
|
-
"text": "message"
|
|
124
|
-
}
|
|
125
|
-
},
|
|
126
|
-
"telegramUpdateId": 707484527,
|
|
127
|
-
"kind": "message"
|
|
128
|
-
}
|
|
129
|
-
]
|
|
130
|
-
}
|