insforge 0.3.1

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 (395) hide show
  1. package/.dockerignore +58 -0
  2. package/.env.example +49 -0
  3. package/.github/ISSUE_TEMPLATE/bug_report.yml +83 -0
  4. package/.github/ISSUE_TEMPLATE/config.yml +11 -0
  5. package/.github/ISSUE_TEMPLATE/feature_request.yml +79 -0
  6. package/.github/copilot-instructions.md +147 -0
  7. package/.github/workflows/build-image.yml +65 -0
  8. package/.github/workflows/ci-premerge-check.yml +24 -0
  9. package/.github/workflows/deploy-aws.yml +130 -0
  10. package/.github/workflows/lint-and-format.yml +33 -0
  11. package/.prettierignore +65 -0
  12. package/.prettierrc +9 -0
  13. package/CHANGELOG.md +3 -0
  14. package/CONTRIBUTING.md +126 -0
  15. package/Dockerfile +27 -0
  16. package/GITHUB_OAUTH_SETUP.md +49 -0
  17. package/GOOGLE_OAUTH_SETUP.md +148 -0
  18. package/LICENSE +201 -0
  19. package/README.md +134 -0
  20. package/assets/Dark.svg +23 -0
  21. package/assets/archDiagram.png +0 -0
  22. package/assets/banner.png +0 -0
  23. package/assets/mcpInstallv2.png +0 -0
  24. package/assets/sampleResponse.png +0 -0
  25. package/assets/signin.png +0 -0
  26. package/assets/userflow.png +0 -0
  27. package/backend/migrations/000_create-base-tables.sql +142 -0
  28. package/backend/migrations/001_create-helper-functions.sql +41 -0
  29. package/backend/migrations/002_rename-auth-tables.sql +30 -0
  30. package/backend/migrations/003_create-users-table.sql +56 -0
  31. package/backend/migrations/004_add-reload-postgrest-func.sql +24 -0
  32. package/backend/migrations/005_enable-project-admin-modify-users.sql +30 -0
  33. package/backend/migrations/006_modify-ai-usage-table.sql +25 -0
  34. package/backend/migrations/007_drop-metadata-table.sql +2 -0
  35. package/backend/migrations/008_add-system-tables.sql +77 -0
  36. package/backend/migrations/009_add-function-secrets.sql +24 -0
  37. package/backend/migrations/010_modify-ai-config-modalities.sql +93 -0
  38. package/backend/migrations/011_refactor-secrets-table.sql +15 -0
  39. package/backend/migrations/012_add-storage-uploaded-by.sql +8 -0
  40. package/backend/package.json +75 -0
  41. package/backend/src/api/middleware/auth.ts +240 -0
  42. package/backend/src/api/middleware/error.ts +231 -0
  43. package/backend/src/api/middleware/upload.ts +59 -0
  44. package/backend/src/api/routes/agent.ts +29 -0
  45. package/backend/src/api/routes/ai.ts +472 -0
  46. package/backend/src/api/routes/auth.oauth.ts +482 -0
  47. package/backend/src/api/routes/auth.ts +386 -0
  48. package/backend/src/api/routes/database.advance.ts +275 -0
  49. package/backend/src/api/routes/database.records.ts +246 -0
  50. package/backend/src/api/routes/database.tables.ts +161 -0
  51. package/backend/src/api/routes/docs.ts +66 -0
  52. package/backend/src/api/routes/functions.ts +183 -0
  53. package/backend/src/api/routes/logs.ts +150 -0
  54. package/backend/src/api/routes/metadata.ts +160 -0
  55. package/backend/src/api/routes/openapi.ts +82 -0
  56. package/backend/src/api/routes/secrets.ts +199 -0
  57. package/backend/src/api/routes/storage.ts +547 -0
  58. package/backend/src/api/routes/usage.ts +96 -0
  59. package/backend/src/core/ai/chat.ts +207 -0
  60. package/backend/src/core/ai/client.ts +242 -0
  61. package/backend/src/core/ai/config.ts +187 -0
  62. package/backend/src/core/ai/image.ts +156 -0
  63. package/backend/src/core/ai/model.ts +117 -0
  64. package/backend/src/core/ai/usage.ts +290 -0
  65. package/backend/src/core/auth/auth.ts +781 -0
  66. package/backend/src/core/auth/oauth.ts +398 -0
  67. package/backend/src/core/database/advance.ts +1074 -0
  68. package/backend/src/core/database/manager.ts +178 -0
  69. package/backend/src/core/database/table.ts +772 -0
  70. package/backend/src/core/documentation/agent.ts +689 -0
  71. package/backend/src/core/documentation/openapi.ts +856 -0
  72. package/backend/src/core/functions/functions.ts +310 -0
  73. package/backend/src/core/logs/analytics.ts +76 -0
  74. package/backend/src/core/logs/audit.ts +255 -0
  75. package/backend/src/core/logs/providers/base.provider.ts +83 -0
  76. package/backend/src/core/logs/providers/cloudwatch.provider.ts +510 -0
  77. package/backend/src/core/logs/providers/localdb.provider.ts +246 -0
  78. package/backend/src/core/secrets/encryption.ts +58 -0
  79. package/backend/src/core/secrets/secrets.ts +410 -0
  80. package/backend/src/core/socket/socket.ts +388 -0
  81. package/backend/src/core/socket/types.ts +79 -0
  82. package/backend/src/core/storage/storage.ts +923 -0
  83. package/backend/src/server.ts +288 -0
  84. package/backend/src/types/ai.ts +46 -0
  85. package/backend/src/types/auth.ts +90 -0
  86. package/backend/src/types/database.ts +136 -0
  87. package/backend/src/types/error-constants.ts +86 -0
  88. package/backend/src/types/logs.ts +47 -0
  89. package/backend/src/types/profile.ts +55 -0
  90. package/backend/src/types/storage.ts +23 -0
  91. package/backend/src/utils/cloud-token.ts +39 -0
  92. package/backend/src/utils/constants.ts +1 -0
  93. package/backend/src/utils/environment.ts +35 -0
  94. package/backend/src/utils/helpers.ts +49 -0
  95. package/backend/src/utils/logger.ts +13 -0
  96. package/backend/src/utils/response.ts +62 -0
  97. package/backend/src/utils/seed.ts +205 -0
  98. package/backend/src/utils/sql-parser.ts +63 -0
  99. package/backend/src/utils/uuid.ts +9 -0
  100. package/backend/src/utils/validations.ts +129 -0
  101. package/backend/tests/README.md +134 -0
  102. package/backend/tests/cleanup-all-test-data.sh +231 -0
  103. package/backend/tests/cloud/test-s3-multitenant.sh +132 -0
  104. package/backend/tests/local/comprehensive-curl-tests.sh +156 -0
  105. package/backend/tests/local/test-auth-router.sh +144 -0
  106. package/backend/tests/local/test-database-router.sh +222 -0
  107. package/backend/tests/local/test-e2e.sh +241 -0
  108. package/backend/tests/local/test-fk-errors.sh +97 -0
  109. package/backend/tests/local/test-id-field.sh +201 -0
  110. package/backend/tests/local/test-public-bucket.sh +265 -0
  111. package/backend/tests/local/test-secrets.sh +248 -0
  112. package/backend/tests/local/test-serverless-functions.sh.disabled +325 -0
  113. package/backend/tests/local/test-traditional-rest.sh +209 -0
  114. package/backend/tests/manual/README.md +51 -0
  115. package/backend/tests/manual/create-large-table-simple.sql +11 -0
  116. package/backend/tests/manual/seed-large-table.sql +101 -0
  117. package/backend/tests/manual/setup-large-table-extras.sql +34 -0
  118. package/backend/tests/manual/test-better-auth.sh +303 -0
  119. package/backend/tests/manual/test-bulk-upsert.sh +410 -0
  120. package/backend/tests/manual/test-database-advance.sh +297 -0
  121. package/backend/tests/manual/test-postgrest-stability.sh +192 -0
  122. package/backend/tests/manual/test-rawsql-export-import.sh +412 -0
  123. package/backend/tests/manual/test-universal-storage.sh +264 -0
  124. package/backend/tests/manual/test-users.sql +18 -0
  125. package/backend/tests/run-all-tests.sh +140 -0
  126. package/backend/tests/setup.ts +22 -0
  127. package/backend/tests/test-config.sh +303 -0
  128. package/backend/tsconfig.json +23 -0
  129. package/backend/tsup.config.ts +18 -0
  130. package/backend/vitest.config.ts +22 -0
  131. package/docker-compose.prod.yml +145 -0
  132. package/docker-compose.yml +167 -0
  133. package/docker-init/db/db-init.sql +125 -0
  134. package/docker-init/db/jwt.sql +5 -0
  135. package/docker-init/db/logs.sql +9 -0
  136. package/docker-init/db/postgresql.conf +17 -0
  137. package/docs/deprecated/insforge-auth-api.md +215 -0
  138. package/docs/deprecated/insforge-auth-sdk.md +100 -0
  139. package/docs/deprecated/insforge-db-api.md +359 -0
  140. package/docs/deprecated/insforge-db-sdk.md +140 -0
  141. package/docs/deprecated/insforge-debug-sdk.md +157 -0
  142. package/docs/deprecated/insforge-debug.md +65 -0
  143. package/docs/deprecated/insforge-instructions.md +124 -0
  144. package/docs/deprecated/insforge-project.md +118 -0
  145. package/docs/deprecated/insforge-storage-api.md +279 -0
  146. package/docs/deprecated/insforge-storage-sdk.md +159 -0
  147. package/docs/insforge-instructions-sdk.md +407 -0
  148. package/eslint.config.js +317 -0
  149. package/examples/oauth/frontend-oauth-example.html +251 -0
  150. package/examples/response-examples.md +444 -0
  151. package/frontend/README.md +112 -0
  152. package/frontend/components.json +17 -0
  153. package/frontend/index.html +13 -0
  154. package/frontend/package.json +63 -0
  155. package/frontend/public/favicon.ico +0 -0
  156. package/frontend/src/App.tsx +106 -0
  157. package/frontend/src/assets/icons/checkbox_checked.svg +6 -0
  158. package/frontend/src/assets/icons/checkbox_undetermined.svg +6 -0
  159. package/frontend/src/assets/icons/checked.svg +3 -0
  160. package/frontend/src/assets/icons/error.svg +3 -0
  161. package/frontend/src/assets/icons/pencil.svg +4 -0
  162. package/frontend/src/assets/icons/refresh.svg +4 -0
  163. package/frontend/src/assets/icons/step_active.svg +3 -0
  164. package/frontend/src/assets/icons/step_inactive.svg +11 -0
  165. package/frontend/src/assets/icons/warning.svg +3 -0
  166. package/frontend/src/assets/logos/amazon.svg +1 -0
  167. package/frontend/src/assets/logos/claude_code.svg +3 -0
  168. package/frontend/src/assets/logos/cline.svg +6 -0
  169. package/frontend/src/assets/logos/cursor.svg +20 -0
  170. package/frontend/src/assets/logos/discord.svg +9 -0
  171. package/frontend/src/assets/logos/gemini.svg +19 -0
  172. package/frontend/src/assets/logos/github.svg +5 -0
  173. package/frontend/src/assets/logos/google.svg +13 -0
  174. package/frontend/src/assets/logos/grok.svg +10 -0
  175. package/frontend/src/assets/logos/insforge_dark.svg +15 -0
  176. package/frontend/src/assets/logos/insforge_light.svg +15 -0
  177. package/frontend/src/assets/logos/openai.svg +10 -0
  178. package/frontend/src/assets/logos/roo_code.svg +9 -0
  179. package/frontend/src/assets/logos/trae.svg +3 -0
  180. package/frontend/src/assets/logos/windsurf.svg +10 -0
  181. package/frontend/src/components/ButtonWithLoading.tsx +27 -0
  182. package/frontend/src/components/Checkbox.tsx +61 -0
  183. package/frontend/src/components/CodeBlock.tsx +32 -0
  184. package/frontend/src/components/ConfirmDialog.tsx +96 -0
  185. package/frontend/src/components/CopyButton.tsx +69 -0
  186. package/frontend/src/components/DeleteActionButton.tsx +42 -0
  187. package/frontend/src/components/EmptyState.tsx +41 -0
  188. package/frontend/src/components/ErrorState.tsx +35 -0
  189. package/frontend/src/components/FeatureSidebar.tsx +126 -0
  190. package/frontend/src/components/FeatureSidebarItem.tsx +101 -0
  191. package/frontend/src/components/JsonHighlight.tsx +61 -0
  192. package/frontend/src/components/LoadingState.tsx +16 -0
  193. package/frontend/src/components/PaginationControls.tsx +54 -0
  194. package/frontend/src/components/PromptDialog.tsx +68 -0
  195. package/frontend/src/components/SearchInput.tsx +90 -0
  196. package/frontend/src/components/SelectionClearButton.tsx +26 -0
  197. package/frontend/src/components/Stepper.tsx +139 -0
  198. package/frontend/src/components/ThemeToggle.tsx +58 -0
  199. package/frontend/src/components/TypeBadge.tsx +20 -0
  200. package/frontend/src/components/datagrid/DataGrid.tsx +264 -0
  201. package/frontend/src/components/datagrid/DefaultCellRenderer.tsx +114 -0
  202. package/frontend/src/components/datagrid/IdCell.tsx +44 -0
  203. package/frontend/src/components/datagrid/SortableHeader.tsx +74 -0
  204. package/frontend/src/components/datagrid/cell-editors/BooleanCellEditor.tsx +54 -0
  205. package/frontend/src/components/datagrid/cell-editors/DateCellEditor.tsx +483 -0
  206. package/frontend/src/components/datagrid/cell-editors/JsonCellEditor.tsx +362 -0
  207. package/frontend/src/components/datagrid/cell-editors/TextCellEditor.tsx +38 -0
  208. package/frontend/src/components/datagrid/cell-editors/index.ts +14 -0
  209. package/frontend/src/components/datagrid/cell-editors/types.ts +43 -0
  210. package/frontend/src/components/datagrid/datagridTypes.tsx +72 -0
  211. package/frontend/src/components/datagrid/index.tsx +20 -0
  212. package/frontend/src/components/index.ts +39 -0
  213. package/frontend/src/components/layout/AppHeader.tsx +146 -0
  214. package/frontend/src/components/layout/AppSidebar.tsx +190 -0
  215. package/frontend/src/components/layout/CloudLayout.tsx +95 -0
  216. package/frontend/src/components/layout/Layout.tsx +43 -0
  217. package/frontend/src/components/radix/Alert.tsx +45 -0
  218. package/frontend/src/components/radix/AlertDialog.tsx +115 -0
  219. package/frontend/src/components/radix/Avatar.tsx +45 -0
  220. package/frontend/src/components/radix/Badge.tsx +33 -0
  221. package/frontend/src/components/radix/Button.tsx +50 -0
  222. package/frontend/src/components/radix/Card.tsx +58 -0
  223. package/frontend/src/components/radix/Dialog.tsx +98 -0
  224. package/frontend/src/components/radix/DropdownMenu.tsx +185 -0
  225. package/frontend/src/components/radix/Form.tsx +167 -0
  226. package/frontend/src/components/radix/Input.tsx +22 -0
  227. package/frontend/src/components/radix/Label.tsx +19 -0
  228. package/frontend/src/components/radix/Popover.tsx +29 -0
  229. package/frontend/src/components/radix/ScrollArea.tsx +44 -0
  230. package/frontend/src/components/radix/Select.tsx +151 -0
  231. package/frontend/src/components/radix/Separator.tsx +26 -0
  232. package/frontend/src/components/radix/Sheet.tsx +119 -0
  233. package/frontend/src/components/radix/Skeleton.tsx +7 -0
  234. package/frontend/src/components/radix/Switch.tsx +29 -0
  235. package/frontend/src/components/radix/Tabs.tsx +50 -0
  236. package/frontend/src/components/radix/Textarea.tsx +21 -0
  237. package/frontend/src/components/radix/Tooltip.tsx +28 -0
  238. package/frontend/src/features/ai/components/AIConfigCard.tsx +154 -0
  239. package/frontend/src/features/ai/components/AIConfigDialog.tsx +76 -0
  240. package/frontend/src/features/ai/components/AIConfigForm.tsx +222 -0
  241. package/frontend/src/features/ai/components/AIEmptyState.tsx +18 -0
  242. package/frontend/src/features/ai/components/fields/ModalityField.tsx +87 -0
  243. package/frontend/src/features/ai/components/fields/ModelSelectionField.tsx +134 -0
  244. package/frontend/src/features/ai/components/fields/SystemPromptField.tsx +33 -0
  245. package/frontend/src/features/ai/helpers.ts +155 -0
  246. package/frontend/src/features/ai/hooks/useAIConfigs.ts +221 -0
  247. package/frontend/src/features/ai/hooks/useAIUsage.ts +77 -0
  248. package/frontend/src/features/ai/page/AIPage.tsx +178 -0
  249. package/frontend/src/features/ai/services/ai.service.ts +148 -0
  250. package/frontend/src/features/auth/components/AddOAuthDialog.tsx +106 -0
  251. package/frontend/src/features/auth/components/AuthMethodTab.tsx +238 -0
  252. package/frontend/src/features/auth/components/OAuthConfigDialog.tsx +303 -0
  253. package/frontend/src/features/auth/components/OAuthEmptyState.tsx +15 -0
  254. package/frontend/src/features/auth/components/UserFormDialog.tsx +248 -0
  255. package/frontend/src/features/auth/components/UsersDataGrid.tsx +183 -0
  256. package/frontend/src/features/auth/components/UsersTab.tsx +114 -0
  257. package/frontend/src/features/auth/hooks/useOAuthConfig.ts +129 -0
  258. package/frontend/src/features/auth/hooks/useUsers.ts +57 -0
  259. package/frontend/src/features/auth/index.ts +9 -0
  260. package/frontend/src/features/auth/page/AuthenticationPage.tsx +169 -0
  261. package/frontend/src/features/auth/services/auth.service.ts +112 -0
  262. package/frontend/src/features/auth/services/oauth.service.ts +49 -0
  263. package/frontend/src/features/dashboard/page/DashboardPage.tsx +194 -0
  264. package/frontend/src/features/database/components/ColumnTypeSelect.tsx +64 -0
  265. package/frontend/src/features/database/components/DatabaseDataGrid.tsx +282 -0
  266. package/frontend/src/features/database/components/ForeignKeyCell.tsx +187 -0
  267. package/frontend/src/features/database/components/ForeignKeyPopover.tsx +378 -0
  268. package/frontend/src/features/database/components/LinkRecordModal.tsx +288 -0
  269. package/frontend/src/features/database/components/RecordFormDialog.tsx +164 -0
  270. package/frontend/src/features/database/components/RecordFormField.tsx +568 -0
  271. package/frontend/src/features/database/components/TableEmptyState.tsx +21 -0
  272. package/frontend/src/features/database/components/TableForm.tsx +656 -0
  273. package/frontend/src/features/database/components/TableFormColumn.tsx +137 -0
  274. package/frontend/src/features/database/components/TableListSkeleton.tsx +9 -0
  275. package/frontend/src/features/database/components/TableSidebar.tsx +47 -0
  276. package/frontend/src/features/database/constants.ts +26 -0
  277. package/frontend/src/features/database/helpers.ts +125 -0
  278. package/frontend/src/features/database/hooks/UseLinkModal.tsx +78 -0
  279. package/frontend/src/features/database/index.ts +12 -0
  280. package/frontend/src/features/database/page/DatabasePage.tsx +626 -0
  281. package/frontend/src/features/database/schema.ts +25 -0
  282. package/frontend/src/features/database/services/database.service.ts +216 -0
  283. package/frontend/src/features/functions/components/FunctionEmptyState.tsx +15 -0
  284. package/frontend/src/features/functions/components/FunctionRow.tsx +71 -0
  285. package/frontend/src/features/functions/components/FunctionViewer.tsx +46 -0
  286. package/frontend/src/features/functions/components/FunctionsContent.tsx +88 -0
  287. package/frontend/src/features/functions/components/FunctionsSidebar.tsx +56 -0
  288. package/frontend/src/features/functions/components/SecretEmptyState.tsx +23 -0
  289. package/frontend/src/features/functions/components/SecretRow.tsx +68 -0
  290. package/frontend/src/features/functions/components/SecretsContent.tsx +120 -0
  291. package/frontend/src/features/functions/hooks/useFunctions.ts +106 -0
  292. package/frontend/src/features/functions/page/FunctionsPage.tsx +28 -0
  293. package/frontend/src/features/functions/services/functions.service.ts +48 -0
  294. package/frontend/src/features/login/components/AuthErrorBoundary.tsx +87 -0
  295. package/frontend/src/features/login/components/PrivateRoute.tsx +24 -0
  296. package/frontend/src/features/login/page/CloudLoginPage.tsx +93 -0
  297. package/frontend/src/features/login/page/LoginPage.tsx +174 -0
  298. package/frontend/src/features/logs/components/AnalyticsLogsTable.tsx +313 -0
  299. package/frontend/src/features/logs/components/LogsTable.tsx +199 -0
  300. package/frontend/src/features/logs/hooks/useAuditLogs.ts +39 -0
  301. package/frontend/src/features/logs/index.ts +5 -0
  302. package/frontend/src/features/logs/page/AnalyticsLogsPage.tsx +530 -0
  303. package/frontend/src/features/logs/page/AuditsPage.tsx +192 -0
  304. package/frontend/src/features/logs/services/log.service.ts +171 -0
  305. package/frontend/src/features/metadata/hooks/useMetadata.ts +53 -0
  306. package/frontend/src/features/metadata/index.ts +0 -0
  307. package/frontend/src/features/metadata/page/MetadataPage.tsx +136 -0
  308. package/frontend/src/features/metadata/services/metadata.service.ts +17 -0
  309. package/frontend/src/features/onboard/components/CompletionCard.tsx +41 -0
  310. package/frontend/src/features/onboard/components/OnboardButton.tsx +84 -0
  311. package/frontend/src/features/onboard/components/StepContent.tsx +91 -0
  312. package/frontend/src/features/onboard/components/TestConnectionStep.tsx +53 -0
  313. package/frontend/src/features/onboard/components/mcp/CursorDeeplinkGenerator.tsx +35 -0
  314. package/frontend/src/features/onboard/components/mcp/McpInstallation.tsx +144 -0
  315. package/frontend/src/features/onboard/components/mcp/index.ts +4 -0
  316. package/frontend/src/features/onboard/components/mcp/mcp-helper.tsx +98 -0
  317. package/frontend/src/features/onboard/index.ts +3 -0
  318. package/frontend/src/features/onboard/page/OnBoardPage.tsx +104 -0
  319. package/frontend/src/features/onboard/types.ts +8 -0
  320. package/frontend/src/features/secrets/hooks/useSecrets.ts +139 -0
  321. package/frontend/src/features/secrets/services/secrets.service.ts +57 -0
  322. package/frontend/src/features/storage/components/BucketEmptyState.tsx +19 -0
  323. package/frontend/src/features/storage/components/BucketFormDialog.tsx +194 -0
  324. package/frontend/src/features/storage/components/BucketListSkeleton.tsx +17 -0
  325. package/frontend/src/features/storage/components/FilePreviewDialog.tsx +287 -0
  326. package/frontend/src/features/storage/components/StorageDataGrid.tsx +239 -0
  327. package/frontend/src/features/storage/components/StorageManager.tsx +236 -0
  328. package/frontend/src/features/storage/components/StorageSidebar.tsx +44 -0
  329. package/frontend/src/features/storage/components/UploadToast.tsx +46 -0
  330. package/frontend/src/features/storage/index.ts +3 -0
  331. package/frontend/src/features/storage/page/StoragePage.tsx +553 -0
  332. package/frontend/src/features/storage/services/storage.service.ts +144 -0
  333. package/frontend/src/features/visualizer/components/AuthNode.tsx +107 -0
  334. package/frontend/src/features/visualizer/components/BucketNode.tsx +34 -0
  335. package/frontend/src/features/visualizer/components/SchemaVisualizer.tsx +359 -0
  336. package/frontend/src/features/visualizer/components/TableNode.tsx +152 -0
  337. package/frontend/src/features/visualizer/components/VisualizerSkeleton.tsx +24 -0
  338. package/frontend/src/features/visualizer/components/index.ts +5 -0
  339. package/frontend/src/features/visualizer/page/VisualizerPage.tsx +127 -0
  340. package/frontend/src/index.css +248 -0
  341. package/frontend/src/lib/api/client.ts +163 -0
  342. package/frontend/src/lib/contexts/AuthContext.tsx +157 -0
  343. package/frontend/src/lib/contexts/OnboardStepContext.tsx +68 -0
  344. package/frontend/src/lib/contexts/SocketContext.tsx +303 -0
  345. package/frontend/src/lib/contexts/ThemeContext.tsx +125 -0
  346. package/frontend/src/lib/hooks/useAuth.ts +4 -0
  347. package/frontend/src/lib/hooks/useConfirm.ts +55 -0
  348. package/frontend/src/lib/hooks/useInterval.ts +27 -0
  349. package/frontend/src/lib/hooks/useMediaQuery.ts +59 -0
  350. package/frontend/src/lib/hooks/useOnboardingCompletion.ts +29 -0
  351. package/frontend/src/lib/hooks/usePagination.ts +27 -0
  352. package/frontend/src/lib/hooks/useTimeout.ts +27 -0
  353. package/frontend/src/lib/hooks/useToast.tsx +229 -0
  354. package/frontend/src/lib/utils/constants.ts +38 -0
  355. package/frontend/src/lib/utils/utils.ts +165 -0
  356. package/frontend/src/lib/utils/validation-schemas.ts +126 -0
  357. package/frontend/src/main.tsx +16 -0
  358. package/frontend/src/rdg.css +194 -0
  359. package/frontend/src/vite-env.d.ts +12 -0
  360. package/frontend/tailwind.config.js +97 -0
  361. package/frontend/tsconfig.json +26 -0
  362. package/frontend/tsconfig.node.json +10 -0
  363. package/frontend/vite.config.ts +37 -0
  364. package/frontend/vitest.config.ts +36 -0
  365. package/functions/deno.json +25 -0
  366. package/functions/server.ts +290 -0
  367. package/functions/worker-template.js +126 -0
  368. package/openapi/ai.yaml +689 -0
  369. package/openapi/auth.yaml +563 -0
  370. package/openapi/functions.yaml +476 -0
  371. package/openapi/health.yaml +30 -0
  372. package/openapi/logs.yaml +224 -0
  373. package/openapi/metadata.yaml +178 -0
  374. package/openapi/records.yaml +382 -0
  375. package/openapi/secrets.yaml +371 -0
  376. package/openapi/storage.yaml +876 -0
  377. package/openapi/tables.yaml +464 -0
  378. package/package.json +88 -0
  379. package/shared-schemas/package.json +31 -0
  380. package/shared-schemas/src/ai-api.schema.ts +167 -0
  381. package/shared-schemas/src/ai.schema.ts +54 -0
  382. package/shared-schemas/src/auth-api.schema.ts +193 -0
  383. package/shared-schemas/src/auth.schema.ts +94 -0
  384. package/shared-schemas/src/database-api.schema.ts +259 -0
  385. package/shared-schemas/src/database.schema.ts +69 -0
  386. package/shared-schemas/src/functions-api.schema.ts +25 -0
  387. package/shared-schemas/src/functions.schema.ts +16 -0
  388. package/shared-schemas/src/index.ts +13 -0
  389. package/shared-schemas/src/logs-api.schema.ts +49 -0
  390. package/shared-schemas/src/logs.schema.ts +14 -0
  391. package/shared-schemas/src/metadata.schema.ts +56 -0
  392. package/shared-schemas/src/storage-api.schema.ts +65 -0
  393. package/shared-schemas/src/storage.schema.ts +19 -0
  394. package/shared-schemas/tsconfig.json +21 -0
  395. package/tsconfig.json +8 -0
@@ -0,0 +1,148 @@
1
+ import { apiClient } from '@/lib/api/client';
2
+ import {
3
+ ListModelsResponse,
4
+ AIConfigurationSchema,
5
+ AIConfigurationWithUsageSchema,
6
+ CreateAIConfigurationRequest,
7
+ UpdateAIConfigurationRequest,
8
+ AIUsageSummarySchema,
9
+ AIUsageRecordSchema,
10
+ ListAIUsageResponse,
11
+ } from '@insforge/shared-schemas';
12
+
13
+ export class AiService {
14
+ getModels(): Promise<ListModelsResponse> {
15
+ return apiClient.request('/ai/models', {
16
+ headers: apiClient.withAccessToken(),
17
+ });
18
+ }
19
+
20
+ // AI Configuration endpoints
21
+ async createConfiguration(
22
+ data: CreateAIConfigurationRequest
23
+ ): Promise<{ id: string; message: string }> {
24
+ return apiClient.request('/ai/configurations', {
25
+ method: 'POST',
26
+ headers: apiClient.withAccessToken(),
27
+ body: JSON.stringify(data),
28
+ });
29
+ }
30
+
31
+ async listConfigurations(): Promise<AIConfigurationWithUsageSchema[]> {
32
+ return apiClient.request('/ai/configurations', {
33
+ headers: apiClient.withAccessToken(),
34
+ });
35
+ }
36
+
37
+ async getConfiguration(id: string): Promise<AIConfigurationSchema> {
38
+ return apiClient.request(`/ai/configurations/${id}`, {
39
+ headers: apiClient.withAccessToken(),
40
+ });
41
+ }
42
+
43
+ async updateConfiguration(
44
+ id: string,
45
+ data: UpdateAIConfigurationRequest
46
+ ): Promise<{ message: string }> {
47
+ return apiClient.request(`/ai/configurations/${id}`, {
48
+ method: 'PATCH',
49
+ headers: apiClient.withAccessToken(),
50
+ body: JSON.stringify(data),
51
+ });
52
+ }
53
+
54
+ async deleteConfiguration(id: string): Promise<{ message: string }> {
55
+ return apiClient.request(`/ai/configurations/${id}`, {
56
+ method: 'DELETE',
57
+ headers: apiClient.withAccessToken(),
58
+ });
59
+ }
60
+
61
+ // AI Usage endpoints
62
+ async getUsageSummary(params?: {
63
+ configId?: string;
64
+ startDate?: string;
65
+ endDate?: string;
66
+ }): Promise<AIUsageSummarySchema> {
67
+ const queryParams = new URLSearchParams();
68
+ if (params?.configId) {
69
+ queryParams.append('configId', params.configId);
70
+ }
71
+ if (params?.startDate) {
72
+ queryParams.append('startDate', params.startDate);
73
+ }
74
+ if (params?.endDate) {
75
+ queryParams.append('endDate', params.endDate);
76
+ }
77
+
78
+ const queryString = queryParams.toString();
79
+ const url = `/ai/usage/summary${queryString ? `?${queryString}` : ''}`;
80
+
81
+ return apiClient.request(url, {
82
+ headers: apiClient.withAccessToken(),
83
+ });
84
+ }
85
+
86
+ async getUsageRecords(params?: {
87
+ startDate?: string;
88
+ endDate?: string;
89
+ limit?: string;
90
+ offset?: string;
91
+ }): Promise<ListAIUsageResponse> {
92
+ const queryParams = new URLSearchParams();
93
+ if (params?.startDate) {
94
+ queryParams.append('startDate', params.startDate);
95
+ }
96
+ if (params?.endDate) {
97
+ queryParams.append('endDate', params.endDate);
98
+ }
99
+ if (params?.limit) {
100
+ queryParams.append('limit', params.limit);
101
+ }
102
+ if (params?.offset) {
103
+ queryParams.append('offset', params.offset);
104
+ }
105
+
106
+ const queryString = queryParams.toString();
107
+ const url = `/ai/usage${queryString ? `?${queryString}` : ''}`;
108
+
109
+ return apiClient.request(url, {
110
+ headers: apiClient.withAccessToken(),
111
+ });
112
+ }
113
+
114
+ async getConfigUsageRecords(
115
+ configId: string,
116
+ params?: {
117
+ startDate?: string;
118
+ endDate?: string;
119
+ }
120
+ ): Promise<AIUsageRecordSchema[]> {
121
+ const queryParams = new URLSearchParams();
122
+ if (params?.startDate) {
123
+ queryParams.append('startDate', params.startDate);
124
+ }
125
+ if (params?.endDate) {
126
+ queryParams.append('endDate', params.endDate);
127
+ }
128
+
129
+ const queryString = queryParams.toString();
130
+ const url = `/ai/usage/config/${configId}${queryString ? `?${queryString}` : ''}`;
131
+
132
+ return apiClient.request(url, {
133
+ headers: apiClient.withAccessToken(),
134
+ });
135
+ }
136
+
137
+ async getRemainingCredits(): Promise<{
138
+ usage: number;
139
+ limit: number | null;
140
+ remaining: number | null;
141
+ }> {
142
+ return apiClient.request('/ai/credits', {
143
+ headers: apiClient.withAccessToken(),
144
+ });
145
+ }
146
+ }
147
+
148
+ export const aiService = new AiService();
@@ -0,0 +1,106 @@
1
+ import { useState, useEffect } from 'react';
2
+ import { Button } from '@/components/radix/Button';
3
+ import { Checkbox } from '@/components/Checkbox';
4
+ import {
5
+ Dialog,
6
+ DialogContent,
7
+ DialogFooter,
8
+ DialogHeader,
9
+ DialogTitle,
10
+ } from '@/components/radix/Dialog';
11
+ import { OAuthProviderInfo } from './AuthMethodTab';
12
+
13
+ interface AddOAuthDialogProps {
14
+ providers: OAuthProviderInfo[];
15
+ open: boolean;
16
+ onOpenChange: (open: boolean) => void;
17
+ onConfirm: (selectedId: 'google' | 'github') => void;
18
+ enabledProviders: Record<'google' | 'github', boolean>;
19
+ }
20
+
21
+ export function AddOAuthDialog({
22
+ providers,
23
+ open,
24
+ onOpenChange,
25
+ onConfirm,
26
+ enabledProviders,
27
+ }: AddOAuthDialogProps) {
28
+ const [selectedId, setSelectedId] = useState<'google' | 'github' | null>(null);
29
+
30
+ // Reset selection when dialog opens
31
+ useEffect(() => {
32
+ if (open) {
33
+ setSelectedId(null);
34
+ }
35
+ }, [open]);
36
+
37
+ const hasSelection = selectedId !== null;
38
+
39
+ // Filter out already enabled providers
40
+ const availableProviders = providers.filter((provider) => !enabledProviders[provider.id]);
41
+
42
+ const selectProvider = (id: 'google' | 'github') => {
43
+ setSelectedId(id);
44
+ };
45
+
46
+ const handleConfirm = () => {
47
+ if (selectedId) {
48
+ onConfirm(selectedId);
49
+ }
50
+ };
51
+
52
+ return (
53
+ <Dialog open={open} onOpenChange={onOpenChange}>
54
+ <DialogContent className="max-w-[600px] p-0 gap-0 dark:bg-neutral-800">
55
+ <DialogHeader className="pl-6 pr-4 py-3 border-b border-zinc-200 dark:border-neutral-700">
56
+ <DialogTitle className="text-lg font-semibold text-zinc-950 dark:text-white">
57
+ Add Authentication
58
+ </DialogTitle>
59
+ </DialogHeader>
60
+ <div className="p-6">
61
+ {availableProviders.length > 0 ? (
62
+ <div className="grid grid-cols-2 gap-3">
63
+ {availableProviders.map((p) => (
64
+ <button
65
+ key={p.id}
66
+ onClick={() => selectProvider(p.id)}
67
+ className="flex items-center justify-start gap-6 rounded-[8px] p-3 bg-white hover:bg-zinc-100 dark:bg-[#333333] dark:hover:bg-neutral-700 border border-neutral-200 dark:border-neutral-700 transition-colors"
68
+ >
69
+ <div className="w-4 h-4" onClick={(e) => e.stopPropagation()}>
70
+ <Checkbox checked={selectedId === p.id} onChange={() => selectProvider(p.id)} />
71
+ </div>
72
+ <div className="flex items-center gap-3">
73
+ {p.icon}
74
+ <p className="text-sm font-medium text-zinc-950 dark:text-white">{p.name}</p>
75
+ </div>
76
+ </button>
77
+ ))}
78
+ </div>
79
+ ) : (
80
+ <div className="text-center py-8">
81
+ <p className="text-sm text-zinc-500 dark:text-neutral-400">
82
+ All authentication methods have been added.
83
+ </p>
84
+ </div>
85
+ )}
86
+ </div>
87
+ <DialogFooter className="px-6 py-4 border-t border-zinc-200 dark:border-neutral-700">
88
+ <Button
89
+ variant="outline"
90
+ className="w-fit h-9 px-3 py-2 rounded-sm dark:bg-neutral-600 dark:text-white dark:border-transparent dark:hover:bg-neutral-700"
91
+ onClick={() => onOpenChange(false)}
92
+ >
93
+ Cancel
94
+ </Button>
95
+ <Button
96
+ className="h-9 px-3 py-2 rounded-sm dark:bg-emerald-300 dark:text-black dark:hover:bg-emerald-400"
97
+ onClick={handleConfirm}
98
+ disabled={!hasSelection}
99
+ >
100
+ Add OAuth
101
+ </Button>
102
+ </DialogFooter>
103
+ </DialogContent>
104
+ </Dialog>
105
+ );
106
+ }
@@ -0,0 +1,238 @@
1
+ import { useState, useCallback, useMemo, ReactElement } from 'react';
2
+ import { Button } from '@/components/radix/Button';
3
+ import { MoreHorizontal, Plus, Trash2, Pencil } from 'lucide-react';
4
+ import Github from '@/assets/logos/github.svg?react';
5
+ import Google from '@/assets/logos/google.svg?react';
6
+ import { OAuthEmptyState } from './OAuthEmptyState';
7
+ import { OAuthConfigDialog } from './OAuthConfigDialog';
8
+ import { AddOAuthDialog } from './AddOAuthDialog';
9
+ import { useOAuthConfig } from '@/features/auth/hooks/useOAuthConfig';
10
+ import { useConfirm } from '@/lib/hooks/useConfirm';
11
+ import { ConfirmDialog } from '@/components/ConfirmDialog';
12
+ import {
13
+ DropdownMenu,
14
+ DropdownMenuContent,
15
+ DropdownMenuItem,
16
+ DropdownMenuTrigger,
17
+ } from '@/components/radix/DropdownMenu';
18
+
19
+ const providers: OAuthProviderInfo[] = [
20
+ {
21
+ id: 'google',
22
+ name: 'Google OAuth',
23
+ icon: <Google className="w-6 h-6" />,
24
+ description: 'Configure Google authentication for your users',
25
+ setupUrl: 'https://console.cloud.google.com/apis/credentials',
26
+ },
27
+ {
28
+ id: 'github',
29
+ name: 'GitHub OAuth',
30
+ icon: <Github className="w-6 h-6 dark:text-white" />,
31
+ description: 'Configure GitHub authentication for your users',
32
+ setupUrl: 'https://github.com/settings/developers',
33
+ },
34
+ ];
35
+
36
+ export interface OAuthProviderInfo {
37
+ id: 'google' | 'github';
38
+ name: string;
39
+ icon: ReactElement;
40
+ description: string;
41
+ setupUrl: string;
42
+ }
43
+
44
+ export function AuthMethodTab() {
45
+ const [selectedProvider, setSelectedProvider] = useState<OAuthProviderInfo>();
46
+ const [isDialogOpen, setIsDialogOpen] = useState(false);
47
+ const [isSelectDialogOpen, setIsSelectDialogOpen] = useState(false);
48
+ const { confirm, confirmDialogProps } = useConfirm();
49
+ const {
50
+ configs,
51
+ isLoadingConfigs,
52
+ deleteConfig,
53
+ refetchConfigs,
54
+ getProviderConfig,
55
+ isProviderConfigured,
56
+ } = useOAuthConfig();
57
+
58
+ const handleConfigureProvider = (provider: OAuthProviderInfo) => {
59
+ setSelectedProvider(provider);
60
+ setIsDialogOpen(true);
61
+ };
62
+
63
+ const deleteOAuthConfig = async (providerId: 'google' | 'github', providerName: string) => {
64
+ const shouldDelete = await confirm({
65
+ title: `Delete ${providerName} OAuth`,
66
+ description: `Are you sure you want to delete the ${providerName} configuration? This action cannot be undone.`,
67
+ confirmText: 'Delete',
68
+ cancelText: 'Cancel',
69
+ destructive: true,
70
+ });
71
+
72
+ if (shouldDelete) {
73
+ try {
74
+ deleteConfig(providerId);
75
+ } catch (error) {
76
+ console.error(`Failed to delete ${providerId} OAuth:`, error);
77
+ }
78
+ }
79
+ };
80
+
81
+ const handleCloseDialog = () => {
82
+ setIsDialogOpen(false);
83
+ setSelectedProvider(undefined);
84
+ };
85
+
86
+ const hasAuthMethods = useMemo(() => {
87
+ return configs.length > 0;
88
+ }, [configs]);
89
+
90
+ const openSelectDialog = () => {
91
+ setIsSelectDialogOpen(true);
92
+ };
93
+
94
+ const enabledProviders = useMemo(() => {
95
+ return {
96
+ google: isProviderConfigured('google'),
97
+ github: isProviderConfigured('github'),
98
+ };
99
+ }, [isProviderConfigured]);
100
+
101
+ // Check if all providers are enabled
102
+ const allProvidersEnabled = useMemo(() => {
103
+ return providers.every((provider) => enabledProviders[provider.id]);
104
+ }, [enabledProviders]);
105
+
106
+ const handleConfirmSelected = (selectedId: 'google' | 'github') => {
107
+ // Find the selected provider
108
+ const selectedProvider = providers.find((p) => p.id === selectedId);
109
+ if (!selectedProvider) {
110
+ return;
111
+ }
112
+
113
+ // Close the select dialog and open the method dialog
114
+ setIsSelectDialogOpen(false);
115
+ setSelectedProvider(selectedProvider);
116
+ setIsDialogOpen(true);
117
+ };
118
+
119
+ const handleSuccess = useCallback(() => {
120
+ // Refresh configuration after successful update
121
+ void refetchConfigs();
122
+ }, [refetchConfigs]);
123
+
124
+ if (isLoadingConfigs) {
125
+ return (
126
+ <div className="flex items-center justify-center py-16">
127
+ <div className="text-center">
128
+ <div className="text-sm text-gray-500 dark:text-zinc-400">
129
+ Loading OAuth configuration...
130
+ </div>
131
+ </div>
132
+ </div>
133
+ );
134
+ }
135
+
136
+ return (
137
+ <>
138
+ <div className="flex flex-col gap-6 h-full overflow-hidden p-6 w-full max-w-[1080px] mx-auto">
139
+ <div className="flex items-center justify-between">
140
+ <h2 className="text-2xl font-semibold text-gray-900 dark:text-white">Auth Method</h2>
141
+ {!allProvidersEnabled && (
142
+ <Button
143
+ className="h-9 pr-3 pl-2 py-2 gap-2 dark:bg-neutral-700 dark:text-white dark:hover:bg-neutral-600 text-sm font-medium rounded-sm"
144
+ onClick={openSelectDialog}
145
+ >
146
+ <Plus className="w-5 h-5" />
147
+ Add Auth
148
+ </Button>
149
+ )}
150
+ </div>
151
+
152
+ <div className="flex-1">
153
+ {hasAuthMethods ? (
154
+ <div className="grid grid-cols-2 gap-x-3 gap-y-6">
155
+ {providers.map((provider) => {
156
+ const providerConfig = getProviderConfig(provider.id);
157
+ if (!providerConfig) {
158
+ return null;
159
+ }
160
+
161
+ return (
162
+ <div
163
+ key={provider.id}
164
+ className="flex items-center justify-between h-15 p-4 bg-white rounded-[8px] border border-gray-200 dark:border-transparent dark:bg-[#333333]"
165
+ >
166
+ <div className="flex-1 flex items-center gap-3">
167
+ {provider.icon}
168
+
169
+ <div className="text-sm font-medium text-black dark:text-white">
170
+ {provider.name}
171
+ </div>
172
+ </div>
173
+
174
+ <div className="flex items-center gap-3">
175
+ {providerConfig.useSharedKey && (
176
+ <span className="px-2 py-0.5 text-xs font-medium text-neutral-500 dark:text-neutral-400 border border-neutral-500 dark:border-neutral-400 rounded">
177
+ Shared Keys
178
+ </span>
179
+ )}
180
+
181
+ <DropdownMenu>
182
+ <DropdownMenuTrigger asChild>
183
+ <Button
184
+ className="h-7 w-7 p-1 text-gray-500 dark:text-neutral-400 hover:bg-neutral-100 dark:hover:bg-neutral-700"
185
+ variant="ghost"
186
+ size="sm"
187
+ >
188
+ <MoreHorizontal className="w-5 h-5" />
189
+ </Button>
190
+ </DropdownMenuTrigger>
191
+ <DropdownMenuContent align="end" className="w-40 py-1 px-2">
192
+ <DropdownMenuItem
193
+ onClick={() => handleConfigureProvider(provider)}
194
+ className="py-2 px-3 flex items-center gap-3 cursor-pointer"
195
+ >
196
+ <Pencil className="w-5 h-5" />
197
+ Edit
198
+ </DropdownMenuItem>
199
+ <DropdownMenuItem
200
+ onClick={() => void deleteOAuthConfig(provider.id, provider.name)}
201
+ className="py-2 px-3 flex items-center gap-3 cursor-pointer text-red-600 dark:text-red-400"
202
+ >
203
+ <Trash2 className="w-5 h-5" />
204
+ Delete
205
+ </DropdownMenuItem>
206
+ </DropdownMenuContent>
207
+ </DropdownMenu>
208
+ </div>
209
+ </div>
210
+ );
211
+ })}
212
+ </div>
213
+ ) : (
214
+ <OAuthEmptyState />
215
+ )}
216
+ </div>
217
+ </div>
218
+
219
+ <OAuthConfigDialog
220
+ provider={selectedProvider}
221
+ isOpen={isDialogOpen}
222
+ onClose={handleCloseDialog}
223
+ onSuccess={handleSuccess}
224
+ />
225
+
226
+ <AddOAuthDialog
227
+ providers={providers}
228
+ open={isSelectDialogOpen}
229
+ onOpenChange={setIsSelectDialogOpen}
230
+ onConfirm={handleConfirmSelected}
231
+ enabledProviders={enabledProviders}
232
+ />
233
+
234
+ {/* Confirm Dialog */}
235
+ <ConfirmDialog {...confirmDialogProps} />
236
+ </>
237
+ );
238
+ }