insforge 0.3.3 → 1.3.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/.claude-plugin/marketplace.json +20 -0
- package/.dockerignore +60 -57
- package/.env.example +84 -49
- package/.github/ISSUE_TEMPLATE/bug_report.yml +36 -83
- package/.github/ISSUE_TEMPLATE/config.yml +11 -11
- package/.github/ISSUE_TEMPLATE/feature_request.yml +26 -79
- package/.github/PULL_REQUEST_TEMPLATE.md +7 -0
- package/.github/copilot-instructions.md +146 -146
- package/.github/workflows/build-image.yml +66 -65
- package/.github/workflows/ci-premerge-check.yml +23 -23
- package/.github/workflows/e2e.yml +63 -0
- package/.github/workflows/lint-and-format.yml +32 -32
- package/.prettierignore +64 -64
- package/CHANGELOG.md +44 -3
- package/CLAUDE_PLUGIN.md +104 -0
- package/CODE_OF_CONDUCT.md +128 -0
- package/CONTRIBUTING.md +125 -125
- package/Dockerfile +30 -27
- package/GITHUB_OAUTH_SETUP.md +49 -49
- package/GOOGLE_OAUTH_SETUP.md +148 -148
- package/LICENSE +201 -201
- package/README.md +182 -134
- package/assets/Dark.svg +23 -23
- package/assets/mcpInstallv2.png +0 -0
- package/assets/sampleResponse.png +0 -0
- package/auth/index.html +13 -0
- package/auth/package.json +28 -0
- package/auth/public/favicon.ico +0 -0
- package/auth/src/App.tsx +33 -0
- package/auth/src/components/ErrorCard.tsx +37 -0
- package/auth/src/components/Layout.tsx +13 -0
- package/auth/src/index.css +19 -0
- package/auth/src/lib/broadcastService.ts +117 -0
- package/auth/src/lib/utils.ts +11 -0
- package/auth/src/main.tsx +22 -0
- package/auth/src/pages/ForgotPasswordPage.tsx +11 -0
- package/auth/src/pages/ResetPasswordPage.tsx +11 -0
- package/auth/src/pages/SignInPage.tsx +60 -0
- package/auth/src/pages/SignUpPage.tsx +60 -0
- package/auth/src/pages/VerifyEmailPage.tsx +20 -0
- package/auth/src/vite-env.d.ts +10 -0
- package/auth/tsconfig.json +32 -0
- package/auth/tsconfig.node.json +11 -0
- package/auth/vite.config.ts +25 -0
- package/backend/package.json +78 -75
- package/backend/src/api/{middleware → middlewares}/auth.ts +8 -9
- package/backend/src/api/middlewares/rate-limiters.ts +127 -0
- package/backend/src/api/routes/{ai.ts → ai/index.routes.ts} +22 -26
- package/backend/src/api/routes/auth/index.routes.ts +667 -0
- package/backend/src/api/routes/auth/oauth.routes.ts +473 -0
- package/backend/src/api/routes/{database.advance.ts → database/advance.routes.ts} +128 -65
- package/backend/src/api/routes/database/index.routes.ts +90 -0
- package/backend/src/api/routes/{database.records.ts → database/records.routes.ts} +26 -12
- package/backend/src/api/routes/{database.tables.ts → database/tables.routes.ts} +6 -23
- package/backend/src/api/routes/docs/index.routes.ts +75 -0
- package/backend/src/api/routes/email/index.routes.ts +35 -0
- package/backend/src/api/routes/functions/index.routes.ts +194 -0
- package/backend/src/api/routes/{logs.ts → logs/index.routes.ts} +25 -30
- package/backend/src/api/routes/{metadata.ts → metadata/index.routes.ts} +33 -31
- package/backend/src/api/routes/realtime/channels.routes.ts +81 -0
- package/backend/src/api/routes/realtime/index.routes.ts +12 -0
- package/backend/src/api/routes/realtime/messages.routes.ts +48 -0
- package/backend/src/api/routes/realtime/permissions.routes.ts +19 -0
- package/backend/src/api/routes/{secrets.ts → secrets/index.routes.ts} +27 -22
- package/backend/src/api/routes/{storage.ts → storage/index.routes.ts} +48 -61
- package/backend/src/api/routes/usage/index.routes.ts +91 -0
- package/backend/src/infra/config/app.config.ts +51 -0
- package/backend/src/infra/database/database.manager.ts +182 -0
- package/backend/{migrations → src/infra/database/migrations}/000_create-base-tables.sql +141 -141
- package/backend/{migrations → src/infra/database/migrations}/001_create-helper-functions.sql +40 -40
- package/backend/{migrations → src/infra/database/migrations}/002_rename-auth-tables.sql +29 -29
- package/backend/{migrations → src/infra/database/migrations}/003_create-users-table.sql +55 -55
- package/backend/{migrations → src/infra/database/migrations}/004_add-reload-postgrest-func.sql +23 -23
- package/backend/{migrations → src/infra/database/migrations}/005_enable-project-admin-modify-users.sql +29 -29
- package/backend/{migrations → src/infra/database/migrations}/006_modify-ai-usage-table.sql +24 -24
- package/backend/{migrations → src/infra/database/migrations}/007_drop-metadata-table.sql +1 -1
- package/backend/{migrations → src/infra/database/migrations}/008_add-system-tables.sql +76 -76
- package/backend/{migrations → src/infra/database/migrations}/009_add-function-secrets.sql +23 -23
- package/backend/{migrations → src/infra/database/migrations}/010_modify-ai-config-modalities.sql +93 -93
- package/backend/{migrations → src/infra/database/migrations}/011_refactor-secrets-table.sql +15 -15
- package/backend/{migrations → src/infra/database/migrations}/012_add-storage-uploaded-by.sql +7 -7
- package/backend/src/infra/database/migrations/013_create-auth-schema-functions.sql +44 -0
- package/backend/src/infra/database/migrations/014_add-updated-at-trigger-user-table.sql +8 -0
- package/backend/src/infra/database/migrations/015_create-auth-config-and-email-otp-tables.sql +60 -0
- package/backend/src/infra/database/migrations/016_update-auth-config-and-email-otp.sql +24 -0
- package/backend/src/infra/database/migrations/017_create-realtime-schema.sql +233 -0
- package/backend/src/infra/realtime/realtime.manager.ts +246 -0
- package/backend/src/infra/realtime/webhook-sender.ts +82 -0
- package/backend/src/{core/secrets/encryption.ts → infra/security/encryption.manager.ts} +3 -2
- package/backend/src/infra/security/token.manager.ts +219 -0
- package/backend/src/infra/socket/socket.manager.ts +522 -0
- package/backend/src/providers/ai/openrouter.provider.ts +380 -0
- package/backend/src/providers/email/base.provider.ts +38 -0
- package/backend/src/providers/email/cloud.provider.ts +271 -0
- package/backend/src/{core/logs/providers → providers/logs}/base.provider.ts +11 -11
- package/backend/src/{core/logs/providers → providers/logs}/cloudwatch.provider.ts +61 -38
- package/backend/src/providers/logs/local.provider.ts +185 -0
- package/backend/src/providers/oauth/apple.provider.ts +266 -0
- package/backend/src/providers/oauth/base.provider.ts +29 -0
- package/backend/src/providers/oauth/discord.provider.ts +195 -0
- package/backend/src/providers/oauth/facebook.provider.ts +194 -0
- package/backend/src/providers/oauth/github.provider.ts +208 -0
- package/backend/src/providers/oauth/google.provider.ts +249 -0
- package/backend/src/providers/oauth/index.ts +8 -0
- package/backend/src/providers/oauth/linkedin.provider.ts +240 -0
- package/backend/src/providers/oauth/microsoft.provider.ts +169 -0
- package/backend/src/providers/oauth/x.provider.ts +202 -0
- package/backend/src/providers/storage/base.provider.ts +29 -0
- package/backend/src/providers/storage/local.provider.ts +103 -0
- package/backend/src/providers/storage/s3.provider.ts +313 -0
- package/backend/src/server.ts +317 -288
- package/backend/src/{core/ai/config.ts → services/ai/ai-config.service.ts} +19 -24
- package/backend/src/services/ai/ai-model.service.ts +60 -0
- package/backend/src/{core/ai/usage.ts → services/ai/ai-usage.service.ts} +28 -35
- package/backend/src/{core/ai/chat.ts → services/ai/chat-completion.service.ts} +37 -24
- package/backend/src/services/ai/helpers.ts +64 -0
- package/backend/src/{core/ai/image.ts → services/ai/image-generation.service.ts} +17 -19
- package/backend/src/services/ai/index.ts +13 -0
- package/backend/src/services/auth/auth-config.service.ts +250 -0
- package/backend/src/services/auth/auth-otp.service.ts +424 -0
- package/backend/src/services/auth/auth.service.ts +1150 -0
- package/backend/src/services/auth/index.ts +4 -0
- package/backend/src/{core/auth/oauth.ts → services/auth/oauth-config.service.ts} +106 -52
- package/backend/src/{core/database/advance.ts → services/database/database-advance.service.ts} +97 -131
- package/backend/src/services/database/database-table.service.ts +802 -0
- package/backend/src/services/database/database.service.ts +127 -0
- package/backend/src/services/email/email.service.ts +73 -0
- package/backend/src/{core/functions/functions.ts → services/functions/function.service.ts} +95 -88
- package/backend/src/{core/logs/audit.ts → services/logs/audit.service.ts} +92 -75
- package/backend/src/services/logs/log.service.ts +73 -0
- package/backend/src/services/realtime/index.ts +3 -0
- package/backend/src/services/realtime/realtime-auth.service.ts +104 -0
- package/backend/src/services/realtime/realtime-channel.service.ts +237 -0
- package/backend/src/services/realtime/realtime-message.service.ts +260 -0
- package/backend/src/{core/secrets/secrets.ts → services/secrets/secret.service.ts} +48 -66
- package/backend/src/services/storage/storage.service.ts +617 -0
- package/backend/src/services/usage/usage.service.ts +149 -0
- package/backend/src/types/auth.ts +77 -2
- package/backend/src/types/email.ts +8 -0
- package/backend/src/types/error-constants.ts +4 -0
- package/backend/src/types/logs.ts +0 -29
- package/backend/src/types/realtime.ts +18 -0
- package/backend/src/{core/socket/types.ts → types/socket.ts} +11 -36
- package/backend/src/utils/cookies.ts +35 -0
- package/backend/src/utils/environment.ts +9 -3
- package/backend/src/utils/logger.ts +20 -2
- package/backend/src/utils/s3-config-loader.ts +64 -0
- package/backend/src/utils/seed.ts +301 -205
- package/backend/src/utils/sql-parser.ts +91 -1
- package/backend/src/utils/utils.ts +114 -0
- package/backend/src/utils/validations.ts +40 -4
- package/backend/tests/README.md +133 -133
- package/backend/tests/cleanup-all-test-data.sh +230 -230
- package/backend/tests/cloud/test-s3-multitenant.sh +131 -131
- package/backend/tests/local/comprehensive-curl-tests.sh +155 -155
- package/backend/tests/local/test-ai-config.sh +129 -0
- package/backend/tests/local/test-ai-usage.sh +80 -0
- package/backend/tests/local/test-auth-router.sh +143 -143
- package/backend/tests/local/test-database-router.sh +222 -222
- package/backend/tests/local/test-e2e.sh +240 -240
- package/backend/tests/local/test-fk-errors.sh +96 -96
- package/backend/tests/local/test-functions.sh +123 -0
- package/backend/tests/local/test-id-field.sh +200 -200
- package/backend/tests/local/test-logs.sh +132 -0
- package/backend/tests/local/test-public-bucket.sh +264 -264
- package/backend/tests/local/test-secrets.sh +249 -247
- package/backend/tests/local/test-serverless-functions.sh.disabled +325 -325
- package/backend/tests/local/test-traditional-rest.sh +208 -208
- package/backend/tests/manual/README.md +50 -50
- package/backend/tests/manual/create-large-table-simple.sql +10 -10
- package/backend/tests/manual/seed-large-table.sql +100 -100
- package/backend/tests/manual/setup-large-table-extras.sql +33 -33
- package/backend/tests/manual/test-bulk-upsert.sh +409 -409
- package/backend/tests/manual/test-database-advance.sh +296 -296
- package/backend/tests/manual/test-postgrest-stability.sh +191 -191
- package/backend/tests/manual/test-rawsql-export-import.sh +411 -411
- package/backend/tests/manual/test-rawsql-modes.sh +244 -0
- package/backend/tests/manual/test-universal-storage.sh +263 -263
- package/backend/tests/manual/test-users.sql +17 -17
- package/backend/tests/run-all-tests.sh +139 -139
- package/backend/tests/setup.ts +0 -0
- package/backend/tests/test-config.sh +338 -302
- package/backend/tests/unit/analyze-query.test.ts +697 -0
- package/backend/tests/unit/cloud-token.test.ts +48 -0
- package/backend/tests/unit/constant.test.ts +8 -0
- package/backend/tests/unit/email.test.ts +372 -0
- package/backend/tests/unit/environment.test.ts +59 -0
- package/backend/tests/unit/helpers.test.ts +63 -0
- package/backend/tests/unit/logger.test.ts +22 -0
- package/backend/tests/unit/rate-limit.test.ts +154 -0
- package/backend/tests/unit/response.test.ts +58 -0
- package/backend/tests/unit/sql-parser.test.ts +74 -0
- package/backend/tests/unit/uuid.test.ts +21 -0
- package/backend/tests/unit/validations.test.ts +80 -0
- package/backend/tsconfig.json +22 -22
- package/backend/vitest.config.ts +11 -0
- package/claude-plugin/.claude-plugin/plugin.json +24 -0
- package/claude-plugin/README.md +133 -0
- package/claude-plugin/skills/insforge-schema-patterns/SKILL.md +270 -0
- package/docker-compose.prod.yml +204 -144
- package/docker-compose.yml +232 -167
- package/docker-init/db/db-init.sql +97 -125
- package/docker-init/db/jwt.sql +5 -5
- package/docker-init/db/postgresql.conf +16 -16
- package/docker-init/logs/vector.yml +236 -0
- package/docs/README.md +44 -0
- package/docs/agent-docs/real-time.md +269 -0
- package/docs/changelog.mdx +119 -0
- package/docs/core-concepts/ai/architecture.mdx +373 -0
- package/docs/core-concepts/ai/sdk.mdx +213 -0
- package/docs/core-concepts/authentication/architecture.mdx +278 -0
- package/docs/core-concepts/authentication/sdk.mdx +414 -0
- package/docs/core-concepts/authentication/ui-components/customization.mdx +529 -0
- package/docs/core-concepts/authentication/ui-components/nextjs.mdx +221 -0
- package/docs/core-concepts/authentication/ui-components/react-router.mdx +184 -0
- package/docs/core-concepts/authentication/ui-components/react.mdx +129 -0
- package/docs/core-concepts/database/architecture.mdx +256 -0
- package/docs/core-concepts/database/sdk.mdx +382 -0
- package/docs/core-concepts/email/architecture.mdx +101 -0
- package/docs/core-concepts/email/sdk.mdx +53 -0
- package/docs/core-concepts/functions/architecture.mdx +105 -0
- package/docs/core-concepts/functions/sdk.mdx +184 -0
- package/docs/core-concepts/realtime/architecture.mdx +446 -0
- package/docs/core-concepts/realtime/sdk.mdx +409 -0
- package/docs/core-concepts/storage/architecture.mdx +243 -0
- package/docs/core-concepts/storage/sdk.mdx +253 -0
- package/docs/deployment/README.md +94 -0
- package/docs/deployment/deploy-to-aws-ec2.md +565 -0
- package/docs/deployment/deploy-to-azure-virtual-machines.md +313 -0
- package/docs/deployment/deploy-to-google-cloud-compute-engine.md +613 -0
- package/docs/deployment/deploy-to-render.md +441 -0
- package/docs/deprecated/insforge-auth-api.md +214 -214
- package/docs/deprecated/insforge-auth-sdk.md +99 -99
- package/docs/deprecated/insforge-db-api.md +358 -358
- package/docs/deprecated/insforge-db-sdk.md +139 -139
- package/docs/deprecated/insforge-debug-sdk.md +156 -156
- package/docs/deprecated/insforge-debug.md +64 -64
- package/docs/deprecated/insforge-instructions.md +123 -123
- package/docs/deprecated/insforge-project.md +117 -117
- package/docs/deprecated/insforge-storage-api.md +278 -278
- package/docs/deprecated/insforge-storage-sdk.md +158 -158
- package/docs/docs.json +232 -0
- package/docs/examples/framework-guides/nextjs.mdx +131 -0
- package/docs/examples/framework-guides/nuxt.mdx +165 -0
- package/docs/examples/framework-guides/react.mdx +165 -0
- package/docs/examples/framework-guides/svelte.mdx +153 -0
- package/docs/examples/framework-guides/vue.mdx +159 -0
- package/docs/examples/overview.mdx +67 -0
- package/docs/favicon.svg +19 -0
- package/docs/images/changelog/dec-2025/ai-integration.png +0 -0
- package/docs/images/changelog/dec-2025/ai-models.webp +0 -0
- package/docs/images/changelog/dec-2025/alipay-payment.webp +0 -0
- package/docs/images/changelog/dec-2025/apple-login.jpg +0 -0
- package/docs/images/changelog/dec-2025/mcp-installer.png +0 -0
- package/docs/images/changelog/dec-2025/realtime-module.jpg +0 -0
- package/docs/images/changelog/nov-2025/auth-components.webp +0 -0
- package/docs/images/changelog/nov-2025/database-metadata.webp +0 -0
- package/docs/images/changelog/nov-2025/quickstart-prompts.webp +0 -0
- package/docs/images/changelog/nov-2025/sql-editor.webp +0 -0
- package/docs/images/changelog/nov-2025/usage-page.webp +0 -0
- package/docs/images/changelog/october-2025/csv-upload.webp +0 -0
- package/docs/images/changelog/october-2025/logs-feature.webp +0 -0
- package/docs/images/changelog/october-2025/oauth-providers.webp +0 -0
- package/docs/images/checks-passed.png +0 -0
- package/docs/images/dashboard-connect-expanded.png +0 -0
- package/docs/images/dashboard-connect.png +0 -0
- package/docs/images/hero-dark.png +0 -0
- package/docs/images/hero-light.png +0 -0
- package/docs/images/icons/ai.svg +4 -0
- package/docs/images/icons/auth.svg +1 -0
- package/docs/images/icons/database.svg +1 -0
- package/docs/images/icons/function.svg +1 -0
- package/docs/images/icons/storage.svg +1 -0
- package/docs/images/logos/nextjs.svg +4 -0
- package/docs/images/logos/nuxt.svg +4 -0
- package/docs/images/logos/react.svg +5 -0
- package/docs/images/logos/svelte.svg +4 -0
- package/docs/images/logos/vue.svg +5 -0
- package/docs/images/mcp-install.png +0 -0
- package/docs/images/onboarding-mcp.png +0 -0
- package/docs/insforge-instructions-sdk.md +89 -407
- package/docs/introduction.mdx +45 -0
- package/docs/logo/dark.svg +22 -0
- package/docs/logo/light.svg +20 -0
- package/docs/partnership.mdx +652 -0
- package/docs/quickstart.mdx +83 -0
- package/docs/showcase/2048-arena.png +0 -0
- package/docs/showcase/framegen-cloud.png +0 -0
- package/docs/showcase/line-connect-race.png +0 -0
- package/docs/showcase/moment-vibe.png +0 -0
- package/docs/showcase/national-flags.png +0 -0
- package/docs/showcase/pokemon-vibe.png +0 -0
- package/docs/showcase/pure-browse-buy.png +0 -0
- package/docs/showcase.mdx +52 -0
- package/docs/snippets/sdk-installation.mdx +22 -0
- package/docs/snippets/service-icons.mdx +27 -0
- package/eslint.config.js +10 -3
- package/examples/oauth/frontend-oauth-example.html +250 -250
- package/examples/response-examples.md +443 -443
- package/frontend/components.json +17 -17
- package/frontend/package.json +69 -63
- package/frontend/src/App.tsx +13 -82
- package/frontend/src/assets/icons/checkbox_checked.svg +6 -6
- package/frontend/src/assets/icons/checkbox_undetermined.svg +6 -6
- package/frontend/src/assets/icons/checked.svg +3 -3
- package/frontend/src/assets/icons/connected.svg +3 -0
- package/frontend/src/assets/icons/error.svg +3 -3
- package/frontend/src/assets/icons/loader.svg +9 -0
- package/frontend/src/assets/icons/pencil.svg +4 -4
- package/frontend/src/assets/icons/refresh.svg +4 -4
- package/frontend/src/assets/icons/step_active.svg +3 -3
- package/frontend/src/assets/icons/step_inactive.svg +11 -11
- package/frontend/src/assets/icons/warning.svg +3 -3
- package/frontend/src/assets/logos/apple.svg +4 -0
- package/frontend/src/assets/logos/claude_code.svg +3 -3
- package/frontend/src/assets/logos/cline.svg +6 -6
- package/frontend/src/assets/logos/cursor.svg +20 -20
- package/frontend/src/assets/logos/discord.svg +8 -8
- package/frontend/src/assets/logos/facebook.svg +3 -0
- package/frontend/src/assets/logos/gemini.svg +19 -19
- package/frontend/src/assets/logos/github.svg +5 -5
- package/frontend/src/assets/logos/google.svg +13 -13
- package/frontend/src/assets/logos/grok.svg +10 -10
- package/frontend/src/assets/logos/insforge_dark.svg +15 -15
- package/frontend/src/assets/logos/insforge_light.svg +15 -15
- package/frontend/src/assets/logos/instagram.svg +2 -0
- package/frontend/src/assets/logos/linkedin.svg +3 -0
- package/frontend/src/assets/logos/microsoft.svg +1 -0
- package/frontend/src/assets/logos/openai.svg +10 -10
- package/frontend/src/assets/logos/roo_code.svg +9 -9
- package/frontend/src/assets/logos/spotify.svg +17 -0
- package/frontend/src/assets/logos/tiktok.svg +6 -0
- package/frontend/src/assets/logos/trae.svg +3 -3
- package/frontend/src/assets/logos/windsurf.svg +10 -10
- package/frontend/src/assets/logos/x.svg +3 -0
- package/frontend/src/components/Checkbox.tsx +27 -29
- package/frontend/src/components/CodeBlock.tsx +55 -2
- package/frontend/src/components/CodeEditor.tsx +92 -0
- package/frontend/src/components/ConfirmDialog.tsx +1 -1
- package/frontend/src/components/ConnectCTA.tsx +38 -0
- package/frontend/src/components/CopyButton.tsx +52 -15
- package/frontend/src/components/ErrorState.tsx +1 -2
- package/frontend/src/components/FeatureSidebar.tsx +6 -6
- package/frontend/src/components/FeatureSidebarItem.tsx +2 -2
- package/frontend/src/components/JsonHighlight.tsx +21 -9
- package/frontend/src/components/ProjectInfoModal.tsx +128 -0
- package/frontend/src/components/PromptDialog.tsx +1 -4
- package/frontend/src/components/SearchInput.tsx +1 -2
- package/frontend/src/components/Stepper.tsx +53 -0
- package/frontend/src/components/ThemeToggle.tsx +3 -3
- package/frontend/src/components/datagrid/DataGrid.tsx +25 -32
- package/frontend/src/components/datagrid/cell-editors/DateCellEditor.tsx +1 -2
- package/frontend/src/components/datagrid/cell-editors/JsonCellEditor.tsx +2 -4
- package/frontend/src/components/datagrid/index.ts +23 -0
- package/frontend/src/components/index.ts +23 -30
- package/frontend/src/components/layout/AppHeader.tsx +131 -91
- package/frontend/src/components/layout/AppSidebar.tsx +80 -170
- package/frontend/src/components/layout/Layout.tsx +12 -23
- package/frontend/src/components/layout/PrimaryMenu.tsx +187 -0
- package/frontend/src/components/layout/SecondaryMenu.tsx +70 -0
- package/frontend/src/components/layout/index.ts +5 -0
- package/frontend/src/components/radix/Tooltip.tsx +24 -13
- package/frontend/src/components/radix/index.ts +22 -0
- package/frontend/src/features/ai/components/AIConfigCard.tsx +129 -83
- package/frontend/src/features/ai/components/AIEmptyState.tsx +12 -7
- package/frontend/src/features/ai/components/ModalityFilterSidebar.tsx +101 -0
- package/frontend/src/features/ai/components/ModelSelectionDialog.tsx +135 -0
- package/frontend/src/features/ai/components/ModelSelectionGrid.tsx +51 -0
- package/frontend/src/features/ai/components/SystemPromptDialog.tsx +118 -0
- package/frontend/src/features/ai/components/index.ts +6 -0
- package/frontend/src/features/ai/helpers.ts +57 -71
- package/frontend/src/features/ai/hooks/useAIConfigs.ts +39 -113
- package/frontend/src/features/ai/hooks/useAIUsage.ts +0 -2
- package/frontend/src/features/ai/pages/AIPage.tsx +166 -0
- package/frontend/src/features/ai/services/ai.service.ts +5 -5
- package/frontend/src/features/auth/components/AuthPreview.tsx +96 -0
- package/frontend/src/features/auth/components/OAuthConfigDialog.tsx +54 -30
- package/frontend/src/features/auth/components/UserFormDialog.tsx +13 -6
- package/frontend/src/features/auth/components/UsersDataGrid.tsx +50 -14
- package/frontend/src/features/auth/components/index.ts +5 -0
- package/frontend/src/features/auth/helpers.tsx +208 -0
- package/frontend/src/features/auth/hooks/useAnonToken.ts +30 -0
- package/frontend/src/features/auth/hooks/useAuthConfig.ts +48 -0
- package/frontend/src/features/auth/hooks/useOAuthConfig.ts +14 -10
- package/frontend/src/features/auth/hooks/useUsers.ts +43 -5
- package/frontend/src/features/auth/index.ts +3 -2
- package/frontend/src/features/auth/pages/AuthMethodsPage.tsx +275 -0
- package/frontend/src/features/auth/pages/ConfigurationPage.tsx +395 -0
- package/frontend/src/features/auth/pages/UsersPage.tsx +257 -0
- package/frontend/src/features/auth/services/anonToken.service.ts +11 -0
- package/frontend/src/features/auth/services/config.service.ts +19 -0
- package/frontend/src/features/auth/services/{oauth.service.ts → oauth-config.service.ts} +4 -4
- package/frontend/src/features/auth/services/{auth.service.ts → user.service.ts} +7 -53
- package/frontend/src/features/dashboard/components/ConnectionSuccessBanner.tsx +35 -0
- package/frontend/src/features/dashboard/components/PromptCard.tsx +21 -0
- package/frontend/src/features/dashboard/components/PromptDialog.tsx +103 -0
- package/frontend/src/features/dashboard/components/StatsCard.tsx +50 -0
- package/frontend/src/features/dashboard/components/index.ts +4 -0
- package/frontend/src/features/dashboard/pages/DashboardPage.tsx +212 -0
- package/frontend/src/features/dashboard/prompts/ai-chatbot.ts +13 -0
- package/frontend/src/features/dashboard/prompts/crm-system.ts +13 -0
- package/frontend/src/features/dashboard/prompts/ecommerce-platform.ts +12 -0
- package/frontend/src/features/dashboard/prompts/index.ts +31 -0
- package/frontend/src/features/dashboard/prompts/instagram-clone.ts +11 -0
- package/frontend/src/features/dashboard/prompts/notion-clone.ts +14 -0
- package/frontend/src/features/dashboard/prompts/reddit-clone.ts +12 -0
- package/frontend/src/features/database/components/DatabaseDataGrid.tsx +48 -17
- package/frontend/src/features/database/components/ForeignKeyCell.tsx +15 -34
- package/frontend/src/features/database/components/ForeignKeyPopover.tsx +19 -20
- package/frontend/src/features/database/components/LinkRecordModal.tsx +120 -125
- package/frontend/src/features/database/components/RecordFormDialog.tsx +22 -33
- package/frontend/src/features/database/components/RecordFormField.tsx +45 -47
- package/frontend/src/features/database/components/SQLModal.tsx +75 -0
- package/frontend/src/features/database/components/TableEmptyState.tsx +6 -5
- package/frontend/src/features/database/components/TableForm.tsx +28 -19
- package/frontend/src/features/database/components/TableFormColumn.tsx +2 -3
- package/frontend/src/features/database/components/TableSidebar.tsx +1 -1
- package/frontend/src/features/database/components/TablesEmptyState.tsx +48 -0
- package/frontend/src/features/database/components/TemplateCard.tsx +37 -0
- package/frontend/src/features/database/components/TemplatePreview.tsx +92 -0
- package/frontend/src/features/database/components/index.ts +19 -0
- package/frontend/src/features/database/constants.ts +28 -2
- package/frontend/src/features/database/contexts/SQLEditorContext.tsx +188 -0
- package/frontend/src/features/database/helpers.ts +2 -2
- package/frontend/src/features/database/hooks/useCSVImport.ts +29 -0
- package/frontend/src/features/database/hooks/useDatabase.ts +66 -0
- package/frontend/src/features/database/hooks/useRawSQL.ts +55 -0
- package/frontend/src/features/database/hooks/useRecords.ts +139 -0
- package/frontend/src/features/database/hooks/useTables.ts +135 -0
- package/frontend/src/features/database/index.ts +7 -1
- package/frontend/src/features/database/pages/FunctionsPage.tsx +203 -0
- package/frontend/src/features/database/pages/IndexesPage.tsx +228 -0
- package/frontend/src/features/database/pages/PoliciesPage.tsx +237 -0
- package/frontend/src/features/database/pages/SQLEditorPage.tsx +382 -0
- package/frontend/src/features/database/{page/DatabasePage.tsx → pages/TablesPage.tsx} +168 -209
- package/frontend/src/features/database/pages/TemplatesPage.tsx +39 -0
- package/frontend/src/features/database/pages/TriggersPage.tsx +230 -0
- package/frontend/src/features/database/services/advance.service.ts +40 -0
- package/frontend/src/features/database/services/database.service.ts +33 -194
- package/frontend/src/features/database/services/record.service.ts +219 -0
- package/frontend/src/features/database/services/table.service.ts +58 -0
- package/frontend/src/features/database/templates/ai-chatbot.ts +402 -0
- package/frontend/src/features/database/templates/crm-system.ts +528 -0
- package/frontend/src/features/database/templates/ecommerce-platform.ts +553 -0
- package/frontend/src/features/database/templates/index.ts +34 -0
- package/frontend/src/features/database/templates/instagram-clone.ts +222 -0
- package/frontend/src/features/database/templates/notion-clone.ts +483 -0
- package/frontend/src/features/database/templates/reddit-clone.ts +526 -0
- package/frontend/src/features/functions/components/FunctionRow.tsx +2 -1
- package/frontend/src/features/functions/components/FunctionsSidebar.tsx +1 -1
- package/frontend/src/features/functions/components/SecretRow.tsx +1 -1
- package/frontend/src/features/functions/components/index.ts +5 -0
- package/frontend/src/features/functions/hooks/useFunctions.ts +4 -4
- package/frontend/src/features/{secrets → functions}/hooks/useSecrets.ts +5 -5
- package/frontend/src/features/functions/pages/FunctionsPage.tsx +148 -0
- package/frontend/src/features/functions/{components/SecretsContent.tsx → pages/SecretsPage.tsx} +19 -21
- package/frontend/src/features/functions/services/{functions.service.ts → function.service.ts} +2 -2
- package/frontend/src/features/{secrets/services/secrets.service.ts → functions/services/secret.service.ts} +2 -2
- package/frontend/src/features/login/hooks/usePartnerOrigin.ts +27 -0
- package/frontend/src/features/login/pages/CloudLoginPage.tsx +118 -0
- package/frontend/src/features/login/{page → pages}/LoginPage.tsx +16 -23
- package/frontend/src/features/login/services/partnership.service.ts +65 -0
- package/frontend/src/features/logs/components/LogsDataGrid.tsx +89 -0
- package/frontend/src/features/logs/components/SeverityBadge.tsx +18 -0
- package/frontend/src/features/logs/components/index.ts +2 -0
- package/frontend/src/features/logs/helpers.ts +24 -0
- package/frontend/src/features/logs/hooks/useAuditLogs.ts +4 -4
- package/frontend/src/features/logs/hooks/useLogSources.ts +137 -0
- package/frontend/src/features/logs/hooks/useLogs.ts +163 -0
- package/frontend/src/features/logs/hooks/useMcpUsage.ts +128 -0
- package/frontend/src/features/logs/index.ts +8 -2
- package/frontend/src/features/logs/{page → pages}/AuditsPage.tsx +91 -38
- package/frontend/src/features/logs/pages/LogsPage.tsx +152 -0
- package/frontend/src/features/logs/pages/MCPLogsPage.tsx +84 -0
- package/frontend/src/features/logs/services/audit.service.ts +63 -0
- package/frontend/src/features/logs/services/log.service.ts +15 -110
- package/frontend/src/features/logs/services/usage.service.ts +31 -0
- package/frontend/src/features/onboard/components/McpConnectionStatus.tsx +68 -0
- package/frontend/src/features/onboard/components/OnboardingModal.tsx +267 -0
- package/frontend/src/features/onboard/components/VideoDemoModal.tsx +38 -0
- package/frontend/src/features/onboard/components/index.ts +4 -0
- package/frontend/src/features/onboard/components/mcp/CursorDeeplinkGenerator.tsx +2 -2
- package/frontend/src/features/onboard/components/mcp/{mcp-helper.tsx → helpers.tsx} +8 -8
- package/frontend/src/features/onboard/components/mcp/index.ts +2 -3
- package/frontend/src/features/onboard/index.ts +13 -3
- package/frontend/src/features/realtime/components/ChannelRow.tsx +83 -0
- package/frontend/src/features/realtime/components/EditChannelModal.tsx +246 -0
- package/frontend/src/features/realtime/components/MessageRow.tsx +85 -0
- package/frontend/src/features/realtime/components/RealtimeEmptyState.tsx +30 -0
- package/frontend/src/features/realtime/hooks/useRealtime.ts +218 -0
- package/frontend/src/features/realtime/index.ts +11 -0
- package/frontend/src/features/realtime/pages/RealtimeChannelsPage.tsx +172 -0
- package/frontend/src/features/realtime/pages/RealtimeMessagesPage.tsx +211 -0
- package/frontend/src/features/realtime/pages/RealtimePermissionsPage.tsx +191 -0
- package/frontend/src/features/realtime/services/realtime.service.ts +107 -0
- package/frontend/src/features/storage/components/BucketEmptyState.tsx +9 -6
- package/frontend/src/features/storage/components/BucketFormDialog.tsx +25 -41
- package/frontend/src/features/storage/components/FilePreviewDialog.tsx +20 -8
- package/frontend/src/features/storage/components/StorageDataGrid.tsx +4 -3
- package/frontend/src/features/storage/components/StorageManager.tsx +23 -34
- package/frontend/src/features/storage/components/index.ts +12 -0
- package/frontend/src/features/storage/hooks/useStorage.ts +208 -0
- package/frontend/src/features/storage/{page → pages}/StoragePage.tsx +41 -143
- package/frontend/src/features/storage/services/storage.service.ts +22 -1
- package/frontend/src/features/visualizer/components/AuthNode.tsx +72 -56
- package/frontend/src/features/visualizer/components/BucketNode.tsx +4 -4
- package/frontend/src/features/visualizer/components/SchemaVisualizer.tsx +108 -80
- package/frontend/src/features/visualizer/components/TableNode.tsx +34 -41
- package/frontend/src/features/visualizer/components/VisualizerSkeleton.tsx +12 -4
- package/frontend/src/features/visualizer/pages/VisualizerPage.tsx +97 -0
- package/frontend/src/index.css +1 -0
- package/frontend/src/lib/analytics/posthog.tsx +27 -0
- package/frontend/src/lib/contexts/AuthContext.tsx +38 -31
- package/frontend/src/lib/contexts/SocketContext.tsx +123 -80
- package/frontend/src/{features/metadata → lib}/hooks/useMetadata.ts +1 -1
- package/frontend/src/lib/hooks/useToast.tsx +6 -2
- package/frontend/src/lib/routing/AppRoutes.tsx +99 -0
- package/frontend/src/lib/routing/RequireAuth.tsx +27 -0
- package/frontend/src/lib/utils/cloudMessaging.ts +20 -0
- package/frontend/src/lib/utils/menuItems.ts +207 -0
- package/frontend/src/lib/utils/{validation-schemas.ts → schemaValidations.ts} +10 -5
- package/frontend/src/lib/utils/utils.ts +32 -1
- package/frontend/src/vite-env.d.ts +1 -0
- package/frontend/tsconfig.json +25 -25
- package/frontend/tsconfig.node.json +9 -9
- package/frontend/vite.config.ts +5 -3
- package/functions/deno.json +24 -24
- package/functions/server.ts +315 -290
- package/functions/worker-template.js +15 -4
- package/i18n/README.ar.md +130 -0
- package/i18n/README.de.md +130 -0
- package/i18n/README.es.md +154 -0
- package/i18n/README.fr.md +134 -0
- package/i18n/README.hi.md +129 -0
- package/i18n/README.ja.md +174 -0
- package/i18n/README.ko.md +137 -0
- package/i18n/README.pt-BR.md +131 -0
- package/i18n/README.ru.md +129 -0
- package/i18n/README.zh-CN.md +133 -0
- package/openapi/ai.yaml +715 -688
- package/openapi/auth.yaml +1244 -563
- package/openapi/email.yaml +158 -0
- package/openapi/functions.yaml +475 -475
- package/openapi/health.yaml +29 -29
- package/openapi/logs.yaml +223 -223
- package/openapi/metadata.yaml +177 -177
- package/openapi/realtime.yaml +699 -0
- package/openapi/records.yaml +381 -381
- package/openapi/secrets.yaml +370 -370
- package/openapi/storage.yaml +875 -875
- package/openapi/tables.yaml +463 -463
- package/package.json +97 -88
- package/shared-schemas/package.json +31 -31
- package/shared-schemas/src/ai-api.schema.ts +34 -58
- package/shared-schemas/src/ai.schema.ts +63 -54
- package/shared-schemas/src/auth-api.schema.ts +352 -193
- package/shared-schemas/src/auth.schema.ts +43 -7
- package/shared-schemas/src/cloud-events.schema.ts +57 -0
- package/shared-schemas/src/database-api.schema.ts +35 -4
- package/shared-schemas/src/database.schema.ts +40 -1
- package/shared-schemas/src/docs.schema.ts +26 -0
- package/shared-schemas/src/email-api.schema.ts +30 -0
- package/shared-schemas/src/index.ts +5 -0
- package/shared-schemas/src/logs-api.schema.ts +7 -1
- package/shared-schemas/src/logs.schema.ts +26 -0
- package/shared-schemas/src/metadata.schema.ts +18 -4
- package/shared-schemas/src/realtime-api.schema.ts +111 -0
- package/shared-schemas/src/realtime.schema.ts +143 -0
- package/shared-schemas/tsconfig.json +21 -21
- package/tsconfig.json +7 -7
- package/zeabur/README.md +13 -0
- package/zeabur/template.yml +1032 -0
- package/.github/workflows/deploy-aws.yml +0 -130
- package/backend/src/api/routes/agent.ts +0 -29
- package/backend/src/api/routes/auth.oauth.ts +0 -482
- package/backend/src/api/routes/auth.ts +0 -386
- package/backend/src/api/routes/docs.ts +0 -66
- package/backend/src/api/routes/functions.ts +0 -183
- package/backend/src/api/routes/openapi.ts +0 -82
- package/backend/src/api/routes/usage.ts +0 -96
- package/backend/src/core/ai/client.ts +0 -242
- package/backend/src/core/ai/model.ts +0 -117
- package/backend/src/core/auth/auth.ts +0 -780
- package/backend/src/core/database/manager.ts +0 -178
- package/backend/src/core/database/table.ts +0 -772
- package/backend/src/core/documentation/agent.ts +0 -689
- package/backend/src/core/documentation/openapi.ts +0 -856
- package/backend/src/core/logs/analytics.ts +0 -76
- package/backend/src/core/logs/providers/localdb.provider.ts +0 -246
- package/backend/src/core/socket/socket.ts +0 -388
- package/backend/src/core/storage/storage.ts +0 -923
- package/backend/src/utils/cloud-token.ts +0 -39
- package/backend/src/utils/helpers.ts +0 -49
- package/backend/src/utils/uuid.ts +0 -9
- package/backend/tests/manual/test-better-auth.sh +0 -303
- package/docker-init/db/logs.sql +0 -9
- package/frontend/README.md +0 -112
- package/frontend/src/components/datagrid/index.tsx +0 -20
- package/frontend/src/components/layout/CloudLayout.tsx +0 -95
- package/frontend/src/features/ai/components/AIConfigDialog.tsx +0 -76
- package/frontend/src/features/ai/components/AIConfigForm.tsx +0 -222
- package/frontend/src/features/ai/components/fields/ModalityField.tsx +0 -87
- package/frontend/src/features/ai/components/fields/ModelSelectionField.tsx +0 -134
- package/frontend/src/features/ai/components/fields/SystemPromptField.tsx +0 -33
- package/frontend/src/features/ai/page/AIPage.tsx +0 -178
- package/frontend/src/features/auth/components/AddOAuthDialog.tsx +0 -106
- package/frontend/src/features/auth/components/AuthMethodTab.tsx +0 -238
- package/frontend/src/features/auth/components/UsersTab.tsx +0 -114
- package/frontend/src/features/auth/page/AuthenticationPage.tsx +0 -169
- package/frontend/src/features/dashboard/page/DashboardPage.tsx +0 -194
- package/frontend/src/features/database/hooks/UseLinkModal.tsx +0 -78
- package/frontend/src/features/functions/components/FunctionViewer.tsx +0 -46
- package/frontend/src/features/functions/components/FunctionsContent.tsx +0 -88
- package/frontend/src/features/functions/page/FunctionsPage.tsx +0 -28
- package/frontend/src/features/login/components/AuthErrorBoundary.tsx +0 -87
- package/frontend/src/features/login/components/PrivateRoute.tsx +0 -24
- package/frontend/src/features/login/page/CloudLoginPage.tsx +0 -93
- package/frontend/src/features/logs/components/AnalyticsLogsTable.tsx +0 -313
- package/frontend/src/features/logs/components/LogsTable.tsx +0 -199
- package/frontend/src/features/logs/page/AnalyticsLogsPage.tsx +0 -530
- package/frontend/src/features/metadata/index.ts +0 -0
- package/frontend/src/features/metadata/page/MetadataPage.tsx +0 -136
- package/frontend/src/features/onboard/components/CompletionCard.tsx +0 -41
- package/frontend/src/features/onboard/components/OnboardButton.tsx +0 -84
- package/frontend/src/features/onboard/components/StepContent.tsx +0 -91
- package/frontend/src/features/onboard/components/TestConnectionStep.tsx +0 -53
- package/frontend/src/features/onboard/components/mcp/McpInstallation.tsx +0 -144
- package/frontend/src/features/onboard/page/OnBoardPage.tsx +0 -104
- package/frontend/src/features/onboard/types.ts +0 -8
- package/frontend/src/features/visualizer/page/VisualizerPage.tsx +0 -127
- package/frontend/src/lib/contexts/OnboardStepContext.tsx +0 -68
- package/frontend/src/lib/hooks/useOnboardingCompletion.ts +0 -29
- /package/backend/src/api/{middleware → middlewares}/error.ts +0 -0
- /package/backend/src/api/{middleware → middlewares}/upload.ts +0 -0
- /package/frontend/src/{features/metadata → lib}/services/metadata.service.ts +0 -0
|
@@ -0,0 +1,222 @@
|
|
|
1
|
+
import { DatabaseTemplate } from './index';
|
|
2
|
+
|
|
3
|
+
export const instagramCloneTemplate: DatabaseTemplate = {
|
|
4
|
+
id: 'instagram-clone',
|
|
5
|
+
title: 'Instagram Clone',
|
|
6
|
+
description: 'An Instagram-style photo sharing app with posts, comments, likes, and follows',
|
|
7
|
+
tableCount: 4,
|
|
8
|
+
visualizerSchema: [
|
|
9
|
+
{
|
|
10
|
+
tableName: 'posts',
|
|
11
|
+
columns: [
|
|
12
|
+
{ columnName: 'id', type: 'uuid', isPrimaryKey: true, isNullable: false, isUnique: true },
|
|
13
|
+
{
|
|
14
|
+
columnName: 'user_id',
|
|
15
|
+
type: 'uuid',
|
|
16
|
+
isPrimaryKey: false,
|
|
17
|
+
isNullable: false,
|
|
18
|
+
isUnique: false,
|
|
19
|
+
foreignKey: {
|
|
20
|
+
referenceTable: 'users',
|
|
21
|
+
referenceColumn: 'id',
|
|
22
|
+
onDelete: 'CASCADE',
|
|
23
|
+
onUpdate: 'CASCADE',
|
|
24
|
+
},
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
columnName: 'image_url',
|
|
28
|
+
type: 'varchar',
|
|
29
|
+
isPrimaryKey: false,
|
|
30
|
+
isNullable: false,
|
|
31
|
+
isUnique: false,
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
columnName: 'caption',
|
|
35
|
+
type: 'text',
|
|
36
|
+
isPrimaryKey: false,
|
|
37
|
+
isNullable: true,
|
|
38
|
+
isUnique: false,
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
columnName: 'created_at',
|
|
42
|
+
type: 'timestamp',
|
|
43
|
+
isPrimaryKey: false,
|
|
44
|
+
isNullable: true,
|
|
45
|
+
isUnique: false,
|
|
46
|
+
},
|
|
47
|
+
],
|
|
48
|
+
},
|
|
49
|
+
{
|
|
50
|
+
tableName: 'comments',
|
|
51
|
+
columns: [
|
|
52
|
+
{ columnName: 'id', type: 'uuid', isPrimaryKey: true, isNullable: false, isUnique: true },
|
|
53
|
+
{
|
|
54
|
+
columnName: 'post_id',
|
|
55
|
+
type: 'uuid',
|
|
56
|
+
isPrimaryKey: false,
|
|
57
|
+
isNullable: false,
|
|
58
|
+
isUnique: false,
|
|
59
|
+
foreignKey: {
|
|
60
|
+
referenceTable: 'posts',
|
|
61
|
+
referenceColumn: 'id',
|
|
62
|
+
onDelete: 'CASCADE',
|
|
63
|
+
onUpdate: 'CASCADE',
|
|
64
|
+
},
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
columnName: 'user_id',
|
|
68
|
+
type: 'uuid',
|
|
69
|
+
isPrimaryKey: false,
|
|
70
|
+
isNullable: false,
|
|
71
|
+
isUnique: false,
|
|
72
|
+
foreignKey: {
|
|
73
|
+
referenceTable: 'users',
|
|
74
|
+
referenceColumn: 'id',
|
|
75
|
+
onDelete: 'CASCADE',
|
|
76
|
+
onUpdate: 'CASCADE',
|
|
77
|
+
},
|
|
78
|
+
},
|
|
79
|
+
{
|
|
80
|
+
columnName: 'content',
|
|
81
|
+
type: 'text',
|
|
82
|
+
isPrimaryKey: false,
|
|
83
|
+
isNullable: false,
|
|
84
|
+
isUnique: false,
|
|
85
|
+
},
|
|
86
|
+
{
|
|
87
|
+
columnName: 'created_at',
|
|
88
|
+
type: 'timestamp',
|
|
89
|
+
isPrimaryKey: false,
|
|
90
|
+
isNullable: true,
|
|
91
|
+
isUnique: false,
|
|
92
|
+
},
|
|
93
|
+
],
|
|
94
|
+
},
|
|
95
|
+
{
|
|
96
|
+
tableName: 'likes',
|
|
97
|
+
columns: [
|
|
98
|
+
{ columnName: 'id', type: 'uuid', isPrimaryKey: true, isNullable: false, isUnique: true },
|
|
99
|
+
{
|
|
100
|
+
columnName: 'user_id',
|
|
101
|
+
type: 'uuid',
|
|
102
|
+
isPrimaryKey: false,
|
|
103
|
+
isNullable: false,
|
|
104
|
+
isUnique: false,
|
|
105
|
+
foreignKey: {
|
|
106
|
+
referenceTable: 'users',
|
|
107
|
+
referenceColumn: 'id',
|
|
108
|
+
onDelete: 'CASCADE',
|
|
109
|
+
onUpdate: 'CASCADE',
|
|
110
|
+
},
|
|
111
|
+
},
|
|
112
|
+
{
|
|
113
|
+
columnName: 'post_id',
|
|
114
|
+
type: 'uuid',
|
|
115
|
+
isPrimaryKey: false,
|
|
116
|
+
isNullable: false,
|
|
117
|
+
isUnique: false,
|
|
118
|
+
foreignKey: {
|
|
119
|
+
referenceTable: 'posts',
|
|
120
|
+
referenceColumn: 'id',
|
|
121
|
+
onDelete: 'CASCADE',
|
|
122
|
+
onUpdate: 'CASCADE',
|
|
123
|
+
},
|
|
124
|
+
},
|
|
125
|
+
{
|
|
126
|
+
columnName: 'created_at',
|
|
127
|
+
type: 'timestamp',
|
|
128
|
+
isPrimaryKey: false,
|
|
129
|
+
isNullable: true,
|
|
130
|
+
isUnique: false,
|
|
131
|
+
},
|
|
132
|
+
],
|
|
133
|
+
},
|
|
134
|
+
{
|
|
135
|
+
tableName: 'follows',
|
|
136
|
+
columns: [
|
|
137
|
+
{ columnName: 'id', type: 'uuid', isPrimaryKey: true, isNullable: false, isUnique: true },
|
|
138
|
+
{
|
|
139
|
+
columnName: 'follower_id',
|
|
140
|
+
type: 'uuid',
|
|
141
|
+
isPrimaryKey: false,
|
|
142
|
+
isNullable: false,
|
|
143
|
+
isUnique: false,
|
|
144
|
+
foreignKey: {
|
|
145
|
+
referenceTable: 'users',
|
|
146
|
+
referenceColumn: 'id',
|
|
147
|
+
onDelete: 'CASCADE',
|
|
148
|
+
onUpdate: 'CASCADE',
|
|
149
|
+
},
|
|
150
|
+
},
|
|
151
|
+
{
|
|
152
|
+
columnName: 'following_id',
|
|
153
|
+
type: 'uuid',
|
|
154
|
+
isPrimaryKey: false,
|
|
155
|
+
isNullable: false,
|
|
156
|
+
isUnique: false,
|
|
157
|
+
foreignKey: {
|
|
158
|
+
referenceTable: 'users',
|
|
159
|
+
referenceColumn: 'id',
|
|
160
|
+
onDelete: 'CASCADE',
|
|
161
|
+
onUpdate: 'CASCADE',
|
|
162
|
+
},
|
|
163
|
+
},
|
|
164
|
+
{
|
|
165
|
+
columnName: 'created_at',
|
|
166
|
+
type: 'timestamp',
|
|
167
|
+
isPrimaryKey: false,
|
|
168
|
+
isNullable: true,
|
|
169
|
+
isUnique: false,
|
|
170
|
+
},
|
|
171
|
+
],
|
|
172
|
+
},
|
|
173
|
+
],
|
|
174
|
+
sql: `-- Instagram Clone Database Schema
|
|
175
|
+
|
|
176
|
+
-- Posts table
|
|
177
|
+
CREATE TABLE posts (
|
|
178
|
+
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
179
|
+
user_id UUID NOT NULL REFERENCES users(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
180
|
+
image_url VARCHAR(500) NOT NULL,
|
|
181
|
+
caption TEXT,
|
|
182
|
+
created_at TIMESTAMP DEFAULT NOW()
|
|
183
|
+
);
|
|
184
|
+
|
|
185
|
+
-- Comments table
|
|
186
|
+
CREATE TABLE comments (
|
|
187
|
+
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
188
|
+
post_id UUID NOT NULL REFERENCES posts(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
189
|
+
user_id UUID NOT NULL REFERENCES users(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
190
|
+
content TEXT NOT NULL,
|
|
191
|
+
created_at TIMESTAMP DEFAULT NOW()
|
|
192
|
+
);
|
|
193
|
+
|
|
194
|
+
-- Likes table
|
|
195
|
+
CREATE TABLE likes (
|
|
196
|
+
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
197
|
+
user_id UUID NOT NULL REFERENCES users(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
198
|
+
post_id UUID NOT NULL REFERENCES posts(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
199
|
+
created_at TIMESTAMP DEFAULT NOW(),
|
|
200
|
+
UNIQUE(user_id, post_id)
|
|
201
|
+
);
|
|
202
|
+
|
|
203
|
+
-- Follows table
|
|
204
|
+
CREATE TABLE follows (
|
|
205
|
+
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
206
|
+
follower_id UUID NOT NULL REFERENCES users(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
207
|
+
following_id UUID NOT NULL REFERENCES users(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
208
|
+
created_at TIMESTAMP DEFAULT NOW(),
|
|
209
|
+
UNIQUE(follower_id, following_id),
|
|
210
|
+
CHECK (follower_id != following_id)
|
|
211
|
+
);
|
|
212
|
+
|
|
213
|
+
-- Create indexes for better performance
|
|
214
|
+
CREATE INDEX idx_posts_user ON posts(user_id);
|
|
215
|
+
CREATE INDEX idx_posts_created ON posts(created_at DESC);
|
|
216
|
+
CREATE INDEX idx_comments_post ON comments(post_id);
|
|
217
|
+
CREATE INDEX idx_comments_user ON comments(user_id);
|
|
218
|
+
CREATE INDEX idx_likes_post ON likes(post_id);
|
|
219
|
+
CREATE INDEX idx_likes_user ON likes(user_id);
|
|
220
|
+
CREATE INDEX idx_follows_follower ON follows(follower_id);
|
|
221
|
+
CREATE INDEX idx_follows_following ON follows(following_id);`,
|
|
222
|
+
};
|
|
@@ -0,0 +1,483 @@
|
|
|
1
|
+
import { DatabaseTemplate } from './index';
|
|
2
|
+
|
|
3
|
+
export const notionCloneTemplate: DatabaseTemplate = {
|
|
4
|
+
id: 'notion-clone',
|
|
5
|
+
title: 'Notion Clone',
|
|
6
|
+
description: 'A notes workspace with pages, search, rich text editing, and flexible access',
|
|
7
|
+
tableCount: 4,
|
|
8
|
+
visualizerSchema: [
|
|
9
|
+
{
|
|
10
|
+
tableName: 'workspaces',
|
|
11
|
+
columns: [
|
|
12
|
+
{ columnName: 'id', type: 'uuid', isPrimaryKey: true, isNullable: false, isUnique: true },
|
|
13
|
+
{
|
|
14
|
+
columnName: 'name',
|
|
15
|
+
type: 'varchar',
|
|
16
|
+
isPrimaryKey: false,
|
|
17
|
+
isNullable: false,
|
|
18
|
+
isUnique: false,
|
|
19
|
+
},
|
|
20
|
+
{
|
|
21
|
+
columnName: 'owner_id',
|
|
22
|
+
type: 'uuid',
|
|
23
|
+
isPrimaryKey: false,
|
|
24
|
+
isNullable: false,
|
|
25
|
+
isUnique: false,
|
|
26
|
+
foreignKey: {
|
|
27
|
+
referenceTable: 'users',
|
|
28
|
+
referenceColumn: 'id',
|
|
29
|
+
onDelete: 'CASCADE',
|
|
30
|
+
onUpdate: 'CASCADE',
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
columnName: 'icon',
|
|
35
|
+
type: 'varchar',
|
|
36
|
+
isPrimaryKey: false,
|
|
37
|
+
isNullable: true,
|
|
38
|
+
isUnique: false,
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
columnName: 'created_at',
|
|
42
|
+
type: 'timestamp',
|
|
43
|
+
isPrimaryKey: false,
|
|
44
|
+
isNullable: true,
|
|
45
|
+
isUnique: false,
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
columnName: 'updated_at',
|
|
49
|
+
type: 'timestamp',
|
|
50
|
+
isPrimaryKey: false,
|
|
51
|
+
isNullable: true,
|
|
52
|
+
isUnique: false,
|
|
53
|
+
},
|
|
54
|
+
],
|
|
55
|
+
},
|
|
56
|
+
{
|
|
57
|
+
tableName: 'pages',
|
|
58
|
+
columns: [
|
|
59
|
+
{ columnName: 'id', type: 'uuid', isPrimaryKey: true, isNullable: false, isUnique: true },
|
|
60
|
+
{
|
|
61
|
+
columnName: 'workspace_id',
|
|
62
|
+
type: 'uuid',
|
|
63
|
+
isPrimaryKey: false,
|
|
64
|
+
isNullable: false,
|
|
65
|
+
isUnique: false,
|
|
66
|
+
foreignKey: {
|
|
67
|
+
referenceTable: 'workspaces',
|
|
68
|
+
referenceColumn: 'id',
|
|
69
|
+
onDelete: 'CASCADE',
|
|
70
|
+
onUpdate: 'CASCADE',
|
|
71
|
+
},
|
|
72
|
+
},
|
|
73
|
+
{
|
|
74
|
+
columnName: 'parent_page_id',
|
|
75
|
+
type: 'uuid',
|
|
76
|
+
isPrimaryKey: false,
|
|
77
|
+
isNullable: true,
|
|
78
|
+
isUnique: false,
|
|
79
|
+
foreignKey: {
|
|
80
|
+
referenceTable: 'pages',
|
|
81
|
+
referenceColumn: 'id',
|
|
82
|
+
onDelete: 'CASCADE',
|
|
83
|
+
onUpdate: 'CASCADE',
|
|
84
|
+
},
|
|
85
|
+
},
|
|
86
|
+
{
|
|
87
|
+
columnName: 'creator_id',
|
|
88
|
+
type: 'uuid',
|
|
89
|
+
isPrimaryKey: false,
|
|
90
|
+
isNullable: false,
|
|
91
|
+
isUnique: false,
|
|
92
|
+
foreignKey: {
|
|
93
|
+
referenceTable: 'users',
|
|
94
|
+
referenceColumn: 'id',
|
|
95
|
+
onDelete: 'CASCADE',
|
|
96
|
+
onUpdate: 'CASCADE',
|
|
97
|
+
},
|
|
98
|
+
},
|
|
99
|
+
{
|
|
100
|
+
columnName: 'title',
|
|
101
|
+
type: 'varchar',
|
|
102
|
+
isPrimaryKey: false,
|
|
103
|
+
isNullable: false,
|
|
104
|
+
isUnique: false,
|
|
105
|
+
},
|
|
106
|
+
{
|
|
107
|
+
columnName: 'content',
|
|
108
|
+
type: 'text',
|
|
109
|
+
isPrimaryKey: false,
|
|
110
|
+
isNullable: true,
|
|
111
|
+
isUnique: false,
|
|
112
|
+
},
|
|
113
|
+
{
|
|
114
|
+
columnName: 'icon',
|
|
115
|
+
type: 'varchar',
|
|
116
|
+
isPrimaryKey: false,
|
|
117
|
+
isNullable: true,
|
|
118
|
+
isUnique: false,
|
|
119
|
+
},
|
|
120
|
+
{
|
|
121
|
+
columnName: 'cover_image',
|
|
122
|
+
type: 'varchar',
|
|
123
|
+
isPrimaryKey: false,
|
|
124
|
+
isNullable: true,
|
|
125
|
+
isUnique: false,
|
|
126
|
+
},
|
|
127
|
+
{
|
|
128
|
+
columnName: 'is_public',
|
|
129
|
+
type: 'boolean',
|
|
130
|
+
isPrimaryKey: false,
|
|
131
|
+
isNullable: true,
|
|
132
|
+
isUnique: false,
|
|
133
|
+
},
|
|
134
|
+
{
|
|
135
|
+
columnName: 'is_archived',
|
|
136
|
+
type: 'boolean',
|
|
137
|
+
isPrimaryKey: false,
|
|
138
|
+
isNullable: true,
|
|
139
|
+
isUnique: false,
|
|
140
|
+
},
|
|
141
|
+
{
|
|
142
|
+
columnName: 'created_at',
|
|
143
|
+
type: 'timestamp',
|
|
144
|
+
isPrimaryKey: false,
|
|
145
|
+
isNullable: true,
|
|
146
|
+
isUnique: false,
|
|
147
|
+
},
|
|
148
|
+
{
|
|
149
|
+
columnName: 'updated_at',
|
|
150
|
+
type: 'timestamp',
|
|
151
|
+
isPrimaryKey: false,
|
|
152
|
+
isNullable: true,
|
|
153
|
+
isUnique: false,
|
|
154
|
+
},
|
|
155
|
+
],
|
|
156
|
+
},
|
|
157
|
+
{
|
|
158
|
+
tableName: 'page_shares',
|
|
159
|
+
columns: [
|
|
160
|
+
{ columnName: 'id', type: 'uuid', isPrimaryKey: true, isNullable: false, isUnique: true },
|
|
161
|
+
{
|
|
162
|
+
columnName: 'page_id',
|
|
163
|
+
type: 'uuid',
|
|
164
|
+
isPrimaryKey: false,
|
|
165
|
+
isNullable: false,
|
|
166
|
+
isUnique: false,
|
|
167
|
+
foreignKey: {
|
|
168
|
+
referenceTable: 'pages',
|
|
169
|
+
referenceColumn: 'id',
|
|
170
|
+
onDelete: 'CASCADE',
|
|
171
|
+
onUpdate: 'CASCADE',
|
|
172
|
+
},
|
|
173
|
+
},
|
|
174
|
+
{
|
|
175
|
+
columnName: 'user_id',
|
|
176
|
+
type: 'uuid',
|
|
177
|
+
isPrimaryKey: false,
|
|
178
|
+
isNullable: false,
|
|
179
|
+
isUnique: false,
|
|
180
|
+
foreignKey: {
|
|
181
|
+
referenceTable: 'users',
|
|
182
|
+
referenceColumn: 'id',
|
|
183
|
+
onDelete: 'CASCADE',
|
|
184
|
+
onUpdate: 'CASCADE',
|
|
185
|
+
},
|
|
186
|
+
},
|
|
187
|
+
{
|
|
188
|
+
columnName: 'permission',
|
|
189
|
+
type: 'varchar',
|
|
190
|
+
isPrimaryKey: false,
|
|
191
|
+
isNullable: false,
|
|
192
|
+
isUnique: false,
|
|
193
|
+
},
|
|
194
|
+
{
|
|
195
|
+
columnName: 'created_at',
|
|
196
|
+
type: 'timestamp',
|
|
197
|
+
isPrimaryKey: false,
|
|
198
|
+
isNullable: true,
|
|
199
|
+
isUnique: false,
|
|
200
|
+
},
|
|
201
|
+
],
|
|
202
|
+
},
|
|
203
|
+
{
|
|
204
|
+
tableName: 'attachments',
|
|
205
|
+
columns: [
|
|
206
|
+
{ columnName: 'id', type: 'uuid', isPrimaryKey: true, isNullable: false, isUnique: true },
|
|
207
|
+
{
|
|
208
|
+
columnName: 'page_id',
|
|
209
|
+
type: 'uuid',
|
|
210
|
+
isPrimaryKey: false,
|
|
211
|
+
isNullable: false,
|
|
212
|
+
isUnique: false,
|
|
213
|
+
foreignKey: {
|
|
214
|
+
referenceTable: 'pages',
|
|
215
|
+
referenceColumn: 'id',
|
|
216
|
+
onDelete: 'CASCADE',
|
|
217
|
+
onUpdate: 'CASCADE',
|
|
218
|
+
},
|
|
219
|
+
},
|
|
220
|
+
{
|
|
221
|
+
columnName: 'user_id',
|
|
222
|
+
type: 'uuid',
|
|
223
|
+
isPrimaryKey: false,
|
|
224
|
+
isNullable: false,
|
|
225
|
+
isUnique: false,
|
|
226
|
+
foreignKey: {
|
|
227
|
+
referenceTable: 'users',
|
|
228
|
+
referenceColumn: 'id',
|
|
229
|
+
onDelete: 'CASCADE',
|
|
230
|
+
onUpdate: 'CASCADE',
|
|
231
|
+
},
|
|
232
|
+
},
|
|
233
|
+
{
|
|
234
|
+
columnName: 'file_name',
|
|
235
|
+
type: 'varchar',
|
|
236
|
+
isPrimaryKey: false,
|
|
237
|
+
isNullable: false,
|
|
238
|
+
isUnique: false,
|
|
239
|
+
},
|
|
240
|
+
{
|
|
241
|
+
columnName: 'file_url',
|
|
242
|
+
type: 'varchar',
|
|
243
|
+
isPrimaryKey: false,
|
|
244
|
+
isNullable: false,
|
|
245
|
+
isUnique: false,
|
|
246
|
+
},
|
|
247
|
+
{
|
|
248
|
+
columnName: 'file_size',
|
|
249
|
+
type: 'integer',
|
|
250
|
+
isPrimaryKey: false,
|
|
251
|
+
isNullable: true,
|
|
252
|
+
isUnique: false,
|
|
253
|
+
},
|
|
254
|
+
{
|
|
255
|
+
columnName: 'mime_type',
|
|
256
|
+
type: 'varchar',
|
|
257
|
+
isPrimaryKey: false,
|
|
258
|
+
isNullable: true,
|
|
259
|
+
isUnique: false,
|
|
260
|
+
},
|
|
261
|
+
{
|
|
262
|
+
columnName: 'created_at',
|
|
263
|
+
type: 'timestamp',
|
|
264
|
+
isPrimaryKey: false,
|
|
265
|
+
isNullable: true,
|
|
266
|
+
isUnique: false,
|
|
267
|
+
},
|
|
268
|
+
],
|
|
269
|
+
},
|
|
270
|
+
],
|
|
271
|
+
sql: `-- Notion Clone Database Schema
|
|
272
|
+
-- A comprehensive notes workspace with pages, hierarchies, sharing, and attachments
|
|
273
|
+
|
|
274
|
+
-- Workspaces table
|
|
275
|
+
CREATE TABLE workspaces (
|
|
276
|
+
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
277
|
+
name VARCHAR(200) NOT NULL,
|
|
278
|
+
owner_id UUID NOT NULL REFERENCES users(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
279
|
+
icon VARCHAR(100),
|
|
280
|
+
created_at TIMESTAMP DEFAULT NOW(),
|
|
281
|
+
updated_at TIMESTAMP DEFAULT NOW()
|
|
282
|
+
);
|
|
283
|
+
|
|
284
|
+
-- Pages table (with hierarchical structure)
|
|
285
|
+
CREATE TABLE pages (
|
|
286
|
+
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
287
|
+
workspace_id UUID NOT NULL REFERENCES workspaces(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
288
|
+
parent_page_id UUID REFERENCES pages(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
289
|
+
creator_id UUID NOT NULL REFERENCES users(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
290
|
+
title VARCHAR(500) NOT NULL CHECK (LENGTH(TRIM(title)) > 0),
|
|
291
|
+
content TEXT,
|
|
292
|
+
icon VARCHAR(100),
|
|
293
|
+
cover_image VARCHAR(500),
|
|
294
|
+
is_public BOOLEAN DEFAULT FALSE,
|
|
295
|
+
is_archived BOOLEAN DEFAULT FALSE,
|
|
296
|
+
created_at TIMESTAMP DEFAULT NOW(),
|
|
297
|
+
updated_at TIMESTAMP DEFAULT NOW()
|
|
298
|
+
);
|
|
299
|
+
|
|
300
|
+
-- Page shares table (for collaborative editing)
|
|
301
|
+
CREATE TABLE page_shares (
|
|
302
|
+
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
303
|
+
page_id UUID NOT NULL REFERENCES pages(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
304
|
+
user_id UUID NOT NULL REFERENCES users(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
305
|
+
permission VARCHAR(20) NOT NULL CHECK (permission IN ('view', 'edit', 'admin')),
|
|
306
|
+
created_at TIMESTAMP DEFAULT NOW(),
|
|
307
|
+
UNIQUE(page_id, user_id)
|
|
308
|
+
);
|
|
309
|
+
|
|
310
|
+
-- Attachments table (files stored in InsForge storage)
|
|
311
|
+
CREATE TABLE attachments (
|
|
312
|
+
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
313
|
+
page_id UUID NOT NULL REFERENCES pages(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
314
|
+
user_id UUID NOT NULL REFERENCES users(id) ON UPDATE CASCADE ON DELETE CASCADE,
|
|
315
|
+
file_name VARCHAR(255) NOT NULL,
|
|
316
|
+
file_url VARCHAR(500) NOT NULL,
|
|
317
|
+
file_size INTEGER,
|
|
318
|
+
mime_type VARCHAR(100),
|
|
319
|
+
created_at TIMESTAMP DEFAULT NOW()
|
|
320
|
+
);
|
|
321
|
+
|
|
322
|
+
-- Create indexes for better performance
|
|
323
|
+
CREATE INDEX idx_workspaces_owner ON workspaces(owner_id);
|
|
324
|
+
CREATE INDEX idx_pages_workspace ON pages(workspace_id);
|
|
325
|
+
CREATE INDEX idx_pages_parent ON pages(parent_page_id);
|
|
326
|
+
CREATE INDEX idx_pages_creator ON pages(creator_id);
|
|
327
|
+
CREATE INDEX idx_pages_title ON pages USING gin(to_tsvector('english', title));
|
|
328
|
+
CREATE INDEX idx_pages_content ON pages USING gin(to_tsvector('english', content));
|
|
329
|
+
CREATE INDEX idx_pages_public ON pages(is_public) WHERE is_public = TRUE;
|
|
330
|
+
CREATE INDEX idx_pages_archived ON pages(is_archived);
|
|
331
|
+
CREATE INDEX idx_pages_updated ON pages(updated_at DESC);
|
|
332
|
+
CREATE INDEX idx_page_shares_page ON page_shares(page_id);
|
|
333
|
+
CREATE INDEX idx_page_shares_user ON page_shares(user_id);
|
|
334
|
+
CREATE INDEX idx_attachments_page ON attachments(page_id);
|
|
335
|
+
CREATE INDEX idx_attachments_user ON attachments(user_id);
|
|
336
|
+
|
|
337
|
+
-- =======================
|
|
338
|
+
-- ROW LEVEL SECURITY (RLS)
|
|
339
|
+
-- =======================
|
|
340
|
+
|
|
341
|
+
-- Enable RLS on all tables
|
|
342
|
+
ALTER TABLE workspaces ENABLE ROW LEVEL SECURITY;
|
|
343
|
+
ALTER TABLE pages ENABLE ROW LEVEL SECURITY;
|
|
344
|
+
ALTER TABLE page_shares ENABLE ROW LEVEL SECURITY;
|
|
345
|
+
ALTER TABLE attachments ENABLE ROW LEVEL SECURITY;
|
|
346
|
+
|
|
347
|
+
-- Workspaces policies
|
|
348
|
+
CREATE POLICY "Users can view their own workspaces"
|
|
349
|
+
ON workspaces FOR SELECT
|
|
350
|
+
TO authenticated
|
|
351
|
+
USING (owner_id = auth.uid());
|
|
352
|
+
|
|
353
|
+
CREATE POLICY "Users can create their own workspaces"
|
|
354
|
+
ON workspaces FOR INSERT
|
|
355
|
+
TO authenticated
|
|
356
|
+
WITH CHECK (owner_id = auth.uid());
|
|
357
|
+
|
|
358
|
+
CREATE POLICY "Users can update their own workspaces"
|
|
359
|
+
ON workspaces FOR UPDATE
|
|
360
|
+
TO authenticated
|
|
361
|
+
USING (owner_id = auth.uid())
|
|
362
|
+
WITH CHECK (owner_id = auth.uid());
|
|
363
|
+
|
|
364
|
+
CREATE POLICY "Users can delete their own workspaces"
|
|
365
|
+
ON workspaces FOR DELETE
|
|
366
|
+
TO authenticated
|
|
367
|
+
USING (owner_id = auth.uid());
|
|
368
|
+
|
|
369
|
+
-- Pages policies (complex: public, owned, shared)
|
|
370
|
+
CREATE POLICY "Users can view pages they have access to"
|
|
371
|
+
ON pages FOR SELECT
|
|
372
|
+
TO authenticated
|
|
373
|
+
USING (
|
|
374
|
+
is_public = TRUE OR
|
|
375
|
+
creator_id = auth.uid() OR
|
|
376
|
+
workspace_id IN (SELECT id FROM workspaces WHERE owner_id = auth.uid()) OR
|
|
377
|
+
EXISTS(SELECT 1 FROM page_shares WHERE page_id = pages.id AND user_id = auth.uid())
|
|
378
|
+
);
|
|
379
|
+
|
|
380
|
+
CREATE POLICY "Users can create pages in their workspaces"
|
|
381
|
+
ON pages FOR INSERT
|
|
382
|
+
TO authenticated
|
|
383
|
+
WITH CHECK (
|
|
384
|
+
creator_id = auth.uid() AND
|
|
385
|
+
workspace_id IN (SELECT id FROM workspaces WHERE owner_id = auth.uid())
|
|
386
|
+
);
|
|
387
|
+
|
|
388
|
+
CREATE POLICY "Users can update pages they own or have edit access"
|
|
389
|
+
ON pages FOR UPDATE
|
|
390
|
+
TO authenticated
|
|
391
|
+
USING (
|
|
392
|
+
creator_id = auth.uid() OR
|
|
393
|
+
workspace_id IN (SELECT id FROM workspaces WHERE owner_id = auth.uid()) OR
|
|
394
|
+
EXISTS(
|
|
395
|
+
SELECT 1 FROM page_shares
|
|
396
|
+
WHERE page_id = pages.id AND user_id = auth.uid() AND permission IN ('edit', 'admin')
|
|
397
|
+
)
|
|
398
|
+
);
|
|
399
|
+
|
|
400
|
+
CREATE POLICY "Users can delete pages they own"
|
|
401
|
+
ON pages FOR DELETE
|
|
402
|
+
TO authenticated
|
|
403
|
+
USING (
|
|
404
|
+
creator_id = auth.uid() OR
|
|
405
|
+
workspace_id IN (SELECT id FROM workspaces WHERE owner_id = auth.uid())
|
|
406
|
+
);
|
|
407
|
+
|
|
408
|
+
-- Page shares policies
|
|
409
|
+
CREATE POLICY "Users can view shares for their pages"
|
|
410
|
+
ON page_shares FOR SELECT
|
|
411
|
+
TO authenticated
|
|
412
|
+
USING (
|
|
413
|
+
EXISTS(
|
|
414
|
+
SELECT 1 FROM pages p
|
|
415
|
+
WHERE p.id = page_shares.page_id AND
|
|
416
|
+
(p.creator_id = auth.uid() OR p.workspace_id IN (SELECT id FROM workspaces WHERE owner_id = auth.uid()))
|
|
417
|
+
) OR
|
|
418
|
+
user_id = auth.uid()
|
|
419
|
+
);
|
|
420
|
+
|
|
421
|
+
CREATE POLICY "Page owners can create shares"
|
|
422
|
+
ON page_shares FOR INSERT
|
|
423
|
+
TO authenticated
|
|
424
|
+
WITH CHECK (
|
|
425
|
+
EXISTS(
|
|
426
|
+
SELECT 1 FROM pages p
|
|
427
|
+
WHERE p.id = page_shares.page_id AND
|
|
428
|
+
(p.creator_id = auth.uid() OR p.workspace_id IN (SELECT id FROM workspaces WHERE owner_id = auth.uid()))
|
|
429
|
+
)
|
|
430
|
+
);
|
|
431
|
+
|
|
432
|
+
CREATE POLICY "Page owners can delete shares"
|
|
433
|
+
ON page_shares FOR DELETE
|
|
434
|
+
TO authenticated
|
|
435
|
+
USING (
|
|
436
|
+
EXISTS(
|
|
437
|
+
SELECT 1 FROM pages p
|
|
438
|
+
WHERE p.id = page_shares.page_id AND
|
|
439
|
+
(p.creator_id = auth.uid() OR p.workspace_id IN (SELECT id FROM workspaces WHERE owner_id = auth.uid()))
|
|
440
|
+
)
|
|
441
|
+
);
|
|
442
|
+
|
|
443
|
+
-- Attachments policies
|
|
444
|
+
CREATE POLICY "Users can view attachments for pages they can access"
|
|
445
|
+
ON attachments FOR SELECT
|
|
446
|
+
TO authenticated
|
|
447
|
+
USING (
|
|
448
|
+
EXISTS(
|
|
449
|
+
SELECT 1 FROM pages p
|
|
450
|
+
WHERE p.id = attachments.page_id AND
|
|
451
|
+
(
|
|
452
|
+
p.is_public = TRUE OR
|
|
453
|
+
p.creator_id = auth.uid() OR
|
|
454
|
+
p.workspace_id IN (SELECT id FROM workspaces WHERE owner_id = auth.uid()) OR
|
|
455
|
+
EXISTS(SELECT 1 FROM page_shares WHERE page_id = p.id AND user_id = auth.uid())
|
|
456
|
+
)
|
|
457
|
+
)
|
|
458
|
+
);
|
|
459
|
+
|
|
460
|
+
CREATE POLICY "Users can create attachments for pages they can edit"
|
|
461
|
+
ON attachments FOR INSERT
|
|
462
|
+
TO authenticated
|
|
463
|
+
WITH CHECK (
|
|
464
|
+
user_id = auth.uid() AND
|
|
465
|
+
EXISTS(
|
|
466
|
+
SELECT 1 FROM pages p
|
|
467
|
+
WHERE p.id = attachments.page_id AND
|
|
468
|
+
(
|
|
469
|
+
p.creator_id = auth.uid() OR
|
|
470
|
+
p.workspace_id IN (SELECT id FROM workspaces WHERE owner_id = auth.uid()) OR
|
|
471
|
+
EXISTS(
|
|
472
|
+
SELECT 1 FROM page_shares
|
|
473
|
+
WHERE page_id = p.id AND user_id = auth.uid() AND permission IN ('edit', 'admin')
|
|
474
|
+
)
|
|
475
|
+
)
|
|
476
|
+
)
|
|
477
|
+
);
|
|
478
|
+
|
|
479
|
+
CREATE POLICY "Users can delete their own attachments"
|
|
480
|
+
ON attachments FOR DELETE
|
|
481
|
+
TO authenticated
|
|
482
|
+
USING (user_id = auth.uid());`,
|
|
483
|
+
};
|