@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,2741 +0,0 @@
1
- {
2
- "id": "4e71e1f3-35b0-4b05-a54e-b600a0908570",
3
- "prevId": "7ff1bc50-1728-4f71-9fb4-bb94c2e7c7e9",
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
- "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_settings": {
1487
- "name": "organization_settings",
1488
- "schema": "",
1489
- "columns": {
1490
- "organizationId": {
1491
- "name": "organizationId",
1492
- "type": "text",
1493
- "primaryKey": true,
1494
- "notNull": true
1495
- },
1496
- "widgetConfig": {
1497
- "name": "widgetConfig",
1498
- "type": "jsonb",
1499
- "primaryKey": false,
1500
- "notNull": false
1501
- },
1502
- "portalConfig": {
1503
- "name": "portalConfig",
1504
- "type": "jsonb",
1505
- "primaryKey": false,
1506
- "notNull": false
1507
- },
1508
- "customDomain": {
1509
- "name": "customDomain",
1510
- "type": "text",
1511
- "primaryKey": false,
1512
- "notNull": false
1513
- },
1514
- "createdAt": {
1515
- "name": "createdAt",
1516
- "type": "timestamp",
1517
- "primaryKey": false,
1518
- "notNull": true,
1519
- "default": "now()"
1520
- },
1521
- "updatedAt": {
1522
- "name": "updatedAt",
1523
- "type": "timestamp",
1524
- "primaryKey": false,
1525
- "notNull": true,
1526
- "default": "now()"
1527
- }
1528
- },
1529
- "indexes": {
1530
- "idx_org_settings_orgId": {
1531
- "name": "idx_org_settings_orgId",
1532
- "columns": [
1533
- {
1534
- "expression": "organizationId",
1535
- "isExpression": false,
1536
- "asc": true,
1537
- "nulls": "last"
1538
- }
1539
- ],
1540
- "isUnique": false,
1541
- "concurrently": false,
1542
- "method": "btree",
1543
- "with": {}
1544
- }
1545
- },
1546
- "foreignKeys": {
1547
- "organization_settings_organizationId_organizations_id_fk": {
1548
- "name": "organization_settings_organizationId_organizations_id_fk",
1549
- "tableFrom": "organization_settings",
1550
- "tableTo": "organizations",
1551
- "columnsFrom": [
1552
- "organizationId"
1553
- ],
1554
- "columnsTo": [
1555
- "id"
1556
- ],
1557
- "onDelete": "cascade",
1558
- "onUpdate": "no action"
1559
- }
1560
- },
1561
- "compositePrimaryKeys": {},
1562
- "uniqueConstraints": {
1563
- "unique_org_custom_domain": {
1564
- "name": "unique_org_custom_domain",
1565
- "nullsNotDistinct": false,
1566
- "columns": [
1567
- "customDomain"
1568
- ]
1569
- }
1570
- },
1571
- "policies": {},
1572
- "checkConstraints": {},
1573
- "isRLSEnabled": false
1574
- },
1575
- "public.organization_members": {
1576
- "name": "organization_members",
1577
- "schema": "",
1578
- "columns": {
1579
- "organization_id": {
1580
- "name": "organization_id",
1581
- "type": "text",
1582
- "primaryKey": false,
1583
- "notNull": true
1584
- },
1585
- "user_id": {
1586
- "name": "user_id",
1587
- "type": "text",
1588
- "primaryKey": false,
1589
- "notNull": true
1590
- },
1591
- "role": {
1592
- "name": "role",
1593
- "type": "text",
1594
- "primaryKey": false,
1595
- "notNull": true
1596
- },
1597
- "created_at": {
1598
- "name": "created_at",
1599
- "type": "timestamp",
1600
- "primaryKey": false,
1601
- "notNull": true,
1602
- "default": "now()"
1603
- }
1604
- },
1605
- "indexes": {},
1606
- "foreignKeys": {
1607
- "organization_members_organization_id_organizations_id_fk": {
1608
- "name": "organization_members_organization_id_organizations_id_fk",
1609
- "tableFrom": "organization_members",
1610
- "tableTo": "organizations",
1611
- "columnsFrom": [
1612
- "organization_id"
1613
- ],
1614
- "columnsTo": [
1615
- "id"
1616
- ],
1617
- "onDelete": "cascade",
1618
- "onUpdate": "no action"
1619
- },
1620
- "organization_members_user_id_user_id_fk": {
1621
- "name": "organization_members_user_id_user_id_fk",
1622
- "tableFrom": "organization_members",
1623
- "tableTo": "user",
1624
- "columnsFrom": [
1625
- "user_id"
1626
- ],
1627
- "columnsTo": [
1628
- "id"
1629
- ],
1630
- "onDelete": "cascade",
1631
- "onUpdate": "no action"
1632
- }
1633
- },
1634
- "compositePrimaryKeys": {
1635
- "organization_members_organization_id_user_id_pk": {
1636
- "name": "organization_members_organization_id_user_id_pk",
1637
- "columns": [
1638
- "organization_id",
1639
- "user_id"
1640
- ]
1641
- }
1642
- },
1643
- "uniqueConstraints": {},
1644
- "policies": {},
1645
- "checkConstraints": {},
1646
- "isRLSEnabled": false
1647
- },
1648
- "public.invitations": {
1649
- "name": "invitations",
1650
- "schema": "",
1651
- "columns": {
1652
- "id": {
1653
- "name": "id",
1654
- "type": "text",
1655
- "primaryKey": true,
1656
- "notNull": true
1657
- },
1658
- "organization_id": {
1659
- "name": "organization_id",
1660
- "type": "text",
1661
- "primaryKey": false,
1662
- "notNull": true
1663
- },
1664
- "email": {
1665
- "name": "email",
1666
- "type": "text",
1667
- "primaryKey": false,
1668
- "notNull": true
1669
- },
1670
- "role": {
1671
- "name": "role",
1672
- "type": "text",
1673
- "primaryKey": false,
1674
- "notNull": true
1675
- },
1676
- "token": {
1677
- "name": "token",
1678
- "type": "text",
1679
- "primaryKey": false,
1680
- "notNull": true
1681
- },
1682
- "expires_at": {
1683
- "name": "expires_at",
1684
- "type": "timestamp",
1685
- "primaryKey": false,
1686
- "notNull": true
1687
- },
1688
- "accepted_at": {
1689
- "name": "accepted_at",
1690
- "type": "timestamp",
1691
- "primaryKey": false,
1692
- "notNull": false
1693
- },
1694
- "created_at": {
1695
- "name": "created_at",
1696
- "type": "timestamp",
1697
- "primaryKey": false,
1698
- "notNull": true,
1699
- "default": "now()"
1700
- }
1701
- },
1702
- "indexes": {},
1703
- "foreignKeys": {
1704
- "invitations_organization_id_organizations_id_fk": {
1705
- "name": "invitations_organization_id_organizations_id_fk",
1706
- "tableFrom": "invitations",
1707
- "tableTo": "organizations",
1708
- "columnsFrom": [
1709
- "organization_id"
1710
- ],
1711
- "columnsTo": [
1712
- "id"
1713
- ],
1714
- "onDelete": "cascade",
1715
- "onUpdate": "no action"
1716
- }
1717
- },
1718
- "compositePrimaryKeys": {},
1719
- "uniqueConstraints": {
1720
- "invitations_token_unique": {
1721
- "name": "invitations_token_unique",
1722
- "nullsNotDistinct": false,
1723
- "columns": [
1724
- "token"
1725
- ]
1726
- }
1727
- },
1728
- "policies": {},
1729
- "checkConstraints": {},
1730
- "isRLSEnabled": false
1731
- },
1732
- "public.votes": {
1733
- "name": "votes",
1734
- "schema": "",
1735
- "columns": {
1736
- "voteId": {
1737
- "name": "voteId",
1738
- "type": "serial",
1739
- "primaryKey": true,
1740
- "notNull": true
1741
- },
1742
- "feedbackId": {
1743
- "name": "feedbackId",
1744
- "type": "serial",
1745
- "primaryKey": false,
1746
- "notNull": true
1747
- },
1748
- "visitorId": {
1749
- "name": "visitorId",
1750
- "type": "text",
1751
- "primaryKey": false,
1752
- "notNull": false
1753
- },
1754
- "userId": {
1755
- "name": "userId",
1756
- "type": "text",
1757
- "primaryKey": false,
1758
- "notNull": false
1759
- },
1760
- "createdAt": {
1761
- "name": "createdAt",
1762
- "type": "timestamp",
1763
- "primaryKey": false,
1764
- "notNull": true,
1765
- "default": "now()"
1766
- }
1767
- },
1768
- "indexes": {
1769
- "idx_votes_feedbackId": {
1770
- "name": "idx_votes_feedbackId",
1771
- "columns": [
1772
- {
1773
- "expression": "feedbackId",
1774
- "isExpression": false,
1775
- "asc": true,
1776
- "nulls": "last"
1777
- }
1778
- ],
1779
- "isUnique": false,
1780
- "concurrently": false,
1781
- "method": "btree",
1782
- "with": {}
1783
- },
1784
- "idx_votes_userId": {
1785
- "name": "idx_votes_userId",
1786
- "columns": [
1787
- {
1788
- "expression": "userId",
1789
- "isExpression": false,
1790
- "asc": true,
1791
- "nulls": "last"
1792
- }
1793
- ],
1794
- "isUnique": false,
1795
- "concurrently": false,
1796
- "method": "btree",
1797
- "with": {}
1798
- }
1799
- },
1800
- "foreignKeys": {
1801
- "votes_feedbackId_feedback_feedbackId_fk": {
1802
- "name": "votes_feedbackId_feedback_feedbackId_fk",
1803
- "tableFrom": "votes",
1804
- "tableTo": "feedback",
1805
- "columnsFrom": [
1806
- "feedbackId"
1807
- ],
1808
- "columnsTo": [
1809
- "feedbackId"
1810
- ],
1811
- "onDelete": "cascade",
1812
- "onUpdate": "no action"
1813
- },
1814
- "votes_userId_user_id_fk": {
1815
- "name": "votes_userId_user_id_fk",
1816
- "tableFrom": "votes",
1817
- "tableTo": "user",
1818
- "columnsFrom": [
1819
- "userId"
1820
- ],
1821
- "columnsTo": [
1822
- "id"
1823
- ],
1824
- "onDelete": "set null",
1825
- "onUpdate": "no action"
1826
- }
1827
- },
1828
- "compositePrimaryKeys": {},
1829
- "uniqueConstraints": {
1830
- "unique_vote": {
1831
- "name": "unique_vote",
1832
- "nullsNotDistinct": false,
1833
- "columns": [
1834
- "feedbackId",
1835
- "visitorId"
1836
- ]
1837
- }
1838
- },
1839
- "policies": {},
1840
- "checkConstraints": {},
1841
- "isRLSEnabled": false
1842
- },
1843
- "public.status_history": {
1844
- "name": "status_history",
1845
- "schema": "",
1846
- "columns": {
1847
- "historyId": {
1848
- "name": "historyId",
1849
- "type": "serial",
1850
- "primaryKey": true,
1851
- "notNull": true
1852
- },
1853
- "feedbackId": {
1854
- "name": "feedbackId",
1855
- "type": "integer",
1856
- "primaryKey": false,
1857
- "notNull": true
1858
- },
1859
- "oldStatus": {
1860
- "name": "oldStatus",
1861
- "type": "text",
1862
- "primaryKey": false,
1863
- "notNull": true
1864
- },
1865
- "newStatus": {
1866
- "name": "newStatus",
1867
- "type": "text",
1868
- "primaryKey": false,
1869
- "notNull": true
1870
- },
1871
- "changedBy": {
1872
- "name": "changedBy",
1873
- "type": "text",
1874
- "primaryKey": false,
1875
- "notNull": false
1876
- },
1877
- "changedAt": {
1878
- "name": "changedAt",
1879
- "type": "timestamp",
1880
- "primaryKey": false,
1881
- "notNull": true,
1882
- "default": "now()"
1883
- },
1884
- "comment": {
1885
- "name": "comment",
1886
- "type": "text",
1887
- "primaryKey": false,
1888
- "notNull": false
1889
- }
1890
- },
1891
- "indexes": {
1892
- "idx_status_history_feedbackId": {
1893
- "name": "idx_status_history_feedbackId",
1894
- "columns": [
1895
- {
1896
- "expression": "feedbackId",
1897
- "isExpression": false,
1898
- "asc": true,
1899
- "nulls": "last"
1900
- }
1901
- ],
1902
- "isUnique": false,
1903
- "concurrently": false,
1904
- "method": "btree",
1905
- "with": {}
1906
- },
1907
- "idx_status_history_changedAt": {
1908
- "name": "idx_status_history_changedAt",
1909
- "columns": [
1910
- {
1911
- "expression": "changedAt",
1912
- "isExpression": false,
1913
- "asc": true,
1914
- "nulls": "last"
1915
- }
1916
- ],
1917
- "isUnique": false,
1918
- "concurrently": false,
1919
- "method": "btree",
1920
- "with": {}
1921
- }
1922
- },
1923
- "foreignKeys": {
1924
- "status_history_feedbackId_feedback_feedbackId_fk": {
1925
- "name": "status_history_feedbackId_feedback_feedbackId_fk",
1926
- "tableFrom": "status_history",
1927
- "tableTo": "feedback",
1928
- "columnsFrom": [
1929
- "feedbackId"
1930
- ],
1931
- "columnsTo": [
1932
- "feedbackId"
1933
- ],
1934
- "onDelete": "cascade",
1935
- "onUpdate": "no action"
1936
- },
1937
- "status_history_changedBy_user_id_fk": {
1938
- "name": "status_history_changedBy_user_id_fk",
1939
- "tableFrom": "status_history",
1940
- "tableTo": "user",
1941
- "columnsFrom": [
1942
- "changedBy"
1943
- ],
1944
- "columnsTo": [
1945
- "id"
1946
- ],
1947
- "onDelete": "set null",
1948
- "onUpdate": "no action"
1949
- }
1950
- },
1951
- "compositePrimaryKeys": {},
1952
- "uniqueConstraints": {},
1953
- "policies": {},
1954
- "checkConstraints": {},
1955
- "isRLSEnabled": false
1956
- },
1957
- "public.notification_preferences": {
1958
- "name": "notification_preferences",
1959
- "schema": "",
1960
- "columns": {
1961
- "userId": {
1962
- "name": "userId",
1963
- "type": "text",
1964
- "primaryKey": true,
1965
- "notNull": true
1966
- },
1967
- "statusChange": {
1968
- "name": "statusChange",
1969
- "type": "boolean",
1970
- "primaryKey": false,
1971
- "notNull": true,
1972
- "default": true
1973
- },
1974
- "newComment": {
1975
- "name": "newComment",
1976
- "type": "boolean",
1977
- "primaryKey": false,
1978
- "notNull": true,
1979
- "default": true
1980
- },
1981
- "updatedAt": {
1982
- "name": "updatedAt",
1983
- "type": "timestamp",
1984
- "primaryKey": false,
1985
- "notNull": true,
1986
- "default": "now()"
1987
- }
1988
- },
1989
- "indexes": {},
1990
- "foreignKeys": {
1991
- "notification_preferences_userId_user_id_fk": {
1992
- "name": "notification_preferences_userId_user_id_fk",
1993
- "tableFrom": "notification_preferences",
1994
- "tableTo": "user",
1995
- "columnsFrom": [
1996
- "userId"
1997
- ],
1998
- "columnsTo": [
1999
- "id"
2000
- ],
2001
- "onDelete": "cascade",
2002
- "onUpdate": "no action"
2003
- }
2004
- },
2005
- "compositePrimaryKeys": {},
2006
- "uniqueConstraints": {},
2007
- "policies": {},
2008
- "checkConstraints": {},
2009
- "isRLSEnabled": false
2010
- },
2011
- "public.notifications": {
2012
- "name": "notifications",
2013
- "schema": "",
2014
- "columns": {
2015
- "notificationId": {
2016
- "name": "notificationId",
2017
- "type": "serial",
2018
- "primaryKey": true,
2019
- "notNull": true
2020
- },
2021
- "userId": {
2022
- "name": "userId",
2023
- "type": "text",
2024
- "primaryKey": false,
2025
- "notNull": true
2026
- },
2027
- "type": {
2028
- "name": "type",
2029
- "type": "text",
2030
- "primaryKey": false,
2031
- "notNull": true
2032
- },
2033
- "feedbackId": {
2034
- "name": "feedbackId",
2035
- "type": "serial",
2036
- "primaryKey": false,
2037
- "notNull": true
2038
- },
2039
- "data": {
2040
- "name": "data",
2041
- "type": "jsonb",
2042
- "primaryKey": false,
2043
- "notNull": false
2044
- },
2045
- "status": {
2046
- "name": "status",
2047
- "type": "text",
2048
- "primaryKey": false,
2049
- "notNull": true,
2050
- "default": "'pending'"
2051
- },
2052
- "sentAt": {
2053
- "name": "sentAt",
2054
- "type": "timestamp",
2055
- "primaryKey": false,
2056
- "notNull": false
2057
- },
2058
- "error": {
2059
- "name": "error",
2060
- "type": "text",
2061
- "primaryKey": false,
2062
- "notNull": false
2063
- },
2064
- "createdAt": {
2065
- "name": "createdAt",
2066
- "type": "timestamp",
2067
- "primaryKey": false,
2068
- "notNull": true,
2069
- "default": "now()"
2070
- }
2071
- },
2072
- "indexes": {
2073
- "idx_notifications_userId": {
2074
- "name": "idx_notifications_userId",
2075
- "columns": [
2076
- {
2077
- "expression": "userId",
2078
- "isExpression": false,
2079
- "asc": true,
2080
- "nulls": "last"
2081
- }
2082
- ],
2083
- "isUnique": false,
2084
- "concurrently": false,
2085
- "method": "btree",
2086
- "with": {}
2087
- },
2088
- "idx_notifications_status": {
2089
- "name": "idx_notifications_status",
2090
- "columns": [
2091
- {
2092
- "expression": "status",
2093
- "isExpression": false,
2094
- "asc": true,
2095
- "nulls": "last"
2096
- }
2097
- ],
2098
- "isUnique": false,
2099
- "concurrently": false,
2100
- "method": "btree",
2101
- "with": {}
2102
- },
2103
- "idx_notifications_type": {
2104
- "name": "idx_notifications_type",
2105
- "columns": [
2106
- {
2107
- "expression": "type",
2108
- "isExpression": false,
2109
- "asc": true,
2110
- "nulls": "last"
2111
- }
2112
- ],
2113
- "isUnique": false,
2114
- "concurrently": false,
2115
- "method": "btree",
2116
- "with": {}
2117
- }
2118
- },
2119
- "foreignKeys": {
2120
- "notifications_userId_user_id_fk": {
2121
- "name": "notifications_userId_user_id_fk",
2122
- "tableFrom": "notifications",
2123
- "tableTo": "user",
2124
- "columnsFrom": [
2125
- "userId"
2126
- ],
2127
- "columnsTo": [
2128
- "id"
2129
- ],
2130
- "onDelete": "cascade",
2131
- "onUpdate": "no action"
2132
- },
2133
- "notifications_feedbackId_feedback_feedbackId_fk": {
2134
- "name": "notifications_feedbackId_feedback_feedbackId_fk",
2135
- "tableFrom": "notifications",
2136
- "tableTo": "feedback",
2137
- "columnsFrom": [
2138
- "feedbackId"
2139
- ],
2140
- "columnsTo": [
2141
- "feedbackId"
2142
- ],
2143
- "onDelete": "cascade",
2144
- "onUpdate": "no action"
2145
- }
2146
- },
2147
- "compositePrimaryKeys": {},
2148
- "uniqueConstraints": {},
2149
- "policies": {},
2150
- "checkConstraints": {},
2151
- "isRLSEnabled": false
2152
- },
2153
- "public.feedback_tags": {
2154
- "name": "feedback_tags",
2155
- "schema": "",
2156
- "columns": {
2157
- "id": {
2158
- "name": "id",
2159
- "type": "serial",
2160
- "primaryKey": true,
2161
- "notNull": true
2162
- },
2163
- "feedbackId": {
2164
- "name": "feedbackId",
2165
- "type": "integer",
2166
- "primaryKey": false,
2167
- "notNull": true
2168
- },
2169
- "tagId": {
2170
- "name": "tagId",
2171
- "type": "integer",
2172
- "primaryKey": false,
2173
- "notNull": true
2174
- },
2175
- "createdAt": {
2176
- "name": "createdAt",
2177
- "type": "timestamp",
2178
- "primaryKey": false,
2179
- "notNull": true,
2180
- "default": "now()"
2181
- }
2182
- },
2183
- "indexes": {
2184
- "idx_feedback_tags_feedbackId": {
2185
- "name": "idx_feedback_tags_feedbackId",
2186
- "columns": [
2187
- {
2188
- "expression": "feedbackId",
2189
- "isExpression": false,
2190
- "asc": true,
2191
- "nulls": "last"
2192
- }
2193
- ],
2194
- "isUnique": false,
2195
- "concurrently": false,
2196
- "method": "btree",
2197
- "with": {}
2198
- },
2199
- "idx_feedback_tags_tagId": {
2200
- "name": "idx_feedback_tags_tagId",
2201
- "columns": [
2202
- {
2203
- "expression": "tagId",
2204
- "isExpression": false,
2205
- "asc": true,
2206
- "nulls": "last"
2207
- }
2208
- ],
2209
- "isUnique": false,
2210
- "concurrently": false,
2211
- "method": "btree",
2212
- "with": {}
2213
- },
2214
- "idx_feedback_tags_unique": {
2215
- "name": "idx_feedback_tags_unique",
2216
- "columns": [
2217
- {
2218
- "expression": "feedbackId",
2219
- "isExpression": false,
2220
- "asc": true,
2221
- "nulls": "last"
2222
- },
2223
- {
2224
- "expression": "tagId",
2225
- "isExpression": false,
2226
- "asc": true,
2227
- "nulls": "last"
2228
- }
2229
- ],
2230
- "isUnique": false,
2231
- "concurrently": false,
2232
- "method": "btree",
2233
- "with": {}
2234
- }
2235
- },
2236
- "foreignKeys": {
2237
- "feedback_tags_feedbackId_feedback_feedbackId_fk": {
2238
- "name": "feedback_tags_feedbackId_feedback_feedbackId_fk",
2239
- "tableFrom": "feedback_tags",
2240
- "tableTo": "feedback",
2241
- "columnsFrom": [
2242
- "feedbackId"
2243
- ],
2244
- "columnsTo": [
2245
- "feedbackId"
2246
- ],
2247
- "onDelete": "cascade",
2248
- "onUpdate": "no action"
2249
- },
2250
- "feedback_tags_tagId_tags_tagId_fk": {
2251
- "name": "feedback_tags_tagId_tags_tagId_fk",
2252
- "tableFrom": "feedback_tags",
2253
- "tableTo": "tags",
2254
- "columnsFrom": [
2255
- "tagId"
2256
- ],
2257
- "columnsTo": [
2258
- "tagId"
2259
- ],
2260
- "onDelete": "cascade",
2261
- "onUpdate": "no action"
2262
- }
2263
- },
2264
- "compositePrimaryKeys": {},
2265
- "uniqueConstraints": {},
2266
- "policies": {},
2267
- "checkConstraints": {},
2268
- "isRLSEnabled": false
2269
- },
2270
- "public.tags": {
2271
- "name": "tags",
2272
- "schema": "",
2273
- "columns": {
2274
- "tagId": {
2275
- "name": "tagId",
2276
- "type": "serial",
2277
- "primaryKey": true,
2278
- "notNull": true
2279
- },
2280
- "name": {
2281
- "name": "name",
2282
- "type": "text",
2283
- "primaryKey": false,
2284
- "notNull": true
2285
- },
2286
- "slug": {
2287
- "name": "slug",
2288
- "type": "text",
2289
- "primaryKey": false,
2290
- "notNull": true
2291
- },
2292
- "color": {
2293
- "name": "color",
2294
- "type": "text",
2295
- "primaryKey": false,
2296
- "notNull": false,
2297
- "default": "'#3b82f6'"
2298
- },
2299
- "description": {
2300
- "name": "description",
2301
- "type": "text",
2302
- "primaryKey": false,
2303
- "notNull": false
2304
- },
2305
- "createdAt": {
2306
- "name": "createdAt",
2307
- "type": "timestamp",
2308
- "primaryKey": false,
2309
- "notNull": true,
2310
- "default": "now()"
2311
- }
2312
- },
2313
- "indexes": {},
2314
- "foreignKeys": {},
2315
- "compositePrimaryKeys": {},
2316
- "uniqueConstraints": {
2317
- "tags_name_unique": {
2318
- "name": "tags_name_unique",
2319
- "nullsNotDistinct": false,
2320
- "columns": [
2321
- "name"
2322
- ]
2323
- },
2324
- "tags_slug_unique": {
2325
- "name": "tags_slug_unique",
2326
- "nullsNotDistinct": false,
2327
- "columns": [
2328
- "slug"
2329
- ]
2330
- }
2331
- },
2332
- "policies": {},
2333
- "checkConstraints": {},
2334
- "isRLSEnabled": false
2335
- },
2336
- "public.webhook_events": {
2337
- "name": "webhook_events",
2338
- "schema": "",
2339
- "columns": {
2340
- "eventId": {
2341
- "name": "eventId",
2342
- "type": "serial",
2343
- "primaryKey": true,
2344
- "notNull": true
2345
- },
2346
- "webhookId": {
2347
- "name": "webhookId",
2348
- "type": "integer",
2349
- "primaryKey": false,
2350
- "notNull": true
2351
- },
2352
- "eventType": {
2353
- "name": "eventType",
2354
- "type": "text",
2355
- "primaryKey": false,
2356
- "notNull": true
2357
- },
2358
- "payload": {
2359
- "name": "payload",
2360
- "type": "jsonb",
2361
- "primaryKey": false,
2362
- "notNull": true
2363
- },
2364
- "status": {
2365
- "name": "status",
2366
- "type": "text",
2367
- "primaryKey": false,
2368
- "notNull": true,
2369
- "default": "'pending'"
2370
- },
2371
- "responseStatus": {
2372
- "name": "responseStatus",
2373
- "type": "integer",
2374
- "primaryKey": false,
2375
- "notNull": false
2376
- },
2377
- "responseBody": {
2378
- "name": "responseBody",
2379
- "type": "text",
2380
- "primaryKey": false,
2381
- "notNull": false
2382
- },
2383
- "retryCount": {
2384
- "name": "retryCount",
2385
- "type": "integer",
2386
- "primaryKey": false,
2387
- "notNull": true,
2388
- "default": 0
2389
- },
2390
- "maxRetries": {
2391
- "name": "maxRetries",
2392
- "type": "integer",
2393
- "primaryKey": false,
2394
- "notNull": true,
2395
- "default": 3
2396
- },
2397
- "nextRetryAt": {
2398
- "name": "nextRetryAt",
2399
- "type": "timestamp",
2400
- "primaryKey": false,
2401
- "notNull": false
2402
- },
2403
- "deliveredAt": {
2404
- "name": "deliveredAt",
2405
- "type": "timestamp",
2406
- "primaryKey": false,
2407
- "notNull": false
2408
- },
2409
- "createdAt": {
2410
- "name": "createdAt",
2411
- "type": "timestamp",
2412
- "primaryKey": false,
2413
- "notNull": true,
2414
- "default": "now()"
2415
- },
2416
- "updatedAt": {
2417
- "name": "updatedAt",
2418
- "type": "timestamp",
2419
- "primaryKey": false,
2420
- "notNull": true,
2421
- "default": "now()"
2422
- }
2423
- },
2424
- "indexes": {
2425
- "idx_webhook_events_webhookId": {
2426
- "name": "idx_webhook_events_webhookId",
2427
- "columns": [
2428
- {
2429
- "expression": "webhookId",
2430
- "isExpression": false,
2431
- "asc": true,
2432
- "nulls": "last"
2433
- }
2434
- ],
2435
- "isUnique": false,
2436
- "concurrently": false,
2437
- "method": "btree",
2438
- "with": {}
2439
- },
2440
- "idx_webhook_events_status": {
2441
- "name": "idx_webhook_events_status",
2442
- "columns": [
2443
- {
2444
- "expression": "status",
2445
- "isExpression": false,
2446
- "asc": true,
2447
- "nulls": "last"
2448
- }
2449
- ],
2450
- "isUnique": false,
2451
- "concurrently": false,
2452
- "method": "btree",
2453
- "with": {}
2454
- },
2455
- "idx_webhook_events_nextRetry": {
2456
- "name": "idx_webhook_events_nextRetry",
2457
- "columns": [
2458
- {
2459
- "expression": "nextRetryAt",
2460
- "isExpression": false,
2461
- "asc": true,
2462
- "nulls": "last"
2463
- }
2464
- ],
2465
- "isUnique": false,
2466
- "concurrently": false,
2467
- "method": "btree",
2468
- "with": {}
2469
- }
2470
- },
2471
- "foreignKeys": {
2472
- "webhook_events_webhookId_webhooks_webhookId_fk": {
2473
- "name": "webhook_events_webhookId_webhooks_webhookId_fk",
2474
- "tableFrom": "webhook_events",
2475
- "tableTo": "webhooks",
2476
- "columnsFrom": [
2477
- "webhookId"
2478
- ],
2479
- "columnsTo": [
2480
- "webhookId"
2481
- ],
2482
- "onDelete": "cascade",
2483
- "onUpdate": "no action"
2484
- }
2485
- },
2486
- "compositePrimaryKeys": {},
2487
- "uniqueConstraints": {},
2488
- "policies": {},
2489
- "checkConstraints": {},
2490
- "isRLSEnabled": false
2491
- },
2492
- "public.webhooks": {
2493
- "name": "webhooks",
2494
- "schema": "",
2495
- "columns": {
2496
- "webhookId": {
2497
- "name": "webhookId",
2498
- "type": "serial",
2499
- "primaryKey": true,
2500
- "notNull": true
2501
- },
2502
- "organizationId": {
2503
- "name": "organizationId",
2504
- "type": "text",
2505
- "primaryKey": false,
2506
- "notNull": true
2507
- },
2508
- "name": {
2509
- "name": "name",
2510
- "type": "text",
2511
- "primaryKey": false,
2512
- "notNull": true
2513
- },
2514
- "url": {
2515
- "name": "url",
2516
- "type": "text",
2517
- "primaryKey": false,
2518
- "notNull": true
2519
- },
2520
- "secret": {
2521
- "name": "secret",
2522
- "type": "text",
2523
- "primaryKey": false,
2524
- "notNull": false
2525
- },
2526
- "events": {
2527
- "name": "events",
2528
- "type": "jsonb",
2529
- "primaryKey": false,
2530
- "notNull": true
2531
- },
2532
- "enabled": {
2533
- "name": "enabled",
2534
- "type": "boolean",
2535
- "primaryKey": false,
2536
- "notNull": true,
2537
- "default": true
2538
- },
2539
- "createdAt": {
2540
- "name": "createdAt",
2541
- "type": "timestamp",
2542
- "primaryKey": false,
2543
- "notNull": true,
2544
- "default": "now()"
2545
- },
2546
- "updatedAt": {
2547
- "name": "updatedAt",
2548
- "type": "timestamp",
2549
- "primaryKey": false,
2550
- "notNull": true,
2551
- "default": "now()"
2552
- }
2553
- },
2554
- "indexes": {
2555
- "idx_webhooks_orgId": {
2556
- "name": "idx_webhooks_orgId",
2557
- "columns": [
2558
- {
2559
- "expression": "organizationId",
2560
- "isExpression": false,
2561
- "asc": true,
2562
- "nulls": "last"
2563
- }
2564
- ],
2565
- "isUnique": false,
2566
- "concurrently": false,
2567
- "method": "btree",
2568
- "with": {}
2569
- },
2570
- "idx_webhooks_enabled": {
2571
- "name": "idx_webhooks_enabled",
2572
- "columns": [
2573
- {
2574
- "expression": "enabled",
2575
- "isExpression": false,
2576
- "asc": true,
2577
- "nulls": "last"
2578
- }
2579
- ],
2580
- "isUnique": false,
2581
- "concurrently": false,
2582
- "method": "btree",
2583
- "with": {}
2584
- }
2585
- },
2586
- "foreignKeys": {
2587
- "webhooks_organizationId_organizations_id_fk": {
2588
- "name": "webhooks_organizationId_organizations_id_fk",
2589
- "tableFrom": "webhooks",
2590
- "tableTo": "organizations",
2591
- "columnsFrom": [
2592
- "organizationId"
2593
- ],
2594
- "columnsTo": [
2595
- "id"
2596
- ],
2597
- "onDelete": "cascade",
2598
- "onUpdate": "no action"
2599
- }
2600
- },
2601
- "compositePrimaryKeys": {},
2602
- "uniqueConstraints": {},
2603
- "policies": {},
2604
- "checkConstraints": {},
2605
- "isRLSEnabled": false
2606
- },
2607
- "public.projects": {
2608
- "name": "projects",
2609
- "schema": "",
2610
- "columns": {
2611
- "projectId": {
2612
- "name": "projectId",
2613
- "type": "uuid",
2614
- "primaryKey": true,
2615
- "notNull": true,
2616
- "default": "gen_random_uuid()"
2617
- },
2618
- "organizationId": {
2619
- "name": "organizationId",
2620
- "type": "text",
2621
- "primaryKey": false,
2622
- "notNull": true
2623
- },
2624
- "name": {
2625
- "name": "name",
2626
- "type": "text",
2627
- "primaryKey": false,
2628
- "notNull": true
2629
- },
2630
- "slug": {
2631
- "name": "slug",
2632
- "type": "text",
2633
- "primaryKey": false,
2634
- "notNull": true
2635
- },
2636
- "description": {
2637
- "name": "description",
2638
- "type": "text",
2639
- "primaryKey": false,
2640
- "notNull": false
2641
- },
2642
- "widgetConfig": {
2643
- "name": "widgetConfig",
2644
- "type": "jsonb",
2645
- "primaryKey": false,
2646
- "notNull": false
2647
- },
2648
- "portalConfig": {
2649
- "name": "portalConfig",
2650
- "type": "jsonb",
2651
- "primaryKey": false,
2652
- "notNull": false
2653
- },
2654
- "customDomain": {
2655
- "name": "customDomain",
2656
- "type": "text",
2657
- "primaryKey": false,
2658
- "notNull": false
2659
- },
2660
- "createdAt": {
2661
- "name": "createdAt",
2662
- "type": "timestamp",
2663
- "primaryKey": false,
2664
- "notNull": true,
2665
- "default": "now()"
2666
- },
2667
- "updatedAt": {
2668
- "name": "updatedAt",
2669
- "type": "timestamp",
2670
- "primaryKey": false,
2671
- "notNull": true,
2672
- "default": "now()"
2673
- }
2674
- },
2675
- "indexes": {
2676
- "idx_projects_orgId": {
2677
- "name": "idx_projects_orgId",
2678
- "columns": [
2679
- {
2680
- "expression": "organizationId",
2681
- "isExpression": false,
2682
- "asc": true,
2683
- "nulls": "last"
2684
- }
2685
- ],
2686
- "isUnique": false,
2687
- "concurrently": false,
2688
- "method": "btree",
2689
- "with": {}
2690
- }
2691
- },
2692
- "foreignKeys": {
2693
- "projects_organizationId_organizations_id_fk": {
2694
- "name": "projects_organizationId_organizations_id_fk",
2695
- "tableFrom": "projects",
2696
- "tableTo": "organizations",
2697
- "columnsFrom": [
2698
- "organizationId"
2699
- ],
2700
- "columnsTo": [
2701
- "id"
2702
- ],
2703
- "onDelete": "cascade",
2704
- "onUpdate": "no action"
2705
- }
2706
- },
2707
- "compositePrimaryKeys": {},
2708
- "uniqueConstraints": {
2709
- "unique_slug_org": {
2710
- "name": "unique_slug_org",
2711
- "nullsNotDistinct": false,
2712
- "columns": [
2713
- "slug",
2714
- "organizationId"
2715
- ]
2716
- },
2717
- "unique_custom_domain": {
2718
- "name": "unique_custom_domain",
2719
- "nullsNotDistinct": false,
2720
- "columns": [
2721
- "customDomain"
2722
- ]
2723
- }
2724
- },
2725
- "policies": {},
2726
- "checkConstraints": {},
2727
- "isRLSEnabled": false
2728
- }
2729
- },
2730
- "enums": {},
2731
- "schemas": {},
2732
- "sequences": {},
2733
- "roles": {},
2734
- "policies": {},
2735
- "views": {},
2736
- "_meta": {
2737
- "columns": {},
2738
- "schemas": {},
2739
- "tables": {}
2740
- }
2741
- }