@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,1615 +0,0 @@
1
- {
2
- "id": "16a78873-3ad4-4019-bf34-d611d7053817",
3
- "prevId": "3638a3ac-c497-4f7a-9ea0-93db6016ea35",
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
- },
712
- "indexes": {
713
- "idx_feedback_orgId": {
714
- "name": "idx_feedback_orgId",
715
- "columns": [
716
- {
717
- "expression": "organizationId",
718
- "isExpression": false,
719
- "asc": true,
720
- "nulls": "last"
721
- }
722
- ],
723
- "isUnique": false,
724
- "concurrently": false,
725
- "method": "btree",
726
- "with": {}
727
- },
728
- "idx_feedback_status": {
729
- "name": "idx_feedback_status",
730
- "columns": [
731
- {
732
- "expression": "status",
733
- "isExpression": false,
734
- "asc": true,
735
- "nulls": "last"
736
- }
737
- ],
738
- "isUnique": false,
739
- "concurrently": false,
740
- "method": "btree",
741
- "with": {}
742
- },
743
- "idx_feedback_createdAt": {
744
- "name": "idx_feedback_createdAt",
745
- "columns": [
746
- {
747
- "expression": "createdAt",
748
- "isExpression": false,
749
- "asc": true,
750
- "nulls": "last"
751
- }
752
- ],
753
- "isUnique": false,
754
- "concurrently": false,
755
- "method": "btree",
756
- "with": {}
757
- },
758
- "idx_feedback_submittedBy": {
759
- "name": "idx_feedback_submittedBy",
760
- "columns": [
761
- {
762
- "expression": "submittedBy",
763
- "isExpression": false,
764
- "asc": true,
765
- "nulls": "last"
766
- }
767
- ],
768
- "isUnique": false,
769
- "concurrently": false,
770
- "method": "btree",
771
- "with": {}
772
- },
773
- "idx_feedback_deletedAt": {
774
- "name": "idx_feedback_deletedAt",
775
- "columns": [
776
- {
777
- "expression": "deletedAt",
778
- "isExpression": false,
779
- "asc": true,
780
- "nulls": "last"
781
- }
782
- ],
783
- "isUnique": false,
784
- "concurrently": false,
785
- "method": "btree",
786
- "with": {}
787
- }
788
- },
789
- "foreignKeys": {
790
- "feedback_submittedBy_user_id_fk": {
791
- "name": "feedback_submittedBy_user_id_fk",
792
- "tableFrom": "feedback",
793
- "tableTo": "user",
794
- "columnsFrom": [
795
- "submittedBy"
796
- ],
797
- "columnsTo": [
798
- "id"
799
- ],
800
- "onDelete": "set null",
801
- "onUpdate": "no action"
802
- }
803
- },
804
- "compositePrimaryKeys": {},
805
- "uniqueConstraints": {},
806
- "policies": {},
807
- "checkConstraints": {},
808
- "isRLSEnabled": false
809
- },
810
- "public.user_profiles": {
811
- "name": "user_profiles",
812
- "schema": "",
813
- "columns": {
814
- "user_id": {
815
- "name": "user_id",
816
- "type": "text",
817
- "primaryKey": true,
818
- "notNull": true
819
- },
820
- "name": {
821
- "name": "name",
822
- "type": "text",
823
- "primaryKey": false,
824
- "notNull": true
825
- },
826
- "created_at": {
827
- "name": "created_at",
828
- "type": "timestamp",
829
- "primaryKey": false,
830
- "notNull": true,
831
- "default": "now()"
832
- },
833
- "updated_at": {
834
- "name": "updated_at",
835
- "type": "timestamp",
836
- "primaryKey": false,
837
- "notNull": true,
838
- "default": "now()"
839
- }
840
- },
841
- "indexes": {},
842
- "foreignKeys": {
843
- "user_profiles_user_id_user_id_fk": {
844
- "name": "user_profiles_user_id_user_id_fk",
845
- "tableFrom": "user_profiles",
846
- "tableTo": "user",
847
- "columnsFrom": [
848
- "user_id"
849
- ],
850
- "columnsTo": [
851
- "id"
852
- ],
853
- "onDelete": "cascade",
854
- "onUpdate": "no action"
855
- }
856
- },
857
- "compositePrimaryKeys": {},
858
- "uniqueConstraints": {},
859
- "policies": {},
860
- "checkConstraints": {},
861
- "isRLSEnabled": false
862
- },
863
- "public.organizations": {
864
- "name": "organizations",
865
- "schema": "",
866
- "columns": {
867
- "id": {
868
- "name": "id",
869
- "type": "text",
870
- "primaryKey": true,
871
- "notNull": true
872
- },
873
- "name": {
874
- "name": "name",
875
- "type": "text",
876
- "primaryKey": false,
877
- "notNull": true
878
- },
879
- "slug": {
880
- "name": "slug",
881
- "type": "text",
882
- "primaryKey": false,
883
- "notNull": true
884
- },
885
- "description": {
886
- "name": "description",
887
- "type": "text",
888
- "primaryKey": false,
889
- "notNull": false
890
- },
891
- "created_at": {
892
- "name": "created_at",
893
- "type": "timestamp",
894
- "primaryKey": false,
895
- "notNull": true,
896
- "default": "now()"
897
- },
898
- "updated_at": {
899
- "name": "updated_at",
900
- "type": "timestamp",
901
- "primaryKey": false,
902
- "notNull": true,
903
- "default": "now()"
904
- }
905
- },
906
- "indexes": {},
907
- "foreignKeys": {},
908
- "compositePrimaryKeys": {},
909
- "uniqueConstraints": {
910
- "organizations_slug_unique": {
911
- "name": "organizations_slug_unique",
912
- "nullsNotDistinct": false,
913
- "columns": [
914
- "slug"
915
- ]
916
- }
917
- },
918
- "policies": {},
919
- "checkConstraints": {},
920
- "isRLSEnabled": false
921
- },
922
- "public.organization_members": {
923
- "name": "organization_members",
924
- "schema": "",
925
- "columns": {
926
- "organization_id": {
927
- "name": "organization_id",
928
- "type": "text",
929
- "primaryKey": false,
930
- "notNull": true
931
- },
932
- "user_id": {
933
- "name": "user_id",
934
- "type": "text",
935
- "primaryKey": false,
936
- "notNull": true
937
- },
938
- "role": {
939
- "name": "role",
940
- "type": "text",
941
- "primaryKey": false,
942
- "notNull": true
943
- },
944
- "created_at": {
945
- "name": "created_at",
946
- "type": "timestamp",
947
- "primaryKey": false,
948
- "notNull": true,
949
- "default": "now()"
950
- }
951
- },
952
- "indexes": {},
953
- "foreignKeys": {
954
- "organization_members_organization_id_organizations_id_fk": {
955
- "name": "organization_members_organization_id_organizations_id_fk",
956
- "tableFrom": "organization_members",
957
- "tableTo": "organizations",
958
- "columnsFrom": [
959
- "organization_id"
960
- ],
961
- "columnsTo": [
962
- "id"
963
- ],
964
- "onDelete": "cascade",
965
- "onUpdate": "no action"
966
- },
967
- "organization_members_user_id_user_id_fk": {
968
- "name": "organization_members_user_id_user_id_fk",
969
- "tableFrom": "organization_members",
970
- "tableTo": "user",
971
- "columnsFrom": [
972
- "user_id"
973
- ],
974
- "columnsTo": [
975
- "id"
976
- ],
977
- "onDelete": "cascade",
978
- "onUpdate": "no action"
979
- }
980
- },
981
- "compositePrimaryKeys": {
982
- "organization_members_organization_id_user_id_pk": {
983
- "name": "organization_members_organization_id_user_id_pk",
984
- "columns": [
985
- "organization_id",
986
- "user_id"
987
- ]
988
- }
989
- },
990
- "uniqueConstraints": {},
991
- "policies": {},
992
- "checkConstraints": {},
993
- "isRLSEnabled": false
994
- },
995
- "public.invitations": {
996
- "name": "invitations",
997
- "schema": "",
998
- "columns": {
999
- "id": {
1000
- "name": "id",
1001
- "type": "text",
1002
- "primaryKey": true,
1003
- "notNull": true
1004
- },
1005
- "organization_id": {
1006
- "name": "organization_id",
1007
- "type": "text",
1008
- "primaryKey": false,
1009
- "notNull": true
1010
- },
1011
- "email": {
1012
- "name": "email",
1013
- "type": "text",
1014
- "primaryKey": false,
1015
- "notNull": true
1016
- },
1017
- "role": {
1018
- "name": "role",
1019
- "type": "text",
1020
- "primaryKey": false,
1021
- "notNull": true
1022
- },
1023
- "token": {
1024
- "name": "token",
1025
- "type": "text",
1026
- "primaryKey": false,
1027
- "notNull": true
1028
- },
1029
- "expires_at": {
1030
- "name": "expires_at",
1031
- "type": "timestamp",
1032
- "primaryKey": false,
1033
- "notNull": true
1034
- },
1035
- "accepted_at": {
1036
- "name": "accepted_at",
1037
- "type": "timestamp",
1038
- "primaryKey": false,
1039
- "notNull": false
1040
- },
1041
- "created_at": {
1042
- "name": "created_at",
1043
- "type": "timestamp",
1044
- "primaryKey": false,
1045
- "notNull": true,
1046
- "default": "now()"
1047
- }
1048
- },
1049
- "indexes": {},
1050
- "foreignKeys": {
1051
- "invitations_organization_id_organizations_id_fk": {
1052
- "name": "invitations_organization_id_organizations_id_fk",
1053
- "tableFrom": "invitations",
1054
- "tableTo": "organizations",
1055
- "columnsFrom": [
1056
- "organization_id"
1057
- ],
1058
- "columnsTo": [
1059
- "id"
1060
- ],
1061
- "onDelete": "cascade",
1062
- "onUpdate": "no action"
1063
- }
1064
- },
1065
- "compositePrimaryKeys": {},
1066
- "uniqueConstraints": {
1067
- "invitations_token_unique": {
1068
- "name": "invitations_token_unique",
1069
- "nullsNotDistinct": false,
1070
- "columns": [
1071
- "token"
1072
- ]
1073
- }
1074
- },
1075
- "policies": {},
1076
- "checkConstraints": {},
1077
- "isRLSEnabled": false
1078
- },
1079
- "public.votes": {
1080
- "name": "votes",
1081
- "schema": "",
1082
- "columns": {
1083
- "voteId": {
1084
- "name": "voteId",
1085
- "type": "serial",
1086
- "primaryKey": true,
1087
- "notNull": true
1088
- },
1089
- "feedbackId": {
1090
- "name": "feedbackId",
1091
- "type": "serial",
1092
- "primaryKey": false,
1093
- "notNull": true
1094
- },
1095
- "visitorId": {
1096
- "name": "visitorId",
1097
- "type": "text",
1098
- "primaryKey": false,
1099
- "notNull": false
1100
- },
1101
- "userId": {
1102
- "name": "userId",
1103
- "type": "text",
1104
- "primaryKey": false,
1105
- "notNull": false
1106
- },
1107
- "createdAt": {
1108
- "name": "createdAt",
1109
- "type": "timestamp",
1110
- "primaryKey": false,
1111
- "notNull": true,
1112
- "default": "now()"
1113
- }
1114
- },
1115
- "indexes": {
1116
- "idx_votes_feedbackId": {
1117
- "name": "idx_votes_feedbackId",
1118
- "columns": [
1119
- {
1120
- "expression": "feedbackId",
1121
- "isExpression": false,
1122
- "asc": true,
1123
- "nulls": "last"
1124
- }
1125
- ],
1126
- "isUnique": false,
1127
- "concurrently": false,
1128
- "method": "btree",
1129
- "with": {}
1130
- },
1131
- "idx_votes_userId": {
1132
- "name": "idx_votes_userId",
1133
- "columns": [
1134
- {
1135
- "expression": "userId",
1136
- "isExpression": false,
1137
- "asc": true,
1138
- "nulls": "last"
1139
- }
1140
- ],
1141
- "isUnique": false,
1142
- "concurrently": false,
1143
- "method": "btree",
1144
- "with": {}
1145
- }
1146
- },
1147
- "foreignKeys": {
1148
- "votes_feedbackId_feedback_feedbackId_fk": {
1149
- "name": "votes_feedbackId_feedback_feedbackId_fk",
1150
- "tableFrom": "votes",
1151
- "tableTo": "feedback",
1152
- "columnsFrom": [
1153
- "feedbackId"
1154
- ],
1155
- "columnsTo": [
1156
- "feedbackId"
1157
- ],
1158
- "onDelete": "cascade",
1159
- "onUpdate": "no action"
1160
- },
1161
- "votes_userId_user_id_fk": {
1162
- "name": "votes_userId_user_id_fk",
1163
- "tableFrom": "votes",
1164
- "tableTo": "user",
1165
- "columnsFrom": [
1166
- "userId"
1167
- ],
1168
- "columnsTo": [
1169
- "id"
1170
- ],
1171
- "onDelete": "set null",
1172
- "onUpdate": "no action"
1173
- }
1174
- },
1175
- "compositePrimaryKeys": {},
1176
- "uniqueConstraints": {
1177
- "unique_vote": {
1178
- "name": "unique_vote",
1179
- "nullsNotDistinct": false,
1180
- "columns": [
1181
- "feedbackId",
1182
- "visitorId"
1183
- ]
1184
- }
1185
- },
1186
- "policies": {},
1187
- "checkConstraints": {},
1188
- "isRLSEnabled": false
1189
- },
1190
- "public.status_history": {
1191
- "name": "status_history",
1192
- "schema": "",
1193
- "columns": {
1194
- "historyId": {
1195
- "name": "historyId",
1196
- "type": "serial",
1197
- "primaryKey": true,
1198
- "notNull": true
1199
- },
1200
- "feedbackId": {
1201
- "name": "feedbackId",
1202
- "type": "integer",
1203
- "primaryKey": false,
1204
- "notNull": true
1205
- },
1206
- "oldStatus": {
1207
- "name": "oldStatus",
1208
- "type": "text",
1209
- "primaryKey": false,
1210
- "notNull": true
1211
- },
1212
- "newStatus": {
1213
- "name": "newStatus",
1214
- "type": "text",
1215
- "primaryKey": false,
1216
- "notNull": true
1217
- },
1218
- "changedBy": {
1219
- "name": "changedBy",
1220
- "type": "text",
1221
- "primaryKey": false,
1222
- "notNull": false
1223
- },
1224
- "changedAt": {
1225
- "name": "changedAt",
1226
- "type": "timestamp",
1227
- "primaryKey": false,
1228
- "notNull": true,
1229
- "default": "now()"
1230
- },
1231
- "comment": {
1232
- "name": "comment",
1233
- "type": "text",
1234
- "primaryKey": false,
1235
- "notNull": false
1236
- }
1237
- },
1238
- "indexes": {
1239
- "idx_status_history_feedbackId": {
1240
- "name": "idx_status_history_feedbackId",
1241
- "columns": [
1242
- {
1243
- "expression": "feedbackId",
1244
- "isExpression": false,
1245
- "asc": true,
1246
- "nulls": "last"
1247
- }
1248
- ],
1249
- "isUnique": false,
1250
- "concurrently": false,
1251
- "method": "btree",
1252
- "with": {}
1253
- },
1254
- "idx_status_history_changedAt": {
1255
- "name": "idx_status_history_changedAt",
1256
- "columns": [
1257
- {
1258
- "expression": "changedAt",
1259
- "isExpression": false,
1260
- "asc": true,
1261
- "nulls": "last"
1262
- }
1263
- ],
1264
- "isUnique": false,
1265
- "concurrently": false,
1266
- "method": "btree",
1267
- "with": {}
1268
- }
1269
- },
1270
- "foreignKeys": {
1271
- "status_history_feedbackId_feedback_feedbackId_fk": {
1272
- "name": "status_history_feedbackId_feedback_feedbackId_fk",
1273
- "tableFrom": "status_history",
1274
- "tableTo": "feedback",
1275
- "columnsFrom": [
1276
- "feedbackId"
1277
- ],
1278
- "columnsTo": [
1279
- "feedbackId"
1280
- ],
1281
- "onDelete": "cascade",
1282
- "onUpdate": "no action"
1283
- },
1284
- "status_history_changedBy_user_id_fk": {
1285
- "name": "status_history_changedBy_user_id_fk",
1286
- "tableFrom": "status_history",
1287
- "tableTo": "user",
1288
- "columnsFrom": [
1289
- "changedBy"
1290
- ],
1291
- "columnsTo": [
1292
- "id"
1293
- ],
1294
- "onDelete": "set null",
1295
- "onUpdate": "no action"
1296
- }
1297
- },
1298
- "compositePrimaryKeys": {},
1299
- "uniqueConstraints": {},
1300
- "policies": {},
1301
- "checkConstraints": {},
1302
- "isRLSEnabled": false
1303
- },
1304
- "public.projects": {
1305
- "name": "projects",
1306
- "schema": "",
1307
- "columns": {
1308
- "projectId": {
1309
- "name": "projectId",
1310
- "type": "uuid",
1311
- "primaryKey": true,
1312
- "notNull": true,
1313
- "default": "gen_random_uuid()"
1314
- },
1315
- "organizationId": {
1316
- "name": "organizationId",
1317
- "type": "text",
1318
- "primaryKey": false,
1319
- "notNull": true
1320
- },
1321
- "name": {
1322
- "name": "name",
1323
- "type": "text",
1324
- "primaryKey": false,
1325
- "notNull": true
1326
- },
1327
- "slug": {
1328
- "name": "slug",
1329
- "type": "text",
1330
- "primaryKey": false,
1331
- "notNull": true
1332
- },
1333
- "description": {
1334
- "name": "description",
1335
- "type": "text",
1336
- "primaryKey": false,
1337
- "notNull": false
1338
- },
1339
- "widgetConfig": {
1340
- "name": "widgetConfig",
1341
- "type": "jsonb",
1342
- "primaryKey": false,
1343
- "notNull": false
1344
- },
1345
- "createdAt": {
1346
- "name": "createdAt",
1347
- "type": "timestamp",
1348
- "primaryKey": false,
1349
- "notNull": true,
1350
- "default": "now()"
1351
- },
1352
- "updatedAt": {
1353
- "name": "updatedAt",
1354
- "type": "timestamp",
1355
- "primaryKey": false,
1356
- "notNull": true,
1357
- "default": "now()"
1358
- }
1359
- },
1360
- "indexes": {
1361
- "idx_projects_orgId": {
1362
- "name": "idx_projects_orgId",
1363
- "columns": [
1364
- {
1365
- "expression": "organizationId",
1366
- "isExpression": false,
1367
- "asc": true,
1368
- "nulls": "last"
1369
- }
1370
- ],
1371
- "isUnique": false,
1372
- "concurrently": false,
1373
- "method": "btree",
1374
- "with": {}
1375
- }
1376
- },
1377
- "foreignKeys": {
1378
- "projects_organizationId_organizations_id_fk": {
1379
- "name": "projects_organizationId_organizations_id_fk",
1380
- "tableFrom": "projects",
1381
- "tableTo": "organizations",
1382
- "columnsFrom": [
1383
- "organizationId"
1384
- ],
1385
- "columnsTo": [
1386
- "id"
1387
- ],
1388
- "onDelete": "cascade",
1389
- "onUpdate": "no action"
1390
- }
1391
- },
1392
- "compositePrimaryKeys": {},
1393
- "uniqueConstraints": {
1394
- "unique_slug_org": {
1395
- "name": "unique_slug_org",
1396
- "nullsNotDistinct": false,
1397
- "columns": [
1398
- "slug",
1399
- "organizationId"
1400
- ]
1401
- }
1402
- },
1403
- "policies": {},
1404
- "checkConstraints": {},
1405
- "isRLSEnabled": false
1406
- },
1407
- "public.notification_preferences": {
1408
- "name": "notification_preferences",
1409
- "schema": "",
1410
- "columns": {
1411
- "userId": {
1412
- "name": "userId",
1413
- "type": "text",
1414
- "primaryKey": true,
1415
- "notNull": true
1416
- },
1417
- "statusChange": {
1418
- "name": "statusChange",
1419
- "type": "boolean",
1420
- "primaryKey": false,
1421
- "notNull": true,
1422
- "default": true
1423
- },
1424
- "newComment": {
1425
- "name": "newComment",
1426
- "type": "boolean",
1427
- "primaryKey": false,
1428
- "notNull": true,
1429
- "default": true
1430
- },
1431
- "updatedAt": {
1432
- "name": "updatedAt",
1433
- "type": "timestamp",
1434
- "primaryKey": false,
1435
- "notNull": true,
1436
- "default": "now()"
1437
- }
1438
- },
1439
- "indexes": {},
1440
- "foreignKeys": {
1441
- "notification_preferences_userId_user_id_fk": {
1442
- "name": "notification_preferences_userId_user_id_fk",
1443
- "tableFrom": "notification_preferences",
1444
- "tableTo": "user",
1445
- "columnsFrom": [
1446
- "userId"
1447
- ],
1448
- "columnsTo": [
1449
- "id"
1450
- ],
1451
- "onDelete": "cascade",
1452
- "onUpdate": "no action"
1453
- }
1454
- },
1455
- "compositePrimaryKeys": {},
1456
- "uniqueConstraints": {},
1457
- "policies": {},
1458
- "checkConstraints": {},
1459
- "isRLSEnabled": false
1460
- },
1461
- "public.notifications": {
1462
- "name": "notifications",
1463
- "schema": "",
1464
- "columns": {
1465
- "notificationId": {
1466
- "name": "notificationId",
1467
- "type": "serial",
1468
- "primaryKey": true,
1469
- "notNull": true
1470
- },
1471
- "userId": {
1472
- "name": "userId",
1473
- "type": "text",
1474
- "primaryKey": false,
1475
- "notNull": true
1476
- },
1477
- "type": {
1478
- "name": "type",
1479
- "type": "text",
1480
- "primaryKey": false,
1481
- "notNull": true
1482
- },
1483
- "feedbackId": {
1484
- "name": "feedbackId",
1485
- "type": "serial",
1486
- "primaryKey": false,
1487
- "notNull": true
1488
- },
1489
- "data": {
1490
- "name": "data",
1491
- "type": "jsonb",
1492
- "primaryKey": false,
1493
- "notNull": false
1494
- },
1495
- "status": {
1496
- "name": "status",
1497
- "type": "text",
1498
- "primaryKey": false,
1499
- "notNull": true,
1500
- "default": "'pending'"
1501
- },
1502
- "sentAt": {
1503
- "name": "sentAt",
1504
- "type": "timestamp",
1505
- "primaryKey": false,
1506
- "notNull": false
1507
- },
1508
- "error": {
1509
- "name": "error",
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
- },
1522
- "indexes": {
1523
- "idx_notifications_userId": {
1524
- "name": "idx_notifications_userId",
1525
- "columns": [
1526
- {
1527
- "expression": "userId",
1528
- "isExpression": false,
1529
- "asc": true,
1530
- "nulls": "last"
1531
- }
1532
- ],
1533
- "isUnique": false,
1534
- "concurrently": false,
1535
- "method": "btree",
1536
- "with": {}
1537
- },
1538
- "idx_notifications_status": {
1539
- "name": "idx_notifications_status",
1540
- "columns": [
1541
- {
1542
- "expression": "status",
1543
- "isExpression": false,
1544
- "asc": true,
1545
- "nulls": "last"
1546
- }
1547
- ],
1548
- "isUnique": false,
1549
- "concurrently": false,
1550
- "method": "btree",
1551
- "with": {}
1552
- },
1553
- "idx_notifications_type": {
1554
- "name": "idx_notifications_type",
1555
- "columns": [
1556
- {
1557
- "expression": "type",
1558
- "isExpression": false,
1559
- "asc": true,
1560
- "nulls": "last"
1561
- }
1562
- ],
1563
- "isUnique": false,
1564
- "concurrently": false,
1565
- "method": "btree",
1566
- "with": {}
1567
- }
1568
- },
1569
- "foreignKeys": {
1570
- "notifications_userId_user_id_fk": {
1571
- "name": "notifications_userId_user_id_fk",
1572
- "tableFrom": "notifications",
1573
- "tableTo": "user",
1574
- "columnsFrom": [
1575
- "userId"
1576
- ],
1577
- "columnsTo": [
1578
- "id"
1579
- ],
1580
- "onDelete": "cascade",
1581
- "onUpdate": "no action"
1582
- },
1583
- "notifications_feedbackId_feedback_feedbackId_fk": {
1584
- "name": "notifications_feedbackId_feedback_feedbackId_fk",
1585
- "tableFrom": "notifications",
1586
- "tableTo": "feedback",
1587
- "columnsFrom": [
1588
- "feedbackId"
1589
- ],
1590
- "columnsTo": [
1591
- "feedbackId"
1592
- ],
1593
- "onDelete": "cascade",
1594
- "onUpdate": "no action"
1595
- }
1596
- },
1597
- "compositePrimaryKeys": {},
1598
- "uniqueConstraints": {},
1599
- "policies": {},
1600
- "checkConstraints": {},
1601
- "isRLSEnabled": false
1602
- }
1603
- },
1604
- "enums": {},
1605
- "schemas": {},
1606
- "sequences": {},
1607
- "roles": {},
1608
- "policies": {},
1609
- "views": {},
1610
- "_meta": {
1611
- "columns": {},
1612
- "schemas": {},
1613
- "tables": {}
1614
- }
1615
- }