@polymorphism-tech/morph-spec 4.6.0 → 4.7.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/README.md +394 -700
- package/docs/ARCHITECTURE.md +331 -0
- package/docs/CHEATSHEET.md +221 -0
- package/docs/COMMAND-FLOWS.md +368 -0
- package/docs/QUICKSTART.md +212 -0
- package/docs/examples/order-management/contracts.cs +84 -0
- package/docs/examples/order-management/proposal.md +24 -0
- package/docs/examples/order-management/spec.md +162 -0
- package/docs/plans/2026-02-23-ddd-architecture-refactor.md +1153 -0
- package/docs/plans/2026-02-23-ddd-nextsteps.md +682 -0
- package/docs/plans/2026-02-23-infra-architect-refactor.md +437 -0
- package/docs/plans/2026-02-23-nextjs-code-review-design.md +156 -0
- package/docs/plans/2026-02-23-nextjs-code-review-impl.md +1254 -0
- package/docs/plans/2026-02-23-nextjs-standards-design.md +149 -0
- package/docs/plans/2026-02-23-nextjs-standards-impl.md +1846 -0
- package/framework/agents/README.md +14 -14
- package/framework/agents/architecture/standards-architect.md +159 -159
- package/framework/agents/frontend/nextjs-expert.md +87 -127
- package/framework/agents/infrastructure/azure-architect.md +147 -147
- package/framework/agents/infrastructure/infra-architect.md +45 -0
- package/framework/agents.json +1145 -278
- package/framework/rules/frontend-standards.md +0 -3
- package/framework/rules/nextjs-standards.md +17 -0
- package/framework/skills/level-0-meta/code-review-nextjs/SKILL.md +147 -0
- package/framework/skills/level-0-meta/code-review-nextjs/references/review-example-nextjs.md +254 -0
- package/framework/skills/level-0-meta/tool-usage-guide/SKILL.md +3 -3
- package/framework/skills/level-1-workflows/phase-design/SKILL.md +45 -9
- package/framework/skills/level-1-workflows/phase-tasks/SKILL.md +38 -0
- package/framework/standards/STANDARDS.json +121 -0
- package/framework/standards/architecture/ddd/bounded-contexts.md +105 -0
- package/framework/standards/architecture/ddd/complexity-levels.md +108 -0
- package/framework/standards/architecture/ddd/ubiquitous-language.md +58 -0
- package/framework/standards/frontend/nextjs/app-router.md +123 -0
- package/framework/standards/frontend/nextjs/components.md +132 -0
- package/framework/standards/frontend/nextjs/data-fetching.md +126 -0
- package/framework/standards/frontend/nextjs/forms.md +128 -0
- package/framework/standards/frontend/nextjs/naming-conventions.md +67 -0
- package/framework/standards/frontend/nextjs/project-structure.md +102 -0
- package/framework/standards/frontend/nextjs/state-management.md +72 -0
- package/framework/standards/frontend/nextjs/testing.md +111 -0
- package/framework/templates/REGISTRY.json +538 -142
- package/framework/templates/code/dotnet/contracts/contracts-level1.cs +69 -0
- package/framework/templates/code/dotnet/contracts/contracts-level2.cs +86 -0
- package/framework/templates/code/dotnet/contracts/contracts-level3.cs +41 -0
- package/framework/templates/docs/spec.md +49 -0
- package/framework/templates/frontend/nextjs/Dockerfile.nextjs.hbs +43 -0
- package/framework/templates/frontend/nextjs/client-component.tsx.hbs +26 -0
- package/framework/templates/frontend/nextjs/env.mjs.hbs +32 -0
- package/framework/templates/frontend/nextjs/feature-form.tsx.hbs +56 -0
- package/framework/templates/frontend/nextjs/page.tsx.hbs +22 -0
- package/framework/templates/frontend/nextjs/tsconfig.json.hbs +26 -0
- package/framework/templates/frontend/nextjs/use-feature.ts.hbs +54 -0
- package/framework/templates/project-structure/dotnet-ddd.md +70 -0
- package/framework/workflows/docs/enforcement-pipeline.md +2 -1
- package/package.json +1 -1
- package/scripts/scan-nextjs.mjs +169 -0
- package/src/commands/project/doctor.js +52 -1
- package/src/commands/project/init.js +15 -1
- package/src/commands/project/update.js +6 -1
- package/src/lib/standards/standards-context-injector.js +5 -0
- package/src/lib/validators/nextjs/index.js +6 -0
- package/src/lib/validators/nextjs/next-component-validator.js +181 -0
- package/src/lib/validators/validation-runner.js +5 -0
- package/src/utils/agents-installer.js +14 -2
- package/.morph/.morphversion +0 -5
- package/.morph/analytics/threads-log.jsonl +0 -6
- package/.morph/config/config.json +0 -8
- package/.morph/framework/agents.json +0 -948
- package/.morph/framework/standards/STANDARDS.json +0 -812
- package/.morph/framework/standards/ai-agents/blazor-ui.md +0 -364
- package/.morph/framework/standards/ai-agents/production.md +0 -415
- package/.morph/framework/standards/ai-agents/setup.md +0 -418
- package/.morph/framework/standards/ai-agents/team-orchestration.md +0 -479
- package/.morph/framework/standards/ai-agents/workflows.md +0 -354
- package/.morph/framework/standards/architecture/ddd/aggregates.md +0 -120
- package/.morph/framework/standards/architecture/ddd/entities.md +0 -99
- package/.morph/framework/standards/architecture/ddd/value-objects.md +0 -124
- package/.morph/framework/standards/backend/api/minimal-api.md +0 -494
- package/.morph/framework/standards/backend/api/rest.md +0 -492
- package/.morph/framework/standards/backend/api/validation.md +0 -88
- package/.morph/framework/standards/backend/authentication/passkeys.md +0 -428
- package/.morph/framework/standards/backend/database/ef-core.md +0 -199
- package/.morph/framework/standards/backend/database/migrations.md +0 -393
- package/.morph/framework/standards/backend/database/postgresql/database.md +0 -352
- package/.morph/framework/standards/backend/database/repository-patterns.md +0 -528
- package/.morph/framework/standards/backend/database/vector-search-rag.md +0 -541
- package/.morph/framework/standards/backend/dotnet/async.md +0 -366
- package/.morph/framework/standards/backend/dotnet/core.md +0 -117
- package/.morph/framework/standards/backend/dotnet/di.md +0 -439
- package/.morph/framework/standards/backend/dotnet/program-cs-checklist.md +0 -92
- package/.morph/framework/standards/backend/integrations/asaas/asaas-api.md +0 -216
- package/.morph/framework/standards/backend/integrations/clerk/clerk-auth.md +0 -290
- package/.morph/framework/standards/backend/integrations/hangfire/hangfire-jobs.md +0 -350
- package/.morph/framework/standards/backend/integrations/resend/resend-email.md +0 -385
- package/.morph/framework/standards/context/analytics.md +0 -96
- package/.morph/framework/standards/context/bundles.md +0 -110
- package/.morph/framework/standards/context/priming.md +0 -78
- package/.morph/framework/standards/core/architecture.md +0 -185
- package/.morph/framework/standards/core/coding.md +0 -214
- package/.morph/framework/standards/core/git-branching-strategy.md +0 -403
- package/.morph/framework/standards/core/git.md +0 -185
- package/.morph/framework/standards/core/testing.md +0 -295
- package/.morph/framework/standards/data/nosql/blob-storage.md +0 -102
- package/.morph/framework/standards/data/nosql/cache/redis.md +0 -97
- package/.morph/framework/standards/data/nosql/cosmos-db.md +0 -118
- package/.morph/framework/standards/data/vector-search/azure-ai-search.md +0 -121
- package/.morph/framework/standards/data/vector-search/rag-chunking.md +0 -104
- package/.morph/framework/standards/frontend/blazor/design-checklist.md +0 -222
- package/.morph/framework/standards/frontend/blazor/fluent-ui-setup.md +0 -595
- package/.morph/framework/standards/frontend/blazor/fluent-ui.md +0 -137
- package/.morph/framework/standards/frontend/blazor/html-conversion.md +0 -184
- package/.morph/framework/standards/frontend/blazor/lifecycle.md +0 -195
- package/.morph/framework/standards/frontend/blazor/pitfalls.md +0 -198
- package/.morph/framework/standards/frontend/blazor/state.md +0 -191
- package/.morph/framework/standards/frontend/design-system/animations.md +0 -151
- package/.morph/framework/standards/frontend/design-system/naming.md +0 -64
- package/.morph/framework/standards/frontend/nextjs/nextjs-patterns.md +0 -215
- package/.morph/framework/standards/infrastructure/azure/azure.md +0 -624
- package/.morph/framework/standards/infrastructure/azure/bicep/bicep-patterns.md +0 -422
- package/.morph/framework/standards/infrastructure/azure/devops/azure-devops-setup.md +0 -516
- package/.morph/framework/standards/infrastructure/azure/devops/local-development.md +0 -520
- package/.morph/framework/standards/infrastructure/azure/services/functions.md +0 -486
- package/.morph/framework/standards/infrastructure/azure/services/service-bus.md +0 -459
- package/.morph/framework/standards/infrastructure/azure/services/storage.md +0 -407
- package/.morph/framework/standards/infrastructure/docker/easypanel-deploy.md +0 -196
- package/.morph/framework/standards/infrastructure/supabase/mcp-setup.md +0 -252
- package/.morph/framework/standards/infrastructure/supabase/supabase-auth.md +0 -176
- package/.morph/framework/standards/infrastructure/supabase/supabase-pgvector.md +0 -169
- package/.morph/framework/standards/infrastructure/supabase/supabase-rls.md +0 -184
- package/.morph/framework/standards/infrastructure/supabase/supabase-storage.md +0 -153
- package/.morph/framework/standards/integration/api/graphql.md +0 -91
- package/.morph/framework/standards/integration/api/grpc.md +0 -114
- package/.morph/framework/standards/integration/api/rest-design.md +0 -95
- package/.morph/framework/standards/integration/event-driven/cqrs.md +0 -101
- package/.morph/framework/standards/integration/event-driven/event-sourcing.md +0 -124
- package/.morph/framework/standards/integration/event-driven/service-bus.md +0 -95
- package/.morph/framework/standards/integration/mcp/mcp-tools.md +0 -384
- package/.morph/framework/standards/observability/logging.md +0 -131
- package/.morph/framework/standards/observability/metrics.md +0 -121
- package/.morph/framework/standards/observability/monitoring.md +0 -114
- package/.morph/framework/standards/observability/tracing.md +0 -132
- package/.morph/framework/standards/workflows/parallel-execution.md +0 -112
- package/.morph/framework/standards/workflows/thread-management.md +0 -113
- package/.morph/framework/templates/.idea/morph-templates.xml +0 -92
- package/.morph/framework/templates/.vscode/morph-templates.code-snippets +0 -186
- package/.morph/framework/templates/IDE-SNIPPETS.md +0 -266
- package/.morph/framework/templates/README.md +0 -814
- package/.morph/framework/templates/REGISTRY.json +0 -1492
- package/.morph/framework/templates/code/dotnet/backend/repository.cs +0 -141
- package/.morph/framework/templates/code/dotnet/backend/service.cs +0 -139
- package/.morph/framework/templates/code/dotnet/contracts/Commands.cs +0 -74
- package/.morph/framework/templates/code/dotnet/contracts/Entities.cs +0 -25
- package/.morph/framework/templates/code/dotnet/contracts/Queries.cs +0 -74
- package/.morph/framework/templates/code/dotnet/contracts/README.md +0 -74
- package/.morph/framework/templates/code/dotnet/contracts/api-contracts.cs +0 -173
- package/.morph/framework/templates/code/dotnet/contracts/contracts.cs +0 -217
- package/.morph/framework/templates/code/dotnet/contracts/contracts.cs.hbs +0 -172
- package/.morph/framework/templates/code/dotnet/database/migration.cs +0 -83
- package/.morph/framework/templates/code/dotnet/frontend/component.razor +0 -239
- package/.morph/framework/templates/code/dotnet/jobs/agent.cs +0 -163
- package/.morph/framework/templates/code/dotnet/jobs/job.cs +0 -171
- package/.morph/framework/templates/code/dotnet/test.cs +0 -239
- package/.morph/framework/templates/code/sql/rls-policy.sql +0 -57
- package/.morph/framework/templates/code/sql/supabase-migration.sql +0 -100
- package/.morph/framework/templates/code/sql/supabase-migration.template.sql +0 -113
- package/.morph/framework/templates/code/typescript/contracts.ts +0 -168
- package/.morph/framework/templates/context/CONTEXT-FEATURE.md +0 -276
- package/.morph/framework/templates/context/CONTEXT.md +0 -181
- package/.morph/framework/templates/docs/clarifications.md +0 -253
- package/.morph/framework/templates/docs/onboarding.md +0 -123
- package/.morph/framework/templates/docs/proposal.md +0 -182
- package/.morph/framework/templates/docs/schema-analysis.md +0 -119
- package/.morph/framework/templates/docs/spec.md +0 -149
- package/.morph/framework/templates/docs/ui-components.md +0 -124
- package/.morph/framework/templates/docs/ui-design-system.md +0 -76
- package/.morph/framework/templates/docs/ui-flows.md +0 -167
- package/.morph/framework/templates/docs/ui-mockups.md +0 -98
- package/.morph/framework/templates/docs/user-stories.md +0 -34
- package/.morph/framework/templates/examples/design-system-examples.md +0 -357
- package/.morph/framework/templates/examples/spec-examples.md +0 -90
- package/.morph/framework/templates/feature/decisions.md +0 -187
- package/.morph/framework/templates/feature/recap.md +0 -146
- package/.morph/framework/templates/feature/tasks.md +0 -199
- package/.morph/framework/templates/infrastructure/azure/Dockerfile.example +0 -82
- package/.morph/framework/templates/infrastructure/azure/README.md +0 -286
- package/.morph/framework/templates/infrastructure/azure/app-insights.bicep +0 -63
- package/.morph/framework/templates/infrastructure/azure/app-service.bicep +0 -164
- package/.morph/framework/templates/infrastructure/azure/container-app-env.bicep +0 -49
- package/.morph/framework/templates/infrastructure/azure/container-app.bicep +0 -156
- package/.morph/framework/templates/infrastructure/azure/deploy-checklist.md +0 -426
- package/.morph/framework/templates/infrastructure/azure/deploy.ps1 +0 -229
- package/.morph/framework/templates/infrastructure/azure/deploy.sh +0 -208
- package/.morph/framework/templates/infrastructure/azure/key-vault.bicep +0 -91
- package/.morph/framework/templates/infrastructure/azure/main.bicep +0 -189
- package/.morph/framework/templates/infrastructure/azure/parameters.dev.json +0 -29
- package/.morph/framework/templates/infrastructure/azure/parameters.prod.json +0 -29
- package/.morph/framework/templates/infrastructure/azure/parameters.staging.json +0 -29
- package/.morph/framework/templates/infrastructure/azure/sql-database.bicep +0 -103
- package/.morph/framework/templates/infrastructure/azure/storage.bicep +0 -106
- package/.morph/framework/templates/infrastructure/docker/Dockerfile.template +0 -58
- package/.morph/framework/templates/infrastructure/docker/docker-compose.template.yml +0 -67
- package/.morph/framework/templates/infrastructure/docker/dockerfile-api.dockerfile +0 -38
- package/.morph/framework/templates/infrastructure/docker/dockerfile-web.dockerfile +0 -48
- package/.morph/framework/templates/infrastructure/docker/easypanel.template.json +0 -54
- package/.morph/framework/templates/infrastructure/github/README.md +0 -593
- package/.morph/framework/templates/infrastructure/github/actions/azure-auth/action.yml.hbs +0 -22
- package/.morph/framework/templates/infrastructure/github/actions/docker-build-push/action.yml.hbs +0 -45
- package/.morph/framework/templates/infrastructure/github/actions/health-check/action.yml.hbs +0 -27
- package/.morph/framework/templates/infrastructure/github/workflows/deploy-azure-app-service.yml.hbs +0 -61
- package/.morph/framework/templates/infrastructure/github/workflows/deploy-easypanel.yml.hbs +0 -31
- package/.morph/framework/templates/infrastructure/github/workflows/docker-build-push.yml.hbs +0 -59
- package/.morph/framework/templates/infrastructure/github/workflows/dotnet-build.yml.hbs +0 -39
- package/.morph/framework/templates/integrations/asaas-client.cs +0 -387
- package/.morph/framework/templates/integrations/asaas-webhook.cs +0 -351
- package/.morph/framework/templates/integrations/azure-identity-config.cs +0 -288
- package/.morph/framework/templates/integrations/clerk-config.cs +0 -258
- package/.morph/framework/templates/meta-prompts/fusion/fusion-agent.md +0 -76
- package/.morph/framework/templates/meta-prompts/fusion/fusion-aggregator.md +0 -100
- package/.morph/framework/templates/meta-prompts/hops/hop-retry.md +0 -78
- package/.morph/framework/templates/meta-prompts/hops/hop-validation.md +0 -97
- package/.morph/framework/templates/meta-prompts/hops/hop-wrapper.md +0 -36
- package/.morph/framework/templates/meta-prompts/parallel-workers/parallel-coordinator.md +0 -113
- package/.morph/framework/templates/meta-prompts/parallel-workers/parallel-worker.md +0 -80
- package/.morph/framework/templates/meta-prompts/squad-leaders/backend-squad.md +0 -90
- package/.morph/framework/templates/meta-prompts/squad-leaders/frontend-squad.md +0 -126
- package/.morph/framework/templates/meta-prompts/squad-leaders/squad-leader.md +0 -43
- package/.morph/framework/templates/meta-prompts/validators/checkpoint-validator.md +0 -107
- package/.morph/framework/templates/meta-prompts/validators/pre-commit-validator.md +0 -95
- package/.morph/framework/templates/saas/subscription.cs +0 -347
- package/.morph/framework/templates/saas/tenant.cs +0 -338
- package/.morph/framework/templates/state.template.json +0 -17
- package/.morph/framework/templates/ui/FluentDesignTheme.cs +0 -149
- package/.morph/framework/templates/ui/MudTheme.cs +0 -281
- package/.morph/framework/templates/ui/design-system.css +0 -226
- package/.morph/logs/tool-failures.log +0 -7
- package/.morph/memory/pre-compact-2026-02-23T15-43-03-521Z.json +0 -16
- package/.morph/state.json +0 -48
- package/framework/templates/code/dotnet/contracts/contracts.cs +0 -217
- package/framework/templates/code/dotnet/contracts/contracts.cs.hbs +0 -172
|
@@ -1,352 +0,0 @@
|
|
|
1
|
-
# Supabase Database Standards
|
|
2
|
-
|
|
3
|
-
> **Scope:** nextjs-supabase
|
|
4
|
-
> **Layer:** 2 (on keyword)
|
|
5
|
-
> **Keywords:** postgresql, postgres, sql, supabase, database schema
|
|
6
|
-
> **Load When:** supabase or postgresql keywords detected
|
|
7
|
-
|
|
8
|
-
Database schema design, migrations, and Row Level Security (RLS) patterns for Supabase.
|
|
9
|
-
|
|
10
|
-
---
|
|
11
|
-
|
|
12
|
-
## Schema Design
|
|
13
|
-
|
|
14
|
-
### Naming Conventions
|
|
15
|
-
|
|
16
|
-
| Element | Convention | Example |
|
|
17
|
-
|---------|-----------|---------|
|
|
18
|
-
| **Tables** | snake_case, plural | `users`, `user_profiles`, `order_items` |
|
|
19
|
-
| **Columns** | snake_case | `created_at`, `user_id`, `is_active` |
|
|
20
|
-
| **Primary Keys** | `id` | `id uuid primary key default gen_random_uuid()` |
|
|
21
|
-
| **Foreign Keys** | `{table}_id` | `user_id`, `order_id` |
|
|
22
|
-
| **Timestamps** | `created_at`, `updated_at` | Always include |
|
|
23
|
-
| **Boolean** | `is_` or `has_` prefix | `is_active`, `has_verified_email` |
|
|
24
|
-
| **Indexes** | `idx_{table}_{column}` | `idx_users_email` |
|
|
25
|
-
|
|
26
|
-
### Standard Table Template
|
|
27
|
-
|
|
28
|
-
```sql
|
|
29
|
-
create table public.users (
|
|
30
|
-
id uuid primary key default gen_random_uuid(),
|
|
31
|
-
email text unique not null,
|
|
32
|
-
full_name text,
|
|
33
|
-
avatar_url text,
|
|
34
|
-
is_active boolean default true,
|
|
35
|
-
created_at timestamptz default now() not null,
|
|
36
|
-
updated_at timestamptz default now() not null
|
|
37
|
-
);
|
|
38
|
-
|
|
39
|
-
-- Updated timestamp trigger
|
|
40
|
-
create or replace function public.handle_updated_at()
|
|
41
|
-
returns trigger as $$
|
|
42
|
-
begin
|
|
43
|
-
new.updated_at = now();
|
|
44
|
-
return new;
|
|
45
|
-
end;
|
|
46
|
-
$$ language plpgsql;
|
|
47
|
-
|
|
48
|
-
create trigger users_updated_at
|
|
49
|
-
before update on public.users
|
|
50
|
-
for each row execute function public.handle_updated_at();
|
|
51
|
-
```
|
|
52
|
-
|
|
53
|
-
---
|
|
54
|
-
|
|
55
|
-
## Row Level Security (RLS)
|
|
56
|
-
|
|
57
|
-
### Enable RLS
|
|
58
|
-
|
|
59
|
-
```sql
|
|
60
|
-
-- Always enable RLS on user-facing tables
|
|
61
|
-
alter table public.profiles enable row level security;
|
|
62
|
-
```
|
|
63
|
-
|
|
64
|
-
### Common RLS Policies
|
|
65
|
-
|
|
66
|
-
#### User can read own profile
|
|
67
|
-
|
|
68
|
-
```sql
|
|
69
|
-
create policy "Users can view own profile"
|
|
70
|
-
on public.profiles for select
|
|
71
|
-
using (auth.uid() = user_id);
|
|
72
|
-
```
|
|
73
|
-
|
|
74
|
-
#### User can update own profile
|
|
75
|
-
|
|
76
|
-
```sql
|
|
77
|
-
create policy "Users can update own profile"
|
|
78
|
-
on public.profiles for update
|
|
79
|
-
using (auth.uid() = user_id)
|
|
80
|
-
with check (auth.uid() = user_id);
|
|
81
|
-
```
|
|
82
|
-
|
|
83
|
-
#### User can insert own profile
|
|
84
|
-
|
|
85
|
-
```sql
|
|
86
|
-
create policy "Users can insert own profile"
|
|
87
|
-
on public.profiles for insert
|
|
88
|
-
with check (auth.uid() = user_id);
|
|
89
|
-
```
|
|
90
|
-
|
|
91
|
-
#### Admin can do anything
|
|
92
|
-
|
|
93
|
-
```sql
|
|
94
|
-
create policy "Admins have full access"
|
|
95
|
-
on public.profiles for all
|
|
96
|
-
using (
|
|
97
|
-
exists (
|
|
98
|
-
select 1 from public.user_roles
|
|
99
|
-
where user_id = auth.uid() and role = 'admin'
|
|
100
|
-
)
|
|
101
|
-
);
|
|
102
|
-
```
|
|
103
|
-
|
|
104
|
-
#### Public read access
|
|
105
|
-
|
|
106
|
-
```sql
|
|
107
|
-
create policy "Public profiles are viewable by everyone"
|
|
108
|
-
on public.profiles for select
|
|
109
|
-
using (is_public = true);
|
|
110
|
-
```
|
|
111
|
-
|
|
112
|
-
---
|
|
113
|
-
|
|
114
|
-
## Migrations
|
|
115
|
-
|
|
116
|
-
### Migration File Naming
|
|
117
|
-
|
|
118
|
-
```
|
|
119
|
-
supabase/migrations/
|
|
120
|
-
20240101000000_create_users_table.sql
|
|
121
|
-
20240102000000_add_user_roles.sql
|
|
122
|
-
20240103000000_enable_rls_users.sql
|
|
123
|
-
```
|
|
124
|
-
|
|
125
|
-
### Migration Template
|
|
126
|
-
|
|
127
|
-
```sql
|
|
128
|
-
-- Create table
|
|
129
|
-
create table if not exists public.example_table (
|
|
130
|
-
id uuid primary key default gen_random_uuid(),
|
|
131
|
-
name text not null,
|
|
132
|
-
created_at timestamptz default now() not null
|
|
133
|
-
);
|
|
134
|
-
|
|
135
|
-
-- Enable RLS
|
|
136
|
-
alter table public.example_table enable row level security;
|
|
137
|
-
|
|
138
|
-
-- Create policies
|
|
139
|
-
create policy "Example policy"
|
|
140
|
-
on public.example_table for select
|
|
141
|
-
using (true);
|
|
142
|
-
|
|
143
|
-
-- Create indexes
|
|
144
|
-
create index if not exists idx_example_table_name
|
|
145
|
-
on public.example_table (name);
|
|
146
|
-
|
|
147
|
-
-- Rollback (always include)
|
|
148
|
-
-- drop table if exists public.example_table cascade;
|
|
149
|
-
```
|
|
150
|
-
|
|
151
|
-
---
|
|
152
|
-
|
|
153
|
-
## Relationships
|
|
154
|
-
|
|
155
|
-
### One-to-Many
|
|
156
|
-
|
|
157
|
-
```sql
|
|
158
|
-
create table public.posts (
|
|
159
|
-
id uuid primary key default gen_random_uuid(),
|
|
160
|
-
author_id uuid references public.users(id) on delete cascade,
|
|
161
|
-
title text not null,
|
|
162
|
-
content text,
|
|
163
|
-
created_at timestamptz default now()
|
|
164
|
-
);
|
|
165
|
-
|
|
166
|
-
create index idx_posts_author_id on public.posts (author_id);
|
|
167
|
-
```
|
|
168
|
-
|
|
169
|
-
### Many-to-Many (Join Table)
|
|
170
|
-
|
|
171
|
-
```sql
|
|
172
|
-
create table public.user_teams (
|
|
173
|
-
user_id uuid references public.users(id) on delete cascade,
|
|
174
|
-
team_id uuid references public.teams(id) on delete cascade,
|
|
175
|
-
role text not null default 'member',
|
|
176
|
-
joined_at timestamptz default now(),
|
|
177
|
-
primary key (user_id, team_id)
|
|
178
|
-
);
|
|
179
|
-
```
|
|
180
|
-
|
|
181
|
-
---
|
|
182
|
-
|
|
183
|
-
## Indexes
|
|
184
|
-
|
|
185
|
-
### When to Add Indexes
|
|
186
|
-
|
|
187
|
-
- Foreign keys (for joins)
|
|
188
|
-
- Columns used in WHERE clauses
|
|
189
|
-
- Columns used in ORDER BY
|
|
190
|
-
- Columns used in GROUP BY
|
|
191
|
-
- Text search columns (GIN index)
|
|
192
|
-
|
|
193
|
-
### Index Examples
|
|
194
|
-
|
|
195
|
-
```sql
|
|
196
|
-
-- B-tree (default, most common)
|
|
197
|
-
create index idx_users_email on public.users (email);
|
|
198
|
-
|
|
199
|
-
-- Partial index (for specific queries)
|
|
200
|
-
create index idx_users_active_email
|
|
201
|
-
on public.users (email) where is_active = true;
|
|
202
|
-
|
|
203
|
-
-- Composite index (multiple columns)
|
|
204
|
-
create index idx_posts_author_created
|
|
205
|
-
on public.posts (author_id, created_at desc);
|
|
206
|
-
|
|
207
|
-
-- GIN index (full-text search)
|
|
208
|
-
create index idx_posts_content_search
|
|
209
|
-
on public.posts using gin(to_tsvector('english', content));
|
|
210
|
-
```
|
|
211
|
-
|
|
212
|
-
---
|
|
213
|
-
|
|
214
|
-
## Functions & Triggers
|
|
215
|
-
|
|
216
|
-
### Auto-update Timestamp
|
|
217
|
-
|
|
218
|
-
```sql
|
|
219
|
-
create or replace function public.handle_updated_at()
|
|
220
|
-
returns trigger as $$
|
|
221
|
-
begin
|
|
222
|
-
new.updated_at = now();
|
|
223
|
-
return new;
|
|
224
|
-
end;
|
|
225
|
-
$$ language plpgsql;
|
|
226
|
-
|
|
227
|
-
-- Apply to any table
|
|
228
|
-
create trigger users_updated_at
|
|
229
|
-
before update on public.users
|
|
230
|
-
for each row execute function public.handle_updated_at();
|
|
231
|
-
```
|
|
232
|
-
|
|
233
|
-
### Soft Delete
|
|
234
|
-
|
|
235
|
-
```sql
|
|
236
|
-
create or replace function public.soft_delete()
|
|
237
|
-
returns trigger as $$
|
|
238
|
-
begin
|
|
239
|
-
update public.users
|
|
240
|
-
set deleted_at = now()
|
|
241
|
-
where id = old.id;
|
|
242
|
-
return null;
|
|
243
|
-
end;
|
|
244
|
-
$$ language plpgsql;
|
|
245
|
-
|
|
246
|
-
create trigger users_soft_delete
|
|
247
|
-
instead of delete on public.users
|
|
248
|
-
for each row execute function public.soft_delete();
|
|
249
|
-
```
|
|
250
|
-
|
|
251
|
-
---
|
|
252
|
-
|
|
253
|
-
## Supabase Client Queries
|
|
254
|
-
|
|
255
|
-
### Select
|
|
256
|
-
|
|
257
|
-
```typescript
|
|
258
|
-
const { data, error } = await supabase
|
|
259
|
-
.from('users')
|
|
260
|
-
.select('id, name, email')
|
|
261
|
-
.eq('is_active', true)
|
|
262
|
-
.order('created_at', { ascending: false })
|
|
263
|
-
.limit(10)
|
|
264
|
-
```
|
|
265
|
-
|
|
266
|
-
### Insert
|
|
267
|
-
|
|
268
|
-
```typescript
|
|
269
|
-
const { data, error } = await supabase
|
|
270
|
-
.from('users')
|
|
271
|
-
.insert({ name: 'John', email: 'john@example.com' })
|
|
272
|
-
.select()
|
|
273
|
-
.single()
|
|
274
|
-
```
|
|
275
|
-
|
|
276
|
-
### Update
|
|
277
|
-
|
|
278
|
-
```typescript
|
|
279
|
-
const { data, error } = await supabase
|
|
280
|
-
.from('users')
|
|
281
|
-
.update({ name: 'John Doe' })
|
|
282
|
-
.eq('id', userId)
|
|
283
|
-
.select()
|
|
284
|
-
.single()
|
|
285
|
-
```
|
|
286
|
-
|
|
287
|
-
### Delete
|
|
288
|
-
|
|
289
|
-
```typescript
|
|
290
|
-
const { error } = await supabase
|
|
291
|
-
.from('users')
|
|
292
|
-
.delete()
|
|
293
|
-
.eq('id', userId)
|
|
294
|
-
```
|
|
295
|
-
|
|
296
|
-
### Joins (Foreign Tables)
|
|
297
|
-
|
|
298
|
-
```typescript
|
|
299
|
-
const { data } = await supabase
|
|
300
|
-
.from('posts')
|
|
301
|
-
.select(`
|
|
302
|
-
id,
|
|
303
|
-
title,
|
|
304
|
-
author:users (
|
|
305
|
-
id,
|
|
306
|
-
name,
|
|
307
|
-
avatar_url
|
|
308
|
-
)
|
|
309
|
-
`)
|
|
310
|
-
```
|
|
311
|
-
|
|
312
|
-
---
|
|
313
|
-
|
|
314
|
-
## Realtime Subscriptions
|
|
315
|
-
|
|
316
|
-
### Listen to Changes
|
|
317
|
-
|
|
318
|
-
```typescript
|
|
319
|
-
const channel = supabase
|
|
320
|
-
.channel('posts-changes')
|
|
321
|
-
.on(
|
|
322
|
-
'postgres_changes',
|
|
323
|
-
{
|
|
324
|
-
event: '*', // or 'INSERT', 'UPDATE', 'DELETE'
|
|
325
|
-
schema: 'public',
|
|
326
|
-
table: 'posts'
|
|
327
|
-
},
|
|
328
|
-
(payload) => {
|
|
329
|
-
console.log('Change received!', payload)
|
|
330
|
-
}
|
|
331
|
-
)
|
|
332
|
-
.subscribe()
|
|
333
|
-
|
|
334
|
-
// Cleanup
|
|
335
|
-
supabase.removeChannel(channel)
|
|
336
|
-
```
|
|
337
|
-
|
|
338
|
-
---
|
|
339
|
-
|
|
340
|
-
## Performance Best Practices
|
|
341
|
-
|
|
342
|
-
1. **Use select() specific columns** - Don't select `*` unnecessarily
|
|
343
|
-
2. **Add indexes** - For foreign keys and WHERE/ORDER BY columns
|
|
344
|
-
3. **Limit results** - Use `.limit()` for pagination
|
|
345
|
-
4. **Use RLS efficiently** - Simple policies are faster
|
|
346
|
-
5. **Batch operations** - Use array inserts instead of loops
|
|
347
|
-
6. **Use materialized views** - For complex aggregations
|
|
348
|
-
7. **Enable statement timeout** - Prevent long-running queries
|
|
349
|
-
|
|
350
|
-
---
|
|
351
|
-
|
|
352
|
-
*Supabase Database Standards - MORPH-SPEC by Polymorphism Tech*
|