@polymorphism-tech/morph-spec 4.7.0 → 4.7.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.
Files changed (232) hide show
  1. package/.morph/.morphversion +5 -0
  2. package/.morph/analytics/threads-log.jsonl +5 -0
  3. package/.morph/config/config.json +8 -0
  4. package/.morph/framework/agents.json +1815 -0
  5. package/.morph/framework/hooks/README.md +205 -0
  6. package/.morph/framework/hooks/claude-code/notification/approval-reminder.js +54 -0
  7. package/.morph/framework/hooks/claude-code/post-tool-use/dispatch.js +83 -0
  8. package/.morph/framework/hooks/claude-code/post-tool-use/handle-tool-failure.js +42 -0
  9. package/.morph/framework/hooks/claude-code/pre-compact/save-morph-context.js +61 -0
  10. package/.morph/framework/hooks/claude-code/pre-tool-use/enforce-phase-writes.js +71 -0
  11. package/.morph/framework/hooks/claude-code/pre-tool-use/protect-readonly-files.js +58 -0
  12. package/.morph/framework/hooks/claude-code/pre-tool-use/protect-spec-files.js +64 -0
  13. package/.morph/framework/hooks/claude-code/session-start/inject-morph-context.js +94 -0
  14. package/.morph/framework/hooks/claude-code/statusline.py +538 -0
  15. package/.morph/framework/hooks/claude-code/statusline.sh +7 -0
  16. package/.morph/framework/hooks/claude-code/stop/validate-completion.js +88 -0
  17. package/.morph/framework/hooks/claude-code/user-prompt/enrich-prompt.js +91 -0
  18. package/.morph/framework/hooks/git/commit-msg/conventional-commits.sh +33 -0
  19. package/.morph/framework/hooks/git/pre-commit/agents.sh +25 -0
  20. package/.morph/framework/hooks/git/pre-commit/orchestrator.sh +64 -0
  21. package/.morph/framework/hooks/git/pre-commit/specs.sh +50 -0
  22. package/.morph/framework/hooks/git/pre-push/run-tests.sh +44 -0
  23. package/.morph/framework/hooks/shared/hook-response.js +45 -0
  24. package/.morph/framework/hooks/shared/phase-utils.js +129 -0
  25. package/.morph/framework/hooks/shared/state-reader.js +138 -0
  26. package/.morph/framework/hooks/shared/stdin-reader.js +26 -0
  27. package/.morph/framework/standards/STANDARDS.json +933 -0
  28. package/.morph/framework/standards/ai-agents/blazor-ui.md +364 -0
  29. package/.morph/framework/standards/ai-agents/production.md +415 -0
  30. package/.morph/framework/standards/ai-agents/setup.md +418 -0
  31. package/.morph/framework/standards/ai-agents/team-orchestration.md +479 -0
  32. package/.morph/framework/standards/ai-agents/workflows.md +354 -0
  33. package/.morph/framework/standards/architecture/ddd/aggregates.md +120 -0
  34. package/.morph/framework/standards/architecture/ddd/bounded-contexts.md +105 -0
  35. package/.morph/framework/standards/architecture/ddd/complexity-levels.md +108 -0
  36. package/.morph/framework/standards/architecture/ddd/entities.md +99 -0
  37. package/.morph/framework/standards/architecture/ddd/ubiquitous-language.md +58 -0
  38. package/.morph/framework/standards/architecture/ddd/value-objects.md +124 -0
  39. package/.morph/framework/standards/backend/api/minimal-api.md +494 -0
  40. package/.morph/framework/standards/backend/api/rest.md +492 -0
  41. package/.morph/framework/standards/backend/api/validation.md +88 -0
  42. package/.morph/framework/standards/backend/authentication/passkeys.md +428 -0
  43. package/.morph/framework/standards/backend/database/ef-core.md +199 -0
  44. package/.morph/framework/standards/backend/database/migrations.md +393 -0
  45. package/.morph/framework/standards/backend/database/postgresql/database.md +352 -0
  46. package/.morph/framework/standards/backend/database/repository-patterns.md +528 -0
  47. package/.morph/framework/standards/backend/database/vector-search-rag.md +541 -0
  48. package/.morph/framework/standards/backend/dotnet/async.md +366 -0
  49. package/.morph/framework/standards/backend/dotnet/core.md +117 -0
  50. package/.morph/framework/standards/backend/dotnet/di.md +439 -0
  51. package/.morph/framework/standards/backend/dotnet/program-cs-checklist.md +92 -0
  52. package/.morph/framework/standards/backend/integrations/asaas/asaas-api.md +216 -0
  53. package/.morph/framework/standards/backend/integrations/clerk/clerk-auth.md +290 -0
  54. package/.morph/framework/standards/backend/integrations/hangfire/hangfire-jobs.md +350 -0
  55. package/.morph/framework/standards/backend/integrations/resend/resend-email.md +385 -0
  56. package/.morph/framework/standards/context/analytics.md +96 -0
  57. package/.morph/framework/standards/context/bundles.md +110 -0
  58. package/.morph/framework/standards/context/priming.md +78 -0
  59. package/.morph/framework/standards/core/architecture.md +185 -0
  60. package/.morph/framework/standards/core/coding.md +214 -0
  61. package/.morph/framework/standards/core/git-branching-strategy.md +403 -0
  62. package/.morph/framework/standards/core/git.md +185 -0
  63. package/.morph/framework/standards/core/testing.md +295 -0
  64. package/.morph/framework/standards/data/nosql/blob-storage.md +102 -0
  65. package/.morph/framework/standards/data/nosql/cache/redis.md +97 -0
  66. package/.morph/framework/standards/data/nosql/cosmos-db.md +118 -0
  67. package/.morph/framework/standards/data/vector-search/azure-ai-search.md +121 -0
  68. package/.morph/framework/standards/data/vector-search/rag-chunking.md +104 -0
  69. package/.morph/framework/standards/frontend/blazor/design-checklist.md +222 -0
  70. package/.morph/framework/standards/frontend/blazor/fluent-ui-setup.md +595 -0
  71. package/.morph/framework/standards/frontend/blazor/fluent-ui.md +137 -0
  72. package/.morph/framework/standards/frontend/blazor/html-conversion.md +184 -0
  73. package/.morph/framework/standards/frontend/blazor/lifecycle.md +195 -0
  74. package/.morph/framework/standards/frontend/blazor/pitfalls.md +198 -0
  75. package/.morph/framework/standards/frontend/blazor/state.md +191 -0
  76. package/.morph/framework/standards/frontend/design-system/animations.md +151 -0
  77. package/.morph/framework/standards/frontend/design-system/naming.md +64 -0
  78. package/.morph/framework/standards/frontend/nextjs/app-router.md +123 -0
  79. package/.morph/framework/standards/frontend/nextjs/components.md +132 -0
  80. package/.morph/framework/standards/frontend/nextjs/data-fetching.md +126 -0
  81. package/.morph/framework/standards/frontend/nextjs/forms.md +128 -0
  82. package/.morph/framework/standards/frontend/nextjs/naming-conventions.md +67 -0
  83. package/.morph/framework/standards/frontend/nextjs/nextjs-patterns.md +215 -0
  84. package/.morph/framework/standards/frontend/nextjs/project-structure.md +102 -0
  85. package/.morph/framework/standards/frontend/nextjs/state-management.md +72 -0
  86. package/.morph/framework/standards/frontend/nextjs/testing.md +111 -0
  87. package/.morph/framework/standards/infrastructure/azure/azure.md +624 -0
  88. package/.morph/framework/standards/infrastructure/azure/bicep/bicep-patterns.md +422 -0
  89. package/.morph/framework/standards/infrastructure/azure/devops/azure-devops-setup.md +516 -0
  90. package/.morph/framework/standards/infrastructure/azure/devops/local-development.md +520 -0
  91. package/.morph/framework/standards/infrastructure/azure/services/functions.md +486 -0
  92. package/.morph/framework/standards/infrastructure/azure/services/service-bus.md +459 -0
  93. package/.morph/framework/standards/infrastructure/azure/services/storage.md +407 -0
  94. package/.morph/framework/standards/infrastructure/docker/easypanel-deploy.md +196 -0
  95. package/.morph/framework/standards/infrastructure/supabase/mcp-setup.md +252 -0
  96. package/.morph/framework/standards/infrastructure/supabase/supabase-auth.md +176 -0
  97. package/.morph/framework/standards/infrastructure/supabase/supabase-pgvector.md +169 -0
  98. package/.morph/framework/standards/infrastructure/supabase/supabase-rls.md +184 -0
  99. package/.morph/framework/standards/infrastructure/supabase/supabase-storage.md +153 -0
  100. package/.morph/framework/standards/integration/api/graphql.md +91 -0
  101. package/.morph/framework/standards/integration/api/grpc.md +114 -0
  102. package/.morph/framework/standards/integration/api/rest-design.md +95 -0
  103. package/.morph/framework/standards/integration/event-driven/cqrs.md +101 -0
  104. package/.morph/framework/standards/integration/event-driven/event-sourcing.md +124 -0
  105. package/.morph/framework/standards/integration/event-driven/service-bus.md +95 -0
  106. package/.morph/framework/standards/integration/mcp/mcp-tools.md +384 -0
  107. package/.morph/framework/standards/observability/logging.md +131 -0
  108. package/.morph/framework/standards/observability/metrics.md +121 -0
  109. package/.morph/framework/standards/observability/monitoring.md +114 -0
  110. package/.morph/framework/standards/observability/tracing.md +132 -0
  111. package/.morph/framework/standards/workflows/parallel-execution.md +112 -0
  112. package/.morph/framework/standards/workflows/thread-management.md +113 -0
  113. package/.morph/framework/templates/.idea/morph-templates.xml +92 -0
  114. package/.morph/framework/templates/.vscode/morph-templates.code-snippets +186 -0
  115. package/.morph/framework/templates/IDE-SNIPPETS.md +266 -0
  116. package/.morph/framework/templates/README.md +814 -0
  117. package/.morph/framework/templates/REGISTRY.json +1888 -0
  118. package/.morph/framework/templates/code/dotnet/backend/repository.cs +141 -0
  119. package/.morph/framework/templates/code/dotnet/backend/service.cs +139 -0
  120. package/.morph/framework/templates/code/dotnet/contracts/Commands.cs +74 -0
  121. package/.morph/framework/templates/code/dotnet/contracts/Entities.cs +25 -0
  122. package/.morph/framework/templates/code/dotnet/contracts/Queries.cs +74 -0
  123. package/.morph/framework/templates/code/dotnet/contracts/README.md +74 -0
  124. package/.morph/framework/templates/code/dotnet/contracts/api-contracts.cs +173 -0
  125. package/.morph/framework/templates/code/dotnet/contracts/contracts-level1.cs +69 -0
  126. package/.morph/framework/templates/code/dotnet/contracts/contracts-level2.cs +86 -0
  127. package/.morph/framework/templates/code/dotnet/contracts/contracts-level3.cs +41 -0
  128. package/.morph/framework/templates/code/dotnet/database/migration.cs +83 -0
  129. package/.morph/framework/templates/code/dotnet/frontend/component.razor +239 -0
  130. package/.morph/framework/templates/code/dotnet/jobs/agent.cs +163 -0
  131. package/.morph/framework/templates/code/dotnet/jobs/job.cs +171 -0
  132. package/.morph/framework/templates/code/dotnet/test.cs +239 -0
  133. package/.morph/framework/templates/code/sql/rls-policy.sql +57 -0
  134. package/.morph/framework/templates/code/sql/supabase-migration.sql +100 -0
  135. package/.morph/framework/templates/code/sql/supabase-migration.template.sql +113 -0
  136. package/.morph/framework/templates/code/typescript/contracts.ts +168 -0
  137. package/.morph/framework/templates/context/CONTEXT-FEATURE.md +276 -0
  138. package/.morph/framework/templates/context/CONTEXT.md +181 -0
  139. package/.morph/framework/templates/docs/clarifications.md +253 -0
  140. package/.morph/framework/templates/docs/onboarding.md +123 -0
  141. package/.morph/framework/templates/docs/proposal.md +182 -0
  142. package/.morph/framework/templates/docs/schema-analysis.md +119 -0
  143. package/.morph/framework/templates/docs/spec.md +198 -0
  144. package/.morph/framework/templates/docs/ui-components.md +124 -0
  145. package/.morph/framework/templates/docs/ui-design-system.md +76 -0
  146. package/.morph/framework/templates/docs/ui-flows.md +167 -0
  147. package/.morph/framework/templates/docs/ui-mockups.md +98 -0
  148. package/.morph/framework/templates/docs/user-stories.md +34 -0
  149. package/.morph/framework/templates/examples/design-system-examples.md +357 -0
  150. package/.morph/framework/templates/examples/spec-examples.md +90 -0
  151. package/.morph/framework/templates/feature/decisions.md +187 -0
  152. package/.morph/framework/templates/feature/recap.md +146 -0
  153. package/.morph/framework/templates/feature/tasks.md +199 -0
  154. package/.morph/framework/templates/frontend/nextjs/Dockerfile.nextjs.hbs +43 -0
  155. package/.morph/framework/templates/frontend/nextjs/client-component.tsx.hbs +26 -0
  156. package/.morph/framework/templates/frontend/nextjs/env.mjs.hbs +32 -0
  157. package/.morph/framework/templates/frontend/nextjs/feature-form.tsx.hbs +56 -0
  158. package/.morph/framework/templates/frontend/nextjs/page.tsx.hbs +22 -0
  159. package/.morph/framework/templates/frontend/nextjs/tsconfig.json.hbs +26 -0
  160. package/.morph/framework/templates/frontend/nextjs/use-feature.ts.hbs +54 -0
  161. package/.morph/framework/templates/infrastructure/azure/Dockerfile.example +82 -0
  162. package/.morph/framework/templates/infrastructure/azure/README.md +286 -0
  163. package/.morph/framework/templates/infrastructure/azure/app-insights.bicep +63 -0
  164. package/.morph/framework/templates/infrastructure/azure/app-service.bicep +164 -0
  165. package/.morph/framework/templates/infrastructure/azure/container-app-env.bicep +49 -0
  166. package/.morph/framework/templates/infrastructure/azure/container-app.bicep +156 -0
  167. package/.morph/framework/templates/infrastructure/azure/deploy-checklist.md +426 -0
  168. package/.morph/framework/templates/infrastructure/azure/deploy.ps1 +229 -0
  169. package/.morph/framework/templates/infrastructure/azure/deploy.sh +208 -0
  170. package/.morph/framework/templates/infrastructure/azure/key-vault.bicep +91 -0
  171. package/.morph/framework/templates/infrastructure/azure/main.bicep +189 -0
  172. package/.morph/framework/templates/infrastructure/azure/parameters.dev.json +29 -0
  173. package/.morph/framework/templates/infrastructure/azure/parameters.prod.json +29 -0
  174. package/.morph/framework/templates/infrastructure/azure/parameters.staging.json +29 -0
  175. package/.morph/framework/templates/infrastructure/azure/sql-database.bicep +103 -0
  176. package/.morph/framework/templates/infrastructure/azure/storage.bicep +106 -0
  177. package/.morph/framework/templates/infrastructure/docker/Dockerfile.template +58 -0
  178. package/.morph/framework/templates/infrastructure/docker/docker-compose.template.yml +67 -0
  179. package/.morph/framework/templates/infrastructure/docker/dockerfile-api.dockerfile +38 -0
  180. package/.morph/framework/templates/infrastructure/docker/dockerfile-web.dockerfile +48 -0
  181. package/.morph/framework/templates/infrastructure/docker/easypanel.template.json +54 -0
  182. package/.morph/framework/templates/infrastructure/github/README.md +593 -0
  183. package/.morph/framework/templates/infrastructure/github/actions/azure-auth/action.yml.hbs +22 -0
  184. package/.morph/framework/templates/infrastructure/github/actions/docker-build-push/action.yml.hbs +45 -0
  185. package/.morph/framework/templates/infrastructure/github/actions/health-check/action.yml.hbs +27 -0
  186. package/.morph/framework/templates/infrastructure/github/workflows/deploy-azure-app-service.yml.hbs +61 -0
  187. package/.morph/framework/templates/infrastructure/github/workflows/deploy-easypanel.yml.hbs +31 -0
  188. package/.morph/framework/templates/infrastructure/github/workflows/docker-build-push.yml.hbs +59 -0
  189. package/.morph/framework/templates/infrastructure/github/workflows/dotnet-build.yml.hbs +39 -0
  190. package/.morph/framework/templates/integrations/asaas-client.cs +387 -0
  191. package/.morph/framework/templates/integrations/asaas-webhook.cs +351 -0
  192. package/.morph/framework/templates/integrations/azure-identity-config.cs +288 -0
  193. package/.morph/framework/templates/integrations/clerk-config.cs +258 -0
  194. package/.morph/framework/templates/meta-prompts/fusion/fusion-agent.md +76 -0
  195. package/.morph/framework/templates/meta-prompts/fusion/fusion-aggregator.md +100 -0
  196. package/.morph/framework/templates/meta-prompts/hops/hop-retry.md +78 -0
  197. package/.morph/framework/templates/meta-prompts/hops/hop-validation.md +97 -0
  198. package/.morph/framework/templates/meta-prompts/hops/hop-wrapper.md +36 -0
  199. package/.morph/framework/templates/meta-prompts/parallel-workers/parallel-coordinator.md +113 -0
  200. package/.morph/framework/templates/meta-prompts/parallel-workers/parallel-worker.md +80 -0
  201. package/.morph/framework/templates/meta-prompts/squad-leaders/backend-squad.md +90 -0
  202. package/.morph/framework/templates/meta-prompts/squad-leaders/frontend-squad.md +126 -0
  203. package/.morph/framework/templates/meta-prompts/squad-leaders/squad-leader.md +43 -0
  204. package/.morph/framework/templates/meta-prompts/validators/checkpoint-validator.md +107 -0
  205. package/.morph/framework/templates/meta-prompts/validators/pre-commit-validator.md +95 -0
  206. package/.morph/framework/templates/project-structure/dotnet-ddd.md +70 -0
  207. package/.morph/framework/templates/saas/subscription.cs +347 -0
  208. package/.morph/framework/templates/saas/tenant.cs +338 -0
  209. package/.morph/framework/templates/state.template.json +17 -0
  210. package/.morph/framework/templates/ui/FluentDesignTheme.cs +149 -0
  211. package/.morph/framework/templates/ui/MudTheme.cs +281 -0
  212. package/.morph/framework/templates/ui/design-system.css +226 -0
  213. package/.morph/logs/tool-failures.log +17 -0
  214. package/.morph/memory/pre-compact-2026-02-24T17-43-30-049Z.json +16 -0
  215. package/.morph/plans/eager-watching-bunny.md +105 -0
  216. package/.morph/plans/temporal-seeking-nebula.md +45 -0
  217. package/.morph/state.json +48 -0
  218. package/CLAUDE.md +1 -1
  219. package/README.md +119 -99
  220. package/bin/morph-spec.js +0 -9
  221. package/framework/CLAUDE.md +1 -1
  222. package/framework/hooks/README.md +10 -6
  223. package/framework/hooks/claude-code/notification/approval-reminder.js +2 -0
  224. package/framework/hooks/claude-code/post-tool-use/dispatch.js +1 -1
  225. package/framework/hooks/claude-code/stop/validate-completion.js +1 -1
  226. package/framework/hooks/claude-code/user-prompt/enrich-prompt.js +1 -1
  227. package/package.json +1 -1
  228. package/src/commands/project/init.js +15 -42
  229. package/src/commands/project/update.js +22 -37
  230. package/src/lib/installers/mcp-installer.js +18 -3
  231. package/src/utils/hooks-installer.js +5 -15
  232. package/src/commands/project/detect.js +0 -114
@@ -0,0 +1,352 @@
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*