@nexttylabs/echo 0.4.0 → 0.6.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.
Files changed (262) hide show
  1. package/CHANGELOG.md +27 -0
  2. package/app/(dashboard)/admin/feedback/[id]/edit/page.tsx +12 -6
  3. package/app/(dashboard)/admin/feedback/new/page.tsx +19 -17
  4. package/app/(dashboard)/admin/layout.tsx +16 -6
  5. package/app/(dashboard)/layout.tsx +4 -2
  6. package/app/(dashboard)/settings/api-keys/page.tsx +13 -3
  7. package/app/(dashboard)/settings/layout.tsx +25 -2
  8. package/app/(dashboard)/settings/organization/page.tsx +8 -9
  9. package/app/(public)/[organizationSlug]/roadmap/page.tsx +19 -1
  10. package/app/api/admin/backup/route.ts +22 -4
  11. package/app/api/auth/register/handler.ts +1 -2
  12. package/app/api/feedback/[id]/comments/[commentId]/route.ts +13 -4
  13. package/app/api/feedback/[id]/reclassify/route.ts +4 -4
  14. package/app/api/organizations/handler.ts +2 -4
  15. package/components/settings/settings-sidebar.tsx +4 -4
  16. package/hooks/use-organization.tsx +116 -0
  17. package/hooks/use-permissions.ts +24 -11
  18. package/lib/auth/config.ts +0 -7
  19. package/lib/auth/organization.ts +20 -0
  20. package/lib/auth/permissions.ts +10 -0
  21. package/lib/db/migrations/0000_needy_leech.sql +335 -0
  22. package/lib/db/migrations/meta/0000_snapshot.json +2186 -1
  23. package/lib/db/migrations/meta/_journal.json +2 -135
  24. package/lib/db/schema/auth.ts +0 -1
  25. package/lib/db/schema/index.ts +0 -1
  26. package/lib/portal/public-context.tsx +5 -0
  27. package/package.json +20 -1
  28. package/.changeset/README.md +0 -21
  29. package/.changeset/config.json +0 -11
  30. package/.changeset/cozy-ghosts-care.md +0 -5
  31. package/.changeset/sharp-lines-stand.md +0 -5
  32. package/.changeset/sour-doodles-eat.md +0 -5
  33. package/.changeset/tender-moose-shop.md +0 -5
  34. package/.github/pull_request_template.md +0 -13
  35. package/.github/workflows/ci.yml +0 -41
  36. package/.github/workflows/publish.yml +0 -44
  37. package/.github/workflows/release.yml +0 -73
  38. package/AGENTS.md +0 -92
  39. package/Dockerfile +0 -57
  40. package/Makefile +0 -77
  41. package/bun.lock +0 -2503
  42. package/components/portal/project-switcher.tsx +0 -20
  43. package/docker-compose.dev.yml +0 -26
  44. package/docker-compose.yml +0 -98
  45. package/docs/architecture.md +0 -259
  46. package/docs/component-inventory.md +0 -261
  47. package/docs/database-migrations.md +0 -76
  48. package/docs/development-guide.md +0 -209
  49. package/docs/e2e-user-flows.csv +0 -31
  50. package/docs/er-diagram-feedback.mmd +0 -138
  51. package/docs/er-diagram.mmd +0 -281
  52. package/docs/i18n-check-report.md +0 -296
  53. package/docs/index.md +0 -214
  54. package/docs/logic-chain.md +0 -94
  55. package/docs/plans/2026-01-02-database-migration-scripts.md +0 -496
  56. package/docs/plans/2026-01-02-user-login-design.md +0 -37
  57. package/docs/plans/2026-01-02-user-login.md +0 -437
  58. package/docs/plans/2026-01-02-user-registration-design.md +0 -47
  59. package/docs/plans/2026-01-02-user-registration.md +0 -628
  60. package/docs/plans/2026-01-03-roles-permissions-design.md +0 -20
  61. package/docs/plans/2026-01-03-roles-permissions.md +0 -266
  62. package/docs/plans/2026-01-05-authentication-middleware.md +0 -207
  63. package/docs/plans/2026-01-05-member-removal.md +0 -186
  64. package/docs/plans/2026-01-05-organization-creation.md +0 -374
  65. package/docs/plans/2026-01-05-rbac-middleware.md +0 -112
  66. package/docs/plans/2026-01-05-role-configuration.md +0 -441
  67. package/docs/plans/2026-01-06-file-upload-support.md +0 -804
  68. package/docs/plans/2026-01-06-permission-check-hook.md +0 -155
  69. package/docs/plans/2026-01-06-resource-ownership-check.md +0 -231
  70. package/docs/plans/2026-01-07-feedback-tracking-link.md +0 -459
  71. package/docs/plans/2026-01-09-logout-redirect-design.md +0 -52
  72. package/docs/plans/2026-01-09-phase2-3-plan.md +0 -654
  73. package/docs/plans/2026-01-09-portal-execution-plan.md +0 -408
  74. package/docs/plans/2026-01-09-project-delete-feature-design.md +0 -163
  75. package/docs/plans/2026-01-09-project-delete-implementation.md +0 -451
  76. package/docs/plans/2026-01-09-project-edit-delete-design.md +0 -52
  77. package/docs/plans/2026-01-09-settings-center-design.md +0 -114
  78. package/docs/plans/2026-01-09-settings-center.md +0 -948
  79. package/docs/plans/2026-01-10-organization-only-design.md +0 -66
  80. package/docs/plans/2026-01-10-organization-only-implementation.md +0 -433
  81. package/docs/plans/2026-01-10-portal-settings-restructure-plan.md +0 -18
  82. package/docs/plans/2026-01-10-project-settings-tabs-design-implementation.md +0 -296
  83. package/docs/plans/2026-01-14-e2e-playwright-feedback.md +0 -173
  84. package/docs/plans/2026-01-15-feedback-management-org-context-design.md +0 -82
  85. package/docs/plans/2026-01-15-feedback-management-org-context-implementation-plan.md +0 -521
  86. package/docs/plans/2026-01-16-admin-feedback-filters-design.md +0 -75
  87. package/docs/plans/2026-01-16-admin-feedback-filters-implementation.md +0 -293
  88. package/docs/plans/2026-01-16-admin-feedback-route-consolidation.md +0 -180
  89. package/docs/plans/2026-01-16-e2e-test-fixes.md +0 -158
  90. package/docs/plans/2026-01-17-admin-feedback-filters.md +0 -214
  91. package/docs/plans/2026-01-17-admin-feedback-improvements.md +0 -453
  92. package/docs/plans/2026-01-18-changesets-design.md +0 -40
  93. package/docs/product_changes.md +0 -37
  94. package/docs/project-overview.md +0 -159
  95. package/docs/project-scan-report.json +0 -104
  96. package/docs/route-role-visibility.md +0 -51
  97. package/docs/source-tree-analysis.md +0 -150
  98. package/docs/testing/delete-project-manual-tests.md +0 -18
  99. package/docs/user-story-tracking.md +0 -191
  100. package/eslint.config.mjs +0 -19
  101. package/lib/db/migrations/.gitkeep +0 -0
  102. package/lib/db/migrations/0000_cynical_gladiator.sql +0 -53
  103. package/lib/db/migrations/0001_wandering_sunfire.sql +0 -27
  104. package/lib/db/migrations/0002_shallow_speedball.sql +0 -1
  105. package/lib/db/migrations/0003_add_org_description.sql +0 -1
  106. package/lib/db/migrations/0003_boring_wild_pack.sql +0 -13
  107. package/lib/db/migrations/0004_windy_tyrannus.sql +0 -27
  108. package/lib/db/migrations/0005_perpetual_doorman.sql +0 -5
  109. package/lib/db/migrations/0006_aberrant_captain_midlands.sql +0 -13
  110. package/lib/db/migrations/0007_clever_captain_cross.sql +0 -14
  111. package/lib/db/migrations/0008_sparkling_pandemic.sql +0 -2
  112. package/lib/db/migrations/0009_happy_black_tom.sql +0 -29
  113. package/lib/db/migrations/0010_kind_junta.sql +0 -8
  114. package/lib/db/migrations/0011_mute_squadron_supreme.sql +0 -25
  115. package/lib/db/migrations/0012_giant_power_man.sql +0 -24
  116. package/lib/db/migrations/0013_damp_titanium_man.sql +0 -17
  117. package/lib/db/migrations/0014_blue_alice.sql +0 -18
  118. package/lib/db/migrations/0015_webhook_tables.sql +0 -41
  119. package/lib/db/migrations/0016_github_integration.sql +0 -30
  120. package/lib/db/migrations/0016_overjoyed_ghost_rider.sql +0 -22
  121. package/lib/db/migrations/0017_slimy_inhumans.sql +0 -6
  122. package/lib/db/migrations/0018_same_spitfire.sql +0 -1
  123. package/lib/db/migrations/0019_jittery_loners.sql +0 -16
  124. package/lib/db/migrations/0019_remove_projects_add_org_settings.sql +0 -14
  125. package/lib/db/migrations/meta/0001_snapshot.json +0 -553
  126. package/lib/db/migrations/meta/0002_snapshot.json +0 -560
  127. package/lib/db/migrations/meta/0003_snapshot.json +0 -650
  128. package/lib/db/migrations/meta/0004_snapshot.json +0 -852
  129. package/lib/db/migrations/meta/0005_snapshot.json +0 -900
  130. package/lib/db/migrations/meta/0006_snapshot.json +0 -1011
  131. package/lib/db/migrations/meta/0007_snapshot.json +0 -1125
  132. package/lib/db/migrations/meta/0008_snapshot.json +0 -1146
  133. package/lib/db/migrations/meta/0009_snapshot.json +0 -1386
  134. package/lib/db/migrations/meta/0010_snapshot.json +0 -1419
  135. package/lib/db/migrations/meta/0011_snapshot.json +0 -1615
  136. package/lib/db/migrations/meta/0012_snapshot.json +0 -1805
  137. package/lib/db/migrations/meta/0013_snapshot.json +0 -1948
  138. package/lib/db/migrations/meta/0014_snapshot.json +0 -2082
  139. package/lib/db/migrations/meta/0015_snapshot.json +0 -2476
  140. package/lib/db/migrations/meta/0016_snapshot.json +0 -2633
  141. package/lib/db/migrations/meta/0017_snapshot.json +0 -2680
  142. package/lib/db/migrations/meta/0018_snapshot.json +0 -2686
  143. package/lib/db/migrations/meta/0019_snapshot.json +0 -2741
  144. package/lib/db/schema/projects.ts +0 -145
  145. package/lib/db/schema/user-profiles.ts +0 -31
  146. package/lib/validations/projects.ts +0 -49
  147. package/next-env.d.ts +0 -6
  148. package/playwright.config.ts +0 -44
  149. package/proxy.test.ts +0 -131
  150. package/proxy.ts +0 -116
  151. package/scripts/backup-db.sh +0 -57
  152. package/scripts/backup-db.ts +0 -24
  153. package/scripts/generate-openapi.ts +0 -22
  154. package/scripts/migration-helper.ts +0 -39
  155. package/scripts/pre-deploy.ts +0 -75
  156. package/scripts/restore-db.sh +0 -60
  157. package/scripts/rollback.ts +0 -72
  158. package/scripts/seed-tags.ts +0 -48
  159. package/tests/api/feedback-bulk.test.ts +0 -47
  160. package/tests/api/feedback-by-id.test.ts +0 -67
  161. package/tests/api/feedback-comments-route-import.test.ts +0 -26
  162. package/tests/api/feedback-create.test.ts +0 -71
  163. package/tests/api/feedback-delete.test.ts +0 -160
  164. package/tests/api/feedback-filter.test.ts +0 -250
  165. package/tests/api/feedback-list.test.ts +0 -234
  166. package/tests/api/feedback-route-assignee-condition.test.ts +0 -32
  167. package/tests/api/feedback-similar.test.ts +0 -46
  168. package/tests/api/feedback-sort.test.ts +0 -261
  169. package/tests/api/feedback-status-enum.test.ts +0 -49
  170. package/tests/api/feedback-status-filter.test.ts +0 -117
  171. package/tests/api/feedback-submit-on-behalf.test.ts +0 -269
  172. package/tests/api/feedback.test.ts +0 -175
  173. package/tests/api/identify-jwt.test.ts +0 -25
  174. package/tests/api/invitation-accept.test.ts +0 -213
  175. package/tests/api/organization-invitations.test.ts +0 -186
  176. package/tests/api/organization-members-list.test.ts +0 -79
  177. package/tests/api/organization-members.test.ts +0 -340
  178. package/tests/api/organizations.test.ts +0 -149
  179. package/tests/api/register.test.ts +0 -112
  180. package/tests/api/upload.test.ts +0 -103
  181. package/tests/api/vote.test.ts +0 -82
  182. package/tests/app/admin-feedback-detail-page.test.tsx +0 -25
  183. package/tests/app/admin-feedback-list-page.test.tsx +0 -25
  184. package/tests/app/admin-feedback-new-page.test.tsx +0 -25
  185. package/tests/app/health-route-helpers.test.ts +0 -27
  186. package/tests/app/login-page.test.ts +0 -26
  187. package/tests/app/portal-page.test.ts +0 -29
  188. package/tests/app/project-portal-overview.test.tsx +0 -25
  189. package/tests/app/widget-page-import.test.ts +0 -25
  190. package/tests/components/create-post-dialog-defaults.test.ts +0 -43
  191. package/tests/components/feedback/duplicate-suggestions-inline.test.tsx +0 -27
  192. package/tests/components/feedback/embedded-feedback-form.test.tsx +0 -96
  193. package/tests/components/feedback/feedback-detail.test.tsx +0 -25
  194. package/tests/components/feedback/feedback-stats.test.tsx +0 -49
  195. package/tests/components/feedback-bulk-actions.test.tsx +0 -39
  196. package/tests/components/feedback-i18n-keys.test.ts +0 -70
  197. package/tests/components/feedback-list-controls-compile.test.ts +0 -25
  198. package/tests/components/feedback-list-controls.test.tsx +0 -204
  199. package/tests/components/feedback-list-item.test.tsx +0 -67
  200. package/tests/components/landing/hero.test.tsx +0 -46
  201. package/tests/components/layout/language-switcher.test.tsx +0 -25
  202. package/tests/components/layout/sidebar.test.tsx +0 -157
  203. package/tests/components/login-form.test.ts +0 -25
  204. package/tests/components/organization-form.test.ts +0 -32
  205. package/tests/components/organization-switcher.test.ts +0 -25
  206. package/tests/components/pagination.test.tsx +0 -43
  207. package/tests/components/portal-overview.test.tsx +0 -25
  208. package/tests/components/profile-form.test.tsx +0 -139
  209. package/tests/components/role-selector.test.ts +0 -31
  210. package/tests/components/status-chart.test.tsx +0 -90
  211. package/tests/e2e/auth.e2e.ts +0 -323
  212. package/tests/e2e/feedback-actions.e2e.ts +0 -471
  213. package/tests/e2e/feedback-attachment.e2e.ts +0 -168
  214. package/tests/e2e/feedback-customer.e2e.ts +0 -226
  215. package/tests/e2e/feedback-management.e2e.ts +0 -565
  216. package/tests/e2e/feedback-submit.e2e.ts +0 -133
  217. package/tests/e2e/feedback-view.e2e.ts +0 -297
  218. package/tests/e2e/fixtures/test-data.ts +0 -235
  219. package/tests/e2e/health-check.e2e.ts +0 -230
  220. package/tests/e2e/helpers/test-utils-helpers.test.ts +0 -43
  221. package/tests/e2e/helpers/test-utils.ts +0 -298
  222. package/tests/e2e/integration-placeholders.e2e.ts +0 -199
  223. package/tests/e2e/organization.e2e.ts +0 -292
  224. package/tests/e2e/permissions.e2e.ts +0 -424
  225. package/tests/e2e/project-widget.e2e.ts +0 -63
  226. package/tests/feedback/filters.test.ts +0 -29
  227. package/tests/hooks/use-permissions.test.ts +0 -52
  228. package/tests/lib/ai/classifier.test.ts +0 -104
  229. package/tests/lib/ai/duplicate-detector.test.ts +0 -234
  230. package/tests/lib/attachments-schema.test.ts +0 -30
  231. package/tests/lib/auth/session.test.ts +0 -49
  232. package/tests/lib/auth-client.test.ts +0 -37
  233. package/tests/lib/auth-config.test.ts +0 -26
  234. package/tests/lib/feedback-prefill.test.ts +0 -52
  235. package/tests/lib/feedback-processor.test.ts +0 -41
  236. package/tests/lib/feedback-schema.test.ts +0 -33
  237. package/tests/lib/file-validator.test.ts +0 -48
  238. package/tests/lib/get-feedback-by-id.test.ts +0 -37
  239. package/tests/lib/invitations.test.ts +0 -35
  240. package/tests/lib/login-schema.test.ts +0 -36
  241. package/tests/lib/org-context.test.ts +0 -95
  242. package/tests/lib/organization-access.test.ts +0 -44
  243. package/tests/lib/organization-member-role-schema.test.ts +0 -41
  244. package/tests/lib/permissions.test.ts +0 -88
  245. package/tests/lib/portal-analytics.test.ts +0 -25
  246. package/tests/lib/portal-contributors.test.ts +0 -25
  247. package/tests/lib/portal-copy.test.ts +0 -27
  248. package/tests/lib/portal-i18n.test.ts +0 -30
  249. package/tests/lib/portal-leaderboard-settings.test.ts +0 -25
  250. package/tests/lib/portal-modules.test.ts +0 -25
  251. package/tests/lib/portal-seo.test.ts +0 -25
  252. package/tests/lib/portal-sharing.test.ts +0 -25
  253. package/tests/lib/portal-sorting.test.ts +0 -25
  254. package/tests/lib/portal-theme.test.ts +0 -25
  255. package/tests/lib/rate-limit.test.ts +0 -142
  256. package/tests/lib/resolve-locale.test.ts +0 -34
  257. package/tests/lib/services/backup.test.ts +0 -145
  258. package/tests/lib/user-organizations.test.ts +0 -42
  259. package/tests/lib/user-role-schema.test.ts +0 -33
  260. package/tests/lib/user-schema.test.ts +0 -25
  261. package/tests/setup.ts +0 -74
  262. package/vercel.json +0 -4
@@ -1,2633 +0,0 @@
1
- {
2
- "id": "9b8e4563-e070-42d2-9b43-c98b0e6b38d2",
3
- "prevId": "7c17086b-ea65-4419-8a1a-70fab1b464ca",
4
- "version": "7",
5
- "dialect": "postgresql",
6
- "tables": {
7
- "public.ai_processing_results": {
8
- "name": "ai_processing_results",
9
- "schema": "",
10
- "columns": {
11
- "id": {
12
- "name": "id",
13
- "type": "serial",
14
- "primaryKey": true,
15
- "notNull": true
16
- },
17
- "feedbackId": {
18
- "name": "feedbackId",
19
- "type": "integer",
20
- "primaryKey": false,
21
- "notNull": true
22
- },
23
- "classification": {
24
- "name": "classification",
25
- "type": "jsonb",
26
- "primaryKey": false,
27
- "notNull": false
28
- },
29
- "tagSuggestions": {
30
- "name": "tagSuggestions",
31
- "type": "jsonb",
32
- "primaryKey": false,
33
- "notNull": false
34
- },
35
- "duplicateCandidates": {
36
- "name": "duplicateCandidates",
37
- "type": "jsonb",
38
- "primaryKey": false,
39
- "notNull": false
40
- },
41
- "processingTime": {
42
- "name": "processingTime",
43
- "type": "integer",
44
- "primaryKey": false,
45
- "notNull": false
46
- },
47
- "status": {
48
- "name": "status",
49
- "type": "text",
50
- "primaryKey": false,
51
- "notNull": true,
52
- "default": "'pending'"
53
- },
54
- "errorMessage": {
55
- "name": "errorMessage",
56
- "type": "text",
57
- "primaryKey": false,
58
- "notNull": false
59
- },
60
- "createdAt": {
61
- "name": "createdAt",
62
- "type": "timestamp",
63
- "primaryKey": false,
64
- "notNull": true,
65
- "default": "now()"
66
- },
67
- "updatedAt": {
68
- "name": "updatedAt",
69
- "type": "timestamp",
70
- "primaryKey": false,
71
- "notNull": true,
72
- "default": "now()"
73
- }
74
- },
75
- "indexes": {
76
- "idx_ai_results_feedback": {
77
- "name": "idx_ai_results_feedback",
78
- "columns": [
79
- {
80
- "expression": "feedbackId",
81
- "isExpression": false,
82
- "asc": true,
83
- "nulls": "last"
84
- }
85
- ],
86
- "isUnique": false,
87
- "concurrently": false,
88
- "method": "btree",
89
- "with": {}
90
- },
91
- "idx_ai_results_status": {
92
- "name": "idx_ai_results_status",
93
- "columns": [
94
- {
95
- "expression": "status",
96
- "isExpression": false,
97
- "asc": true,
98
- "nulls": "last"
99
- }
100
- ],
101
- "isUnique": false,
102
- "concurrently": false,
103
- "method": "btree",
104
- "with": {}
105
- }
106
- },
107
- "foreignKeys": {
108
- "ai_processing_results_feedbackId_feedback_feedbackId_fk": {
109
- "name": "ai_processing_results_feedbackId_feedback_feedbackId_fk",
110
- "tableFrom": "ai_processing_results",
111
- "tableTo": "feedback",
112
- "columnsFrom": [
113
- "feedbackId"
114
- ],
115
- "columnsTo": [
116
- "feedbackId"
117
- ],
118
- "onDelete": "cascade",
119
- "onUpdate": "no action"
120
- }
121
- },
122
- "compositePrimaryKeys": {},
123
- "uniqueConstraints": {},
124
- "policies": {},
125
- "checkConstraints": {},
126
- "isRLSEnabled": false
127
- },
128
- "public.api_keys": {
129
- "name": "api_keys",
130
- "schema": "",
131
- "columns": {
132
- "keyId": {
133
- "name": "keyId",
134
- "type": "serial",
135
- "primaryKey": true,
136
- "notNull": true
137
- },
138
- "name": {
139
- "name": "name",
140
- "type": "text",
141
- "primaryKey": false,
142
- "notNull": true
143
- },
144
- "hashedKey": {
145
- "name": "hashedKey",
146
- "type": "text",
147
- "primaryKey": false,
148
- "notNull": true
149
- },
150
- "prefix": {
151
- "name": "prefix",
152
- "type": "text",
153
- "primaryKey": false,
154
- "notNull": true
155
- },
156
- "organizationId": {
157
- "name": "organizationId",
158
- "type": "text",
159
- "primaryKey": false,
160
- "notNull": true
161
- },
162
- "disabled": {
163
- "name": "disabled",
164
- "type": "boolean",
165
- "primaryKey": false,
166
- "notNull": true,
167
- "default": false
168
- },
169
- "lastUsed": {
170
- "name": "lastUsed",
171
- "type": "timestamp",
172
- "primaryKey": false,
173
- "notNull": false
174
- },
175
- "createdAt": {
176
- "name": "createdAt",
177
- "type": "timestamp",
178
- "primaryKey": false,
179
- "notNull": true,
180
- "default": "now()"
181
- },
182
- "updatedAt": {
183
- "name": "updatedAt",
184
- "type": "timestamp",
185
- "primaryKey": false,
186
- "notNull": true,
187
- "default": "now()"
188
- }
189
- },
190
- "indexes": {
191
- "idx_api_keys_hashedKey": {
192
- "name": "idx_api_keys_hashedKey",
193
- "columns": [
194
- {
195
- "expression": "hashedKey",
196
- "isExpression": false,
197
- "asc": true,
198
- "nulls": "last"
199
- }
200
- ],
201
- "isUnique": false,
202
- "concurrently": false,
203
- "method": "btree",
204
- "with": {}
205
- },
206
- "idx_api_keys_orgId": {
207
- "name": "idx_api_keys_orgId",
208
- "columns": [
209
- {
210
- "expression": "organizationId",
211
- "isExpression": false,
212
- "asc": true,
213
- "nulls": "last"
214
- }
215
- ],
216
- "isUnique": false,
217
- "concurrently": false,
218
- "method": "btree",
219
- "with": {}
220
- }
221
- },
222
- "foreignKeys": {
223
- "api_keys_organizationId_organizations_id_fk": {
224
- "name": "api_keys_organizationId_organizations_id_fk",
225
- "tableFrom": "api_keys",
226
- "tableTo": "organizations",
227
- "columnsFrom": [
228
- "organizationId"
229
- ],
230
- "columnsTo": [
231
- "id"
232
- ],
233
- "onDelete": "cascade",
234
- "onUpdate": "no action"
235
- }
236
- },
237
- "compositePrimaryKeys": {},
238
- "uniqueConstraints": {
239
- "api_keys_hashedKey_unique": {
240
- "name": "api_keys_hashedKey_unique",
241
- "nullsNotDistinct": false,
242
- "columns": [
243
- "hashedKey"
244
- ]
245
- }
246
- },
247
- "policies": {},
248
- "checkConstraints": {},
249
- "isRLSEnabled": false
250
- },
251
- "public.attachments": {
252
- "name": "attachments",
253
- "schema": "",
254
- "columns": {
255
- "attachmentId": {
256
- "name": "attachmentId",
257
- "type": "serial",
258
- "primaryKey": true,
259
- "notNull": true
260
- },
261
- "feedbackId": {
262
- "name": "feedbackId",
263
- "type": "integer",
264
- "primaryKey": false,
265
- "notNull": true
266
- },
267
- "fileName": {
268
- "name": "fileName",
269
- "type": "text",
270
- "primaryKey": false,
271
- "notNull": true
272
- },
273
- "filePath": {
274
- "name": "filePath",
275
- "type": "text",
276
- "primaryKey": false,
277
- "notNull": true
278
- },
279
- "fileSize": {
280
- "name": "fileSize",
281
- "type": "integer",
282
- "primaryKey": false,
283
- "notNull": true
284
- },
285
- "mimeType": {
286
- "name": "mimeType",
287
- "type": "text",
288
- "primaryKey": false,
289
- "notNull": true
290
- },
291
- "createdAt": {
292
- "name": "createdAt",
293
- "type": "timestamp",
294
- "primaryKey": false,
295
- "notNull": true,
296
- "default": "now()"
297
- }
298
- },
299
- "indexes": {
300
- "idx_attachments_feedbackId": {
301
- "name": "idx_attachments_feedbackId",
302
- "columns": [
303
- {
304
- "expression": "feedbackId",
305
- "isExpression": false,
306
- "asc": true,
307
- "nulls": "last"
308
- }
309
- ],
310
- "isUnique": false,
311
- "concurrently": false,
312
- "method": "btree",
313
- "with": {}
314
- }
315
- },
316
- "foreignKeys": {
317
- "attachments_feedbackId_feedback_feedbackId_fk": {
318
- "name": "attachments_feedbackId_feedback_feedbackId_fk",
319
- "tableFrom": "attachments",
320
- "tableTo": "feedback",
321
- "columnsFrom": [
322
- "feedbackId"
323
- ],
324
- "columnsTo": [
325
- "feedbackId"
326
- ],
327
- "onDelete": "cascade",
328
- "onUpdate": "no action"
329
- }
330
- },
331
- "compositePrimaryKeys": {},
332
- "uniqueConstraints": {},
333
- "policies": {},
334
- "checkConstraints": {},
335
- "isRLSEnabled": false
336
- },
337
- "public.account": {
338
- "name": "account",
339
- "schema": "",
340
- "columns": {
341
- "id": {
342
- "name": "id",
343
- "type": "text",
344
- "primaryKey": true,
345
- "notNull": true
346
- },
347
- "account_id": {
348
- "name": "account_id",
349
- "type": "text",
350
- "primaryKey": false,
351
- "notNull": true
352
- },
353
- "provider_id": {
354
- "name": "provider_id",
355
- "type": "text",
356
- "primaryKey": false,
357
- "notNull": true
358
- },
359
- "user_id": {
360
- "name": "user_id",
361
- "type": "text",
362
- "primaryKey": false,
363
- "notNull": true
364
- },
365
- "access_token": {
366
- "name": "access_token",
367
- "type": "text",
368
- "primaryKey": false,
369
- "notNull": false
370
- },
371
- "refresh_token": {
372
- "name": "refresh_token",
373
- "type": "text",
374
- "primaryKey": false,
375
- "notNull": false
376
- },
377
- "id_token": {
378
- "name": "id_token",
379
- "type": "text",
380
- "primaryKey": false,
381
- "notNull": false
382
- },
383
- "access_token_expires_at": {
384
- "name": "access_token_expires_at",
385
- "type": "timestamp",
386
- "primaryKey": false,
387
- "notNull": false
388
- },
389
- "refresh_token_expires_at": {
390
- "name": "refresh_token_expires_at",
391
- "type": "timestamp",
392
- "primaryKey": false,
393
- "notNull": false
394
- },
395
- "scope": {
396
- "name": "scope",
397
- "type": "text",
398
- "primaryKey": false,
399
- "notNull": false
400
- },
401
- "password": {
402
- "name": "password",
403
- "type": "text",
404
- "primaryKey": false,
405
- "notNull": false
406
- },
407
- "created_at": {
408
- "name": "created_at",
409
- "type": "timestamp",
410
- "primaryKey": false,
411
- "notNull": true,
412
- "default": "now()"
413
- },
414
- "updated_at": {
415
- "name": "updated_at",
416
- "type": "timestamp",
417
- "primaryKey": false,
418
- "notNull": true
419
- }
420
- },
421
- "indexes": {
422
- "account_userId_idx": {
423
- "name": "account_userId_idx",
424
- "columns": [
425
- {
426
- "expression": "user_id",
427
- "isExpression": false,
428
- "asc": true,
429
- "nulls": "last"
430
- }
431
- ],
432
- "isUnique": false,
433
- "concurrently": false,
434
- "method": "btree",
435
- "with": {}
436
- }
437
- },
438
- "foreignKeys": {
439
- "account_user_id_user_id_fk": {
440
- "name": "account_user_id_user_id_fk",
441
- "tableFrom": "account",
442
- "tableTo": "user",
443
- "columnsFrom": [
444
- "user_id"
445
- ],
446
- "columnsTo": [
447
- "id"
448
- ],
449
- "onDelete": "cascade",
450
- "onUpdate": "no action"
451
- }
452
- },
453
- "compositePrimaryKeys": {},
454
- "uniqueConstraints": {},
455
- "policies": {},
456
- "checkConstraints": {},
457
- "isRLSEnabled": false
458
- },
459
- "public.session": {
460
- "name": "session",
461
- "schema": "",
462
- "columns": {
463
- "id": {
464
- "name": "id",
465
- "type": "text",
466
- "primaryKey": true,
467
- "notNull": true
468
- },
469
- "expires_at": {
470
- "name": "expires_at",
471
- "type": "timestamp",
472
- "primaryKey": false,
473
- "notNull": true
474
- },
475
- "token": {
476
- "name": "token",
477
- "type": "text",
478
- "primaryKey": false,
479
- "notNull": true
480
- },
481
- "created_at": {
482
- "name": "created_at",
483
- "type": "timestamp",
484
- "primaryKey": false,
485
- "notNull": true,
486
- "default": "now()"
487
- },
488
- "updated_at": {
489
- "name": "updated_at",
490
- "type": "timestamp",
491
- "primaryKey": false,
492
- "notNull": true
493
- },
494
- "ip_address": {
495
- "name": "ip_address",
496
- "type": "text",
497
- "primaryKey": false,
498
- "notNull": false
499
- },
500
- "user_agent": {
501
- "name": "user_agent",
502
- "type": "text",
503
- "primaryKey": false,
504
- "notNull": false
505
- },
506
- "user_id": {
507
- "name": "user_id",
508
- "type": "text",
509
- "primaryKey": false,
510
- "notNull": true
511
- }
512
- },
513
- "indexes": {
514
- "session_userId_idx": {
515
- "name": "session_userId_idx",
516
- "columns": [
517
- {
518
- "expression": "user_id",
519
- "isExpression": false,
520
- "asc": true,
521
- "nulls": "last"
522
- }
523
- ],
524
- "isUnique": false,
525
- "concurrently": false,
526
- "method": "btree",
527
- "with": {}
528
- }
529
- },
530
- "foreignKeys": {
531
- "session_user_id_user_id_fk": {
532
- "name": "session_user_id_user_id_fk",
533
- "tableFrom": "session",
534
- "tableTo": "user",
535
- "columnsFrom": [
536
- "user_id"
537
- ],
538
- "columnsTo": [
539
- "id"
540
- ],
541
- "onDelete": "cascade",
542
- "onUpdate": "no action"
543
- }
544
- },
545
- "compositePrimaryKeys": {},
546
- "uniqueConstraints": {
547
- "session_token_unique": {
548
- "name": "session_token_unique",
549
- "nullsNotDistinct": false,
550
- "columns": [
551
- "token"
552
- ]
553
- }
554
- },
555
- "policies": {},
556
- "checkConstraints": {},
557
- "isRLSEnabled": false
558
- },
559
- "public.user": {
560
- "name": "user",
561
- "schema": "",
562
- "columns": {
563
- "id": {
564
- "name": "id",
565
- "type": "text",
566
- "primaryKey": true,
567
- "notNull": true
568
- },
569
- "name": {
570
- "name": "name",
571
- "type": "text",
572
- "primaryKey": false,
573
- "notNull": true
574
- },
575
- "email": {
576
- "name": "email",
577
- "type": "text",
578
- "primaryKey": false,
579
- "notNull": true
580
- },
581
- "role": {
582
- "name": "role",
583
- "type": "text",
584
- "primaryKey": false,
585
- "notNull": true,
586
- "default": "'customer'"
587
- },
588
- "email_verified": {
589
- "name": "email_verified",
590
- "type": "boolean",
591
- "primaryKey": false,
592
- "notNull": true,
593
- "default": false
594
- },
595
- "image": {
596
- "name": "image",
597
- "type": "text",
598
- "primaryKey": false,
599
- "notNull": false
600
- },
601
- "created_at": {
602
- "name": "created_at",
603
- "type": "timestamp",
604
- "primaryKey": false,
605
- "notNull": true,
606
- "default": "now()"
607
- },
608
- "updated_at": {
609
- "name": "updated_at",
610
- "type": "timestamp",
611
- "primaryKey": false,
612
- "notNull": true,
613
- "default": "now()"
614
- }
615
- },
616
- "indexes": {},
617
- "foreignKeys": {},
618
- "compositePrimaryKeys": {},
619
- "uniqueConstraints": {
620
- "user_email_unique": {
621
- "name": "user_email_unique",
622
- "nullsNotDistinct": false,
623
- "columns": [
624
- "email"
625
- ]
626
- }
627
- },
628
- "policies": {},
629
- "checkConstraints": {},
630
- "isRLSEnabled": false
631
- },
632
- "public.verification": {
633
- "name": "verification",
634
- "schema": "",
635
- "columns": {
636
- "id": {
637
- "name": "id",
638
- "type": "text",
639
- "primaryKey": true,
640
- "notNull": true
641
- },
642
- "identifier": {
643
- "name": "identifier",
644
- "type": "text",
645
- "primaryKey": false,
646
- "notNull": true
647
- },
648
- "value": {
649
- "name": "value",
650
- "type": "text",
651
- "primaryKey": false,
652
- "notNull": true
653
- },
654
- "expires_at": {
655
- "name": "expires_at",
656
- "type": "timestamp",
657
- "primaryKey": false,
658
- "notNull": true
659
- },
660
- "created_at": {
661
- "name": "created_at",
662
- "type": "timestamp",
663
- "primaryKey": false,
664
- "notNull": true,
665
- "default": "now()"
666
- },
667
- "updated_at": {
668
- "name": "updated_at",
669
- "type": "timestamp",
670
- "primaryKey": false,
671
- "notNull": true,
672
- "default": "now()"
673
- }
674
- },
675
- "indexes": {
676
- "verification_identifier_idx": {
677
- "name": "verification_identifier_idx",
678
- "columns": [
679
- {
680
- "expression": "identifier",
681
- "isExpression": false,
682
- "asc": true,
683
- "nulls": "last"
684
- }
685
- ],
686
- "isUnique": false,
687
- "concurrently": false,
688
- "method": "btree",
689
- "with": {}
690
- }
691
- },
692
- "foreignKeys": {},
693
- "compositePrimaryKeys": {},
694
- "uniqueConstraints": {},
695
- "policies": {},
696
- "checkConstraints": {},
697
- "isRLSEnabled": false
698
- },
699
- "public.comments": {
700
- "name": "comments",
701
- "schema": "",
702
- "columns": {
703
- "commentId": {
704
- "name": "commentId",
705
- "type": "serial",
706
- "primaryKey": true,
707
- "notNull": true
708
- },
709
- "feedbackId": {
710
- "name": "feedbackId",
711
- "type": "serial",
712
- "primaryKey": false,
713
- "notNull": true
714
- },
715
- "userId": {
716
- "name": "userId",
717
- "type": "text",
718
- "primaryKey": false,
719
- "notNull": false
720
- },
721
- "authorName": {
722
- "name": "authorName",
723
- "type": "text",
724
- "primaryKey": false,
725
- "notNull": false
726
- },
727
- "authorEmail": {
728
- "name": "authorEmail",
729
- "type": "text",
730
- "primaryKey": false,
731
- "notNull": false
732
- },
733
- "guestToken": {
734
- "name": "guestToken",
735
- "type": "text",
736
- "primaryKey": false,
737
- "notNull": false
738
- },
739
- "content": {
740
- "name": "content",
741
- "type": "text",
742
- "primaryKey": false,
743
- "notNull": true
744
- },
745
- "isInternal": {
746
- "name": "isInternal",
747
- "type": "boolean",
748
- "primaryKey": false,
749
- "notNull": true,
750
- "default": true
751
- },
752
- "createdAt": {
753
- "name": "createdAt",
754
- "type": "timestamp",
755
- "primaryKey": false,
756
- "notNull": true,
757
- "default": "now()"
758
- },
759
- "updatedAt": {
760
- "name": "updatedAt",
761
- "type": "timestamp",
762
- "primaryKey": false,
763
- "notNull": true,
764
- "default": "now()"
765
- }
766
- },
767
- "indexes": {
768
- "idx_comments_feedbackId": {
769
- "name": "idx_comments_feedbackId",
770
- "columns": [
771
- {
772
- "expression": "feedbackId",
773
- "isExpression": false,
774
- "asc": true,
775
- "nulls": "last"
776
- }
777
- ],
778
- "isUnique": false,
779
- "concurrently": false,
780
- "method": "btree",
781
- "with": {}
782
- },
783
- "idx_comments_isInternal": {
784
- "name": "idx_comments_isInternal",
785
- "columns": [
786
- {
787
- "expression": "isInternal",
788
- "isExpression": false,
789
- "asc": true,
790
- "nulls": "last"
791
- }
792
- ],
793
- "isUnique": false,
794
- "concurrently": false,
795
- "method": "btree",
796
- "with": {}
797
- },
798
- "idx_comments_internal_feedbacks": {
799
- "name": "idx_comments_internal_feedbacks",
800
- "columns": [
801
- {
802
- "expression": "feedbackId",
803
- "isExpression": false,
804
- "asc": true,
805
- "nulls": "last"
806
- },
807
- {
808
- "expression": "isInternal",
809
- "isExpression": false,
810
- "asc": true,
811
- "nulls": "last"
812
- }
813
- ],
814
- "isUnique": false,
815
- "concurrently": false,
816
- "method": "btree",
817
- "with": {}
818
- },
819
- "idx_comments_guestToken": {
820
- "name": "idx_comments_guestToken",
821
- "columns": [
822
- {
823
- "expression": "guestToken",
824
- "isExpression": false,
825
- "asc": true,
826
- "nulls": "last"
827
- }
828
- ],
829
- "isUnique": false,
830
- "concurrently": false,
831
- "method": "btree",
832
- "with": {}
833
- }
834
- },
835
- "foreignKeys": {
836
- "comments_feedbackId_feedback_feedbackId_fk": {
837
- "name": "comments_feedbackId_feedback_feedbackId_fk",
838
- "tableFrom": "comments",
839
- "tableTo": "feedback",
840
- "columnsFrom": [
841
- "feedbackId"
842
- ],
843
- "columnsTo": [
844
- "feedbackId"
845
- ],
846
- "onDelete": "cascade",
847
- "onUpdate": "no action"
848
- },
849
- "comments_userId_user_id_fk": {
850
- "name": "comments_userId_user_id_fk",
851
- "tableFrom": "comments",
852
- "tableTo": "user",
853
- "columnsFrom": [
854
- "userId"
855
- ],
856
- "columnsTo": [
857
- "id"
858
- ],
859
- "onDelete": "set null",
860
- "onUpdate": "no action"
861
- }
862
- },
863
- "compositePrimaryKeys": {},
864
- "uniqueConstraints": {},
865
- "policies": {},
866
- "checkConstraints": {},
867
- "isRLSEnabled": false
868
- },
869
- "public.duplicate_feedback": {
870
- "name": "duplicate_feedback",
871
- "schema": "",
872
- "columns": {
873
- "id": {
874
- "name": "id",
875
- "type": "serial",
876
- "primaryKey": true,
877
- "notNull": true
878
- },
879
- "originalFeedbackId": {
880
- "name": "originalFeedbackId",
881
- "type": "integer",
882
- "primaryKey": false,
883
- "notNull": true
884
- },
885
- "duplicateFeedbackId": {
886
- "name": "duplicateFeedbackId",
887
- "type": "integer",
888
- "primaryKey": false,
889
- "notNull": true
890
- },
891
- "similarity": {
892
- "name": "similarity",
893
- "type": "integer",
894
- "primaryKey": false,
895
- "notNull": true
896
- },
897
- "status": {
898
- "name": "status",
899
- "type": "text",
900
- "primaryKey": false,
901
- "notNull": true,
902
- "default": "'pending'"
903
- },
904
- "createdAt": {
905
- "name": "createdAt",
906
- "type": "timestamp",
907
- "primaryKey": false,
908
- "notNull": true,
909
- "default": "now()"
910
- },
911
- "confirmedBy": {
912
- "name": "confirmedBy",
913
- "type": "text",
914
- "primaryKey": false,
915
- "notNull": false
916
- },
917
- "confirmedAt": {
918
- "name": "confirmedAt",
919
- "type": "timestamp",
920
- "primaryKey": false,
921
- "notNull": false
922
- }
923
- },
924
- "indexes": {
925
- "idx_duplicate_original": {
926
- "name": "idx_duplicate_original",
927
- "columns": [
928
- {
929
- "expression": "originalFeedbackId",
930
- "isExpression": false,
931
- "asc": true,
932
- "nulls": "last"
933
- }
934
- ],
935
- "isUnique": false,
936
- "concurrently": false,
937
- "method": "btree",
938
- "with": {}
939
- },
940
- "idx_duplicate_duplicate": {
941
- "name": "idx_duplicate_duplicate",
942
- "columns": [
943
- {
944
- "expression": "duplicateFeedbackId",
945
- "isExpression": false,
946
- "asc": true,
947
- "nulls": "last"
948
- }
949
- ],
950
- "isUnique": false,
951
- "concurrently": false,
952
- "method": "btree",
953
- "with": {}
954
- }
955
- },
956
- "foreignKeys": {
957
- "duplicate_feedback_originalFeedbackId_feedback_feedbackId_fk": {
958
- "name": "duplicate_feedback_originalFeedbackId_feedback_feedbackId_fk",
959
- "tableFrom": "duplicate_feedback",
960
- "tableTo": "feedback",
961
- "columnsFrom": [
962
- "originalFeedbackId"
963
- ],
964
- "columnsTo": [
965
- "feedbackId"
966
- ],
967
- "onDelete": "cascade",
968
- "onUpdate": "no action"
969
- },
970
- "duplicate_feedback_duplicateFeedbackId_feedback_feedbackId_fk": {
971
- "name": "duplicate_feedback_duplicateFeedbackId_feedback_feedbackId_fk",
972
- "tableFrom": "duplicate_feedback",
973
- "tableTo": "feedback",
974
- "columnsFrom": [
975
- "duplicateFeedbackId"
976
- ],
977
- "columnsTo": [
978
- "feedbackId"
979
- ],
980
- "onDelete": "cascade",
981
- "onUpdate": "no action"
982
- },
983
- "duplicate_feedback_confirmedBy_user_id_fk": {
984
- "name": "duplicate_feedback_confirmedBy_user_id_fk",
985
- "tableFrom": "duplicate_feedback",
986
- "tableTo": "user",
987
- "columnsFrom": [
988
- "confirmedBy"
989
- ],
990
- "columnsTo": [
991
- "id"
992
- ],
993
- "onDelete": "set null",
994
- "onUpdate": "no action"
995
- }
996
- },
997
- "compositePrimaryKeys": {},
998
- "uniqueConstraints": {
999
- "unique_duplicate_pair": {
1000
- "name": "unique_duplicate_pair",
1001
- "nullsNotDistinct": false,
1002
- "columns": [
1003
- "originalFeedbackId",
1004
- "duplicateFeedbackId"
1005
- ]
1006
- }
1007
- },
1008
- "policies": {},
1009
- "checkConstraints": {},
1010
- "isRLSEnabled": false
1011
- },
1012
- "public.feedback": {
1013
- "name": "feedback",
1014
- "schema": "",
1015
- "columns": {
1016
- "feedbackId": {
1017
- "name": "feedbackId",
1018
- "type": "serial",
1019
- "primaryKey": true,
1020
- "notNull": true
1021
- },
1022
- "title": {
1023
- "name": "title",
1024
- "type": "text",
1025
- "primaryKey": false,
1026
- "notNull": true
1027
- },
1028
- "description": {
1029
- "name": "description",
1030
- "type": "text",
1031
- "primaryKey": false,
1032
- "notNull": true
1033
- },
1034
- "type": {
1035
- "name": "type",
1036
- "type": "text",
1037
- "primaryKey": false,
1038
- "notNull": true
1039
- },
1040
- "priority": {
1041
- "name": "priority",
1042
- "type": "text",
1043
- "primaryKey": false,
1044
- "notNull": true
1045
- },
1046
- "status": {
1047
- "name": "status",
1048
- "type": "text",
1049
- "primaryKey": false,
1050
- "notNull": true,
1051
- "default": "'new'"
1052
- },
1053
- "organizationId": {
1054
- "name": "organizationId",
1055
- "type": "text",
1056
- "primaryKey": false,
1057
- "notNull": true
1058
- },
1059
- "submittedOnBehalf": {
1060
- "name": "submittedOnBehalf",
1061
- "type": "boolean",
1062
- "primaryKey": false,
1063
- "notNull": true,
1064
- "default": false
1065
- },
1066
- "submittedBy": {
1067
- "name": "submittedBy",
1068
- "type": "text",
1069
- "primaryKey": false,
1070
- "notNull": false
1071
- },
1072
- "customerInfo": {
1073
- "name": "customerInfo",
1074
- "type": "jsonb",
1075
- "primaryKey": false,
1076
- "notNull": false
1077
- },
1078
- "createdAt": {
1079
- "name": "createdAt",
1080
- "type": "timestamp",
1081
- "primaryKey": false,
1082
- "notNull": true,
1083
- "default": "now()"
1084
- },
1085
- "updatedAt": {
1086
- "name": "updatedAt",
1087
- "type": "timestamp",
1088
- "primaryKey": false,
1089
- "notNull": true,
1090
- "default": "now()"
1091
- },
1092
- "deletedAt": {
1093
- "name": "deletedAt",
1094
- "type": "timestamp",
1095
- "primaryKey": false,
1096
- "notNull": false
1097
- },
1098
- "autoClassified": {
1099
- "name": "autoClassified",
1100
- "type": "boolean",
1101
- "primaryKey": false,
1102
- "notNull": true,
1103
- "default": false
1104
- },
1105
- "processingStatus": {
1106
- "name": "processingStatus",
1107
- "type": "text",
1108
- "primaryKey": false,
1109
- "notNull": false,
1110
- "default": "'pending'"
1111
- },
1112
- "processedAt": {
1113
- "name": "processedAt",
1114
- "type": "timestamp",
1115
- "primaryKey": false,
1116
- "notNull": false
1117
- },
1118
- "githubIssueId": {
1119
- "name": "githubIssueId",
1120
- "type": "integer",
1121
- "primaryKey": false,
1122
- "notNull": false
1123
- },
1124
- "githubIssueNumber": {
1125
- "name": "githubIssueNumber",
1126
- "type": "integer",
1127
- "primaryKey": false,
1128
- "notNull": false
1129
- },
1130
- "githubIssueUrl": {
1131
- "name": "githubIssueUrl",
1132
- "type": "text",
1133
- "primaryKey": false,
1134
- "notNull": false
1135
- },
1136
- "githubSyncedAt": {
1137
- "name": "githubSyncedAt",
1138
- "type": "timestamp",
1139
- "primaryKey": false,
1140
- "notNull": false
1141
- },
1142
- "githubStatus": {
1143
- "name": "githubStatus",
1144
- "type": "text",
1145
- "primaryKey": false,
1146
- "notNull": false
1147
- }
1148
- },
1149
- "indexes": {
1150
- "idx_feedback_orgId": {
1151
- "name": "idx_feedback_orgId",
1152
- "columns": [
1153
- {
1154
- "expression": "organizationId",
1155
- "isExpression": false,
1156
- "asc": true,
1157
- "nulls": "last"
1158
- }
1159
- ],
1160
- "isUnique": false,
1161
- "concurrently": false,
1162
- "method": "btree",
1163
- "with": {}
1164
- },
1165
- "idx_feedback_status": {
1166
- "name": "idx_feedback_status",
1167
- "columns": [
1168
- {
1169
- "expression": "status",
1170
- "isExpression": false,
1171
- "asc": true,
1172
- "nulls": "last"
1173
- }
1174
- ],
1175
- "isUnique": false,
1176
- "concurrently": false,
1177
- "method": "btree",
1178
- "with": {}
1179
- },
1180
- "idx_feedback_createdAt": {
1181
- "name": "idx_feedback_createdAt",
1182
- "columns": [
1183
- {
1184
- "expression": "createdAt",
1185
- "isExpression": false,
1186
- "asc": true,
1187
- "nulls": "last"
1188
- }
1189
- ],
1190
- "isUnique": false,
1191
- "concurrently": false,
1192
- "method": "btree",
1193
- "with": {}
1194
- },
1195
- "idx_feedback_submittedBy": {
1196
- "name": "idx_feedback_submittedBy",
1197
- "columns": [
1198
- {
1199
- "expression": "submittedBy",
1200
- "isExpression": false,
1201
- "asc": true,
1202
- "nulls": "last"
1203
- }
1204
- ],
1205
- "isUnique": false,
1206
- "concurrently": false,
1207
- "method": "btree",
1208
- "with": {}
1209
- },
1210
- "idx_feedback_deletedAt": {
1211
- "name": "idx_feedback_deletedAt",
1212
- "columns": [
1213
- {
1214
- "expression": "deletedAt",
1215
- "isExpression": false,
1216
- "asc": true,
1217
- "nulls": "last"
1218
- }
1219
- ],
1220
- "isUnique": false,
1221
- "concurrently": false,
1222
- "method": "btree",
1223
- "with": {}
1224
- },
1225
- "idx_feedback_githubIssueId": {
1226
- "name": "idx_feedback_githubIssueId",
1227
- "columns": [
1228
- {
1229
- "expression": "githubIssueId",
1230
- "isExpression": false,
1231
- "asc": true,
1232
- "nulls": "last"
1233
- }
1234
- ],
1235
- "isUnique": false,
1236
- "concurrently": false,
1237
- "method": "btree",
1238
- "with": {}
1239
- }
1240
- },
1241
- "foreignKeys": {
1242
- "feedback_submittedBy_user_id_fk": {
1243
- "name": "feedback_submittedBy_user_id_fk",
1244
- "tableFrom": "feedback",
1245
- "tableTo": "user",
1246
- "columnsFrom": [
1247
- "submittedBy"
1248
- ],
1249
- "columnsTo": [
1250
- "id"
1251
- ],
1252
- "onDelete": "set null",
1253
- "onUpdate": "no action"
1254
- }
1255
- },
1256
- "compositePrimaryKeys": {},
1257
- "uniqueConstraints": {},
1258
- "policies": {},
1259
- "checkConstraints": {},
1260
- "isRLSEnabled": false
1261
- },
1262
- "public.github_integrations": {
1263
- "name": "github_integrations",
1264
- "schema": "",
1265
- "columns": {
1266
- "id": {
1267
- "name": "id",
1268
- "type": "serial",
1269
- "primaryKey": true,
1270
- "notNull": true
1271
- },
1272
- "organizationId": {
1273
- "name": "organizationId",
1274
- "type": "text",
1275
- "primaryKey": false,
1276
- "notNull": true
1277
- },
1278
- "accessToken": {
1279
- "name": "accessToken",
1280
- "type": "text",
1281
- "primaryKey": false,
1282
- "notNull": true
1283
- },
1284
- "owner": {
1285
- "name": "owner",
1286
- "type": "text",
1287
- "primaryKey": false,
1288
- "notNull": true
1289
- },
1290
- "repo": {
1291
- "name": "repo",
1292
- "type": "text",
1293
- "primaryKey": false,
1294
- "notNull": true
1295
- },
1296
- "labelMapping": {
1297
- "name": "labelMapping",
1298
- "type": "jsonb",
1299
- "primaryKey": false,
1300
- "notNull": false
1301
- },
1302
- "statusMapping": {
1303
- "name": "statusMapping",
1304
- "type": "jsonb",
1305
- "primaryKey": false,
1306
- "notNull": false
1307
- },
1308
- "autoSync": {
1309
- "name": "autoSync",
1310
- "type": "boolean",
1311
- "primaryKey": false,
1312
- "notNull": true,
1313
- "default": true
1314
- },
1315
- "webhookSecret": {
1316
- "name": "webhookSecret",
1317
- "type": "text",
1318
- "primaryKey": false,
1319
- "notNull": false
1320
- },
1321
- "createdAt": {
1322
- "name": "createdAt",
1323
- "type": "timestamp",
1324
- "primaryKey": false,
1325
- "notNull": true,
1326
- "default": "now()"
1327
- },
1328
- "updatedAt": {
1329
- "name": "updatedAt",
1330
- "type": "timestamp",
1331
- "primaryKey": false,
1332
- "notNull": true,
1333
- "default": "now()"
1334
- }
1335
- },
1336
- "indexes": {
1337
- "idx_github_integrations_orgId": {
1338
- "name": "idx_github_integrations_orgId",
1339
- "columns": [
1340
- {
1341
- "expression": "organizationId",
1342
- "isExpression": false,
1343
- "asc": true,
1344
- "nulls": "last"
1345
- }
1346
- ],
1347
- "isUnique": false,
1348
- "concurrently": false,
1349
- "method": "btree",
1350
- "with": {}
1351
- }
1352
- },
1353
- "foreignKeys": {
1354
- "github_integrations_organizationId_organizations_id_fk": {
1355
- "name": "github_integrations_organizationId_organizations_id_fk",
1356
- "tableFrom": "github_integrations",
1357
- "tableTo": "organizations",
1358
- "columnsFrom": [
1359
- "organizationId"
1360
- ],
1361
- "columnsTo": [
1362
- "id"
1363
- ],
1364
- "onDelete": "cascade",
1365
- "onUpdate": "no action"
1366
- }
1367
- },
1368
- "compositePrimaryKeys": {},
1369
- "uniqueConstraints": {},
1370
- "policies": {},
1371
- "checkConstraints": {},
1372
- "isRLSEnabled": false
1373
- },
1374
- "public.user_profiles": {
1375
- "name": "user_profiles",
1376
- "schema": "",
1377
- "columns": {
1378
- "user_id": {
1379
- "name": "user_id",
1380
- "type": "text",
1381
- "primaryKey": true,
1382
- "notNull": true
1383
- },
1384
- "name": {
1385
- "name": "name",
1386
- "type": "text",
1387
- "primaryKey": false,
1388
- "notNull": true
1389
- },
1390
- "created_at": {
1391
- "name": "created_at",
1392
- "type": "timestamp",
1393
- "primaryKey": false,
1394
- "notNull": true,
1395
- "default": "now()"
1396
- },
1397
- "updated_at": {
1398
- "name": "updated_at",
1399
- "type": "timestamp",
1400
- "primaryKey": false,
1401
- "notNull": true,
1402
- "default": "now()"
1403
- }
1404
- },
1405
- "indexes": {},
1406
- "foreignKeys": {
1407
- "user_profiles_user_id_user_id_fk": {
1408
- "name": "user_profiles_user_id_user_id_fk",
1409
- "tableFrom": "user_profiles",
1410
- "tableTo": "user",
1411
- "columnsFrom": [
1412
- "user_id"
1413
- ],
1414
- "columnsTo": [
1415
- "id"
1416
- ],
1417
- "onDelete": "cascade",
1418
- "onUpdate": "no action"
1419
- }
1420
- },
1421
- "compositePrimaryKeys": {},
1422
- "uniqueConstraints": {},
1423
- "policies": {},
1424
- "checkConstraints": {},
1425
- "isRLSEnabled": false
1426
- },
1427
- "public.organizations": {
1428
- "name": "organizations",
1429
- "schema": "",
1430
- "columns": {
1431
- "id": {
1432
- "name": "id",
1433
- "type": "text",
1434
- "primaryKey": true,
1435
- "notNull": true
1436
- },
1437
- "name": {
1438
- "name": "name",
1439
- "type": "text",
1440
- "primaryKey": false,
1441
- "notNull": true
1442
- },
1443
- "slug": {
1444
- "name": "slug",
1445
- "type": "text",
1446
- "primaryKey": false,
1447
- "notNull": true
1448
- },
1449
- "description": {
1450
- "name": "description",
1451
- "type": "text",
1452
- "primaryKey": false,
1453
- "notNull": false
1454
- },
1455
- "created_at": {
1456
- "name": "created_at",
1457
- "type": "timestamp",
1458
- "primaryKey": false,
1459
- "notNull": true,
1460
- "default": "now()"
1461
- },
1462
- "updated_at": {
1463
- "name": "updated_at",
1464
- "type": "timestamp",
1465
- "primaryKey": false,
1466
- "notNull": true,
1467
- "default": "now()"
1468
- }
1469
- },
1470
- "indexes": {},
1471
- "foreignKeys": {},
1472
- "compositePrimaryKeys": {},
1473
- "uniqueConstraints": {
1474
- "organizations_slug_unique": {
1475
- "name": "organizations_slug_unique",
1476
- "nullsNotDistinct": false,
1477
- "columns": [
1478
- "slug"
1479
- ]
1480
- }
1481
- },
1482
- "policies": {},
1483
- "checkConstraints": {},
1484
- "isRLSEnabled": false
1485
- },
1486
- "public.organization_members": {
1487
- "name": "organization_members",
1488
- "schema": "",
1489
- "columns": {
1490
- "organization_id": {
1491
- "name": "organization_id",
1492
- "type": "text",
1493
- "primaryKey": false,
1494
- "notNull": true
1495
- },
1496
- "user_id": {
1497
- "name": "user_id",
1498
- "type": "text",
1499
- "primaryKey": false,
1500
- "notNull": true
1501
- },
1502
- "role": {
1503
- "name": "role",
1504
- "type": "text",
1505
- "primaryKey": false,
1506
- "notNull": true
1507
- },
1508
- "created_at": {
1509
- "name": "created_at",
1510
- "type": "timestamp",
1511
- "primaryKey": false,
1512
- "notNull": true,
1513
- "default": "now()"
1514
- }
1515
- },
1516
- "indexes": {},
1517
- "foreignKeys": {
1518
- "organization_members_organization_id_organizations_id_fk": {
1519
- "name": "organization_members_organization_id_organizations_id_fk",
1520
- "tableFrom": "organization_members",
1521
- "tableTo": "organizations",
1522
- "columnsFrom": [
1523
- "organization_id"
1524
- ],
1525
- "columnsTo": [
1526
- "id"
1527
- ],
1528
- "onDelete": "cascade",
1529
- "onUpdate": "no action"
1530
- },
1531
- "organization_members_user_id_user_id_fk": {
1532
- "name": "organization_members_user_id_user_id_fk",
1533
- "tableFrom": "organization_members",
1534
- "tableTo": "user",
1535
- "columnsFrom": [
1536
- "user_id"
1537
- ],
1538
- "columnsTo": [
1539
- "id"
1540
- ],
1541
- "onDelete": "cascade",
1542
- "onUpdate": "no action"
1543
- }
1544
- },
1545
- "compositePrimaryKeys": {
1546
- "organization_members_organization_id_user_id_pk": {
1547
- "name": "organization_members_organization_id_user_id_pk",
1548
- "columns": [
1549
- "organization_id",
1550
- "user_id"
1551
- ]
1552
- }
1553
- },
1554
- "uniqueConstraints": {},
1555
- "policies": {},
1556
- "checkConstraints": {},
1557
- "isRLSEnabled": false
1558
- },
1559
- "public.invitations": {
1560
- "name": "invitations",
1561
- "schema": "",
1562
- "columns": {
1563
- "id": {
1564
- "name": "id",
1565
- "type": "text",
1566
- "primaryKey": true,
1567
- "notNull": true
1568
- },
1569
- "organization_id": {
1570
- "name": "organization_id",
1571
- "type": "text",
1572
- "primaryKey": false,
1573
- "notNull": true
1574
- },
1575
- "email": {
1576
- "name": "email",
1577
- "type": "text",
1578
- "primaryKey": false,
1579
- "notNull": true
1580
- },
1581
- "role": {
1582
- "name": "role",
1583
- "type": "text",
1584
- "primaryKey": false,
1585
- "notNull": true
1586
- },
1587
- "token": {
1588
- "name": "token",
1589
- "type": "text",
1590
- "primaryKey": false,
1591
- "notNull": true
1592
- },
1593
- "expires_at": {
1594
- "name": "expires_at",
1595
- "type": "timestamp",
1596
- "primaryKey": false,
1597
- "notNull": true
1598
- },
1599
- "accepted_at": {
1600
- "name": "accepted_at",
1601
- "type": "timestamp",
1602
- "primaryKey": false,
1603
- "notNull": false
1604
- },
1605
- "created_at": {
1606
- "name": "created_at",
1607
- "type": "timestamp",
1608
- "primaryKey": false,
1609
- "notNull": true,
1610
- "default": "now()"
1611
- }
1612
- },
1613
- "indexes": {},
1614
- "foreignKeys": {
1615
- "invitations_organization_id_organizations_id_fk": {
1616
- "name": "invitations_organization_id_organizations_id_fk",
1617
- "tableFrom": "invitations",
1618
- "tableTo": "organizations",
1619
- "columnsFrom": [
1620
- "organization_id"
1621
- ],
1622
- "columnsTo": [
1623
- "id"
1624
- ],
1625
- "onDelete": "cascade",
1626
- "onUpdate": "no action"
1627
- }
1628
- },
1629
- "compositePrimaryKeys": {},
1630
- "uniqueConstraints": {
1631
- "invitations_token_unique": {
1632
- "name": "invitations_token_unique",
1633
- "nullsNotDistinct": false,
1634
- "columns": [
1635
- "token"
1636
- ]
1637
- }
1638
- },
1639
- "policies": {},
1640
- "checkConstraints": {},
1641
- "isRLSEnabled": false
1642
- },
1643
- "public.votes": {
1644
- "name": "votes",
1645
- "schema": "",
1646
- "columns": {
1647
- "voteId": {
1648
- "name": "voteId",
1649
- "type": "serial",
1650
- "primaryKey": true,
1651
- "notNull": true
1652
- },
1653
- "feedbackId": {
1654
- "name": "feedbackId",
1655
- "type": "serial",
1656
- "primaryKey": false,
1657
- "notNull": true
1658
- },
1659
- "visitorId": {
1660
- "name": "visitorId",
1661
- "type": "text",
1662
- "primaryKey": false,
1663
- "notNull": false
1664
- },
1665
- "userId": {
1666
- "name": "userId",
1667
- "type": "text",
1668
- "primaryKey": false,
1669
- "notNull": false
1670
- },
1671
- "createdAt": {
1672
- "name": "createdAt",
1673
- "type": "timestamp",
1674
- "primaryKey": false,
1675
- "notNull": true,
1676
- "default": "now()"
1677
- }
1678
- },
1679
- "indexes": {
1680
- "idx_votes_feedbackId": {
1681
- "name": "idx_votes_feedbackId",
1682
- "columns": [
1683
- {
1684
- "expression": "feedbackId",
1685
- "isExpression": false,
1686
- "asc": true,
1687
- "nulls": "last"
1688
- }
1689
- ],
1690
- "isUnique": false,
1691
- "concurrently": false,
1692
- "method": "btree",
1693
- "with": {}
1694
- },
1695
- "idx_votes_userId": {
1696
- "name": "idx_votes_userId",
1697
- "columns": [
1698
- {
1699
- "expression": "userId",
1700
- "isExpression": false,
1701
- "asc": true,
1702
- "nulls": "last"
1703
- }
1704
- ],
1705
- "isUnique": false,
1706
- "concurrently": false,
1707
- "method": "btree",
1708
- "with": {}
1709
- }
1710
- },
1711
- "foreignKeys": {
1712
- "votes_feedbackId_feedback_feedbackId_fk": {
1713
- "name": "votes_feedbackId_feedback_feedbackId_fk",
1714
- "tableFrom": "votes",
1715
- "tableTo": "feedback",
1716
- "columnsFrom": [
1717
- "feedbackId"
1718
- ],
1719
- "columnsTo": [
1720
- "feedbackId"
1721
- ],
1722
- "onDelete": "cascade",
1723
- "onUpdate": "no action"
1724
- },
1725
- "votes_userId_user_id_fk": {
1726
- "name": "votes_userId_user_id_fk",
1727
- "tableFrom": "votes",
1728
- "tableTo": "user",
1729
- "columnsFrom": [
1730
- "userId"
1731
- ],
1732
- "columnsTo": [
1733
- "id"
1734
- ],
1735
- "onDelete": "set null",
1736
- "onUpdate": "no action"
1737
- }
1738
- },
1739
- "compositePrimaryKeys": {},
1740
- "uniqueConstraints": {
1741
- "unique_vote": {
1742
- "name": "unique_vote",
1743
- "nullsNotDistinct": false,
1744
- "columns": [
1745
- "feedbackId",
1746
- "visitorId"
1747
- ]
1748
- }
1749
- },
1750
- "policies": {},
1751
- "checkConstraints": {},
1752
- "isRLSEnabled": false
1753
- },
1754
- "public.status_history": {
1755
- "name": "status_history",
1756
- "schema": "",
1757
- "columns": {
1758
- "historyId": {
1759
- "name": "historyId",
1760
- "type": "serial",
1761
- "primaryKey": true,
1762
- "notNull": true
1763
- },
1764
- "feedbackId": {
1765
- "name": "feedbackId",
1766
- "type": "integer",
1767
- "primaryKey": false,
1768
- "notNull": true
1769
- },
1770
- "oldStatus": {
1771
- "name": "oldStatus",
1772
- "type": "text",
1773
- "primaryKey": false,
1774
- "notNull": true
1775
- },
1776
- "newStatus": {
1777
- "name": "newStatus",
1778
- "type": "text",
1779
- "primaryKey": false,
1780
- "notNull": true
1781
- },
1782
- "changedBy": {
1783
- "name": "changedBy",
1784
- "type": "text",
1785
- "primaryKey": false,
1786
- "notNull": false
1787
- },
1788
- "changedAt": {
1789
- "name": "changedAt",
1790
- "type": "timestamp",
1791
- "primaryKey": false,
1792
- "notNull": true,
1793
- "default": "now()"
1794
- },
1795
- "comment": {
1796
- "name": "comment",
1797
- "type": "text",
1798
- "primaryKey": false,
1799
- "notNull": false
1800
- }
1801
- },
1802
- "indexes": {
1803
- "idx_status_history_feedbackId": {
1804
- "name": "idx_status_history_feedbackId",
1805
- "columns": [
1806
- {
1807
- "expression": "feedbackId",
1808
- "isExpression": false,
1809
- "asc": true,
1810
- "nulls": "last"
1811
- }
1812
- ],
1813
- "isUnique": false,
1814
- "concurrently": false,
1815
- "method": "btree",
1816
- "with": {}
1817
- },
1818
- "idx_status_history_changedAt": {
1819
- "name": "idx_status_history_changedAt",
1820
- "columns": [
1821
- {
1822
- "expression": "changedAt",
1823
- "isExpression": false,
1824
- "asc": true,
1825
- "nulls": "last"
1826
- }
1827
- ],
1828
- "isUnique": false,
1829
- "concurrently": false,
1830
- "method": "btree",
1831
- "with": {}
1832
- }
1833
- },
1834
- "foreignKeys": {
1835
- "status_history_feedbackId_feedback_feedbackId_fk": {
1836
- "name": "status_history_feedbackId_feedback_feedbackId_fk",
1837
- "tableFrom": "status_history",
1838
- "tableTo": "feedback",
1839
- "columnsFrom": [
1840
- "feedbackId"
1841
- ],
1842
- "columnsTo": [
1843
- "feedbackId"
1844
- ],
1845
- "onDelete": "cascade",
1846
- "onUpdate": "no action"
1847
- },
1848
- "status_history_changedBy_user_id_fk": {
1849
- "name": "status_history_changedBy_user_id_fk",
1850
- "tableFrom": "status_history",
1851
- "tableTo": "user",
1852
- "columnsFrom": [
1853
- "changedBy"
1854
- ],
1855
- "columnsTo": [
1856
- "id"
1857
- ],
1858
- "onDelete": "set null",
1859
- "onUpdate": "no action"
1860
- }
1861
- },
1862
- "compositePrimaryKeys": {},
1863
- "uniqueConstraints": {},
1864
- "policies": {},
1865
- "checkConstraints": {},
1866
- "isRLSEnabled": false
1867
- },
1868
- "public.projects": {
1869
- "name": "projects",
1870
- "schema": "",
1871
- "columns": {
1872
- "projectId": {
1873
- "name": "projectId",
1874
- "type": "uuid",
1875
- "primaryKey": true,
1876
- "notNull": true,
1877
- "default": "gen_random_uuid()"
1878
- },
1879
- "organizationId": {
1880
- "name": "organizationId",
1881
- "type": "text",
1882
- "primaryKey": false,
1883
- "notNull": true
1884
- },
1885
- "name": {
1886
- "name": "name",
1887
- "type": "text",
1888
- "primaryKey": false,
1889
- "notNull": true
1890
- },
1891
- "slug": {
1892
- "name": "slug",
1893
- "type": "text",
1894
- "primaryKey": false,
1895
- "notNull": true
1896
- },
1897
- "description": {
1898
- "name": "description",
1899
- "type": "text",
1900
- "primaryKey": false,
1901
- "notNull": false
1902
- },
1903
- "widgetConfig": {
1904
- "name": "widgetConfig",
1905
- "type": "jsonb",
1906
- "primaryKey": false,
1907
- "notNull": false
1908
- },
1909
- "createdAt": {
1910
- "name": "createdAt",
1911
- "type": "timestamp",
1912
- "primaryKey": false,
1913
- "notNull": true,
1914
- "default": "now()"
1915
- },
1916
- "updatedAt": {
1917
- "name": "updatedAt",
1918
- "type": "timestamp",
1919
- "primaryKey": false,
1920
- "notNull": true,
1921
- "default": "now()"
1922
- }
1923
- },
1924
- "indexes": {
1925
- "idx_projects_orgId": {
1926
- "name": "idx_projects_orgId",
1927
- "columns": [
1928
- {
1929
- "expression": "organizationId",
1930
- "isExpression": false,
1931
- "asc": true,
1932
- "nulls": "last"
1933
- }
1934
- ],
1935
- "isUnique": false,
1936
- "concurrently": false,
1937
- "method": "btree",
1938
- "with": {}
1939
- }
1940
- },
1941
- "foreignKeys": {
1942
- "projects_organizationId_organizations_id_fk": {
1943
- "name": "projects_organizationId_organizations_id_fk",
1944
- "tableFrom": "projects",
1945
- "tableTo": "organizations",
1946
- "columnsFrom": [
1947
- "organizationId"
1948
- ],
1949
- "columnsTo": [
1950
- "id"
1951
- ],
1952
- "onDelete": "cascade",
1953
- "onUpdate": "no action"
1954
- }
1955
- },
1956
- "compositePrimaryKeys": {},
1957
- "uniqueConstraints": {
1958
- "unique_slug_org": {
1959
- "name": "unique_slug_org",
1960
- "nullsNotDistinct": false,
1961
- "columns": [
1962
- "slug",
1963
- "organizationId"
1964
- ]
1965
- }
1966
- },
1967
- "policies": {},
1968
- "checkConstraints": {},
1969
- "isRLSEnabled": false
1970
- },
1971
- "public.notification_preferences": {
1972
- "name": "notification_preferences",
1973
- "schema": "",
1974
- "columns": {
1975
- "userId": {
1976
- "name": "userId",
1977
- "type": "text",
1978
- "primaryKey": true,
1979
- "notNull": true
1980
- },
1981
- "statusChange": {
1982
- "name": "statusChange",
1983
- "type": "boolean",
1984
- "primaryKey": false,
1985
- "notNull": true,
1986
- "default": true
1987
- },
1988
- "newComment": {
1989
- "name": "newComment",
1990
- "type": "boolean",
1991
- "primaryKey": false,
1992
- "notNull": true,
1993
- "default": true
1994
- },
1995
- "updatedAt": {
1996
- "name": "updatedAt",
1997
- "type": "timestamp",
1998
- "primaryKey": false,
1999
- "notNull": true,
2000
- "default": "now()"
2001
- }
2002
- },
2003
- "indexes": {},
2004
- "foreignKeys": {
2005
- "notification_preferences_userId_user_id_fk": {
2006
- "name": "notification_preferences_userId_user_id_fk",
2007
- "tableFrom": "notification_preferences",
2008
- "tableTo": "user",
2009
- "columnsFrom": [
2010
- "userId"
2011
- ],
2012
- "columnsTo": [
2013
- "id"
2014
- ],
2015
- "onDelete": "cascade",
2016
- "onUpdate": "no action"
2017
- }
2018
- },
2019
- "compositePrimaryKeys": {},
2020
- "uniqueConstraints": {},
2021
- "policies": {},
2022
- "checkConstraints": {},
2023
- "isRLSEnabled": false
2024
- },
2025
- "public.notifications": {
2026
- "name": "notifications",
2027
- "schema": "",
2028
- "columns": {
2029
- "notificationId": {
2030
- "name": "notificationId",
2031
- "type": "serial",
2032
- "primaryKey": true,
2033
- "notNull": true
2034
- },
2035
- "userId": {
2036
- "name": "userId",
2037
- "type": "text",
2038
- "primaryKey": false,
2039
- "notNull": true
2040
- },
2041
- "type": {
2042
- "name": "type",
2043
- "type": "text",
2044
- "primaryKey": false,
2045
- "notNull": true
2046
- },
2047
- "feedbackId": {
2048
- "name": "feedbackId",
2049
- "type": "serial",
2050
- "primaryKey": false,
2051
- "notNull": true
2052
- },
2053
- "data": {
2054
- "name": "data",
2055
- "type": "jsonb",
2056
- "primaryKey": false,
2057
- "notNull": false
2058
- },
2059
- "status": {
2060
- "name": "status",
2061
- "type": "text",
2062
- "primaryKey": false,
2063
- "notNull": true,
2064
- "default": "'pending'"
2065
- },
2066
- "sentAt": {
2067
- "name": "sentAt",
2068
- "type": "timestamp",
2069
- "primaryKey": false,
2070
- "notNull": false
2071
- },
2072
- "error": {
2073
- "name": "error",
2074
- "type": "text",
2075
- "primaryKey": false,
2076
- "notNull": false
2077
- },
2078
- "createdAt": {
2079
- "name": "createdAt",
2080
- "type": "timestamp",
2081
- "primaryKey": false,
2082
- "notNull": true,
2083
- "default": "now()"
2084
- }
2085
- },
2086
- "indexes": {
2087
- "idx_notifications_userId": {
2088
- "name": "idx_notifications_userId",
2089
- "columns": [
2090
- {
2091
- "expression": "userId",
2092
- "isExpression": false,
2093
- "asc": true,
2094
- "nulls": "last"
2095
- }
2096
- ],
2097
- "isUnique": false,
2098
- "concurrently": false,
2099
- "method": "btree",
2100
- "with": {}
2101
- },
2102
- "idx_notifications_status": {
2103
- "name": "idx_notifications_status",
2104
- "columns": [
2105
- {
2106
- "expression": "status",
2107
- "isExpression": false,
2108
- "asc": true,
2109
- "nulls": "last"
2110
- }
2111
- ],
2112
- "isUnique": false,
2113
- "concurrently": false,
2114
- "method": "btree",
2115
- "with": {}
2116
- },
2117
- "idx_notifications_type": {
2118
- "name": "idx_notifications_type",
2119
- "columns": [
2120
- {
2121
- "expression": "type",
2122
- "isExpression": false,
2123
- "asc": true,
2124
- "nulls": "last"
2125
- }
2126
- ],
2127
- "isUnique": false,
2128
- "concurrently": false,
2129
- "method": "btree",
2130
- "with": {}
2131
- }
2132
- },
2133
- "foreignKeys": {
2134
- "notifications_userId_user_id_fk": {
2135
- "name": "notifications_userId_user_id_fk",
2136
- "tableFrom": "notifications",
2137
- "tableTo": "user",
2138
- "columnsFrom": [
2139
- "userId"
2140
- ],
2141
- "columnsTo": [
2142
- "id"
2143
- ],
2144
- "onDelete": "cascade",
2145
- "onUpdate": "no action"
2146
- },
2147
- "notifications_feedbackId_feedback_feedbackId_fk": {
2148
- "name": "notifications_feedbackId_feedback_feedbackId_fk",
2149
- "tableFrom": "notifications",
2150
- "tableTo": "feedback",
2151
- "columnsFrom": [
2152
- "feedbackId"
2153
- ],
2154
- "columnsTo": [
2155
- "feedbackId"
2156
- ],
2157
- "onDelete": "cascade",
2158
- "onUpdate": "no action"
2159
- }
2160
- },
2161
- "compositePrimaryKeys": {},
2162
- "uniqueConstraints": {},
2163
- "policies": {},
2164
- "checkConstraints": {},
2165
- "isRLSEnabled": false
2166
- },
2167
- "public.feedback_tags": {
2168
- "name": "feedback_tags",
2169
- "schema": "",
2170
- "columns": {
2171
- "id": {
2172
- "name": "id",
2173
- "type": "serial",
2174
- "primaryKey": true,
2175
- "notNull": true
2176
- },
2177
- "feedbackId": {
2178
- "name": "feedbackId",
2179
- "type": "integer",
2180
- "primaryKey": false,
2181
- "notNull": true
2182
- },
2183
- "tagId": {
2184
- "name": "tagId",
2185
- "type": "integer",
2186
- "primaryKey": false,
2187
- "notNull": true
2188
- },
2189
- "createdAt": {
2190
- "name": "createdAt",
2191
- "type": "timestamp",
2192
- "primaryKey": false,
2193
- "notNull": true,
2194
- "default": "now()"
2195
- }
2196
- },
2197
- "indexes": {
2198
- "idx_feedback_tags_feedbackId": {
2199
- "name": "idx_feedback_tags_feedbackId",
2200
- "columns": [
2201
- {
2202
- "expression": "feedbackId",
2203
- "isExpression": false,
2204
- "asc": true,
2205
- "nulls": "last"
2206
- }
2207
- ],
2208
- "isUnique": false,
2209
- "concurrently": false,
2210
- "method": "btree",
2211
- "with": {}
2212
- },
2213
- "idx_feedback_tags_tagId": {
2214
- "name": "idx_feedback_tags_tagId",
2215
- "columns": [
2216
- {
2217
- "expression": "tagId",
2218
- "isExpression": false,
2219
- "asc": true,
2220
- "nulls": "last"
2221
- }
2222
- ],
2223
- "isUnique": false,
2224
- "concurrently": false,
2225
- "method": "btree",
2226
- "with": {}
2227
- },
2228
- "idx_feedback_tags_unique": {
2229
- "name": "idx_feedback_tags_unique",
2230
- "columns": [
2231
- {
2232
- "expression": "feedbackId",
2233
- "isExpression": false,
2234
- "asc": true,
2235
- "nulls": "last"
2236
- },
2237
- {
2238
- "expression": "tagId",
2239
- "isExpression": false,
2240
- "asc": true,
2241
- "nulls": "last"
2242
- }
2243
- ],
2244
- "isUnique": false,
2245
- "concurrently": false,
2246
- "method": "btree",
2247
- "with": {}
2248
- }
2249
- },
2250
- "foreignKeys": {
2251
- "feedback_tags_feedbackId_feedback_feedbackId_fk": {
2252
- "name": "feedback_tags_feedbackId_feedback_feedbackId_fk",
2253
- "tableFrom": "feedback_tags",
2254
- "tableTo": "feedback",
2255
- "columnsFrom": [
2256
- "feedbackId"
2257
- ],
2258
- "columnsTo": [
2259
- "feedbackId"
2260
- ],
2261
- "onDelete": "cascade",
2262
- "onUpdate": "no action"
2263
- },
2264
- "feedback_tags_tagId_tags_tagId_fk": {
2265
- "name": "feedback_tags_tagId_tags_tagId_fk",
2266
- "tableFrom": "feedback_tags",
2267
- "tableTo": "tags",
2268
- "columnsFrom": [
2269
- "tagId"
2270
- ],
2271
- "columnsTo": [
2272
- "tagId"
2273
- ],
2274
- "onDelete": "cascade",
2275
- "onUpdate": "no action"
2276
- }
2277
- },
2278
- "compositePrimaryKeys": {},
2279
- "uniqueConstraints": {},
2280
- "policies": {},
2281
- "checkConstraints": {},
2282
- "isRLSEnabled": false
2283
- },
2284
- "public.tags": {
2285
- "name": "tags",
2286
- "schema": "",
2287
- "columns": {
2288
- "tagId": {
2289
- "name": "tagId",
2290
- "type": "serial",
2291
- "primaryKey": true,
2292
- "notNull": true
2293
- },
2294
- "name": {
2295
- "name": "name",
2296
- "type": "text",
2297
- "primaryKey": false,
2298
- "notNull": true
2299
- },
2300
- "slug": {
2301
- "name": "slug",
2302
- "type": "text",
2303
- "primaryKey": false,
2304
- "notNull": true
2305
- },
2306
- "color": {
2307
- "name": "color",
2308
- "type": "text",
2309
- "primaryKey": false,
2310
- "notNull": false,
2311
- "default": "'#3b82f6'"
2312
- },
2313
- "description": {
2314
- "name": "description",
2315
- "type": "text",
2316
- "primaryKey": false,
2317
- "notNull": false
2318
- },
2319
- "createdAt": {
2320
- "name": "createdAt",
2321
- "type": "timestamp",
2322
- "primaryKey": false,
2323
- "notNull": true,
2324
- "default": "now()"
2325
- }
2326
- },
2327
- "indexes": {},
2328
- "foreignKeys": {},
2329
- "compositePrimaryKeys": {},
2330
- "uniqueConstraints": {
2331
- "tags_name_unique": {
2332
- "name": "tags_name_unique",
2333
- "nullsNotDistinct": false,
2334
- "columns": [
2335
- "name"
2336
- ]
2337
- },
2338
- "tags_slug_unique": {
2339
- "name": "tags_slug_unique",
2340
- "nullsNotDistinct": false,
2341
- "columns": [
2342
- "slug"
2343
- ]
2344
- }
2345
- },
2346
- "policies": {},
2347
- "checkConstraints": {},
2348
- "isRLSEnabled": false
2349
- },
2350
- "public.webhook_events": {
2351
- "name": "webhook_events",
2352
- "schema": "",
2353
- "columns": {
2354
- "eventId": {
2355
- "name": "eventId",
2356
- "type": "serial",
2357
- "primaryKey": true,
2358
- "notNull": true
2359
- },
2360
- "webhookId": {
2361
- "name": "webhookId",
2362
- "type": "integer",
2363
- "primaryKey": false,
2364
- "notNull": true
2365
- },
2366
- "eventType": {
2367
- "name": "eventType",
2368
- "type": "text",
2369
- "primaryKey": false,
2370
- "notNull": true
2371
- },
2372
- "payload": {
2373
- "name": "payload",
2374
- "type": "jsonb",
2375
- "primaryKey": false,
2376
- "notNull": true
2377
- },
2378
- "status": {
2379
- "name": "status",
2380
- "type": "text",
2381
- "primaryKey": false,
2382
- "notNull": true,
2383
- "default": "'pending'"
2384
- },
2385
- "responseStatus": {
2386
- "name": "responseStatus",
2387
- "type": "integer",
2388
- "primaryKey": false,
2389
- "notNull": false
2390
- },
2391
- "responseBody": {
2392
- "name": "responseBody",
2393
- "type": "text",
2394
- "primaryKey": false,
2395
- "notNull": false
2396
- },
2397
- "retryCount": {
2398
- "name": "retryCount",
2399
- "type": "integer",
2400
- "primaryKey": false,
2401
- "notNull": true,
2402
- "default": 0
2403
- },
2404
- "maxRetries": {
2405
- "name": "maxRetries",
2406
- "type": "integer",
2407
- "primaryKey": false,
2408
- "notNull": true,
2409
- "default": 3
2410
- },
2411
- "nextRetryAt": {
2412
- "name": "nextRetryAt",
2413
- "type": "timestamp",
2414
- "primaryKey": false,
2415
- "notNull": false
2416
- },
2417
- "deliveredAt": {
2418
- "name": "deliveredAt",
2419
- "type": "timestamp",
2420
- "primaryKey": false,
2421
- "notNull": false
2422
- },
2423
- "createdAt": {
2424
- "name": "createdAt",
2425
- "type": "timestamp",
2426
- "primaryKey": false,
2427
- "notNull": true,
2428
- "default": "now()"
2429
- },
2430
- "updatedAt": {
2431
- "name": "updatedAt",
2432
- "type": "timestamp",
2433
- "primaryKey": false,
2434
- "notNull": true,
2435
- "default": "now()"
2436
- }
2437
- },
2438
- "indexes": {
2439
- "idx_webhook_events_webhookId": {
2440
- "name": "idx_webhook_events_webhookId",
2441
- "columns": [
2442
- {
2443
- "expression": "webhookId",
2444
- "isExpression": false,
2445
- "asc": true,
2446
- "nulls": "last"
2447
- }
2448
- ],
2449
- "isUnique": false,
2450
- "concurrently": false,
2451
- "method": "btree",
2452
- "with": {}
2453
- },
2454
- "idx_webhook_events_status": {
2455
- "name": "idx_webhook_events_status",
2456
- "columns": [
2457
- {
2458
- "expression": "status",
2459
- "isExpression": false,
2460
- "asc": true,
2461
- "nulls": "last"
2462
- }
2463
- ],
2464
- "isUnique": false,
2465
- "concurrently": false,
2466
- "method": "btree",
2467
- "with": {}
2468
- },
2469
- "idx_webhook_events_nextRetry": {
2470
- "name": "idx_webhook_events_nextRetry",
2471
- "columns": [
2472
- {
2473
- "expression": "nextRetryAt",
2474
- "isExpression": false,
2475
- "asc": true,
2476
- "nulls": "last"
2477
- }
2478
- ],
2479
- "isUnique": false,
2480
- "concurrently": false,
2481
- "method": "btree",
2482
- "with": {}
2483
- }
2484
- },
2485
- "foreignKeys": {
2486
- "webhook_events_webhookId_webhooks_webhookId_fk": {
2487
- "name": "webhook_events_webhookId_webhooks_webhookId_fk",
2488
- "tableFrom": "webhook_events",
2489
- "tableTo": "webhooks",
2490
- "columnsFrom": [
2491
- "webhookId"
2492
- ],
2493
- "columnsTo": [
2494
- "webhookId"
2495
- ],
2496
- "onDelete": "cascade",
2497
- "onUpdate": "no action"
2498
- }
2499
- },
2500
- "compositePrimaryKeys": {},
2501
- "uniqueConstraints": {},
2502
- "policies": {},
2503
- "checkConstraints": {},
2504
- "isRLSEnabled": false
2505
- },
2506
- "public.webhooks": {
2507
- "name": "webhooks",
2508
- "schema": "",
2509
- "columns": {
2510
- "webhookId": {
2511
- "name": "webhookId",
2512
- "type": "serial",
2513
- "primaryKey": true,
2514
- "notNull": true
2515
- },
2516
- "organizationId": {
2517
- "name": "organizationId",
2518
- "type": "text",
2519
- "primaryKey": false,
2520
- "notNull": true
2521
- },
2522
- "name": {
2523
- "name": "name",
2524
- "type": "text",
2525
- "primaryKey": false,
2526
- "notNull": true
2527
- },
2528
- "url": {
2529
- "name": "url",
2530
- "type": "text",
2531
- "primaryKey": false,
2532
- "notNull": true
2533
- },
2534
- "secret": {
2535
- "name": "secret",
2536
- "type": "text",
2537
- "primaryKey": false,
2538
- "notNull": false
2539
- },
2540
- "events": {
2541
- "name": "events",
2542
- "type": "jsonb",
2543
- "primaryKey": false,
2544
- "notNull": true
2545
- },
2546
- "enabled": {
2547
- "name": "enabled",
2548
- "type": "boolean",
2549
- "primaryKey": false,
2550
- "notNull": true,
2551
- "default": true
2552
- },
2553
- "createdAt": {
2554
- "name": "createdAt",
2555
- "type": "timestamp",
2556
- "primaryKey": false,
2557
- "notNull": true,
2558
- "default": "now()"
2559
- },
2560
- "updatedAt": {
2561
- "name": "updatedAt",
2562
- "type": "timestamp",
2563
- "primaryKey": false,
2564
- "notNull": true,
2565
- "default": "now()"
2566
- }
2567
- },
2568
- "indexes": {
2569
- "idx_webhooks_orgId": {
2570
- "name": "idx_webhooks_orgId",
2571
- "columns": [
2572
- {
2573
- "expression": "organizationId",
2574
- "isExpression": false,
2575
- "asc": true,
2576
- "nulls": "last"
2577
- }
2578
- ],
2579
- "isUnique": false,
2580
- "concurrently": false,
2581
- "method": "btree",
2582
- "with": {}
2583
- },
2584
- "idx_webhooks_enabled": {
2585
- "name": "idx_webhooks_enabled",
2586
- "columns": [
2587
- {
2588
- "expression": "enabled",
2589
- "isExpression": false,
2590
- "asc": true,
2591
- "nulls": "last"
2592
- }
2593
- ],
2594
- "isUnique": false,
2595
- "concurrently": false,
2596
- "method": "btree",
2597
- "with": {}
2598
- }
2599
- },
2600
- "foreignKeys": {
2601
- "webhooks_organizationId_organizations_id_fk": {
2602
- "name": "webhooks_organizationId_organizations_id_fk",
2603
- "tableFrom": "webhooks",
2604
- "tableTo": "organizations",
2605
- "columnsFrom": [
2606
- "organizationId"
2607
- ],
2608
- "columnsTo": [
2609
- "id"
2610
- ],
2611
- "onDelete": "cascade",
2612
- "onUpdate": "no action"
2613
- }
2614
- },
2615
- "compositePrimaryKeys": {},
2616
- "uniqueConstraints": {},
2617
- "policies": {},
2618
- "checkConstraints": {},
2619
- "isRLSEnabled": false
2620
- }
2621
- },
2622
- "enums": {},
2623
- "schemas": {},
2624
- "sequences": {},
2625
- "roles": {},
2626
- "policies": {},
2627
- "views": {},
2628
- "_meta": {
2629
- "columns": {},
2630
- "schemas": {},
2631
- "tables": {}
2632
- }
2633
- }