@nexttylabs/echo 0.3.0 → 0.5.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 (248) hide show
  1. package/CHANGELOG.md +25 -0
  2. package/app/(public)/[organizationSlug]/roadmap/page.tsx +19 -1
  3. package/app/api/admin/backup/route.ts +22 -4
  4. package/app/api/auth/register/handler.ts +1 -2
  5. package/lib/auth/config.ts +0 -7
  6. package/lib/db/migrations/0000_needy_leech.sql +335 -0
  7. package/lib/db/migrations/meta/0000_snapshot.json +2186 -1
  8. package/lib/db/migrations/meta/_journal.json +2 -135
  9. package/lib/db/schema/auth.ts +0 -1
  10. package/lib/db/schema/index.ts +0 -1
  11. package/lib/portal/public-context.tsx +5 -0
  12. package/package.json +20 -1
  13. package/.changeset/README.md +0 -21
  14. package/.changeset/config.json +0 -11
  15. package/.changeset/cozy-ghosts-care.md +0 -5
  16. package/.changeset/sharp-lines-stand.md +0 -5
  17. package/.changeset/sour-doodles-eat.md +0 -5
  18. package/.changeset/tender-moose-shop.md +0 -5
  19. package/.github/pull_request_template.md +0 -13
  20. package/.github/workflows/ci.yml +0 -41
  21. package/.github/workflows/publish.yml +0 -44
  22. package/.github/workflows/release.yml +0 -73
  23. package/AGENTS.md +0 -92
  24. package/Dockerfile +0 -57
  25. package/Makefile +0 -77
  26. package/app/api/internal/domain-lookup/route.ts +0 -67
  27. package/bun.lock +0 -2503
  28. package/components/portal/project-switcher.tsx +0 -20
  29. package/docker-compose.dev.yml +0 -26
  30. package/docker-compose.yml +0 -98
  31. package/docs/architecture.md +0 -259
  32. package/docs/component-inventory.md +0 -261
  33. package/docs/database-migrations.md +0 -76
  34. package/docs/development-guide.md +0 -209
  35. package/docs/e2e-user-flows.csv +0 -31
  36. package/docs/er-diagram-feedback.mmd +0 -138
  37. package/docs/er-diagram.mmd +0 -281
  38. package/docs/i18n-check-report.md +0 -296
  39. package/docs/index.md +0 -214
  40. package/docs/logic-chain.md +0 -94
  41. package/docs/plans/2026-01-02-database-migration-scripts.md +0 -496
  42. package/docs/plans/2026-01-02-user-login-design.md +0 -37
  43. package/docs/plans/2026-01-02-user-login.md +0 -437
  44. package/docs/plans/2026-01-02-user-registration-design.md +0 -47
  45. package/docs/plans/2026-01-02-user-registration.md +0 -628
  46. package/docs/plans/2026-01-03-roles-permissions-design.md +0 -20
  47. package/docs/plans/2026-01-03-roles-permissions.md +0 -266
  48. package/docs/plans/2026-01-05-authentication-middleware.md +0 -207
  49. package/docs/plans/2026-01-05-member-removal.md +0 -186
  50. package/docs/plans/2026-01-05-organization-creation.md +0 -374
  51. package/docs/plans/2026-01-05-rbac-middleware.md +0 -112
  52. package/docs/plans/2026-01-05-role-configuration.md +0 -441
  53. package/docs/plans/2026-01-06-file-upload-support.md +0 -804
  54. package/docs/plans/2026-01-06-permission-check-hook.md +0 -155
  55. package/docs/plans/2026-01-06-resource-ownership-check.md +0 -231
  56. package/docs/plans/2026-01-07-feedback-tracking-link.md +0 -459
  57. package/docs/plans/2026-01-09-logout-redirect-design.md +0 -52
  58. package/docs/plans/2026-01-09-phase2-3-plan.md +0 -654
  59. package/docs/plans/2026-01-09-portal-execution-plan.md +0 -408
  60. package/docs/plans/2026-01-09-project-delete-feature-design.md +0 -163
  61. package/docs/plans/2026-01-09-project-delete-implementation.md +0 -451
  62. package/docs/plans/2026-01-09-project-edit-delete-design.md +0 -52
  63. package/docs/plans/2026-01-09-settings-center-design.md +0 -114
  64. package/docs/plans/2026-01-09-settings-center.md +0 -948
  65. package/docs/plans/2026-01-10-organization-only-design.md +0 -66
  66. package/docs/plans/2026-01-10-organization-only-implementation.md +0 -433
  67. package/docs/plans/2026-01-10-portal-settings-restructure-plan.md +0 -18
  68. package/docs/plans/2026-01-10-project-settings-tabs-design-implementation.md +0 -296
  69. package/docs/plans/2026-01-14-e2e-playwright-feedback.md +0 -173
  70. package/docs/plans/2026-01-15-feedback-management-org-context-design.md +0 -82
  71. package/docs/plans/2026-01-15-feedback-management-org-context-implementation-plan.md +0 -521
  72. package/docs/plans/2026-01-16-admin-feedback-filters-design.md +0 -75
  73. package/docs/plans/2026-01-16-admin-feedback-filters-implementation.md +0 -293
  74. package/docs/plans/2026-01-16-admin-feedback-route-consolidation.md +0 -180
  75. package/docs/plans/2026-01-16-e2e-test-fixes.md +0 -158
  76. package/docs/plans/2026-01-17-admin-feedback-filters.md +0 -214
  77. package/docs/plans/2026-01-17-admin-feedback-improvements.md +0 -453
  78. package/docs/plans/2026-01-18-changesets-design.md +0 -40
  79. package/docs/product_changes.md +0 -37
  80. package/docs/project-overview.md +0 -159
  81. package/docs/project-scan-report.json +0 -104
  82. package/docs/route-role-visibility.md +0 -51
  83. package/docs/source-tree-analysis.md +0 -150
  84. package/docs/testing/delete-project-manual-tests.md +0 -18
  85. package/docs/user-story-tracking.md +0 -191
  86. package/eslint.config.mjs +0 -19
  87. package/lib/db/migrations/.gitkeep +0 -0
  88. package/lib/db/migrations/0000_cynical_gladiator.sql +0 -53
  89. package/lib/db/migrations/0001_wandering_sunfire.sql +0 -27
  90. package/lib/db/migrations/0002_shallow_speedball.sql +0 -1
  91. package/lib/db/migrations/0003_add_org_description.sql +0 -1
  92. package/lib/db/migrations/0003_boring_wild_pack.sql +0 -13
  93. package/lib/db/migrations/0004_windy_tyrannus.sql +0 -27
  94. package/lib/db/migrations/0005_perpetual_doorman.sql +0 -5
  95. package/lib/db/migrations/0006_aberrant_captain_midlands.sql +0 -13
  96. package/lib/db/migrations/0007_clever_captain_cross.sql +0 -14
  97. package/lib/db/migrations/0008_sparkling_pandemic.sql +0 -2
  98. package/lib/db/migrations/0009_happy_black_tom.sql +0 -29
  99. package/lib/db/migrations/0010_kind_junta.sql +0 -8
  100. package/lib/db/migrations/0011_mute_squadron_supreme.sql +0 -25
  101. package/lib/db/migrations/0012_giant_power_man.sql +0 -24
  102. package/lib/db/migrations/0013_damp_titanium_man.sql +0 -17
  103. package/lib/db/migrations/0014_blue_alice.sql +0 -18
  104. package/lib/db/migrations/0015_webhook_tables.sql +0 -41
  105. package/lib/db/migrations/0016_github_integration.sql +0 -30
  106. package/lib/db/migrations/0016_overjoyed_ghost_rider.sql +0 -22
  107. package/lib/db/migrations/0017_slimy_inhumans.sql +0 -6
  108. package/lib/db/migrations/0018_same_spitfire.sql +0 -1
  109. package/lib/db/migrations/0019_jittery_loners.sql +0 -16
  110. package/lib/db/migrations/0019_remove_projects_add_org_settings.sql +0 -14
  111. package/lib/db/migrations/meta/0001_snapshot.json +0 -553
  112. package/lib/db/migrations/meta/0002_snapshot.json +0 -560
  113. package/lib/db/migrations/meta/0003_snapshot.json +0 -650
  114. package/lib/db/migrations/meta/0004_snapshot.json +0 -852
  115. package/lib/db/migrations/meta/0005_snapshot.json +0 -900
  116. package/lib/db/migrations/meta/0006_snapshot.json +0 -1011
  117. package/lib/db/migrations/meta/0007_snapshot.json +0 -1125
  118. package/lib/db/migrations/meta/0008_snapshot.json +0 -1146
  119. package/lib/db/migrations/meta/0009_snapshot.json +0 -1386
  120. package/lib/db/migrations/meta/0010_snapshot.json +0 -1419
  121. package/lib/db/migrations/meta/0011_snapshot.json +0 -1615
  122. package/lib/db/migrations/meta/0012_snapshot.json +0 -1805
  123. package/lib/db/migrations/meta/0013_snapshot.json +0 -1948
  124. package/lib/db/migrations/meta/0014_snapshot.json +0 -2082
  125. package/lib/db/migrations/meta/0015_snapshot.json +0 -2476
  126. package/lib/db/migrations/meta/0016_snapshot.json +0 -2633
  127. package/lib/db/migrations/meta/0017_snapshot.json +0 -2680
  128. package/lib/db/migrations/meta/0018_snapshot.json +0 -2686
  129. package/lib/db/migrations/meta/0019_snapshot.json +0 -2741
  130. package/lib/db/schema/projects.ts +0 -145
  131. package/lib/db/schema/user-profiles.ts +0 -31
  132. package/lib/validations/projects.ts +0 -49
  133. package/next-env.d.ts +0 -6
  134. package/playwright.config.ts +0 -44
  135. package/proxy.test.ts +0 -131
  136. package/proxy.ts +0 -190
  137. package/scripts/backup-db.sh +0 -57
  138. package/scripts/backup-db.ts +0 -24
  139. package/scripts/generate-openapi.ts +0 -22
  140. package/scripts/migration-helper.ts +0 -39
  141. package/scripts/pre-deploy.ts +0 -75
  142. package/scripts/restore-db.sh +0 -60
  143. package/scripts/rollback.ts +0 -72
  144. package/scripts/seed-tags.ts +0 -48
  145. package/tests/api/feedback-bulk.test.ts +0 -47
  146. package/tests/api/feedback-by-id.test.ts +0 -67
  147. package/tests/api/feedback-comments-route-import.test.ts +0 -26
  148. package/tests/api/feedback-create.test.ts +0 -71
  149. package/tests/api/feedback-delete.test.ts +0 -160
  150. package/tests/api/feedback-filter.test.ts +0 -250
  151. package/tests/api/feedback-list.test.ts +0 -234
  152. package/tests/api/feedback-route-assignee-condition.test.ts +0 -32
  153. package/tests/api/feedback-similar.test.ts +0 -46
  154. package/tests/api/feedback-sort.test.ts +0 -261
  155. package/tests/api/feedback-status-enum.test.ts +0 -49
  156. package/tests/api/feedback-status-filter.test.ts +0 -117
  157. package/tests/api/feedback-submit-on-behalf.test.ts +0 -269
  158. package/tests/api/feedback.test.ts +0 -175
  159. package/tests/api/identify-jwt.test.ts +0 -25
  160. package/tests/api/invitation-accept.test.ts +0 -213
  161. package/tests/api/organization-invitations.test.ts +0 -186
  162. package/tests/api/organization-members-list.test.ts +0 -79
  163. package/tests/api/organization-members.test.ts +0 -340
  164. package/tests/api/organizations.test.ts +0 -149
  165. package/tests/api/register.test.ts +0 -112
  166. package/tests/api/upload.test.ts +0 -103
  167. package/tests/api/vote.test.ts +0 -82
  168. package/tests/app/admin-feedback-detail-page.test.tsx +0 -25
  169. package/tests/app/admin-feedback-list-page.test.tsx +0 -25
  170. package/tests/app/admin-feedback-new-page.test.tsx +0 -25
  171. package/tests/app/health-route-helpers.test.ts +0 -27
  172. package/tests/app/login-page.test.ts +0 -26
  173. package/tests/app/portal-page.test.ts +0 -29
  174. package/tests/app/project-portal-overview.test.tsx +0 -25
  175. package/tests/app/widget-page-import.test.ts +0 -25
  176. package/tests/components/create-post-dialog-defaults.test.ts +0 -43
  177. package/tests/components/feedback/duplicate-suggestions-inline.test.tsx +0 -27
  178. package/tests/components/feedback/embedded-feedback-form.test.tsx +0 -96
  179. package/tests/components/feedback/feedback-detail.test.tsx +0 -25
  180. package/tests/components/feedback/feedback-stats.test.tsx +0 -49
  181. package/tests/components/feedback-bulk-actions.test.tsx +0 -39
  182. package/tests/components/feedback-i18n-keys.test.ts +0 -70
  183. package/tests/components/feedback-list-controls-compile.test.ts +0 -25
  184. package/tests/components/feedback-list-controls.test.tsx +0 -204
  185. package/tests/components/feedback-list-item.test.tsx +0 -67
  186. package/tests/components/landing/hero.test.tsx +0 -46
  187. package/tests/components/layout/language-switcher.test.tsx +0 -25
  188. package/tests/components/layout/sidebar.test.tsx +0 -157
  189. package/tests/components/login-form.test.ts +0 -25
  190. package/tests/components/organization-form.test.ts +0 -32
  191. package/tests/components/organization-switcher.test.ts +0 -25
  192. package/tests/components/pagination.test.tsx +0 -43
  193. package/tests/components/portal-overview.test.tsx +0 -25
  194. package/tests/components/profile-form.test.tsx +0 -139
  195. package/tests/components/role-selector.test.ts +0 -31
  196. package/tests/components/status-chart.test.tsx +0 -90
  197. package/tests/e2e/auth.e2e.ts +0 -323
  198. package/tests/e2e/feedback-actions.e2e.ts +0 -471
  199. package/tests/e2e/feedback-attachment.e2e.ts +0 -168
  200. package/tests/e2e/feedback-customer.e2e.ts +0 -226
  201. package/tests/e2e/feedback-management.e2e.ts +0 -565
  202. package/tests/e2e/feedback-submit.e2e.ts +0 -133
  203. package/tests/e2e/feedback-view.e2e.ts +0 -297
  204. package/tests/e2e/fixtures/test-data.ts +0 -235
  205. package/tests/e2e/health-check.e2e.ts +0 -230
  206. package/tests/e2e/helpers/test-utils-helpers.test.ts +0 -43
  207. package/tests/e2e/helpers/test-utils.ts +0 -298
  208. package/tests/e2e/integration-placeholders.e2e.ts +0 -199
  209. package/tests/e2e/organization.e2e.ts +0 -292
  210. package/tests/e2e/permissions.e2e.ts +0 -424
  211. package/tests/e2e/project-widget.e2e.ts +0 -63
  212. package/tests/feedback/filters.test.ts +0 -29
  213. package/tests/hooks/use-permissions.test.ts +0 -52
  214. package/tests/lib/ai/classifier.test.ts +0 -104
  215. package/tests/lib/ai/duplicate-detector.test.ts +0 -234
  216. package/tests/lib/attachments-schema.test.ts +0 -30
  217. package/tests/lib/auth/session.test.ts +0 -49
  218. package/tests/lib/auth-client.test.ts +0 -37
  219. package/tests/lib/auth-config.test.ts +0 -26
  220. package/tests/lib/feedback-prefill.test.ts +0 -52
  221. package/tests/lib/feedback-processor.test.ts +0 -41
  222. package/tests/lib/feedback-schema.test.ts +0 -33
  223. package/tests/lib/file-validator.test.ts +0 -48
  224. package/tests/lib/get-feedback-by-id.test.ts +0 -37
  225. package/tests/lib/invitations.test.ts +0 -35
  226. package/tests/lib/login-schema.test.ts +0 -36
  227. package/tests/lib/org-context.test.ts +0 -95
  228. package/tests/lib/organization-access.test.ts +0 -44
  229. package/tests/lib/organization-member-role-schema.test.ts +0 -41
  230. package/tests/lib/permissions.test.ts +0 -88
  231. package/tests/lib/portal-analytics.test.ts +0 -25
  232. package/tests/lib/portal-contributors.test.ts +0 -25
  233. package/tests/lib/portal-copy.test.ts +0 -27
  234. package/tests/lib/portal-i18n.test.ts +0 -30
  235. package/tests/lib/portal-leaderboard-settings.test.ts +0 -25
  236. package/tests/lib/portal-modules.test.ts +0 -25
  237. package/tests/lib/portal-seo.test.ts +0 -25
  238. package/tests/lib/portal-sharing.test.ts +0 -25
  239. package/tests/lib/portal-sorting.test.ts +0 -25
  240. package/tests/lib/portal-theme.test.ts +0 -25
  241. package/tests/lib/rate-limit.test.ts +0 -142
  242. package/tests/lib/resolve-locale.test.ts +0 -34
  243. package/tests/lib/services/backup.test.ts +0 -145
  244. package/tests/lib/user-organizations.test.ts +0 -42
  245. package/tests/lib/user-role-schema.test.ts +0 -33
  246. package/tests/lib/user-schema.test.ts +0 -25
  247. package/tests/setup.ts +0 -74
  248. package/vercel.json +0 -4
@@ -1,2686 +0,0 @@
1
- {
2
- "id": "7ff1bc50-1728-4f71-9fb4-bb94c2e7c7e9",
3
- "prevId": "bfb9975f-ce05-467c-9bd4-6f60b60c4ca8",
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": "'admin'"
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
- "projectId": {
1060
- "name": "projectId",
1061
- "type": "uuid",
1062
- "primaryKey": false,
1063
- "notNull": false
1064
- },
1065
- "submittedOnBehalf": {
1066
- "name": "submittedOnBehalf",
1067
- "type": "boolean",
1068
- "primaryKey": false,
1069
- "notNull": true,
1070
- "default": false
1071
- },
1072
- "submittedBy": {
1073
- "name": "submittedBy",
1074
- "type": "text",
1075
- "primaryKey": false,
1076
- "notNull": false
1077
- },
1078
- "customerInfo": {
1079
- "name": "customerInfo",
1080
- "type": "jsonb",
1081
- "primaryKey": false,
1082
- "notNull": false
1083
- },
1084
- "createdAt": {
1085
- "name": "createdAt",
1086
- "type": "timestamp",
1087
- "primaryKey": false,
1088
- "notNull": true,
1089
- "default": "now()"
1090
- },
1091
- "updatedAt": {
1092
- "name": "updatedAt",
1093
- "type": "timestamp",
1094
- "primaryKey": false,
1095
- "notNull": true,
1096
- "default": "now()"
1097
- },
1098
- "deletedAt": {
1099
- "name": "deletedAt",
1100
- "type": "timestamp",
1101
- "primaryKey": false,
1102
- "notNull": false
1103
- },
1104
- "autoClassified": {
1105
- "name": "autoClassified",
1106
- "type": "boolean",
1107
- "primaryKey": false,
1108
- "notNull": true,
1109
- "default": false
1110
- },
1111
- "processingStatus": {
1112
- "name": "processingStatus",
1113
- "type": "text",
1114
- "primaryKey": false,
1115
- "notNull": false,
1116
- "default": "'pending'"
1117
- },
1118
- "processedAt": {
1119
- "name": "processedAt",
1120
- "type": "timestamp",
1121
- "primaryKey": false,
1122
- "notNull": false
1123
- },
1124
- "githubIssueId": {
1125
- "name": "githubIssueId",
1126
- "type": "integer",
1127
- "primaryKey": false,
1128
- "notNull": false
1129
- },
1130
- "githubIssueNumber": {
1131
- "name": "githubIssueNumber",
1132
- "type": "integer",
1133
- "primaryKey": false,
1134
- "notNull": false
1135
- },
1136
- "githubIssueUrl": {
1137
- "name": "githubIssueUrl",
1138
- "type": "text",
1139
- "primaryKey": false,
1140
- "notNull": false
1141
- },
1142
- "githubSyncedAt": {
1143
- "name": "githubSyncedAt",
1144
- "type": "timestamp",
1145
- "primaryKey": false,
1146
- "notNull": false
1147
- },
1148
- "githubStatus": {
1149
- "name": "githubStatus",
1150
- "type": "text",
1151
- "primaryKey": false,
1152
- "notNull": false
1153
- }
1154
- },
1155
- "indexes": {
1156
- "idx_feedback_orgId": {
1157
- "name": "idx_feedback_orgId",
1158
- "columns": [
1159
- {
1160
- "expression": "organizationId",
1161
- "isExpression": false,
1162
- "asc": true,
1163
- "nulls": "last"
1164
- }
1165
- ],
1166
- "isUnique": false,
1167
- "concurrently": false,
1168
- "method": "btree",
1169
- "with": {}
1170
- },
1171
- "idx_feedback_projectId": {
1172
- "name": "idx_feedback_projectId",
1173
- "columns": [
1174
- {
1175
- "expression": "projectId",
1176
- "isExpression": false,
1177
- "asc": true,
1178
- "nulls": "last"
1179
- }
1180
- ],
1181
- "isUnique": false,
1182
- "concurrently": false,
1183
- "method": "btree",
1184
- "with": {}
1185
- },
1186
- "idx_feedback_status": {
1187
- "name": "idx_feedback_status",
1188
- "columns": [
1189
- {
1190
- "expression": "status",
1191
- "isExpression": false,
1192
- "asc": true,
1193
- "nulls": "last"
1194
- }
1195
- ],
1196
- "isUnique": false,
1197
- "concurrently": false,
1198
- "method": "btree",
1199
- "with": {}
1200
- },
1201
- "idx_feedback_createdAt": {
1202
- "name": "idx_feedback_createdAt",
1203
- "columns": [
1204
- {
1205
- "expression": "createdAt",
1206
- "isExpression": false,
1207
- "asc": true,
1208
- "nulls": "last"
1209
- }
1210
- ],
1211
- "isUnique": false,
1212
- "concurrently": false,
1213
- "method": "btree",
1214
- "with": {}
1215
- },
1216
- "idx_feedback_submittedBy": {
1217
- "name": "idx_feedback_submittedBy",
1218
- "columns": [
1219
- {
1220
- "expression": "submittedBy",
1221
- "isExpression": false,
1222
- "asc": true,
1223
- "nulls": "last"
1224
- }
1225
- ],
1226
- "isUnique": false,
1227
- "concurrently": false,
1228
- "method": "btree",
1229
- "with": {}
1230
- },
1231
- "idx_feedback_deletedAt": {
1232
- "name": "idx_feedback_deletedAt",
1233
- "columns": [
1234
- {
1235
- "expression": "deletedAt",
1236
- "isExpression": false,
1237
- "asc": true,
1238
- "nulls": "last"
1239
- }
1240
- ],
1241
- "isUnique": false,
1242
- "concurrently": false,
1243
- "method": "btree",
1244
- "with": {}
1245
- },
1246
- "idx_feedback_githubIssueId": {
1247
- "name": "idx_feedback_githubIssueId",
1248
- "columns": [
1249
- {
1250
- "expression": "githubIssueId",
1251
- "isExpression": false,
1252
- "asc": true,
1253
- "nulls": "last"
1254
- }
1255
- ],
1256
- "isUnique": false,
1257
- "concurrently": false,
1258
- "method": "btree",
1259
- "with": {}
1260
- }
1261
- },
1262
- "foreignKeys": {
1263
- "feedback_projectId_projects_projectId_fk": {
1264
- "name": "feedback_projectId_projects_projectId_fk",
1265
- "tableFrom": "feedback",
1266
- "tableTo": "projects",
1267
- "columnsFrom": [
1268
- "projectId"
1269
- ],
1270
- "columnsTo": [
1271
- "projectId"
1272
- ],
1273
- "onDelete": "set null",
1274
- "onUpdate": "no action"
1275
- },
1276
- "feedback_submittedBy_user_id_fk": {
1277
- "name": "feedback_submittedBy_user_id_fk",
1278
- "tableFrom": "feedback",
1279
- "tableTo": "user",
1280
- "columnsFrom": [
1281
- "submittedBy"
1282
- ],
1283
- "columnsTo": [
1284
- "id"
1285
- ],
1286
- "onDelete": "set null",
1287
- "onUpdate": "no action"
1288
- }
1289
- },
1290
- "compositePrimaryKeys": {},
1291
- "uniqueConstraints": {},
1292
- "policies": {},
1293
- "checkConstraints": {},
1294
- "isRLSEnabled": false
1295
- },
1296
- "public.github_integrations": {
1297
- "name": "github_integrations",
1298
- "schema": "",
1299
- "columns": {
1300
- "id": {
1301
- "name": "id",
1302
- "type": "serial",
1303
- "primaryKey": true,
1304
- "notNull": true
1305
- },
1306
- "organizationId": {
1307
- "name": "organizationId",
1308
- "type": "text",
1309
- "primaryKey": false,
1310
- "notNull": true
1311
- },
1312
- "accessToken": {
1313
- "name": "accessToken",
1314
- "type": "text",
1315
- "primaryKey": false,
1316
- "notNull": true
1317
- },
1318
- "owner": {
1319
- "name": "owner",
1320
- "type": "text",
1321
- "primaryKey": false,
1322
- "notNull": true
1323
- },
1324
- "repo": {
1325
- "name": "repo",
1326
- "type": "text",
1327
- "primaryKey": false,
1328
- "notNull": true
1329
- },
1330
- "labelMapping": {
1331
- "name": "labelMapping",
1332
- "type": "jsonb",
1333
- "primaryKey": false,
1334
- "notNull": false
1335
- },
1336
- "statusMapping": {
1337
- "name": "statusMapping",
1338
- "type": "jsonb",
1339
- "primaryKey": false,
1340
- "notNull": false
1341
- },
1342
- "autoSync": {
1343
- "name": "autoSync",
1344
- "type": "boolean",
1345
- "primaryKey": false,
1346
- "notNull": true,
1347
- "default": true
1348
- },
1349
- "webhookSecret": {
1350
- "name": "webhookSecret",
1351
- "type": "text",
1352
- "primaryKey": false,
1353
- "notNull": false
1354
- },
1355
- "createdAt": {
1356
- "name": "createdAt",
1357
- "type": "timestamp",
1358
- "primaryKey": false,
1359
- "notNull": true,
1360
- "default": "now()"
1361
- },
1362
- "updatedAt": {
1363
- "name": "updatedAt",
1364
- "type": "timestamp",
1365
- "primaryKey": false,
1366
- "notNull": true,
1367
- "default": "now()"
1368
- }
1369
- },
1370
- "indexes": {
1371
- "idx_github_integrations_orgId": {
1372
- "name": "idx_github_integrations_orgId",
1373
- "columns": [
1374
- {
1375
- "expression": "organizationId",
1376
- "isExpression": false,
1377
- "asc": true,
1378
- "nulls": "last"
1379
- }
1380
- ],
1381
- "isUnique": false,
1382
- "concurrently": false,
1383
- "method": "btree",
1384
- "with": {}
1385
- }
1386
- },
1387
- "foreignKeys": {
1388
- "github_integrations_organizationId_organizations_id_fk": {
1389
- "name": "github_integrations_organizationId_organizations_id_fk",
1390
- "tableFrom": "github_integrations",
1391
- "tableTo": "organizations",
1392
- "columnsFrom": [
1393
- "organizationId"
1394
- ],
1395
- "columnsTo": [
1396
- "id"
1397
- ],
1398
- "onDelete": "cascade",
1399
- "onUpdate": "no action"
1400
- }
1401
- },
1402
- "compositePrimaryKeys": {},
1403
- "uniqueConstraints": {},
1404
- "policies": {},
1405
- "checkConstraints": {},
1406
- "isRLSEnabled": false
1407
- },
1408
- "public.user_profiles": {
1409
- "name": "user_profiles",
1410
- "schema": "",
1411
- "columns": {
1412
- "user_id": {
1413
- "name": "user_id",
1414
- "type": "text",
1415
- "primaryKey": true,
1416
- "notNull": true
1417
- },
1418
- "name": {
1419
- "name": "name",
1420
- "type": "text",
1421
- "primaryKey": false,
1422
- "notNull": true
1423
- },
1424
- "created_at": {
1425
- "name": "created_at",
1426
- "type": "timestamp",
1427
- "primaryKey": false,
1428
- "notNull": true,
1429
- "default": "now()"
1430
- },
1431
- "updated_at": {
1432
- "name": "updated_at",
1433
- "type": "timestamp",
1434
- "primaryKey": false,
1435
- "notNull": true,
1436
- "default": "now()"
1437
- }
1438
- },
1439
- "indexes": {},
1440
- "foreignKeys": {
1441
- "user_profiles_user_id_user_id_fk": {
1442
- "name": "user_profiles_user_id_user_id_fk",
1443
- "tableFrom": "user_profiles",
1444
- "tableTo": "user",
1445
- "columnsFrom": [
1446
- "user_id"
1447
- ],
1448
- "columnsTo": [
1449
- "id"
1450
- ],
1451
- "onDelete": "cascade",
1452
- "onUpdate": "no action"
1453
- }
1454
- },
1455
- "compositePrimaryKeys": {},
1456
- "uniqueConstraints": {},
1457
- "policies": {},
1458
- "checkConstraints": {},
1459
- "isRLSEnabled": false
1460
- },
1461
- "public.organizations": {
1462
- "name": "organizations",
1463
- "schema": "",
1464
- "columns": {
1465
- "id": {
1466
- "name": "id",
1467
- "type": "text",
1468
- "primaryKey": true,
1469
- "notNull": true
1470
- },
1471
- "name": {
1472
- "name": "name",
1473
- "type": "text",
1474
- "primaryKey": false,
1475
- "notNull": true
1476
- },
1477
- "slug": {
1478
- "name": "slug",
1479
- "type": "text",
1480
- "primaryKey": false,
1481
- "notNull": true
1482
- },
1483
- "description": {
1484
- "name": "description",
1485
- "type": "text",
1486
- "primaryKey": false,
1487
- "notNull": false
1488
- },
1489
- "created_at": {
1490
- "name": "created_at",
1491
- "type": "timestamp",
1492
- "primaryKey": false,
1493
- "notNull": true,
1494
- "default": "now()"
1495
- },
1496
- "updated_at": {
1497
- "name": "updated_at",
1498
- "type": "timestamp",
1499
- "primaryKey": false,
1500
- "notNull": true,
1501
- "default": "now()"
1502
- }
1503
- },
1504
- "indexes": {},
1505
- "foreignKeys": {},
1506
- "compositePrimaryKeys": {},
1507
- "uniqueConstraints": {
1508
- "organizations_slug_unique": {
1509
- "name": "organizations_slug_unique",
1510
- "nullsNotDistinct": false,
1511
- "columns": [
1512
- "slug"
1513
- ]
1514
- }
1515
- },
1516
- "policies": {},
1517
- "checkConstraints": {},
1518
- "isRLSEnabled": false
1519
- },
1520
- "public.organization_members": {
1521
- "name": "organization_members",
1522
- "schema": "",
1523
- "columns": {
1524
- "organization_id": {
1525
- "name": "organization_id",
1526
- "type": "text",
1527
- "primaryKey": false,
1528
- "notNull": true
1529
- },
1530
- "user_id": {
1531
- "name": "user_id",
1532
- "type": "text",
1533
- "primaryKey": false,
1534
- "notNull": true
1535
- },
1536
- "role": {
1537
- "name": "role",
1538
- "type": "text",
1539
- "primaryKey": false,
1540
- "notNull": true
1541
- },
1542
- "created_at": {
1543
- "name": "created_at",
1544
- "type": "timestamp",
1545
- "primaryKey": false,
1546
- "notNull": true,
1547
- "default": "now()"
1548
- }
1549
- },
1550
- "indexes": {},
1551
- "foreignKeys": {
1552
- "organization_members_organization_id_organizations_id_fk": {
1553
- "name": "organization_members_organization_id_organizations_id_fk",
1554
- "tableFrom": "organization_members",
1555
- "tableTo": "organizations",
1556
- "columnsFrom": [
1557
- "organization_id"
1558
- ],
1559
- "columnsTo": [
1560
- "id"
1561
- ],
1562
- "onDelete": "cascade",
1563
- "onUpdate": "no action"
1564
- },
1565
- "organization_members_user_id_user_id_fk": {
1566
- "name": "organization_members_user_id_user_id_fk",
1567
- "tableFrom": "organization_members",
1568
- "tableTo": "user",
1569
- "columnsFrom": [
1570
- "user_id"
1571
- ],
1572
- "columnsTo": [
1573
- "id"
1574
- ],
1575
- "onDelete": "cascade",
1576
- "onUpdate": "no action"
1577
- }
1578
- },
1579
- "compositePrimaryKeys": {
1580
- "organization_members_organization_id_user_id_pk": {
1581
- "name": "organization_members_organization_id_user_id_pk",
1582
- "columns": [
1583
- "organization_id",
1584
- "user_id"
1585
- ]
1586
- }
1587
- },
1588
- "uniqueConstraints": {},
1589
- "policies": {},
1590
- "checkConstraints": {},
1591
- "isRLSEnabled": false
1592
- },
1593
- "public.invitations": {
1594
- "name": "invitations",
1595
- "schema": "",
1596
- "columns": {
1597
- "id": {
1598
- "name": "id",
1599
- "type": "text",
1600
- "primaryKey": true,
1601
- "notNull": true
1602
- },
1603
- "organization_id": {
1604
- "name": "organization_id",
1605
- "type": "text",
1606
- "primaryKey": false,
1607
- "notNull": true
1608
- },
1609
- "email": {
1610
- "name": "email",
1611
- "type": "text",
1612
- "primaryKey": false,
1613
- "notNull": true
1614
- },
1615
- "role": {
1616
- "name": "role",
1617
- "type": "text",
1618
- "primaryKey": false,
1619
- "notNull": true
1620
- },
1621
- "token": {
1622
- "name": "token",
1623
- "type": "text",
1624
- "primaryKey": false,
1625
- "notNull": true
1626
- },
1627
- "expires_at": {
1628
- "name": "expires_at",
1629
- "type": "timestamp",
1630
- "primaryKey": false,
1631
- "notNull": true
1632
- },
1633
- "accepted_at": {
1634
- "name": "accepted_at",
1635
- "type": "timestamp",
1636
- "primaryKey": false,
1637
- "notNull": false
1638
- },
1639
- "created_at": {
1640
- "name": "created_at",
1641
- "type": "timestamp",
1642
- "primaryKey": false,
1643
- "notNull": true,
1644
- "default": "now()"
1645
- }
1646
- },
1647
- "indexes": {},
1648
- "foreignKeys": {
1649
- "invitations_organization_id_organizations_id_fk": {
1650
- "name": "invitations_organization_id_organizations_id_fk",
1651
- "tableFrom": "invitations",
1652
- "tableTo": "organizations",
1653
- "columnsFrom": [
1654
- "organization_id"
1655
- ],
1656
- "columnsTo": [
1657
- "id"
1658
- ],
1659
- "onDelete": "cascade",
1660
- "onUpdate": "no action"
1661
- }
1662
- },
1663
- "compositePrimaryKeys": {},
1664
- "uniqueConstraints": {
1665
- "invitations_token_unique": {
1666
- "name": "invitations_token_unique",
1667
- "nullsNotDistinct": false,
1668
- "columns": [
1669
- "token"
1670
- ]
1671
- }
1672
- },
1673
- "policies": {},
1674
- "checkConstraints": {},
1675
- "isRLSEnabled": false
1676
- },
1677
- "public.votes": {
1678
- "name": "votes",
1679
- "schema": "",
1680
- "columns": {
1681
- "voteId": {
1682
- "name": "voteId",
1683
- "type": "serial",
1684
- "primaryKey": true,
1685
- "notNull": true
1686
- },
1687
- "feedbackId": {
1688
- "name": "feedbackId",
1689
- "type": "serial",
1690
- "primaryKey": false,
1691
- "notNull": true
1692
- },
1693
- "visitorId": {
1694
- "name": "visitorId",
1695
- "type": "text",
1696
- "primaryKey": false,
1697
- "notNull": false
1698
- },
1699
- "userId": {
1700
- "name": "userId",
1701
- "type": "text",
1702
- "primaryKey": false,
1703
- "notNull": false
1704
- },
1705
- "createdAt": {
1706
- "name": "createdAt",
1707
- "type": "timestamp",
1708
- "primaryKey": false,
1709
- "notNull": true,
1710
- "default": "now()"
1711
- }
1712
- },
1713
- "indexes": {
1714
- "idx_votes_feedbackId": {
1715
- "name": "idx_votes_feedbackId",
1716
- "columns": [
1717
- {
1718
- "expression": "feedbackId",
1719
- "isExpression": false,
1720
- "asc": true,
1721
- "nulls": "last"
1722
- }
1723
- ],
1724
- "isUnique": false,
1725
- "concurrently": false,
1726
- "method": "btree",
1727
- "with": {}
1728
- },
1729
- "idx_votes_userId": {
1730
- "name": "idx_votes_userId",
1731
- "columns": [
1732
- {
1733
- "expression": "userId",
1734
- "isExpression": false,
1735
- "asc": true,
1736
- "nulls": "last"
1737
- }
1738
- ],
1739
- "isUnique": false,
1740
- "concurrently": false,
1741
- "method": "btree",
1742
- "with": {}
1743
- }
1744
- },
1745
- "foreignKeys": {
1746
- "votes_feedbackId_feedback_feedbackId_fk": {
1747
- "name": "votes_feedbackId_feedback_feedbackId_fk",
1748
- "tableFrom": "votes",
1749
- "tableTo": "feedback",
1750
- "columnsFrom": [
1751
- "feedbackId"
1752
- ],
1753
- "columnsTo": [
1754
- "feedbackId"
1755
- ],
1756
- "onDelete": "cascade",
1757
- "onUpdate": "no action"
1758
- },
1759
- "votes_userId_user_id_fk": {
1760
- "name": "votes_userId_user_id_fk",
1761
- "tableFrom": "votes",
1762
- "tableTo": "user",
1763
- "columnsFrom": [
1764
- "userId"
1765
- ],
1766
- "columnsTo": [
1767
- "id"
1768
- ],
1769
- "onDelete": "set null",
1770
- "onUpdate": "no action"
1771
- }
1772
- },
1773
- "compositePrimaryKeys": {},
1774
- "uniqueConstraints": {
1775
- "unique_vote": {
1776
- "name": "unique_vote",
1777
- "nullsNotDistinct": false,
1778
- "columns": [
1779
- "feedbackId",
1780
- "visitorId"
1781
- ]
1782
- }
1783
- },
1784
- "policies": {},
1785
- "checkConstraints": {},
1786
- "isRLSEnabled": false
1787
- },
1788
- "public.status_history": {
1789
- "name": "status_history",
1790
- "schema": "",
1791
- "columns": {
1792
- "historyId": {
1793
- "name": "historyId",
1794
- "type": "serial",
1795
- "primaryKey": true,
1796
- "notNull": true
1797
- },
1798
- "feedbackId": {
1799
- "name": "feedbackId",
1800
- "type": "integer",
1801
- "primaryKey": false,
1802
- "notNull": true
1803
- },
1804
- "oldStatus": {
1805
- "name": "oldStatus",
1806
- "type": "text",
1807
- "primaryKey": false,
1808
- "notNull": true
1809
- },
1810
- "newStatus": {
1811
- "name": "newStatus",
1812
- "type": "text",
1813
- "primaryKey": false,
1814
- "notNull": true
1815
- },
1816
- "changedBy": {
1817
- "name": "changedBy",
1818
- "type": "text",
1819
- "primaryKey": false,
1820
- "notNull": false
1821
- },
1822
- "changedAt": {
1823
- "name": "changedAt",
1824
- "type": "timestamp",
1825
- "primaryKey": false,
1826
- "notNull": true,
1827
- "default": "now()"
1828
- },
1829
- "comment": {
1830
- "name": "comment",
1831
- "type": "text",
1832
- "primaryKey": false,
1833
- "notNull": false
1834
- }
1835
- },
1836
- "indexes": {
1837
- "idx_status_history_feedbackId": {
1838
- "name": "idx_status_history_feedbackId",
1839
- "columns": [
1840
- {
1841
- "expression": "feedbackId",
1842
- "isExpression": false,
1843
- "asc": true,
1844
- "nulls": "last"
1845
- }
1846
- ],
1847
- "isUnique": false,
1848
- "concurrently": false,
1849
- "method": "btree",
1850
- "with": {}
1851
- },
1852
- "idx_status_history_changedAt": {
1853
- "name": "idx_status_history_changedAt",
1854
- "columns": [
1855
- {
1856
- "expression": "changedAt",
1857
- "isExpression": false,
1858
- "asc": true,
1859
- "nulls": "last"
1860
- }
1861
- ],
1862
- "isUnique": false,
1863
- "concurrently": false,
1864
- "method": "btree",
1865
- "with": {}
1866
- }
1867
- },
1868
- "foreignKeys": {
1869
- "status_history_feedbackId_feedback_feedbackId_fk": {
1870
- "name": "status_history_feedbackId_feedback_feedbackId_fk",
1871
- "tableFrom": "status_history",
1872
- "tableTo": "feedback",
1873
- "columnsFrom": [
1874
- "feedbackId"
1875
- ],
1876
- "columnsTo": [
1877
- "feedbackId"
1878
- ],
1879
- "onDelete": "cascade",
1880
- "onUpdate": "no action"
1881
- },
1882
- "status_history_changedBy_user_id_fk": {
1883
- "name": "status_history_changedBy_user_id_fk",
1884
- "tableFrom": "status_history",
1885
- "tableTo": "user",
1886
- "columnsFrom": [
1887
- "changedBy"
1888
- ],
1889
- "columnsTo": [
1890
- "id"
1891
- ],
1892
- "onDelete": "set null",
1893
- "onUpdate": "no action"
1894
- }
1895
- },
1896
- "compositePrimaryKeys": {},
1897
- "uniqueConstraints": {},
1898
- "policies": {},
1899
- "checkConstraints": {},
1900
- "isRLSEnabled": false
1901
- },
1902
- "public.projects": {
1903
- "name": "projects",
1904
- "schema": "",
1905
- "columns": {
1906
- "projectId": {
1907
- "name": "projectId",
1908
- "type": "uuid",
1909
- "primaryKey": true,
1910
- "notNull": true,
1911
- "default": "gen_random_uuid()"
1912
- },
1913
- "organizationId": {
1914
- "name": "organizationId",
1915
- "type": "text",
1916
- "primaryKey": false,
1917
- "notNull": true
1918
- },
1919
- "name": {
1920
- "name": "name",
1921
- "type": "text",
1922
- "primaryKey": false,
1923
- "notNull": true
1924
- },
1925
- "slug": {
1926
- "name": "slug",
1927
- "type": "text",
1928
- "primaryKey": false,
1929
- "notNull": true
1930
- },
1931
- "description": {
1932
- "name": "description",
1933
- "type": "text",
1934
- "primaryKey": false,
1935
- "notNull": false
1936
- },
1937
- "widgetConfig": {
1938
- "name": "widgetConfig",
1939
- "type": "jsonb",
1940
- "primaryKey": false,
1941
- "notNull": false
1942
- },
1943
- "portalConfig": {
1944
- "name": "portalConfig",
1945
- "type": "jsonb",
1946
- "primaryKey": false,
1947
- "notNull": false
1948
- },
1949
- "customDomain": {
1950
- "name": "customDomain",
1951
- "type": "text",
1952
- "primaryKey": false,
1953
- "notNull": false
1954
- },
1955
- "createdAt": {
1956
- "name": "createdAt",
1957
- "type": "timestamp",
1958
- "primaryKey": false,
1959
- "notNull": true,
1960
- "default": "now()"
1961
- },
1962
- "updatedAt": {
1963
- "name": "updatedAt",
1964
- "type": "timestamp",
1965
- "primaryKey": false,
1966
- "notNull": true,
1967
- "default": "now()"
1968
- }
1969
- },
1970
- "indexes": {
1971
- "idx_projects_orgId": {
1972
- "name": "idx_projects_orgId",
1973
- "columns": [
1974
- {
1975
- "expression": "organizationId",
1976
- "isExpression": false,
1977
- "asc": true,
1978
- "nulls": "last"
1979
- }
1980
- ],
1981
- "isUnique": false,
1982
- "concurrently": false,
1983
- "method": "btree",
1984
- "with": {}
1985
- }
1986
- },
1987
- "foreignKeys": {
1988
- "projects_organizationId_organizations_id_fk": {
1989
- "name": "projects_organizationId_organizations_id_fk",
1990
- "tableFrom": "projects",
1991
- "tableTo": "organizations",
1992
- "columnsFrom": [
1993
- "organizationId"
1994
- ],
1995
- "columnsTo": [
1996
- "id"
1997
- ],
1998
- "onDelete": "cascade",
1999
- "onUpdate": "no action"
2000
- }
2001
- },
2002
- "compositePrimaryKeys": {},
2003
- "uniqueConstraints": {
2004
- "unique_slug_org": {
2005
- "name": "unique_slug_org",
2006
- "nullsNotDistinct": false,
2007
- "columns": [
2008
- "slug",
2009
- "organizationId"
2010
- ]
2011
- },
2012
- "unique_custom_domain": {
2013
- "name": "unique_custom_domain",
2014
- "nullsNotDistinct": false,
2015
- "columns": [
2016
- "customDomain"
2017
- ]
2018
- }
2019
- },
2020
- "policies": {},
2021
- "checkConstraints": {},
2022
- "isRLSEnabled": false
2023
- },
2024
- "public.notification_preferences": {
2025
- "name": "notification_preferences",
2026
- "schema": "",
2027
- "columns": {
2028
- "userId": {
2029
- "name": "userId",
2030
- "type": "text",
2031
- "primaryKey": true,
2032
- "notNull": true
2033
- },
2034
- "statusChange": {
2035
- "name": "statusChange",
2036
- "type": "boolean",
2037
- "primaryKey": false,
2038
- "notNull": true,
2039
- "default": true
2040
- },
2041
- "newComment": {
2042
- "name": "newComment",
2043
- "type": "boolean",
2044
- "primaryKey": false,
2045
- "notNull": true,
2046
- "default": true
2047
- },
2048
- "updatedAt": {
2049
- "name": "updatedAt",
2050
- "type": "timestamp",
2051
- "primaryKey": false,
2052
- "notNull": true,
2053
- "default": "now()"
2054
- }
2055
- },
2056
- "indexes": {},
2057
- "foreignKeys": {
2058
- "notification_preferences_userId_user_id_fk": {
2059
- "name": "notification_preferences_userId_user_id_fk",
2060
- "tableFrom": "notification_preferences",
2061
- "tableTo": "user",
2062
- "columnsFrom": [
2063
- "userId"
2064
- ],
2065
- "columnsTo": [
2066
- "id"
2067
- ],
2068
- "onDelete": "cascade",
2069
- "onUpdate": "no action"
2070
- }
2071
- },
2072
- "compositePrimaryKeys": {},
2073
- "uniqueConstraints": {},
2074
- "policies": {},
2075
- "checkConstraints": {},
2076
- "isRLSEnabled": false
2077
- },
2078
- "public.notifications": {
2079
- "name": "notifications",
2080
- "schema": "",
2081
- "columns": {
2082
- "notificationId": {
2083
- "name": "notificationId",
2084
- "type": "serial",
2085
- "primaryKey": true,
2086
- "notNull": true
2087
- },
2088
- "userId": {
2089
- "name": "userId",
2090
- "type": "text",
2091
- "primaryKey": false,
2092
- "notNull": true
2093
- },
2094
- "type": {
2095
- "name": "type",
2096
- "type": "text",
2097
- "primaryKey": false,
2098
- "notNull": true
2099
- },
2100
- "feedbackId": {
2101
- "name": "feedbackId",
2102
- "type": "serial",
2103
- "primaryKey": false,
2104
- "notNull": true
2105
- },
2106
- "data": {
2107
- "name": "data",
2108
- "type": "jsonb",
2109
- "primaryKey": false,
2110
- "notNull": false
2111
- },
2112
- "status": {
2113
- "name": "status",
2114
- "type": "text",
2115
- "primaryKey": false,
2116
- "notNull": true,
2117
- "default": "'pending'"
2118
- },
2119
- "sentAt": {
2120
- "name": "sentAt",
2121
- "type": "timestamp",
2122
- "primaryKey": false,
2123
- "notNull": false
2124
- },
2125
- "error": {
2126
- "name": "error",
2127
- "type": "text",
2128
- "primaryKey": false,
2129
- "notNull": false
2130
- },
2131
- "createdAt": {
2132
- "name": "createdAt",
2133
- "type": "timestamp",
2134
- "primaryKey": false,
2135
- "notNull": true,
2136
- "default": "now()"
2137
- }
2138
- },
2139
- "indexes": {
2140
- "idx_notifications_userId": {
2141
- "name": "idx_notifications_userId",
2142
- "columns": [
2143
- {
2144
- "expression": "userId",
2145
- "isExpression": false,
2146
- "asc": true,
2147
- "nulls": "last"
2148
- }
2149
- ],
2150
- "isUnique": false,
2151
- "concurrently": false,
2152
- "method": "btree",
2153
- "with": {}
2154
- },
2155
- "idx_notifications_status": {
2156
- "name": "idx_notifications_status",
2157
- "columns": [
2158
- {
2159
- "expression": "status",
2160
- "isExpression": false,
2161
- "asc": true,
2162
- "nulls": "last"
2163
- }
2164
- ],
2165
- "isUnique": false,
2166
- "concurrently": false,
2167
- "method": "btree",
2168
- "with": {}
2169
- },
2170
- "idx_notifications_type": {
2171
- "name": "idx_notifications_type",
2172
- "columns": [
2173
- {
2174
- "expression": "type",
2175
- "isExpression": false,
2176
- "asc": true,
2177
- "nulls": "last"
2178
- }
2179
- ],
2180
- "isUnique": false,
2181
- "concurrently": false,
2182
- "method": "btree",
2183
- "with": {}
2184
- }
2185
- },
2186
- "foreignKeys": {
2187
- "notifications_userId_user_id_fk": {
2188
- "name": "notifications_userId_user_id_fk",
2189
- "tableFrom": "notifications",
2190
- "tableTo": "user",
2191
- "columnsFrom": [
2192
- "userId"
2193
- ],
2194
- "columnsTo": [
2195
- "id"
2196
- ],
2197
- "onDelete": "cascade",
2198
- "onUpdate": "no action"
2199
- },
2200
- "notifications_feedbackId_feedback_feedbackId_fk": {
2201
- "name": "notifications_feedbackId_feedback_feedbackId_fk",
2202
- "tableFrom": "notifications",
2203
- "tableTo": "feedback",
2204
- "columnsFrom": [
2205
- "feedbackId"
2206
- ],
2207
- "columnsTo": [
2208
- "feedbackId"
2209
- ],
2210
- "onDelete": "cascade",
2211
- "onUpdate": "no action"
2212
- }
2213
- },
2214
- "compositePrimaryKeys": {},
2215
- "uniqueConstraints": {},
2216
- "policies": {},
2217
- "checkConstraints": {},
2218
- "isRLSEnabled": false
2219
- },
2220
- "public.feedback_tags": {
2221
- "name": "feedback_tags",
2222
- "schema": "",
2223
- "columns": {
2224
- "id": {
2225
- "name": "id",
2226
- "type": "serial",
2227
- "primaryKey": true,
2228
- "notNull": true
2229
- },
2230
- "feedbackId": {
2231
- "name": "feedbackId",
2232
- "type": "integer",
2233
- "primaryKey": false,
2234
- "notNull": true
2235
- },
2236
- "tagId": {
2237
- "name": "tagId",
2238
- "type": "integer",
2239
- "primaryKey": false,
2240
- "notNull": true
2241
- },
2242
- "createdAt": {
2243
- "name": "createdAt",
2244
- "type": "timestamp",
2245
- "primaryKey": false,
2246
- "notNull": true,
2247
- "default": "now()"
2248
- }
2249
- },
2250
- "indexes": {
2251
- "idx_feedback_tags_feedbackId": {
2252
- "name": "idx_feedback_tags_feedbackId",
2253
- "columns": [
2254
- {
2255
- "expression": "feedbackId",
2256
- "isExpression": false,
2257
- "asc": true,
2258
- "nulls": "last"
2259
- }
2260
- ],
2261
- "isUnique": false,
2262
- "concurrently": false,
2263
- "method": "btree",
2264
- "with": {}
2265
- },
2266
- "idx_feedback_tags_tagId": {
2267
- "name": "idx_feedback_tags_tagId",
2268
- "columns": [
2269
- {
2270
- "expression": "tagId",
2271
- "isExpression": false,
2272
- "asc": true,
2273
- "nulls": "last"
2274
- }
2275
- ],
2276
- "isUnique": false,
2277
- "concurrently": false,
2278
- "method": "btree",
2279
- "with": {}
2280
- },
2281
- "idx_feedback_tags_unique": {
2282
- "name": "idx_feedback_tags_unique",
2283
- "columns": [
2284
- {
2285
- "expression": "feedbackId",
2286
- "isExpression": false,
2287
- "asc": true,
2288
- "nulls": "last"
2289
- },
2290
- {
2291
- "expression": "tagId",
2292
- "isExpression": false,
2293
- "asc": true,
2294
- "nulls": "last"
2295
- }
2296
- ],
2297
- "isUnique": false,
2298
- "concurrently": false,
2299
- "method": "btree",
2300
- "with": {}
2301
- }
2302
- },
2303
- "foreignKeys": {
2304
- "feedback_tags_feedbackId_feedback_feedbackId_fk": {
2305
- "name": "feedback_tags_feedbackId_feedback_feedbackId_fk",
2306
- "tableFrom": "feedback_tags",
2307
- "tableTo": "feedback",
2308
- "columnsFrom": [
2309
- "feedbackId"
2310
- ],
2311
- "columnsTo": [
2312
- "feedbackId"
2313
- ],
2314
- "onDelete": "cascade",
2315
- "onUpdate": "no action"
2316
- },
2317
- "feedback_tags_tagId_tags_tagId_fk": {
2318
- "name": "feedback_tags_tagId_tags_tagId_fk",
2319
- "tableFrom": "feedback_tags",
2320
- "tableTo": "tags",
2321
- "columnsFrom": [
2322
- "tagId"
2323
- ],
2324
- "columnsTo": [
2325
- "tagId"
2326
- ],
2327
- "onDelete": "cascade",
2328
- "onUpdate": "no action"
2329
- }
2330
- },
2331
- "compositePrimaryKeys": {},
2332
- "uniqueConstraints": {},
2333
- "policies": {},
2334
- "checkConstraints": {},
2335
- "isRLSEnabled": false
2336
- },
2337
- "public.tags": {
2338
- "name": "tags",
2339
- "schema": "",
2340
- "columns": {
2341
- "tagId": {
2342
- "name": "tagId",
2343
- "type": "serial",
2344
- "primaryKey": true,
2345
- "notNull": true
2346
- },
2347
- "name": {
2348
- "name": "name",
2349
- "type": "text",
2350
- "primaryKey": false,
2351
- "notNull": true
2352
- },
2353
- "slug": {
2354
- "name": "slug",
2355
- "type": "text",
2356
- "primaryKey": false,
2357
- "notNull": true
2358
- },
2359
- "color": {
2360
- "name": "color",
2361
- "type": "text",
2362
- "primaryKey": false,
2363
- "notNull": false,
2364
- "default": "'#3b82f6'"
2365
- },
2366
- "description": {
2367
- "name": "description",
2368
- "type": "text",
2369
- "primaryKey": false,
2370
- "notNull": false
2371
- },
2372
- "createdAt": {
2373
- "name": "createdAt",
2374
- "type": "timestamp",
2375
- "primaryKey": false,
2376
- "notNull": true,
2377
- "default": "now()"
2378
- }
2379
- },
2380
- "indexes": {},
2381
- "foreignKeys": {},
2382
- "compositePrimaryKeys": {},
2383
- "uniqueConstraints": {
2384
- "tags_name_unique": {
2385
- "name": "tags_name_unique",
2386
- "nullsNotDistinct": false,
2387
- "columns": [
2388
- "name"
2389
- ]
2390
- },
2391
- "tags_slug_unique": {
2392
- "name": "tags_slug_unique",
2393
- "nullsNotDistinct": false,
2394
- "columns": [
2395
- "slug"
2396
- ]
2397
- }
2398
- },
2399
- "policies": {},
2400
- "checkConstraints": {},
2401
- "isRLSEnabled": false
2402
- },
2403
- "public.webhook_events": {
2404
- "name": "webhook_events",
2405
- "schema": "",
2406
- "columns": {
2407
- "eventId": {
2408
- "name": "eventId",
2409
- "type": "serial",
2410
- "primaryKey": true,
2411
- "notNull": true
2412
- },
2413
- "webhookId": {
2414
- "name": "webhookId",
2415
- "type": "integer",
2416
- "primaryKey": false,
2417
- "notNull": true
2418
- },
2419
- "eventType": {
2420
- "name": "eventType",
2421
- "type": "text",
2422
- "primaryKey": false,
2423
- "notNull": true
2424
- },
2425
- "payload": {
2426
- "name": "payload",
2427
- "type": "jsonb",
2428
- "primaryKey": false,
2429
- "notNull": true
2430
- },
2431
- "status": {
2432
- "name": "status",
2433
- "type": "text",
2434
- "primaryKey": false,
2435
- "notNull": true,
2436
- "default": "'pending'"
2437
- },
2438
- "responseStatus": {
2439
- "name": "responseStatus",
2440
- "type": "integer",
2441
- "primaryKey": false,
2442
- "notNull": false
2443
- },
2444
- "responseBody": {
2445
- "name": "responseBody",
2446
- "type": "text",
2447
- "primaryKey": false,
2448
- "notNull": false
2449
- },
2450
- "retryCount": {
2451
- "name": "retryCount",
2452
- "type": "integer",
2453
- "primaryKey": false,
2454
- "notNull": true,
2455
- "default": 0
2456
- },
2457
- "maxRetries": {
2458
- "name": "maxRetries",
2459
- "type": "integer",
2460
- "primaryKey": false,
2461
- "notNull": true,
2462
- "default": 3
2463
- },
2464
- "nextRetryAt": {
2465
- "name": "nextRetryAt",
2466
- "type": "timestamp",
2467
- "primaryKey": false,
2468
- "notNull": false
2469
- },
2470
- "deliveredAt": {
2471
- "name": "deliveredAt",
2472
- "type": "timestamp",
2473
- "primaryKey": false,
2474
- "notNull": false
2475
- },
2476
- "createdAt": {
2477
- "name": "createdAt",
2478
- "type": "timestamp",
2479
- "primaryKey": false,
2480
- "notNull": true,
2481
- "default": "now()"
2482
- },
2483
- "updatedAt": {
2484
- "name": "updatedAt",
2485
- "type": "timestamp",
2486
- "primaryKey": false,
2487
- "notNull": true,
2488
- "default": "now()"
2489
- }
2490
- },
2491
- "indexes": {
2492
- "idx_webhook_events_webhookId": {
2493
- "name": "idx_webhook_events_webhookId",
2494
- "columns": [
2495
- {
2496
- "expression": "webhookId",
2497
- "isExpression": false,
2498
- "asc": true,
2499
- "nulls": "last"
2500
- }
2501
- ],
2502
- "isUnique": false,
2503
- "concurrently": false,
2504
- "method": "btree",
2505
- "with": {}
2506
- },
2507
- "idx_webhook_events_status": {
2508
- "name": "idx_webhook_events_status",
2509
- "columns": [
2510
- {
2511
- "expression": "status",
2512
- "isExpression": false,
2513
- "asc": true,
2514
- "nulls": "last"
2515
- }
2516
- ],
2517
- "isUnique": false,
2518
- "concurrently": false,
2519
- "method": "btree",
2520
- "with": {}
2521
- },
2522
- "idx_webhook_events_nextRetry": {
2523
- "name": "idx_webhook_events_nextRetry",
2524
- "columns": [
2525
- {
2526
- "expression": "nextRetryAt",
2527
- "isExpression": false,
2528
- "asc": true,
2529
- "nulls": "last"
2530
- }
2531
- ],
2532
- "isUnique": false,
2533
- "concurrently": false,
2534
- "method": "btree",
2535
- "with": {}
2536
- }
2537
- },
2538
- "foreignKeys": {
2539
- "webhook_events_webhookId_webhooks_webhookId_fk": {
2540
- "name": "webhook_events_webhookId_webhooks_webhookId_fk",
2541
- "tableFrom": "webhook_events",
2542
- "tableTo": "webhooks",
2543
- "columnsFrom": [
2544
- "webhookId"
2545
- ],
2546
- "columnsTo": [
2547
- "webhookId"
2548
- ],
2549
- "onDelete": "cascade",
2550
- "onUpdate": "no action"
2551
- }
2552
- },
2553
- "compositePrimaryKeys": {},
2554
- "uniqueConstraints": {},
2555
- "policies": {},
2556
- "checkConstraints": {},
2557
- "isRLSEnabled": false
2558
- },
2559
- "public.webhooks": {
2560
- "name": "webhooks",
2561
- "schema": "",
2562
- "columns": {
2563
- "webhookId": {
2564
- "name": "webhookId",
2565
- "type": "serial",
2566
- "primaryKey": true,
2567
- "notNull": true
2568
- },
2569
- "organizationId": {
2570
- "name": "organizationId",
2571
- "type": "text",
2572
- "primaryKey": false,
2573
- "notNull": true
2574
- },
2575
- "name": {
2576
- "name": "name",
2577
- "type": "text",
2578
- "primaryKey": false,
2579
- "notNull": true
2580
- },
2581
- "url": {
2582
- "name": "url",
2583
- "type": "text",
2584
- "primaryKey": false,
2585
- "notNull": true
2586
- },
2587
- "secret": {
2588
- "name": "secret",
2589
- "type": "text",
2590
- "primaryKey": false,
2591
- "notNull": false
2592
- },
2593
- "events": {
2594
- "name": "events",
2595
- "type": "jsonb",
2596
- "primaryKey": false,
2597
- "notNull": true
2598
- },
2599
- "enabled": {
2600
- "name": "enabled",
2601
- "type": "boolean",
2602
- "primaryKey": false,
2603
- "notNull": true,
2604
- "default": true
2605
- },
2606
- "createdAt": {
2607
- "name": "createdAt",
2608
- "type": "timestamp",
2609
- "primaryKey": false,
2610
- "notNull": true,
2611
- "default": "now()"
2612
- },
2613
- "updatedAt": {
2614
- "name": "updatedAt",
2615
- "type": "timestamp",
2616
- "primaryKey": false,
2617
- "notNull": true,
2618
- "default": "now()"
2619
- }
2620
- },
2621
- "indexes": {
2622
- "idx_webhooks_orgId": {
2623
- "name": "idx_webhooks_orgId",
2624
- "columns": [
2625
- {
2626
- "expression": "organizationId",
2627
- "isExpression": false,
2628
- "asc": true,
2629
- "nulls": "last"
2630
- }
2631
- ],
2632
- "isUnique": false,
2633
- "concurrently": false,
2634
- "method": "btree",
2635
- "with": {}
2636
- },
2637
- "idx_webhooks_enabled": {
2638
- "name": "idx_webhooks_enabled",
2639
- "columns": [
2640
- {
2641
- "expression": "enabled",
2642
- "isExpression": false,
2643
- "asc": true,
2644
- "nulls": "last"
2645
- }
2646
- ],
2647
- "isUnique": false,
2648
- "concurrently": false,
2649
- "method": "btree",
2650
- "with": {}
2651
- }
2652
- },
2653
- "foreignKeys": {
2654
- "webhooks_organizationId_organizations_id_fk": {
2655
- "name": "webhooks_organizationId_organizations_id_fk",
2656
- "tableFrom": "webhooks",
2657
- "tableTo": "organizations",
2658
- "columnsFrom": [
2659
- "organizationId"
2660
- ],
2661
- "columnsTo": [
2662
- "id"
2663
- ],
2664
- "onDelete": "cascade",
2665
- "onUpdate": "no action"
2666
- }
2667
- },
2668
- "compositePrimaryKeys": {},
2669
- "uniqueConstraints": {},
2670
- "policies": {},
2671
- "checkConstraints": {},
2672
- "isRLSEnabled": false
2673
- }
2674
- },
2675
- "enums": {},
2676
- "schemas": {},
2677
- "sequences": {},
2678
- "roles": {},
2679
- "policies": {},
2680
- "views": {},
2681
- "_meta": {
2682
- "columns": {},
2683
- "schemas": {},
2684
- "tables": {}
2685
- }
2686
- }