@nexttylabs/echo 0.4.0 → 0.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (262) hide show
  1. package/CHANGELOG.md +27 -0
  2. package/app/(dashboard)/admin/feedback/[id]/edit/page.tsx +12 -6
  3. package/app/(dashboard)/admin/feedback/new/page.tsx +19 -17
  4. package/app/(dashboard)/admin/layout.tsx +16 -6
  5. package/app/(dashboard)/layout.tsx +4 -2
  6. package/app/(dashboard)/settings/api-keys/page.tsx +13 -3
  7. package/app/(dashboard)/settings/layout.tsx +25 -2
  8. package/app/(dashboard)/settings/organization/page.tsx +8 -9
  9. package/app/(public)/[organizationSlug]/roadmap/page.tsx +19 -1
  10. package/app/api/admin/backup/route.ts +22 -4
  11. package/app/api/auth/register/handler.ts +1 -2
  12. package/app/api/feedback/[id]/comments/[commentId]/route.ts +13 -4
  13. package/app/api/feedback/[id]/reclassify/route.ts +4 -4
  14. package/app/api/organizations/handler.ts +2 -4
  15. package/components/settings/settings-sidebar.tsx +4 -4
  16. package/hooks/use-organization.tsx +116 -0
  17. package/hooks/use-permissions.ts +24 -11
  18. package/lib/auth/config.ts +0 -7
  19. package/lib/auth/organization.ts +20 -0
  20. package/lib/auth/permissions.ts +10 -0
  21. package/lib/db/migrations/0000_needy_leech.sql +335 -0
  22. package/lib/db/migrations/meta/0000_snapshot.json +2186 -1
  23. package/lib/db/migrations/meta/_journal.json +2 -135
  24. package/lib/db/schema/auth.ts +0 -1
  25. package/lib/db/schema/index.ts +0 -1
  26. package/lib/portal/public-context.tsx +5 -0
  27. package/package.json +20 -1
  28. package/.changeset/README.md +0 -21
  29. package/.changeset/config.json +0 -11
  30. package/.changeset/cozy-ghosts-care.md +0 -5
  31. package/.changeset/sharp-lines-stand.md +0 -5
  32. package/.changeset/sour-doodles-eat.md +0 -5
  33. package/.changeset/tender-moose-shop.md +0 -5
  34. package/.github/pull_request_template.md +0 -13
  35. package/.github/workflows/ci.yml +0 -41
  36. package/.github/workflows/publish.yml +0 -44
  37. package/.github/workflows/release.yml +0 -73
  38. package/AGENTS.md +0 -92
  39. package/Dockerfile +0 -57
  40. package/Makefile +0 -77
  41. package/bun.lock +0 -2503
  42. package/components/portal/project-switcher.tsx +0 -20
  43. package/docker-compose.dev.yml +0 -26
  44. package/docker-compose.yml +0 -98
  45. package/docs/architecture.md +0 -259
  46. package/docs/component-inventory.md +0 -261
  47. package/docs/database-migrations.md +0 -76
  48. package/docs/development-guide.md +0 -209
  49. package/docs/e2e-user-flows.csv +0 -31
  50. package/docs/er-diagram-feedback.mmd +0 -138
  51. package/docs/er-diagram.mmd +0 -281
  52. package/docs/i18n-check-report.md +0 -296
  53. package/docs/index.md +0 -214
  54. package/docs/logic-chain.md +0 -94
  55. package/docs/plans/2026-01-02-database-migration-scripts.md +0 -496
  56. package/docs/plans/2026-01-02-user-login-design.md +0 -37
  57. package/docs/plans/2026-01-02-user-login.md +0 -437
  58. package/docs/plans/2026-01-02-user-registration-design.md +0 -47
  59. package/docs/plans/2026-01-02-user-registration.md +0 -628
  60. package/docs/plans/2026-01-03-roles-permissions-design.md +0 -20
  61. package/docs/plans/2026-01-03-roles-permissions.md +0 -266
  62. package/docs/plans/2026-01-05-authentication-middleware.md +0 -207
  63. package/docs/plans/2026-01-05-member-removal.md +0 -186
  64. package/docs/plans/2026-01-05-organization-creation.md +0 -374
  65. package/docs/plans/2026-01-05-rbac-middleware.md +0 -112
  66. package/docs/plans/2026-01-05-role-configuration.md +0 -441
  67. package/docs/plans/2026-01-06-file-upload-support.md +0 -804
  68. package/docs/plans/2026-01-06-permission-check-hook.md +0 -155
  69. package/docs/plans/2026-01-06-resource-ownership-check.md +0 -231
  70. package/docs/plans/2026-01-07-feedback-tracking-link.md +0 -459
  71. package/docs/plans/2026-01-09-logout-redirect-design.md +0 -52
  72. package/docs/plans/2026-01-09-phase2-3-plan.md +0 -654
  73. package/docs/plans/2026-01-09-portal-execution-plan.md +0 -408
  74. package/docs/plans/2026-01-09-project-delete-feature-design.md +0 -163
  75. package/docs/plans/2026-01-09-project-delete-implementation.md +0 -451
  76. package/docs/plans/2026-01-09-project-edit-delete-design.md +0 -52
  77. package/docs/plans/2026-01-09-settings-center-design.md +0 -114
  78. package/docs/plans/2026-01-09-settings-center.md +0 -948
  79. package/docs/plans/2026-01-10-organization-only-design.md +0 -66
  80. package/docs/plans/2026-01-10-organization-only-implementation.md +0 -433
  81. package/docs/plans/2026-01-10-portal-settings-restructure-plan.md +0 -18
  82. package/docs/plans/2026-01-10-project-settings-tabs-design-implementation.md +0 -296
  83. package/docs/plans/2026-01-14-e2e-playwright-feedback.md +0 -173
  84. package/docs/plans/2026-01-15-feedback-management-org-context-design.md +0 -82
  85. package/docs/plans/2026-01-15-feedback-management-org-context-implementation-plan.md +0 -521
  86. package/docs/plans/2026-01-16-admin-feedback-filters-design.md +0 -75
  87. package/docs/plans/2026-01-16-admin-feedback-filters-implementation.md +0 -293
  88. package/docs/plans/2026-01-16-admin-feedback-route-consolidation.md +0 -180
  89. package/docs/plans/2026-01-16-e2e-test-fixes.md +0 -158
  90. package/docs/plans/2026-01-17-admin-feedback-filters.md +0 -214
  91. package/docs/plans/2026-01-17-admin-feedback-improvements.md +0 -453
  92. package/docs/plans/2026-01-18-changesets-design.md +0 -40
  93. package/docs/product_changes.md +0 -37
  94. package/docs/project-overview.md +0 -159
  95. package/docs/project-scan-report.json +0 -104
  96. package/docs/route-role-visibility.md +0 -51
  97. package/docs/source-tree-analysis.md +0 -150
  98. package/docs/testing/delete-project-manual-tests.md +0 -18
  99. package/docs/user-story-tracking.md +0 -191
  100. package/eslint.config.mjs +0 -19
  101. package/lib/db/migrations/.gitkeep +0 -0
  102. package/lib/db/migrations/0000_cynical_gladiator.sql +0 -53
  103. package/lib/db/migrations/0001_wandering_sunfire.sql +0 -27
  104. package/lib/db/migrations/0002_shallow_speedball.sql +0 -1
  105. package/lib/db/migrations/0003_add_org_description.sql +0 -1
  106. package/lib/db/migrations/0003_boring_wild_pack.sql +0 -13
  107. package/lib/db/migrations/0004_windy_tyrannus.sql +0 -27
  108. package/lib/db/migrations/0005_perpetual_doorman.sql +0 -5
  109. package/lib/db/migrations/0006_aberrant_captain_midlands.sql +0 -13
  110. package/lib/db/migrations/0007_clever_captain_cross.sql +0 -14
  111. package/lib/db/migrations/0008_sparkling_pandemic.sql +0 -2
  112. package/lib/db/migrations/0009_happy_black_tom.sql +0 -29
  113. package/lib/db/migrations/0010_kind_junta.sql +0 -8
  114. package/lib/db/migrations/0011_mute_squadron_supreme.sql +0 -25
  115. package/lib/db/migrations/0012_giant_power_man.sql +0 -24
  116. package/lib/db/migrations/0013_damp_titanium_man.sql +0 -17
  117. package/lib/db/migrations/0014_blue_alice.sql +0 -18
  118. package/lib/db/migrations/0015_webhook_tables.sql +0 -41
  119. package/lib/db/migrations/0016_github_integration.sql +0 -30
  120. package/lib/db/migrations/0016_overjoyed_ghost_rider.sql +0 -22
  121. package/lib/db/migrations/0017_slimy_inhumans.sql +0 -6
  122. package/lib/db/migrations/0018_same_spitfire.sql +0 -1
  123. package/lib/db/migrations/0019_jittery_loners.sql +0 -16
  124. package/lib/db/migrations/0019_remove_projects_add_org_settings.sql +0 -14
  125. package/lib/db/migrations/meta/0001_snapshot.json +0 -553
  126. package/lib/db/migrations/meta/0002_snapshot.json +0 -560
  127. package/lib/db/migrations/meta/0003_snapshot.json +0 -650
  128. package/lib/db/migrations/meta/0004_snapshot.json +0 -852
  129. package/lib/db/migrations/meta/0005_snapshot.json +0 -900
  130. package/lib/db/migrations/meta/0006_snapshot.json +0 -1011
  131. package/lib/db/migrations/meta/0007_snapshot.json +0 -1125
  132. package/lib/db/migrations/meta/0008_snapshot.json +0 -1146
  133. package/lib/db/migrations/meta/0009_snapshot.json +0 -1386
  134. package/lib/db/migrations/meta/0010_snapshot.json +0 -1419
  135. package/lib/db/migrations/meta/0011_snapshot.json +0 -1615
  136. package/lib/db/migrations/meta/0012_snapshot.json +0 -1805
  137. package/lib/db/migrations/meta/0013_snapshot.json +0 -1948
  138. package/lib/db/migrations/meta/0014_snapshot.json +0 -2082
  139. package/lib/db/migrations/meta/0015_snapshot.json +0 -2476
  140. package/lib/db/migrations/meta/0016_snapshot.json +0 -2633
  141. package/lib/db/migrations/meta/0017_snapshot.json +0 -2680
  142. package/lib/db/migrations/meta/0018_snapshot.json +0 -2686
  143. package/lib/db/migrations/meta/0019_snapshot.json +0 -2741
  144. package/lib/db/schema/projects.ts +0 -145
  145. package/lib/db/schema/user-profiles.ts +0 -31
  146. package/lib/validations/projects.ts +0 -49
  147. package/next-env.d.ts +0 -6
  148. package/playwright.config.ts +0 -44
  149. package/proxy.test.ts +0 -131
  150. package/proxy.ts +0 -116
  151. package/scripts/backup-db.sh +0 -57
  152. package/scripts/backup-db.ts +0 -24
  153. package/scripts/generate-openapi.ts +0 -22
  154. package/scripts/migration-helper.ts +0 -39
  155. package/scripts/pre-deploy.ts +0 -75
  156. package/scripts/restore-db.sh +0 -60
  157. package/scripts/rollback.ts +0 -72
  158. package/scripts/seed-tags.ts +0 -48
  159. package/tests/api/feedback-bulk.test.ts +0 -47
  160. package/tests/api/feedback-by-id.test.ts +0 -67
  161. package/tests/api/feedback-comments-route-import.test.ts +0 -26
  162. package/tests/api/feedback-create.test.ts +0 -71
  163. package/tests/api/feedback-delete.test.ts +0 -160
  164. package/tests/api/feedback-filter.test.ts +0 -250
  165. package/tests/api/feedback-list.test.ts +0 -234
  166. package/tests/api/feedback-route-assignee-condition.test.ts +0 -32
  167. package/tests/api/feedback-similar.test.ts +0 -46
  168. package/tests/api/feedback-sort.test.ts +0 -261
  169. package/tests/api/feedback-status-enum.test.ts +0 -49
  170. package/tests/api/feedback-status-filter.test.ts +0 -117
  171. package/tests/api/feedback-submit-on-behalf.test.ts +0 -269
  172. package/tests/api/feedback.test.ts +0 -175
  173. package/tests/api/identify-jwt.test.ts +0 -25
  174. package/tests/api/invitation-accept.test.ts +0 -213
  175. package/tests/api/organization-invitations.test.ts +0 -186
  176. package/tests/api/organization-members-list.test.ts +0 -79
  177. package/tests/api/organization-members.test.ts +0 -340
  178. package/tests/api/organizations.test.ts +0 -149
  179. package/tests/api/register.test.ts +0 -112
  180. package/tests/api/upload.test.ts +0 -103
  181. package/tests/api/vote.test.ts +0 -82
  182. package/tests/app/admin-feedback-detail-page.test.tsx +0 -25
  183. package/tests/app/admin-feedback-list-page.test.tsx +0 -25
  184. package/tests/app/admin-feedback-new-page.test.tsx +0 -25
  185. package/tests/app/health-route-helpers.test.ts +0 -27
  186. package/tests/app/login-page.test.ts +0 -26
  187. package/tests/app/portal-page.test.ts +0 -29
  188. package/tests/app/project-portal-overview.test.tsx +0 -25
  189. package/tests/app/widget-page-import.test.ts +0 -25
  190. package/tests/components/create-post-dialog-defaults.test.ts +0 -43
  191. package/tests/components/feedback/duplicate-suggestions-inline.test.tsx +0 -27
  192. package/tests/components/feedback/embedded-feedback-form.test.tsx +0 -96
  193. package/tests/components/feedback/feedback-detail.test.tsx +0 -25
  194. package/tests/components/feedback/feedback-stats.test.tsx +0 -49
  195. package/tests/components/feedback-bulk-actions.test.tsx +0 -39
  196. package/tests/components/feedback-i18n-keys.test.ts +0 -70
  197. package/tests/components/feedback-list-controls-compile.test.ts +0 -25
  198. package/tests/components/feedback-list-controls.test.tsx +0 -204
  199. package/tests/components/feedback-list-item.test.tsx +0 -67
  200. package/tests/components/landing/hero.test.tsx +0 -46
  201. package/tests/components/layout/language-switcher.test.tsx +0 -25
  202. package/tests/components/layout/sidebar.test.tsx +0 -157
  203. package/tests/components/login-form.test.ts +0 -25
  204. package/tests/components/organization-form.test.ts +0 -32
  205. package/tests/components/organization-switcher.test.ts +0 -25
  206. package/tests/components/pagination.test.tsx +0 -43
  207. package/tests/components/portal-overview.test.tsx +0 -25
  208. package/tests/components/profile-form.test.tsx +0 -139
  209. package/tests/components/role-selector.test.ts +0 -31
  210. package/tests/components/status-chart.test.tsx +0 -90
  211. package/tests/e2e/auth.e2e.ts +0 -323
  212. package/tests/e2e/feedback-actions.e2e.ts +0 -471
  213. package/tests/e2e/feedback-attachment.e2e.ts +0 -168
  214. package/tests/e2e/feedback-customer.e2e.ts +0 -226
  215. package/tests/e2e/feedback-management.e2e.ts +0 -565
  216. package/tests/e2e/feedback-submit.e2e.ts +0 -133
  217. package/tests/e2e/feedback-view.e2e.ts +0 -297
  218. package/tests/e2e/fixtures/test-data.ts +0 -235
  219. package/tests/e2e/health-check.e2e.ts +0 -230
  220. package/tests/e2e/helpers/test-utils-helpers.test.ts +0 -43
  221. package/tests/e2e/helpers/test-utils.ts +0 -298
  222. package/tests/e2e/integration-placeholders.e2e.ts +0 -199
  223. package/tests/e2e/organization.e2e.ts +0 -292
  224. package/tests/e2e/permissions.e2e.ts +0 -424
  225. package/tests/e2e/project-widget.e2e.ts +0 -63
  226. package/tests/feedback/filters.test.ts +0 -29
  227. package/tests/hooks/use-permissions.test.ts +0 -52
  228. package/tests/lib/ai/classifier.test.ts +0 -104
  229. package/tests/lib/ai/duplicate-detector.test.ts +0 -234
  230. package/tests/lib/attachments-schema.test.ts +0 -30
  231. package/tests/lib/auth/session.test.ts +0 -49
  232. package/tests/lib/auth-client.test.ts +0 -37
  233. package/tests/lib/auth-config.test.ts +0 -26
  234. package/tests/lib/feedback-prefill.test.ts +0 -52
  235. package/tests/lib/feedback-processor.test.ts +0 -41
  236. package/tests/lib/feedback-schema.test.ts +0 -33
  237. package/tests/lib/file-validator.test.ts +0 -48
  238. package/tests/lib/get-feedback-by-id.test.ts +0 -37
  239. package/tests/lib/invitations.test.ts +0 -35
  240. package/tests/lib/login-schema.test.ts +0 -36
  241. package/tests/lib/org-context.test.ts +0 -95
  242. package/tests/lib/organization-access.test.ts +0 -44
  243. package/tests/lib/organization-member-role-schema.test.ts +0 -41
  244. package/tests/lib/permissions.test.ts +0 -88
  245. package/tests/lib/portal-analytics.test.ts +0 -25
  246. package/tests/lib/portal-contributors.test.ts +0 -25
  247. package/tests/lib/portal-copy.test.ts +0 -27
  248. package/tests/lib/portal-i18n.test.ts +0 -30
  249. package/tests/lib/portal-leaderboard-settings.test.ts +0 -25
  250. package/tests/lib/portal-modules.test.ts +0 -25
  251. package/tests/lib/portal-seo.test.ts +0 -25
  252. package/tests/lib/portal-sharing.test.ts +0 -25
  253. package/tests/lib/portal-sorting.test.ts +0 -25
  254. package/tests/lib/portal-theme.test.ts +0 -25
  255. package/tests/lib/rate-limit.test.ts +0 -142
  256. package/tests/lib/resolve-locale.test.ts +0 -34
  257. package/tests/lib/services/backup.test.ts +0 -145
  258. package/tests/lib/user-organizations.test.ts +0 -42
  259. package/tests/lib/user-role-schema.test.ts +0 -33
  260. package/tests/lib/user-schema.test.ts +0 -25
  261. package/tests/setup.ts +0 -74
  262. package/vercel.json +0 -4
@@ -1,1805 +0,0 @@
1
- {
2
- "id": "ca376c90-9c4f-4882-8d66-b8e4dd7f0254",
3
- "prevId": "16a78873-3ad4-4019-bf34-d611d7053817",
4
- "version": "7",
5
- "dialect": "postgresql",
6
- "tables": {
7
- "public.attachments": {
8
- "name": "attachments",
9
- "schema": "",
10
- "columns": {
11
- "attachmentId": {
12
- "name": "attachmentId",
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
- "fileName": {
24
- "name": "fileName",
25
- "type": "text",
26
- "primaryKey": false,
27
- "notNull": true
28
- },
29
- "filePath": {
30
- "name": "filePath",
31
- "type": "text",
32
- "primaryKey": false,
33
- "notNull": true
34
- },
35
- "fileSize": {
36
- "name": "fileSize",
37
- "type": "integer",
38
- "primaryKey": false,
39
- "notNull": true
40
- },
41
- "mimeType": {
42
- "name": "mimeType",
43
- "type": "text",
44
- "primaryKey": false,
45
- "notNull": true
46
- },
47
- "createdAt": {
48
- "name": "createdAt",
49
- "type": "timestamp",
50
- "primaryKey": false,
51
- "notNull": true,
52
- "default": "now()"
53
- }
54
- },
55
- "indexes": {
56
- "idx_attachments_feedbackId": {
57
- "name": "idx_attachments_feedbackId",
58
- "columns": [
59
- {
60
- "expression": "feedbackId",
61
- "isExpression": false,
62
- "asc": true,
63
- "nulls": "last"
64
- }
65
- ],
66
- "isUnique": false,
67
- "concurrently": false,
68
- "method": "btree",
69
- "with": {}
70
- }
71
- },
72
- "foreignKeys": {
73
- "attachments_feedbackId_feedback_feedbackId_fk": {
74
- "name": "attachments_feedbackId_feedback_feedbackId_fk",
75
- "tableFrom": "attachments",
76
- "tableTo": "feedback",
77
- "columnsFrom": [
78
- "feedbackId"
79
- ],
80
- "columnsTo": [
81
- "feedbackId"
82
- ],
83
- "onDelete": "cascade",
84
- "onUpdate": "no action"
85
- }
86
- },
87
- "compositePrimaryKeys": {},
88
- "uniqueConstraints": {},
89
- "policies": {},
90
- "checkConstraints": {},
91
- "isRLSEnabled": false
92
- },
93
- "public.account": {
94
- "name": "account",
95
- "schema": "",
96
- "columns": {
97
- "id": {
98
- "name": "id",
99
- "type": "text",
100
- "primaryKey": true,
101
- "notNull": true
102
- },
103
- "account_id": {
104
- "name": "account_id",
105
- "type": "text",
106
- "primaryKey": false,
107
- "notNull": true
108
- },
109
- "provider_id": {
110
- "name": "provider_id",
111
- "type": "text",
112
- "primaryKey": false,
113
- "notNull": true
114
- },
115
- "user_id": {
116
- "name": "user_id",
117
- "type": "text",
118
- "primaryKey": false,
119
- "notNull": true
120
- },
121
- "access_token": {
122
- "name": "access_token",
123
- "type": "text",
124
- "primaryKey": false,
125
- "notNull": false
126
- },
127
- "refresh_token": {
128
- "name": "refresh_token",
129
- "type": "text",
130
- "primaryKey": false,
131
- "notNull": false
132
- },
133
- "id_token": {
134
- "name": "id_token",
135
- "type": "text",
136
- "primaryKey": false,
137
- "notNull": false
138
- },
139
- "access_token_expires_at": {
140
- "name": "access_token_expires_at",
141
- "type": "timestamp",
142
- "primaryKey": false,
143
- "notNull": false
144
- },
145
- "refresh_token_expires_at": {
146
- "name": "refresh_token_expires_at",
147
- "type": "timestamp",
148
- "primaryKey": false,
149
- "notNull": false
150
- },
151
- "scope": {
152
- "name": "scope",
153
- "type": "text",
154
- "primaryKey": false,
155
- "notNull": false
156
- },
157
- "password": {
158
- "name": "password",
159
- "type": "text",
160
- "primaryKey": false,
161
- "notNull": false
162
- },
163
- "created_at": {
164
- "name": "created_at",
165
- "type": "timestamp",
166
- "primaryKey": false,
167
- "notNull": true,
168
- "default": "now()"
169
- },
170
- "updated_at": {
171
- "name": "updated_at",
172
- "type": "timestamp",
173
- "primaryKey": false,
174
- "notNull": true
175
- }
176
- },
177
- "indexes": {
178
- "account_userId_idx": {
179
- "name": "account_userId_idx",
180
- "columns": [
181
- {
182
- "expression": "user_id",
183
- "isExpression": false,
184
- "asc": true,
185
- "nulls": "last"
186
- }
187
- ],
188
- "isUnique": false,
189
- "concurrently": false,
190
- "method": "btree",
191
- "with": {}
192
- }
193
- },
194
- "foreignKeys": {
195
- "account_user_id_user_id_fk": {
196
- "name": "account_user_id_user_id_fk",
197
- "tableFrom": "account",
198
- "tableTo": "user",
199
- "columnsFrom": [
200
- "user_id"
201
- ],
202
- "columnsTo": [
203
- "id"
204
- ],
205
- "onDelete": "cascade",
206
- "onUpdate": "no action"
207
- }
208
- },
209
- "compositePrimaryKeys": {},
210
- "uniqueConstraints": {},
211
- "policies": {},
212
- "checkConstraints": {},
213
- "isRLSEnabled": false
214
- },
215
- "public.session": {
216
- "name": "session",
217
- "schema": "",
218
- "columns": {
219
- "id": {
220
- "name": "id",
221
- "type": "text",
222
- "primaryKey": true,
223
- "notNull": true
224
- },
225
- "expires_at": {
226
- "name": "expires_at",
227
- "type": "timestamp",
228
- "primaryKey": false,
229
- "notNull": true
230
- },
231
- "token": {
232
- "name": "token",
233
- "type": "text",
234
- "primaryKey": false,
235
- "notNull": true
236
- },
237
- "created_at": {
238
- "name": "created_at",
239
- "type": "timestamp",
240
- "primaryKey": false,
241
- "notNull": true,
242
- "default": "now()"
243
- },
244
- "updated_at": {
245
- "name": "updated_at",
246
- "type": "timestamp",
247
- "primaryKey": false,
248
- "notNull": true
249
- },
250
- "ip_address": {
251
- "name": "ip_address",
252
- "type": "text",
253
- "primaryKey": false,
254
- "notNull": false
255
- },
256
- "user_agent": {
257
- "name": "user_agent",
258
- "type": "text",
259
- "primaryKey": false,
260
- "notNull": false
261
- },
262
- "user_id": {
263
- "name": "user_id",
264
- "type": "text",
265
- "primaryKey": false,
266
- "notNull": true
267
- }
268
- },
269
- "indexes": {
270
- "session_userId_idx": {
271
- "name": "session_userId_idx",
272
- "columns": [
273
- {
274
- "expression": "user_id",
275
- "isExpression": false,
276
- "asc": true,
277
- "nulls": "last"
278
- }
279
- ],
280
- "isUnique": false,
281
- "concurrently": false,
282
- "method": "btree",
283
- "with": {}
284
- }
285
- },
286
- "foreignKeys": {
287
- "session_user_id_user_id_fk": {
288
- "name": "session_user_id_user_id_fk",
289
- "tableFrom": "session",
290
- "tableTo": "user",
291
- "columnsFrom": [
292
- "user_id"
293
- ],
294
- "columnsTo": [
295
- "id"
296
- ],
297
- "onDelete": "cascade",
298
- "onUpdate": "no action"
299
- }
300
- },
301
- "compositePrimaryKeys": {},
302
- "uniqueConstraints": {
303
- "session_token_unique": {
304
- "name": "session_token_unique",
305
- "nullsNotDistinct": false,
306
- "columns": [
307
- "token"
308
- ]
309
- }
310
- },
311
- "policies": {},
312
- "checkConstraints": {},
313
- "isRLSEnabled": false
314
- },
315
- "public.user": {
316
- "name": "user",
317
- "schema": "",
318
- "columns": {
319
- "id": {
320
- "name": "id",
321
- "type": "text",
322
- "primaryKey": true,
323
- "notNull": true
324
- },
325
- "name": {
326
- "name": "name",
327
- "type": "text",
328
- "primaryKey": false,
329
- "notNull": true
330
- },
331
- "email": {
332
- "name": "email",
333
- "type": "text",
334
- "primaryKey": false,
335
- "notNull": true
336
- },
337
- "role": {
338
- "name": "role",
339
- "type": "text",
340
- "primaryKey": false,
341
- "notNull": true,
342
- "default": "'customer'"
343
- },
344
- "email_verified": {
345
- "name": "email_verified",
346
- "type": "boolean",
347
- "primaryKey": false,
348
- "notNull": true,
349
- "default": false
350
- },
351
- "image": {
352
- "name": "image",
353
- "type": "text",
354
- "primaryKey": false,
355
- "notNull": false
356
- },
357
- "created_at": {
358
- "name": "created_at",
359
- "type": "timestamp",
360
- "primaryKey": false,
361
- "notNull": true,
362
- "default": "now()"
363
- },
364
- "updated_at": {
365
- "name": "updated_at",
366
- "type": "timestamp",
367
- "primaryKey": false,
368
- "notNull": true,
369
- "default": "now()"
370
- }
371
- },
372
- "indexes": {},
373
- "foreignKeys": {},
374
- "compositePrimaryKeys": {},
375
- "uniqueConstraints": {
376
- "user_email_unique": {
377
- "name": "user_email_unique",
378
- "nullsNotDistinct": false,
379
- "columns": [
380
- "email"
381
- ]
382
- }
383
- },
384
- "policies": {},
385
- "checkConstraints": {},
386
- "isRLSEnabled": false
387
- },
388
- "public.verification": {
389
- "name": "verification",
390
- "schema": "",
391
- "columns": {
392
- "id": {
393
- "name": "id",
394
- "type": "text",
395
- "primaryKey": true,
396
- "notNull": true
397
- },
398
- "identifier": {
399
- "name": "identifier",
400
- "type": "text",
401
- "primaryKey": false,
402
- "notNull": true
403
- },
404
- "value": {
405
- "name": "value",
406
- "type": "text",
407
- "primaryKey": false,
408
- "notNull": true
409
- },
410
- "expires_at": {
411
- "name": "expires_at",
412
- "type": "timestamp",
413
- "primaryKey": false,
414
- "notNull": true
415
- },
416
- "created_at": {
417
- "name": "created_at",
418
- "type": "timestamp",
419
- "primaryKey": false,
420
- "notNull": true,
421
- "default": "now()"
422
- },
423
- "updated_at": {
424
- "name": "updated_at",
425
- "type": "timestamp",
426
- "primaryKey": false,
427
- "notNull": true,
428
- "default": "now()"
429
- }
430
- },
431
- "indexes": {
432
- "verification_identifier_idx": {
433
- "name": "verification_identifier_idx",
434
- "columns": [
435
- {
436
- "expression": "identifier",
437
- "isExpression": false,
438
- "asc": true,
439
- "nulls": "last"
440
- }
441
- ],
442
- "isUnique": false,
443
- "concurrently": false,
444
- "method": "btree",
445
- "with": {}
446
- }
447
- },
448
- "foreignKeys": {},
449
- "compositePrimaryKeys": {},
450
- "uniqueConstraints": {},
451
- "policies": {},
452
- "checkConstraints": {},
453
- "isRLSEnabled": false
454
- },
455
- "public.comments": {
456
- "name": "comments",
457
- "schema": "",
458
- "columns": {
459
- "commentId": {
460
- "name": "commentId",
461
- "type": "serial",
462
- "primaryKey": true,
463
- "notNull": true
464
- },
465
- "feedbackId": {
466
- "name": "feedbackId",
467
- "type": "serial",
468
- "primaryKey": false,
469
- "notNull": true
470
- },
471
- "userId": {
472
- "name": "userId",
473
- "type": "text",
474
- "primaryKey": false,
475
- "notNull": false
476
- },
477
- "authorName": {
478
- "name": "authorName",
479
- "type": "text",
480
- "primaryKey": false,
481
- "notNull": false
482
- },
483
- "authorEmail": {
484
- "name": "authorEmail",
485
- "type": "text",
486
- "primaryKey": false,
487
- "notNull": false
488
- },
489
- "guestToken": {
490
- "name": "guestToken",
491
- "type": "text",
492
- "primaryKey": false,
493
- "notNull": false
494
- },
495
- "content": {
496
- "name": "content",
497
- "type": "text",
498
- "primaryKey": false,
499
- "notNull": true
500
- },
501
- "isInternal": {
502
- "name": "isInternal",
503
- "type": "boolean",
504
- "primaryKey": false,
505
- "notNull": true,
506
- "default": true
507
- },
508
- "createdAt": {
509
- "name": "createdAt",
510
- "type": "timestamp",
511
- "primaryKey": false,
512
- "notNull": true,
513
- "default": "now()"
514
- },
515
- "updatedAt": {
516
- "name": "updatedAt",
517
- "type": "timestamp",
518
- "primaryKey": false,
519
- "notNull": true,
520
- "default": "now()"
521
- }
522
- },
523
- "indexes": {
524
- "idx_comments_feedbackId": {
525
- "name": "idx_comments_feedbackId",
526
- "columns": [
527
- {
528
- "expression": "feedbackId",
529
- "isExpression": false,
530
- "asc": true,
531
- "nulls": "last"
532
- }
533
- ],
534
- "isUnique": false,
535
- "concurrently": false,
536
- "method": "btree",
537
- "with": {}
538
- },
539
- "idx_comments_isInternal": {
540
- "name": "idx_comments_isInternal",
541
- "columns": [
542
- {
543
- "expression": "isInternal",
544
- "isExpression": false,
545
- "asc": true,
546
- "nulls": "last"
547
- }
548
- ],
549
- "isUnique": false,
550
- "concurrently": false,
551
- "method": "btree",
552
- "with": {}
553
- },
554
- "idx_comments_internal_feedbacks": {
555
- "name": "idx_comments_internal_feedbacks",
556
- "columns": [
557
- {
558
- "expression": "feedbackId",
559
- "isExpression": false,
560
- "asc": true,
561
- "nulls": "last"
562
- },
563
- {
564
- "expression": "isInternal",
565
- "isExpression": false,
566
- "asc": true,
567
- "nulls": "last"
568
- }
569
- ],
570
- "isUnique": false,
571
- "concurrently": false,
572
- "method": "btree",
573
- "with": {}
574
- },
575
- "idx_comments_guestToken": {
576
- "name": "idx_comments_guestToken",
577
- "columns": [
578
- {
579
- "expression": "guestToken",
580
- "isExpression": false,
581
- "asc": true,
582
- "nulls": "last"
583
- }
584
- ],
585
- "isUnique": false,
586
- "concurrently": false,
587
- "method": "btree",
588
- "with": {}
589
- }
590
- },
591
- "foreignKeys": {
592
- "comments_feedbackId_feedback_feedbackId_fk": {
593
- "name": "comments_feedbackId_feedback_feedbackId_fk",
594
- "tableFrom": "comments",
595
- "tableTo": "feedback",
596
- "columnsFrom": [
597
- "feedbackId"
598
- ],
599
- "columnsTo": [
600
- "feedbackId"
601
- ],
602
- "onDelete": "cascade",
603
- "onUpdate": "no action"
604
- },
605
- "comments_userId_user_id_fk": {
606
- "name": "comments_userId_user_id_fk",
607
- "tableFrom": "comments",
608
- "tableTo": "user",
609
- "columnsFrom": [
610
- "userId"
611
- ],
612
- "columnsTo": [
613
- "id"
614
- ],
615
- "onDelete": "set null",
616
- "onUpdate": "no action"
617
- }
618
- },
619
- "compositePrimaryKeys": {},
620
- "uniqueConstraints": {},
621
- "policies": {},
622
- "checkConstraints": {},
623
- "isRLSEnabled": false
624
- },
625
- "public.feedback": {
626
- "name": "feedback",
627
- "schema": "",
628
- "columns": {
629
- "feedbackId": {
630
- "name": "feedbackId",
631
- "type": "serial",
632
- "primaryKey": true,
633
- "notNull": true
634
- },
635
- "title": {
636
- "name": "title",
637
- "type": "text",
638
- "primaryKey": false,
639
- "notNull": true
640
- },
641
- "description": {
642
- "name": "description",
643
- "type": "text",
644
- "primaryKey": false,
645
- "notNull": true
646
- },
647
- "type": {
648
- "name": "type",
649
- "type": "text",
650
- "primaryKey": false,
651
- "notNull": true
652
- },
653
- "priority": {
654
- "name": "priority",
655
- "type": "text",
656
- "primaryKey": false,
657
- "notNull": true
658
- },
659
- "status": {
660
- "name": "status",
661
- "type": "text",
662
- "primaryKey": false,
663
- "notNull": true,
664
- "default": "'new'"
665
- },
666
- "organizationId": {
667
- "name": "organizationId",
668
- "type": "text",
669
- "primaryKey": false,
670
- "notNull": true
671
- },
672
- "submittedOnBehalf": {
673
- "name": "submittedOnBehalf",
674
- "type": "boolean",
675
- "primaryKey": false,
676
- "notNull": true,
677
- "default": false
678
- },
679
- "submittedBy": {
680
- "name": "submittedBy",
681
- "type": "text",
682
- "primaryKey": false,
683
- "notNull": false
684
- },
685
- "customerInfo": {
686
- "name": "customerInfo",
687
- "type": "jsonb",
688
- "primaryKey": false,
689
- "notNull": false
690
- },
691
- "createdAt": {
692
- "name": "createdAt",
693
- "type": "timestamp",
694
- "primaryKey": false,
695
- "notNull": true,
696
- "default": "now()"
697
- },
698
- "updatedAt": {
699
- "name": "updatedAt",
700
- "type": "timestamp",
701
- "primaryKey": false,
702
- "notNull": true,
703
- "default": "now()"
704
- },
705
- "deletedAt": {
706
- "name": "deletedAt",
707
- "type": "timestamp",
708
- "primaryKey": false,
709
- "notNull": false
710
- },
711
- "autoClassified": {
712
- "name": "autoClassified",
713
- "type": "boolean",
714
- "primaryKey": false,
715
- "notNull": true,
716
- "default": false
717
- }
718
- },
719
- "indexes": {
720
- "idx_feedback_orgId": {
721
- "name": "idx_feedback_orgId",
722
- "columns": [
723
- {
724
- "expression": "organizationId",
725
- "isExpression": false,
726
- "asc": true,
727
- "nulls": "last"
728
- }
729
- ],
730
- "isUnique": false,
731
- "concurrently": false,
732
- "method": "btree",
733
- "with": {}
734
- },
735
- "idx_feedback_status": {
736
- "name": "idx_feedback_status",
737
- "columns": [
738
- {
739
- "expression": "status",
740
- "isExpression": false,
741
- "asc": true,
742
- "nulls": "last"
743
- }
744
- ],
745
- "isUnique": false,
746
- "concurrently": false,
747
- "method": "btree",
748
- "with": {}
749
- },
750
- "idx_feedback_createdAt": {
751
- "name": "idx_feedback_createdAt",
752
- "columns": [
753
- {
754
- "expression": "createdAt",
755
- "isExpression": false,
756
- "asc": true,
757
- "nulls": "last"
758
- }
759
- ],
760
- "isUnique": false,
761
- "concurrently": false,
762
- "method": "btree",
763
- "with": {}
764
- },
765
- "idx_feedback_submittedBy": {
766
- "name": "idx_feedback_submittedBy",
767
- "columns": [
768
- {
769
- "expression": "submittedBy",
770
- "isExpression": false,
771
- "asc": true,
772
- "nulls": "last"
773
- }
774
- ],
775
- "isUnique": false,
776
- "concurrently": false,
777
- "method": "btree",
778
- "with": {}
779
- },
780
- "idx_feedback_deletedAt": {
781
- "name": "idx_feedback_deletedAt",
782
- "columns": [
783
- {
784
- "expression": "deletedAt",
785
- "isExpression": false,
786
- "asc": true,
787
- "nulls": "last"
788
- }
789
- ],
790
- "isUnique": false,
791
- "concurrently": false,
792
- "method": "btree",
793
- "with": {}
794
- }
795
- },
796
- "foreignKeys": {
797
- "feedback_submittedBy_user_id_fk": {
798
- "name": "feedback_submittedBy_user_id_fk",
799
- "tableFrom": "feedback",
800
- "tableTo": "user",
801
- "columnsFrom": [
802
- "submittedBy"
803
- ],
804
- "columnsTo": [
805
- "id"
806
- ],
807
- "onDelete": "set null",
808
- "onUpdate": "no action"
809
- }
810
- },
811
- "compositePrimaryKeys": {},
812
- "uniqueConstraints": {},
813
- "policies": {},
814
- "checkConstraints": {},
815
- "isRLSEnabled": false
816
- },
817
- "public.user_profiles": {
818
- "name": "user_profiles",
819
- "schema": "",
820
- "columns": {
821
- "user_id": {
822
- "name": "user_id",
823
- "type": "text",
824
- "primaryKey": true,
825
- "notNull": true
826
- },
827
- "name": {
828
- "name": "name",
829
- "type": "text",
830
- "primaryKey": false,
831
- "notNull": true
832
- },
833
- "created_at": {
834
- "name": "created_at",
835
- "type": "timestamp",
836
- "primaryKey": false,
837
- "notNull": true,
838
- "default": "now()"
839
- },
840
- "updated_at": {
841
- "name": "updated_at",
842
- "type": "timestamp",
843
- "primaryKey": false,
844
- "notNull": true,
845
- "default": "now()"
846
- }
847
- },
848
- "indexes": {},
849
- "foreignKeys": {
850
- "user_profiles_user_id_user_id_fk": {
851
- "name": "user_profiles_user_id_user_id_fk",
852
- "tableFrom": "user_profiles",
853
- "tableTo": "user",
854
- "columnsFrom": [
855
- "user_id"
856
- ],
857
- "columnsTo": [
858
- "id"
859
- ],
860
- "onDelete": "cascade",
861
- "onUpdate": "no action"
862
- }
863
- },
864
- "compositePrimaryKeys": {},
865
- "uniqueConstraints": {},
866
- "policies": {},
867
- "checkConstraints": {},
868
- "isRLSEnabled": false
869
- },
870
- "public.organizations": {
871
- "name": "organizations",
872
- "schema": "",
873
- "columns": {
874
- "id": {
875
- "name": "id",
876
- "type": "text",
877
- "primaryKey": true,
878
- "notNull": true
879
- },
880
- "name": {
881
- "name": "name",
882
- "type": "text",
883
- "primaryKey": false,
884
- "notNull": true
885
- },
886
- "slug": {
887
- "name": "slug",
888
- "type": "text",
889
- "primaryKey": false,
890
- "notNull": true
891
- },
892
- "description": {
893
- "name": "description",
894
- "type": "text",
895
- "primaryKey": false,
896
- "notNull": false
897
- },
898
- "created_at": {
899
- "name": "created_at",
900
- "type": "timestamp",
901
- "primaryKey": false,
902
- "notNull": true,
903
- "default": "now()"
904
- },
905
- "updated_at": {
906
- "name": "updated_at",
907
- "type": "timestamp",
908
- "primaryKey": false,
909
- "notNull": true,
910
- "default": "now()"
911
- }
912
- },
913
- "indexes": {},
914
- "foreignKeys": {},
915
- "compositePrimaryKeys": {},
916
- "uniqueConstraints": {
917
- "organizations_slug_unique": {
918
- "name": "organizations_slug_unique",
919
- "nullsNotDistinct": false,
920
- "columns": [
921
- "slug"
922
- ]
923
- }
924
- },
925
- "policies": {},
926
- "checkConstraints": {},
927
- "isRLSEnabled": false
928
- },
929
- "public.organization_members": {
930
- "name": "organization_members",
931
- "schema": "",
932
- "columns": {
933
- "organization_id": {
934
- "name": "organization_id",
935
- "type": "text",
936
- "primaryKey": false,
937
- "notNull": true
938
- },
939
- "user_id": {
940
- "name": "user_id",
941
- "type": "text",
942
- "primaryKey": false,
943
- "notNull": true
944
- },
945
- "role": {
946
- "name": "role",
947
- "type": "text",
948
- "primaryKey": false,
949
- "notNull": true
950
- },
951
- "created_at": {
952
- "name": "created_at",
953
- "type": "timestamp",
954
- "primaryKey": false,
955
- "notNull": true,
956
- "default": "now()"
957
- }
958
- },
959
- "indexes": {},
960
- "foreignKeys": {
961
- "organization_members_organization_id_organizations_id_fk": {
962
- "name": "organization_members_organization_id_organizations_id_fk",
963
- "tableFrom": "organization_members",
964
- "tableTo": "organizations",
965
- "columnsFrom": [
966
- "organization_id"
967
- ],
968
- "columnsTo": [
969
- "id"
970
- ],
971
- "onDelete": "cascade",
972
- "onUpdate": "no action"
973
- },
974
- "organization_members_user_id_user_id_fk": {
975
- "name": "organization_members_user_id_user_id_fk",
976
- "tableFrom": "organization_members",
977
- "tableTo": "user",
978
- "columnsFrom": [
979
- "user_id"
980
- ],
981
- "columnsTo": [
982
- "id"
983
- ],
984
- "onDelete": "cascade",
985
- "onUpdate": "no action"
986
- }
987
- },
988
- "compositePrimaryKeys": {
989
- "organization_members_organization_id_user_id_pk": {
990
- "name": "organization_members_organization_id_user_id_pk",
991
- "columns": [
992
- "organization_id",
993
- "user_id"
994
- ]
995
- }
996
- },
997
- "uniqueConstraints": {},
998
- "policies": {},
999
- "checkConstraints": {},
1000
- "isRLSEnabled": false
1001
- },
1002
- "public.invitations": {
1003
- "name": "invitations",
1004
- "schema": "",
1005
- "columns": {
1006
- "id": {
1007
- "name": "id",
1008
- "type": "text",
1009
- "primaryKey": true,
1010
- "notNull": true
1011
- },
1012
- "organization_id": {
1013
- "name": "organization_id",
1014
- "type": "text",
1015
- "primaryKey": false,
1016
- "notNull": true
1017
- },
1018
- "email": {
1019
- "name": "email",
1020
- "type": "text",
1021
- "primaryKey": false,
1022
- "notNull": true
1023
- },
1024
- "role": {
1025
- "name": "role",
1026
- "type": "text",
1027
- "primaryKey": false,
1028
- "notNull": true
1029
- },
1030
- "token": {
1031
- "name": "token",
1032
- "type": "text",
1033
- "primaryKey": false,
1034
- "notNull": true
1035
- },
1036
- "expires_at": {
1037
- "name": "expires_at",
1038
- "type": "timestamp",
1039
- "primaryKey": false,
1040
- "notNull": true
1041
- },
1042
- "accepted_at": {
1043
- "name": "accepted_at",
1044
- "type": "timestamp",
1045
- "primaryKey": false,
1046
- "notNull": false
1047
- },
1048
- "created_at": {
1049
- "name": "created_at",
1050
- "type": "timestamp",
1051
- "primaryKey": false,
1052
- "notNull": true,
1053
- "default": "now()"
1054
- }
1055
- },
1056
- "indexes": {},
1057
- "foreignKeys": {
1058
- "invitations_organization_id_organizations_id_fk": {
1059
- "name": "invitations_organization_id_organizations_id_fk",
1060
- "tableFrom": "invitations",
1061
- "tableTo": "organizations",
1062
- "columnsFrom": [
1063
- "organization_id"
1064
- ],
1065
- "columnsTo": [
1066
- "id"
1067
- ],
1068
- "onDelete": "cascade",
1069
- "onUpdate": "no action"
1070
- }
1071
- },
1072
- "compositePrimaryKeys": {},
1073
- "uniqueConstraints": {
1074
- "invitations_token_unique": {
1075
- "name": "invitations_token_unique",
1076
- "nullsNotDistinct": false,
1077
- "columns": [
1078
- "token"
1079
- ]
1080
- }
1081
- },
1082
- "policies": {},
1083
- "checkConstraints": {},
1084
- "isRLSEnabled": false
1085
- },
1086
- "public.votes": {
1087
- "name": "votes",
1088
- "schema": "",
1089
- "columns": {
1090
- "voteId": {
1091
- "name": "voteId",
1092
- "type": "serial",
1093
- "primaryKey": true,
1094
- "notNull": true
1095
- },
1096
- "feedbackId": {
1097
- "name": "feedbackId",
1098
- "type": "serial",
1099
- "primaryKey": false,
1100
- "notNull": true
1101
- },
1102
- "visitorId": {
1103
- "name": "visitorId",
1104
- "type": "text",
1105
- "primaryKey": false,
1106
- "notNull": false
1107
- },
1108
- "userId": {
1109
- "name": "userId",
1110
- "type": "text",
1111
- "primaryKey": false,
1112
- "notNull": false
1113
- },
1114
- "createdAt": {
1115
- "name": "createdAt",
1116
- "type": "timestamp",
1117
- "primaryKey": false,
1118
- "notNull": true,
1119
- "default": "now()"
1120
- }
1121
- },
1122
- "indexes": {
1123
- "idx_votes_feedbackId": {
1124
- "name": "idx_votes_feedbackId",
1125
- "columns": [
1126
- {
1127
- "expression": "feedbackId",
1128
- "isExpression": false,
1129
- "asc": true,
1130
- "nulls": "last"
1131
- }
1132
- ],
1133
- "isUnique": false,
1134
- "concurrently": false,
1135
- "method": "btree",
1136
- "with": {}
1137
- },
1138
- "idx_votes_userId": {
1139
- "name": "idx_votes_userId",
1140
- "columns": [
1141
- {
1142
- "expression": "userId",
1143
- "isExpression": false,
1144
- "asc": true,
1145
- "nulls": "last"
1146
- }
1147
- ],
1148
- "isUnique": false,
1149
- "concurrently": false,
1150
- "method": "btree",
1151
- "with": {}
1152
- }
1153
- },
1154
- "foreignKeys": {
1155
- "votes_feedbackId_feedback_feedbackId_fk": {
1156
- "name": "votes_feedbackId_feedback_feedbackId_fk",
1157
- "tableFrom": "votes",
1158
- "tableTo": "feedback",
1159
- "columnsFrom": [
1160
- "feedbackId"
1161
- ],
1162
- "columnsTo": [
1163
- "feedbackId"
1164
- ],
1165
- "onDelete": "cascade",
1166
- "onUpdate": "no action"
1167
- },
1168
- "votes_userId_user_id_fk": {
1169
- "name": "votes_userId_user_id_fk",
1170
- "tableFrom": "votes",
1171
- "tableTo": "user",
1172
- "columnsFrom": [
1173
- "userId"
1174
- ],
1175
- "columnsTo": [
1176
- "id"
1177
- ],
1178
- "onDelete": "set null",
1179
- "onUpdate": "no action"
1180
- }
1181
- },
1182
- "compositePrimaryKeys": {},
1183
- "uniqueConstraints": {
1184
- "unique_vote": {
1185
- "name": "unique_vote",
1186
- "nullsNotDistinct": false,
1187
- "columns": [
1188
- "feedbackId",
1189
- "visitorId"
1190
- ]
1191
- }
1192
- },
1193
- "policies": {},
1194
- "checkConstraints": {},
1195
- "isRLSEnabled": false
1196
- },
1197
- "public.status_history": {
1198
- "name": "status_history",
1199
- "schema": "",
1200
- "columns": {
1201
- "historyId": {
1202
- "name": "historyId",
1203
- "type": "serial",
1204
- "primaryKey": true,
1205
- "notNull": true
1206
- },
1207
- "feedbackId": {
1208
- "name": "feedbackId",
1209
- "type": "integer",
1210
- "primaryKey": false,
1211
- "notNull": true
1212
- },
1213
- "oldStatus": {
1214
- "name": "oldStatus",
1215
- "type": "text",
1216
- "primaryKey": false,
1217
- "notNull": true
1218
- },
1219
- "newStatus": {
1220
- "name": "newStatus",
1221
- "type": "text",
1222
- "primaryKey": false,
1223
- "notNull": true
1224
- },
1225
- "changedBy": {
1226
- "name": "changedBy",
1227
- "type": "text",
1228
- "primaryKey": false,
1229
- "notNull": false
1230
- },
1231
- "changedAt": {
1232
- "name": "changedAt",
1233
- "type": "timestamp",
1234
- "primaryKey": false,
1235
- "notNull": true,
1236
- "default": "now()"
1237
- },
1238
- "comment": {
1239
- "name": "comment",
1240
- "type": "text",
1241
- "primaryKey": false,
1242
- "notNull": false
1243
- }
1244
- },
1245
- "indexes": {
1246
- "idx_status_history_feedbackId": {
1247
- "name": "idx_status_history_feedbackId",
1248
- "columns": [
1249
- {
1250
- "expression": "feedbackId",
1251
- "isExpression": false,
1252
- "asc": true,
1253
- "nulls": "last"
1254
- }
1255
- ],
1256
- "isUnique": false,
1257
- "concurrently": false,
1258
- "method": "btree",
1259
- "with": {}
1260
- },
1261
- "idx_status_history_changedAt": {
1262
- "name": "idx_status_history_changedAt",
1263
- "columns": [
1264
- {
1265
- "expression": "changedAt",
1266
- "isExpression": false,
1267
- "asc": true,
1268
- "nulls": "last"
1269
- }
1270
- ],
1271
- "isUnique": false,
1272
- "concurrently": false,
1273
- "method": "btree",
1274
- "with": {}
1275
- }
1276
- },
1277
- "foreignKeys": {
1278
- "status_history_feedbackId_feedback_feedbackId_fk": {
1279
- "name": "status_history_feedbackId_feedback_feedbackId_fk",
1280
- "tableFrom": "status_history",
1281
- "tableTo": "feedback",
1282
- "columnsFrom": [
1283
- "feedbackId"
1284
- ],
1285
- "columnsTo": [
1286
- "feedbackId"
1287
- ],
1288
- "onDelete": "cascade",
1289
- "onUpdate": "no action"
1290
- },
1291
- "status_history_changedBy_user_id_fk": {
1292
- "name": "status_history_changedBy_user_id_fk",
1293
- "tableFrom": "status_history",
1294
- "tableTo": "user",
1295
- "columnsFrom": [
1296
- "changedBy"
1297
- ],
1298
- "columnsTo": [
1299
- "id"
1300
- ],
1301
- "onDelete": "set null",
1302
- "onUpdate": "no action"
1303
- }
1304
- },
1305
- "compositePrimaryKeys": {},
1306
- "uniqueConstraints": {},
1307
- "policies": {},
1308
- "checkConstraints": {},
1309
- "isRLSEnabled": false
1310
- },
1311
- "public.projects": {
1312
- "name": "projects",
1313
- "schema": "",
1314
- "columns": {
1315
- "projectId": {
1316
- "name": "projectId",
1317
- "type": "uuid",
1318
- "primaryKey": true,
1319
- "notNull": true,
1320
- "default": "gen_random_uuid()"
1321
- },
1322
- "organizationId": {
1323
- "name": "organizationId",
1324
- "type": "text",
1325
- "primaryKey": false,
1326
- "notNull": true
1327
- },
1328
- "name": {
1329
- "name": "name",
1330
- "type": "text",
1331
- "primaryKey": false,
1332
- "notNull": true
1333
- },
1334
- "slug": {
1335
- "name": "slug",
1336
- "type": "text",
1337
- "primaryKey": false,
1338
- "notNull": true
1339
- },
1340
- "description": {
1341
- "name": "description",
1342
- "type": "text",
1343
- "primaryKey": false,
1344
- "notNull": false
1345
- },
1346
- "widgetConfig": {
1347
- "name": "widgetConfig",
1348
- "type": "jsonb",
1349
- "primaryKey": false,
1350
- "notNull": false
1351
- },
1352
- "createdAt": {
1353
- "name": "createdAt",
1354
- "type": "timestamp",
1355
- "primaryKey": false,
1356
- "notNull": true,
1357
- "default": "now()"
1358
- },
1359
- "updatedAt": {
1360
- "name": "updatedAt",
1361
- "type": "timestamp",
1362
- "primaryKey": false,
1363
- "notNull": true,
1364
- "default": "now()"
1365
- }
1366
- },
1367
- "indexes": {
1368
- "idx_projects_orgId": {
1369
- "name": "idx_projects_orgId",
1370
- "columns": [
1371
- {
1372
- "expression": "organizationId",
1373
- "isExpression": false,
1374
- "asc": true,
1375
- "nulls": "last"
1376
- }
1377
- ],
1378
- "isUnique": false,
1379
- "concurrently": false,
1380
- "method": "btree",
1381
- "with": {}
1382
- }
1383
- },
1384
- "foreignKeys": {
1385
- "projects_organizationId_organizations_id_fk": {
1386
- "name": "projects_organizationId_organizations_id_fk",
1387
- "tableFrom": "projects",
1388
- "tableTo": "organizations",
1389
- "columnsFrom": [
1390
- "organizationId"
1391
- ],
1392
- "columnsTo": [
1393
- "id"
1394
- ],
1395
- "onDelete": "cascade",
1396
- "onUpdate": "no action"
1397
- }
1398
- },
1399
- "compositePrimaryKeys": {},
1400
- "uniqueConstraints": {
1401
- "unique_slug_org": {
1402
- "name": "unique_slug_org",
1403
- "nullsNotDistinct": false,
1404
- "columns": [
1405
- "slug",
1406
- "organizationId"
1407
- ]
1408
- }
1409
- },
1410
- "policies": {},
1411
- "checkConstraints": {},
1412
- "isRLSEnabled": false
1413
- },
1414
- "public.notification_preferences": {
1415
- "name": "notification_preferences",
1416
- "schema": "",
1417
- "columns": {
1418
- "userId": {
1419
- "name": "userId",
1420
- "type": "text",
1421
- "primaryKey": true,
1422
- "notNull": true
1423
- },
1424
- "statusChange": {
1425
- "name": "statusChange",
1426
- "type": "boolean",
1427
- "primaryKey": false,
1428
- "notNull": true,
1429
- "default": true
1430
- },
1431
- "newComment": {
1432
- "name": "newComment",
1433
- "type": "boolean",
1434
- "primaryKey": false,
1435
- "notNull": true,
1436
- "default": true
1437
- },
1438
- "updatedAt": {
1439
- "name": "updatedAt",
1440
- "type": "timestamp",
1441
- "primaryKey": false,
1442
- "notNull": true,
1443
- "default": "now()"
1444
- }
1445
- },
1446
- "indexes": {},
1447
- "foreignKeys": {
1448
- "notification_preferences_userId_user_id_fk": {
1449
- "name": "notification_preferences_userId_user_id_fk",
1450
- "tableFrom": "notification_preferences",
1451
- "tableTo": "user",
1452
- "columnsFrom": [
1453
- "userId"
1454
- ],
1455
- "columnsTo": [
1456
- "id"
1457
- ],
1458
- "onDelete": "cascade",
1459
- "onUpdate": "no action"
1460
- }
1461
- },
1462
- "compositePrimaryKeys": {},
1463
- "uniqueConstraints": {},
1464
- "policies": {},
1465
- "checkConstraints": {},
1466
- "isRLSEnabled": false
1467
- },
1468
- "public.notifications": {
1469
- "name": "notifications",
1470
- "schema": "",
1471
- "columns": {
1472
- "notificationId": {
1473
- "name": "notificationId",
1474
- "type": "serial",
1475
- "primaryKey": true,
1476
- "notNull": true
1477
- },
1478
- "userId": {
1479
- "name": "userId",
1480
- "type": "text",
1481
- "primaryKey": false,
1482
- "notNull": true
1483
- },
1484
- "type": {
1485
- "name": "type",
1486
- "type": "text",
1487
- "primaryKey": false,
1488
- "notNull": true
1489
- },
1490
- "feedbackId": {
1491
- "name": "feedbackId",
1492
- "type": "serial",
1493
- "primaryKey": false,
1494
- "notNull": true
1495
- },
1496
- "data": {
1497
- "name": "data",
1498
- "type": "jsonb",
1499
- "primaryKey": false,
1500
- "notNull": false
1501
- },
1502
- "status": {
1503
- "name": "status",
1504
- "type": "text",
1505
- "primaryKey": false,
1506
- "notNull": true,
1507
- "default": "'pending'"
1508
- },
1509
- "sentAt": {
1510
- "name": "sentAt",
1511
- "type": "timestamp",
1512
- "primaryKey": false,
1513
- "notNull": false
1514
- },
1515
- "error": {
1516
- "name": "error",
1517
- "type": "text",
1518
- "primaryKey": false,
1519
- "notNull": false
1520
- },
1521
- "createdAt": {
1522
- "name": "createdAt",
1523
- "type": "timestamp",
1524
- "primaryKey": false,
1525
- "notNull": true,
1526
- "default": "now()"
1527
- }
1528
- },
1529
- "indexes": {
1530
- "idx_notifications_userId": {
1531
- "name": "idx_notifications_userId",
1532
- "columns": [
1533
- {
1534
- "expression": "userId",
1535
- "isExpression": false,
1536
- "asc": true,
1537
- "nulls": "last"
1538
- }
1539
- ],
1540
- "isUnique": false,
1541
- "concurrently": false,
1542
- "method": "btree",
1543
- "with": {}
1544
- },
1545
- "idx_notifications_status": {
1546
- "name": "idx_notifications_status",
1547
- "columns": [
1548
- {
1549
- "expression": "status",
1550
- "isExpression": false,
1551
- "asc": true,
1552
- "nulls": "last"
1553
- }
1554
- ],
1555
- "isUnique": false,
1556
- "concurrently": false,
1557
- "method": "btree",
1558
- "with": {}
1559
- },
1560
- "idx_notifications_type": {
1561
- "name": "idx_notifications_type",
1562
- "columns": [
1563
- {
1564
- "expression": "type",
1565
- "isExpression": false,
1566
- "asc": true,
1567
- "nulls": "last"
1568
- }
1569
- ],
1570
- "isUnique": false,
1571
- "concurrently": false,
1572
- "method": "btree",
1573
- "with": {}
1574
- }
1575
- },
1576
- "foreignKeys": {
1577
- "notifications_userId_user_id_fk": {
1578
- "name": "notifications_userId_user_id_fk",
1579
- "tableFrom": "notifications",
1580
- "tableTo": "user",
1581
- "columnsFrom": [
1582
- "userId"
1583
- ],
1584
- "columnsTo": [
1585
- "id"
1586
- ],
1587
- "onDelete": "cascade",
1588
- "onUpdate": "no action"
1589
- },
1590
- "notifications_feedbackId_feedback_feedbackId_fk": {
1591
- "name": "notifications_feedbackId_feedback_feedbackId_fk",
1592
- "tableFrom": "notifications",
1593
- "tableTo": "feedback",
1594
- "columnsFrom": [
1595
- "feedbackId"
1596
- ],
1597
- "columnsTo": [
1598
- "feedbackId"
1599
- ],
1600
- "onDelete": "cascade",
1601
- "onUpdate": "no action"
1602
- }
1603
- },
1604
- "compositePrimaryKeys": {},
1605
- "uniqueConstraints": {},
1606
- "policies": {},
1607
- "checkConstraints": {},
1608
- "isRLSEnabled": false
1609
- },
1610
- "public.feedback_tags": {
1611
- "name": "feedback_tags",
1612
- "schema": "",
1613
- "columns": {
1614
- "id": {
1615
- "name": "id",
1616
- "type": "serial",
1617
- "primaryKey": true,
1618
- "notNull": true
1619
- },
1620
- "feedbackId": {
1621
- "name": "feedbackId",
1622
- "type": "integer",
1623
- "primaryKey": false,
1624
- "notNull": true
1625
- },
1626
- "tagId": {
1627
- "name": "tagId",
1628
- "type": "integer",
1629
- "primaryKey": false,
1630
- "notNull": true
1631
- },
1632
- "createdAt": {
1633
- "name": "createdAt",
1634
- "type": "timestamp",
1635
- "primaryKey": false,
1636
- "notNull": true,
1637
- "default": "now()"
1638
- }
1639
- },
1640
- "indexes": {
1641
- "idx_feedback_tags_feedbackId": {
1642
- "name": "idx_feedback_tags_feedbackId",
1643
- "columns": [
1644
- {
1645
- "expression": "feedbackId",
1646
- "isExpression": false,
1647
- "asc": true,
1648
- "nulls": "last"
1649
- }
1650
- ],
1651
- "isUnique": false,
1652
- "concurrently": false,
1653
- "method": "btree",
1654
- "with": {}
1655
- },
1656
- "idx_feedback_tags_tagId": {
1657
- "name": "idx_feedback_tags_tagId",
1658
- "columns": [
1659
- {
1660
- "expression": "tagId",
1661
- "isExpression": false,
1662
- "asc": true,
1663
- "nulls": "last"
1664
- }
1665
- ],
1666
- "isUnique": false,
1667
- "concurrently": false,
1668
- "method": "btree",
1669
- "with": {}
1670
- },
1671
- "idx_feedback_tags_unique": {
1672
- "name": "idx_feedback_tags_unique",
1673
- "columns": [
1674
- {
1675
- "expression": "feedbackId",
1676
- "isExpression": false,
1677
- "asc": true,
1678
- "nulls": "last"
1679
- },
1680
- {
1681
- "expression": "tagId",
1682
- "isExpression": false,
1683
- "asc": true,
1684
- "nulls": "last"
1685
- }
1686
- ],
1687
- "isUnique": false,
1688
- "concurrently": false,
1689
- "method": "btree",
1690
- "with": {}
1691
- }
1692
- },
1693
- "foreignKeys": {
1694
- "feedback_tags_feedbackId_feedback_feedbackId_fk": {
1695
- "name": "feedback_tags_feedbackId_feedback_feedbackId_fk",
1696
- "tableFrom": "feedback_tags",
1697
- "tableTo": "feedback",
1698
- "columnsFrom": [
1699
- "feedbackId"
1700
- ],
1701
- "columnsTo": [
1702
- "feedbackId"
1703
- ],
1704
- "onDelete": "cascade",
1705
- "onUpdate": "no action"
1706
- },
1707
- "feedback_tags_tagId_tags_tagId_fk": {
1708
- "name": "feedback_tags_tagId_tags_tagId_fk",
1709
- "tableFrom": "feedback_tags",
1710
- "tableTo": "tags",
1711
- "columnsFrom": [
1712
- "tagId"
1713
- ],
1714
- "columnsTo": [
1715
- "tagId"
1716
- ],
1717
- "onDelete": "cascade",
1718
- "onUpdate": "no action"
1719
- }
1720
- },
1721
- "compositePrimaryKeys": {},
1722
- "uniqueConstraints": {},
1723
- "policies": {},
1724
- "checkConstraints": {},
1725
- "isRLSEnabled": false
1726
- },
1727
- "public.tags": {
1728
- "name": "tags",
1729
- "schema": "",
1730
- "columns": {
1731
- "tagId": {
1732
- "name": "tagId",
1733
- "type": "serial",
1734
- "primaryKey": true,
1735
- "notNull": true
1736
- },
1737
- "name": {
1738
- "name": "name",
1739
- "type": "text",
1740
- "primaryKey": false,
1741
- "notNull": true
1742
- },
1743
- "slug": {
1744
- "name": "slug",
1745
- "type": "text",
1746
- "primaryKey": false,
1747
- "notNull": true
1748
- },
1749
- "color": {
1750
- "name": "color",
1751
- "type": "text",
1752
- "primaryKey": false,
1753
- "notNull": false,
1754
- "default": "'#3b82f6'"
1755
- },
1756
- "description": {
1757
- "name": "description",
1758
- "type": "text",
1759
- "primaryKey": false,
1760
- "notNull": false
1761
- },
1762
- "createdAt": {
1763
- "name": "createdAt",
1764
- "type": "timestamp",
1765
- "primaryKey": false,
1766
- "notNull": true,
1767
- "default": "now()"
1768
- }
1769
- },
1770
- "indexes": {},
1771
- "foreignKeys": {},
1772
- "compositePrimaryKeys": {},
1773
- "uniqueConstraints": {
1774
- "tags_name_unique": {
1775
- "name": "tags_name_unique",
1776
- "nullsNotDistinct": false,
1777
- "columns": [
1778
- "name"
1779
- ]
1780
- },
1781
- "tags_slug_unique": {
1782
- "name": "tags_slug_unique",
1783
- "nullsNotDistinct": false,
1784
- "columns": [
1785
- "slug"
1786
- ]
1787
- }
1788
- },
1789
- "policies": {},
1790
- "checkConstraints": {},
1791
- "isRLSEnabled": false
1792
- }
1793
- },
1794
- "enums": {},
1795
- "schemas": {},
1796
- "sequences": {},
1797
- "roles": {},
1798
- "policies": {},
1799
- "views": {},
1800
- "_meta": {
1801
- "columns": {},
1802
- "schemas": {},
1803
- "tables": {}
1804
- }
1805
- }