dmart 0.1.9__py3-none-any.whl

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 (149) hide show
  1. alembic/__init__.py +0 -0
  2. alembic/env.py +91 -0
  3. alembic/scripts/__init__.py +0 -0
  4. alembic/scripts/calculate_checksums.py +77 -0
  5. alembic/scripts/migration_f7a4949eed19.py +28 -0
  6. alembic/versions/0f3d2b1a7c21_add_authz_materialized_views.py +87 -0
  7. alembic/versions/10d2041b94d4_last_checksum_history.py +62 -0
  8. alembic/versions/1cf4e1ee3cb8_ext_permission_with_filter_fields_values.py +33 -0
  9. alembic/versions/26bfe19b49d4_rm_failedloginattempts.py +42 -0
  10. alembic/versions/3c8bca2219cc_add_otp_table.py +38 -0
  11. alembic/versions/6675fd9dfe42_remove_unique_from_sessions_table.py +36 -0
  12. alembic/versions/71bc1df82e6a_adding_user_last_login_at.py +43 -0
  13. alembic/versions/74288ccbd3b5_initial.py +264 -0
  14. alembic/versions/7520a89a8467_rm_activesession_table.py +39 -0
  15. alembic/versions/848b623755a4_make_created_nd_updated_at_required.py +138 -0
  16. alembic/versions/8640dcbebf85_add_notes_to_users.py +32 -0
  17. alembic/versions/91c94250232a_adding_fk_on_owner_shortname.py +104 -0
  18. alembic/versions/98ecd6f56f9a_ext_meta_with_owner_group_shortname.py +66 -0
  19. alembic/versions/9aae9138c4ef_indexing_created_at_updated_at.py +80 -0
  20. alembic/versions/__init__.py +0 -0
  21. alembic/versions/b53f916b3f6d_json_to_jsonb.py +492 -0
  22. alembic/versions/eb5f1ec65156_adding_user_locked_to_device.py +36 -0
  23. alembic/versions/f7a4949eed19_adding_query_policies_to_meta.py +60 -0
  24. api/__init__.py +0 -0
  25. api/info/__init__.py +0 -0
  26. api/info/router.py +109 -0
  27. api/managed/__init__.py +0 -0
  28. api/managed/router.py +1541 -0
  29. api/managed/utils.py +1850 -0
  30. api/public/__init__.py +0 -0
  31. api/public/router.py +758 -0
  32. api/qr/__init__.py +0 -0
  33. api/qr/router.py +108 -0
  34. api/user/__init__.py +0 -0
  35. api/user/model/__init__.py +0 -0
  36. api/user/model/errors.py +14 -0
  37. api/user/model/requests.py +165 -0
  38. api/user/model/responses.py +11 -0
  39. api/user/router.py +1401 -0
  40. api/user/service.py +270 -0
  41. bundler.py +44 -0
  42. config/__init__.py +0 -0
  43. config/channels.json +11 -0
  44. config/notification.json +17 -0
  45. data_adapters/__init__.py +0 -0
  46. data_adapters/adapter.py +16 -0
  47. data_adapters/base_data_adapter.py +467 -0
  48. data_adapters/file/__init__.py +0 -0
  49. data_adapters/file/adapter.py +2043 -0
  50. data_adapters/file/adapter_helpers.py +1013 -0
  51. data_adapters/file/archive.py +150 -0
  52. data_adapters/file/create_index.py +331 -0
  53. data_adapters/file/create_users_folders.py +52 -0
  54. data_adapters/file/custom_validations.py +68 -0
  55. data_adapters/file/drop_index.py +40 -0
  56. data_adapters/file/health_check.py +560 -0
  57. data_adapters/file/redis_services.py +1110 -0
  58. data_adapters/helpers.py +27 -0
  59. data_adapters/sql/__init__.py +0 -0
  60. data_adapters/sql/adapter.py +3210 -0
  61. data_adapters/sql/adapter_helpers.py +491 -0
  62. data_adapters/sql/create_tables.py +451 -0
  63. data_adapters/sql/create_users_folders.py +53 -0
  64. data_adapters/sql/db_to_json_migration.py +482 -0
  65. data_adapters/sql/health_check_sql.py +232 -0
  66. data_adapters/sql/json_to_db_migration.py +454 -0
  67. data_adapters/sql/update_query_policies.py +101 -0
  68. data_generator.py +81 -0
  69. dmart-0.1.9.dist-info/METADATA +64 -0
  70. dmart-0.1.9.dist-info/RECORD +149 -0
  71. dmart-0.1.9.dist-info/WHEEL +5 -0
  72. dmart-0.1.9.dist-info/entry_points.txt +2 -0
  73. dmart-0.1.9.dist-info/top_level.txt +23 -0
  74. dmart.py +513 -0
  75. get_settings.py +7 -0
  76. languages/__init__.py +0 -0
  77. languages/arabic.json +15 -0
  78. languages/english.json +16 -0
  79. languages/kurdish.json +14 -0
  80. languages/loader.py +13 -0
  81. main.py +506 -0
  82. migrate.py +24 -0
  83. models/__init__.py +0 -0
  84. models/api.py +203 -0
  85. models/core.py +597 -0
  86. models/enums.py +255 -0
  87. password_gen.py +8 -0
  88. plugins/__init__.py +0 -0
  89. plugins/action_log/__init__.py +0 -0
  90. plugins/action_log/plugin.py +121 -0
  91. plugins/admin_notification_sender/__init__.py +0 -0
  92. plugins/admin_notification_sender/plugin.py +124 -0
  93. plugins/ldap_manager/__init__.py +0 -0
  94. plugins/ldap_manager/plugin.py +100 -0
  95. plugins/local_notification/__init__.py +0 -0
  96. plugins/local_notification/plugin.py +123 -0
  97. plugins/realtime_updates_notifier/__init__.py +0 -0
  98. plugins/realtime_updates_notifier/plugin.py +58 -0
  99. plugins/redis_db_update/__init__.py +0 -0
  100. plugins/redis_db_update/plugin.py +188 -0
  101. plugins/resource_folders_creation/__init__.py +0 -0
  102. plugins/resource_folders_creation/plugin.py +81 -0
  103. plugins/system_notification_sender/__init__.py +0 -0
  104. plugins/system_notification_sender/plugin.py +188 -0
  105. plugins/update_access_controls/__init__.py +0 -0
  106. plugins/update_access_controls/plugin.py +9 -0
  107. pytests/__init__.py +0 -0
  108. pytests/api_user_models_erros_test.py +16 -0
  109. pytests/api_user_models_requests_test.py +98 -0
  110. pytests/archive_test.py +72 -0
  111. pytests/base_test.py +300 -0
  112. pytests/get_settings_test.py +14 -0
  113. pytests/json_to_db_migration_test.py +237 -0
  114. pytests/service_test.py +26 -0
  115. pytests/test_info.py +55 -0
  116. pytests/test_status.py +15 -0
  117. run_notification_campaign.py +98 -0
  118. scheduled_notification_handler.py +121 -0
  119. schema_migration.py +208 -0
  120. schema_modulate.py +192 -0
  121. set_admin_passwd.py +55 -0
  122. sync.py +202 -0
  123. utils/__init__.py +0 -0
  124. utils/access_control.py +306 -0
  125. utils/async_request.py +8 -0
  126. utils/exporter.py +309 -0
  127. utils/firebase_notifier.py +57 -0
  128. utils/generate_email.py +38 -0
  129. utils/helpers.py +352 -0
  130. utils/hypercorn_config.py +12 -0
  131. utils/internal_error_code.py +60 -0
  132. utils/jwt.py +124 -0
  133. utils/logger.py +167 -0
  134. utils/middleware.py +99 -0
  135. utils/notification.py +75 -0
  136. utils/password_hashing.py +16 -0
  137. utils/plugin_manager.py +215 -0
  138. utils/query_policies_helper.py +112 -0
  139. utils/regex.py +44 -0
  140. utils/repository.py +529 -0
  141. utils/router_helper.py +19 -0
  142. utils/settings.py +165 -0
  143. utils/sms_notifier.py +21 -0
  144. utils/social_sso.py +67 -0
  145. utils/templates/activation.html.j2 +26 -0
  146. utils/templates/reminder.html.j2 +17 -0
  147. utils/ticket_sys_utils.py +203 -0
  148. utils/web_notifier.py +29 -0
  149. websocket.py +231 -0
@@ -0,0 +1,80 @@
1
+ """indexing created_at updated_at
2
+
3
+ Revision ID: 9aae9138c4ef
4
+ Revises: 91c94250232a
5
+ Create Date: 2025-03-04 22:54:14.895030
6
+
7
+ """
8
+ from typing import Sequence, Union
9
+
10
+ from alembic import op
11
+ import sqlalchemy as sa
12
+ import sqlmodel
13
+ import sqlmodel.sql.sqltypes
14
+
15
+
16
+ # revision identifiers, used by Alembic.
17
+ revision: str = '9aae9138c4ef'
18
+ down_revision: Union[str, None] = '91c94250232a'
19
+ branch_labels: Union[str, Sequence[str], None] = None
20
+ depends_on: Union[str, Sequence[str], None] = None
21
+
22
+
23
+ def upgrade() -> None:
24
+ # ### commands auto generated by Alembic - please adjust! ###
25
+ with op.batch_alter_table('attachments', schema=None) as batch_op:
26
+ batch_op.create_index(batch_op.f('ix_attachments_created_at'), ['created_at'], unique=False)
27
+ batch_op.create_index(batch_op.f('ix_attachments_updated_at'), ['updated_at'], unique=False)
28
+
29
+ with op.batch_alter_table('entries', schema=None) as batch_op:
30
+ batch_op.create_index(batch_op.f('ix_entries_created_at'), ['created_at'], unique=False)
31
+ batch_op.create_index(batch_op.f('ix_entries_updated_at'), ['updated_at'], unique=False)
32
+
33
+ with op.batch_alter_table('permissions', schema=None) as batch_op:
34
+ batch_op.create_index(batch_op.f('ix_permissions_created_at'), ['created_at'], unique=False)
35
+ batch_op.create_index(batch_op.f('ix_permissions_updated_at'), ['updated_at'], unique=False)
36
+
37
+ with op.batch_alter_table('roles', schema=None) as batch_op:
38
+ batch_op.create_index(batch_op.f('ix_roles_created_at'), ['created_at'], unique=False)
39
+ batch_op.create_index(batch_op.f('ix_roles_updated_at'), ['updated_at'], unique=False)
40
+
41
+ with op.batch_alter_table('spaces', schema=None) as batch_op:
42
+ batch_op.create_index(batch_op.f('ix_spaces_created_at'), ['created_at'], unique=False)
43
+ batch_op.create_index(batch_op.f('ix_spaces_updated_at'), ['updated_at'], unique=False)
44
+
45
+ with op.batch_alter_table('users', schema=None) as batch_op:
46
+ batch_op.create_index(batch_op.f('ix_users_created_at'), ['created_at'], unique=False)
47
+ batch_op.create_index(batch_op.f('ix_users_updated_at'), ['updated_at'], unique=False)
48
+ batch_op.create_foreign_key(None, 'users', ['owner_shortname'], ['shortname'])
49
+
50
+ # ### end Alembic commands ###
51
+
52
+
53
+ def downgrade() -> None:
54
+ # ### commands auto generated by Alembic - please adjust! ###
55
+ with op.batch_alter_table('users', schema=None) as batch_op:
56
+ batch_op.drop_constraint(None, type_='foreignkey')
57
+ batch_op.drop_index(batch_op.f('ix_users_updated_at'))
58
+ batch_op.drop_index(batch_op.f('ix_users_created_at'))
59
+
60
+ with op.batch_alter_table('spaces', schema=None) as batch_op:
61
+ batch_op.drop_index(batch_op.f('ix_spaces_updated_at'))
62
+ batch_op.drop_index(batch_op.f('ix_spaces_created_at'))
63
+
64
+ with op.batch_alter_table('roles', schema=None) as batch_op:
65
+ batch_op.drop_index(batch_op.f('ix_roles_updated_at'))
66
+ batch_op.drop_index(batch_op.f('ix_roles_created_at'))
67
+
68
+ with op.batch_alter_table('permissions', schema=None) as batch_op:
69
+ batch_op.drop_index(batch_op.f('ix_permissions_updated_at'))
70
+ batch_op.drop_index(batch_op.f('ix_permissions_created_at'))
71
+
72
+ with op.batch_alter_table('entries', schema=None) as batch_op:
73
+ batch_op.drop_index(batch_op.f('ix_entries_updated_at'))
74
+ batch_op.drop_index(batch_op.f('ix_entries_created_at'))
75
+
76
+ with op.batch_alter_table('attachments', schema=None) as batch_op:
77
+ batch_op.drop_index(batch_op.f('ix_attachments_updated_at'))
78
+ batch_op.drop_index(batch_op.f('ix_attachments_created_at'))
79
+
80
+ # ### end Alembic commands ###
File without changes
@@ -0,0 +1,492 @@
1
+ """json to jsonb
2
+
3
+ Revision ID: b53f916b3f6d
4
+ Revises: 26bfe19b49d4
5
+ Create Date: 2024-12-19 21:08:36.586642
6
+
7
+ """
8
+ from typing import Sequence, Union
9
+
10
+ from alembic import op
11
+ import sqlalchemy as sa
12
+ from sqlalchemy.dialects import postgresql
13
+
14
+ # revision identifiers, used by Alembic.
15
+ revision: str = 'b53f916b3f6d'
16
+ down_revision: Union[str, None] = '26bfe19b49d4'
17
+ branch_labels: Union[str, Sequence[str], None] = None
18
+ depends_on: Union[str, Sequence[str], None] = None
19
+
20
+
21
+ def upgrade() -> None:
22
+ # ### commands auto generated by Alembic - please adjust! ###
23
+ with op.batch_alter_table('attachments', schema=None) as batch_op:
24
+ batch_op.alter_column('displayname',
25
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
26
+ type_=postgresql.JSONB(astext_type=sa.Text()),
27
+ existing_nullable=True)
28
+ batch_op.alter_column('description',
29
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
30
+ type_=postgresql.JSONB(astext_type=sa.Text()),
31
+ existing_nullable=True)
32
+ batch_op.alter_column('tags',
33
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
34
+ type_=postgresql.JSONB(astext_type=sa.Text()),
35
+ existing_nullable=False)
36
+ batch_op.alter_column('acl',
37
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
38
+ type_=postgresql.JSONB(astext_type=sa.Text()),
39
+ existing_nullable=True)
40
+ batch_op.alter_column('payload',
41
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
42
+ type_=postgresql.JSONB(astext_type=sa.Text()),
43
+ existing_nullable=True)
44
+ batch_op.alter_column('relationships',
45
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
46
+ type_=postgresql.JSONB(astext_type=sa.Text()),
47
+ existing_nullable=True)
48
+
49
+ with op.batch_alter_table('entries', schema=None) as batch_op:
50
+ batch_op.alter_column('displayname',
51
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
52
+ type_=postgresql.JSONB(astext_type=sa.Text()),
53
+ existing_nullable=True)
54
+ batch_op.alter_column('description',
55
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
56
+ type_=postgresql.JSONB(astext_type=sa.Text()),
57
+ existing_nullable=True)
58
+ batch_op.alter_column('tags',
59
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
60
+ type_=postgresql.JSONB(astext_type=sa.Text()),
61
+ existing_nullable=False)
62
+ batch_op.alter_column('acl',
63
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
64
+ type_=postgresql.JSONB(astext_type=sa.Text()),
65
+ existing_nullable=True)
66
+ batch_op.alter_column('payload',
67
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
68
+ type_=postgresql.JSONB(astext_type=sa.Text()),
69
+ existing_nullable=True)
70
+ batch_op.alter_column('relationships',
71
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
72
+ type_=postgresql.JSONB(astext_type=sa.Text()),
73
+ existing_nullable=True)
74
+ batch_op.alter_column('reporter',
75
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
76
+ type_=postgresql.JSONB(astext_type=sa.Text()),
77
+ existing_nullable=True)
78
+ batch_op.alter_column('collaborators',
79
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
80
+ type_=postgresql.JSONB(astext_type=sa.Text()),
81
+ existing_nullable=True)
82
+
83
+ with op.batch_alter_table('histories', schema=None) as batch_op:
84
+ batch_op.alter_column('request_headers',
85
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
86
+ type_=postgresql.JSONB(astext_type=sa.Text()),
87
+ existing_nullable=False)
88
+ batch_op.alter_column('diff',
89
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
90
+ type_=postgresql.JSONB(astext_type=sa.Text()),
91
+ existing_nullable=False)
92
+
93
+ with op.batch_alter_table('locks', schema=None) as batch_op:
94
+ batch_op.alter_column('payload',
95
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
96
+ type_=postgresql.JSONB(astext_type=sa.Text()),
97
+ existing_nullable=True)
98
+
99
+ with op.batch_alter_table('permissions', schema=None) as batch_op:
100
+ batch_op.alter_column('displayname',
101
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
102
+ type_=postgresql.JSONB(astext_type=sa.Text()),
103
+ existing_nullable=True)
104
+ batch_op.alter_column('description',
105
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
106
+ type_=postgresql.JSONB(astext_type=sa.Text()),
107
+ existing_nullable=True)
108
+ batch_op.alter_column('tags',
109
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
110
+ type_=postgresql.JSONB(astext_type=sa.Text()),
111
+ existing_nullable=False)
112
+ batch_op.alter_column('acl',
113
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
114
+ type_=postgresql.JSONB(astext_type=sa.Text()),
115
+ existing_nullable=True)
116
+ batch_op.alter_column('payload',
117
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
118
+ type_=postgresql.JSONB(astext_type=sa.Text()),
119
+ existing_nullable=True)
120
+ batch_op.alter_column('relationships',
121
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
122
+ type_=postgresql.JSONB(astext_type=sa.Text()),
123
+ existing_nullable=True)
124
+ batch_op.alter_column('subpaths',
125
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
126
+ type_=postgresql.JSONB(astext_type=sa.Text()),
127
+ existing_nullable=False)
128
+ batch_op.alter_column('resource_types',
129
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
130
+ type_=postgresql.JSONB(astext_type=sa.Text()),
131
+ existing_nullable=False)
132
+ batch_op.alter_column('actions',
133
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
134
+ type_=postgresql.JSONB(astext_type=sa.Text()),
135
+ existing_nullable=False)
136
+ batch_op.alter_column('conditions',
137
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
138
+ type_=postgresql.JSONB(astext_type=sa.Text()),
139
+ existing_nullable=False)
140
+ batch_op.alter_column('restricted_fields',
141
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
142
+ type_=postgresql.JSONB(astext_type=sa.Text()),
143
+ existing_nullable=True)
144
+ batch_op.alter_column('allowed_fields_values',
145
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
146
+ type_=postgresql.JSONB(astext_type=sa.Text()),
147
+ existing_nullable=True)
148
+
149
+ with op.batch_alter_table('roles', schema=None) as batch_op:
150
+ batch_op.alter_column('displayname',
151
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
152
+ type_=postgresql.JSONB(astext_type=sa.Text()),
153
+ existing_nullable=True)
154
+ batch_op.alter_column('description',
155
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
156
+ type_=postgresql.JSONB(astext_type=sa.Text()),
157
+ existing_nullable=True)
158
+ batch_op.alter_column('tags',
159
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
160
+ type_=postgresql.JSONB(astext_type=sa.Text()),
161
+ existing_nullable=False)
162
+ batch_op.alter_column('acl',
163
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
164
+ type_=postgresql.JSONB(astext_type=sa.Text()),
165
+ existing_nullable=True)
166
+ batch_op.alter_column('payload',
167
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
168
+ type_=postgresql.JSONB(astext_type=sa.Text()),
169
+ existing_nullable=True)
170
+ batch_op.alter_column('relationships',
171
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
172
+ type_=postgresql.JSONB(astext_type=sa.Text()),
173
+ existing_nullable=True)
174
+ batch_op.alter_column('permissions',
175
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
176
+ type_=postgresql.JSONB(astext_type=sa.Text()),
177
+ existing_nullable=False)
178
+
179
+ with op.batch_alter_table('spaces', schema=None) as batch_op:
180
+ batch_op.alter_column('displayname',
181
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
182
+ type_=postgresql.JSONB(astext_type=sa.Text()),
183
+ existing_nullable=True)
184
+ batch_op.alter_column('description',
185
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
186
+ type_=postgresql.JSONB(astext_type=sa.Text()),
187
+ existing_nullable=True)
188
+ batch_op.alter_column('tags',
189
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
190
+ type_=postgresql.JSONB(astext_type=sa.Text()),
191
+ existing_nullable=False)
192
+ batch_op.alter_column('acl',
193
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
194
+ type_=postgresql.JSONB(astext_type=sa.Text()),
195
+ existing_nullable=True)
196
+ batch_op.alter_column('payload',
197
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
198
+ type_=postgresql.JSONB(astext_type=sa.Text()),
199
+ existing_nullable=True)
200
+ batch_op.alter_column('relationships',
201
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
202
+ type_=postgresql.JSONB(astext_type=sa.Text()),
203
+ existing_nullable=True)
204
+ batch_op.alter_column('languages',
205
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
206
+ type_=postgresql.JSONB(astext_type=sa.Text()),
207
+ existing_nullable=False)
208
+ batch_op.alter_column('mirrors',
209
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
210
+ type_=postgresql.JSONB(astext_type=sa.Text()),
211
+ existing_nullable=True)
212
+ batch_op.alter_column('hide_folders',
213
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
214
+ type_=postgresql.JSONB(astext_type=sa.Text()),
215
+ existing_nullable=True)
216
+ batch_op.alter_column('active_plugins',
217
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
218
+ type_=postgresql.JSONB(astext_type=sa.Text()),
219
+ existing_nullable=True)
220
+
221
+ with op.batch_alter_table('users', schema=None) as batch_op:
222
+ batch_op.alter_column('displayname',
223
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
224
+ type_=postgresql.JSONB(astext_type=sa.Text()),
225
+ existing_nullable=True)
226
+ batch_op.alter_column('description',
227
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
228
+ type_=postgresql.JSONB(astext_type=sa.Text()),
229
+ existing_nullable=True)
230
+ batch_op.alter_column('tags',
231
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
232
+ type_=postgresql.JSONB(astext_type=sa.Text()),
233
+ existing_nullable=False)
234
+ batch_op.alter_column('payload',
235
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
236
+ type_=postgresql.JSONB(astext_type=sa.Text()),
237
+ existing_nullable=True)
238
+ batch_op.alter_column('roles',
239
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
240
+ type_=postgresql.JSONB(astext_type=sa.Text()),
241
+ existing_nullable=False)
242
+ batch_op.alter_column('groups',
243
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
244
+ type_=postgresql.JSONB(astext_type=sa.Text()),
245
+ existing_nullable=False)
246
+ batch_op.alter_column('acl',
247
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
248
+ type_=postgresql.JSONB(astext_type=sa.Text()),
249
+ existing_nullable=True)
250
+ batch_op.alter_column('relationships',
251
+ existing_type=postgresql.JSON(astext_type=sa.Text()),
252
+ type_=postgresql.JSONB(astext_type=sa.Text()),
253
+ existing_nullable=True)
254
+
255
+ # ### end Alembic commands ###
256
+
257
+
258
+ def downgrade() -> None:
259
+ # ### commands auto generated by Alembic - please adjust! ###
260
+ with op.batch_alter_table('users', schema=None) as batch_op:
261
+ batch_op.alter_column('relationships',
262
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
263
+ type_=postgresql.JSON(astext_type=sa.Text()),
264
+ existing_nullable=True)
265
+ batch_op.alter_column('acl',
266
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
267
+ type_=postgresql.JSON(astext_type=sa.Text()),
268
+ existing_nullable=True)
269
+ batch_op.alter_column('groups',
270
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
271
+ type_=postgresql.JSON(astext_type=sa.Text()),
272
+ existing_nullable=False)
273
+ batch_op.alter_column('roles',
274
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
275
+ type_=postgresql.JSON(astext_type=sa.Text()),
276
+ existing_nullable=False)
277
+ batch_op.alter_column('payload',
278
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
279
+ type_=postgresql.JSON(astext_type=sa.Text()),
280
+ existing_nullable=True)
281
+ batch_op.alter_column('tags',
282
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
283
+ type_=postgresql.JSON(astext_type=sa.Text()),
284
+ existing_nullable=False)
285
+ batch_op.alter_column('description',
286
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
287
+ type_=postgresql.JSON(astext_type=sa.Text()),
288
+ existing_nullable=True)
289
+ batch_op.alter_column('displayname',
290
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
291
+ type_=postgresql.JSON(astext_type=sa.Text()),
292
+ existing_nullable=True)
293
+
294
+ with op.batch_alter_table('spaces', schema=None) as batch_op:
295
+ batch_op.alter_column('active_plugins',
296
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
297
+ type_=postgresql.JSON(astext_type=sa.Text()),
298
+ existing_nullable=True)
299
+ batch_op.alter_column('hide_folders',
300
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
301
+ type_=postgresql.JSON(astext_type=sa.Text()),
302
+ existing_nullable=True)
303
+ batch_op.alter_column('mirrors',
304
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
305
+ type_=postgresql.JSON(astext_type=sa.Text()),
306
+ existing_nullable=True)
307
+ batch_op.alter_column('languages',
308
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
309
+ type_=postgresql.JSON(astext_type=sa.Text()),
310
+ existing_nullable=False)
311
+ batch_op.alter_column('relationships',
312
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
313
+ type_=postgresql.JSON(astext_type=sa.Text()),
314
+ existing_nullable=True)
315
+ batch_op.alter_column('payload',
316
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
317
+ type_=postgresql.JSON(astext_type=sa.Text()),
318
+ existing_nullable=True)
319
+ batch_op.alter_column('acl',
320
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
321
+ type_=postgresql.JSON(astext_type=sa.Text()),
322
+ existing_nullable=True)
323
+ batch_op.alter_column('tags',
324
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
325
+ type_=postgresql.JSON(astext_type=sa.Text()),
326
+ existing_nullable=False)
327
+ batch_op.alter_column('description',
328
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
329
+ type_=postgresql.JSON(astext_type=sa.Text()),
330
+ existing_nullable=True)
331
+ batch_op.alter_column('displayname',
332
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
333
+ type_=postgresql.JSON(astext_type=sa.Text()),
334
+ existing_nullable=True)
335
+
336
+ with op.batch_alter_table('roles', schema=None) as batch_op:
337
+ batch_op.alter_column('permissions',
338
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
339
+ type_=postgresql.JSON(astext_type=sa.Text()),
340
+ existing_nullable=False)
341
+ batch_op.alter_column('relationships',
342
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
343
+ type_=postgresql.JSON(astext_type=sa.Text()),
344
+ existing_nullable=True)
345
+ batch_op.alter_column('payload',
346
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
347
+ type_=postgresql.JSON(astext_type=sa.Text()),
348
+ existing_nullable=True)
349
+ batch_op.alter_column('acl',
350
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
351
+ type_=postgresql.JSON(astext_type=sa.Text()),
352
+ existing_nullable=True)
353
+ batch_op.alter_column('tags',
354
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
355
+ type_=postgresql.JSON(astext_type=sa.Text()),
356
+ existing_nullable=False)
357
+ batch_op.alter_column('description',
358
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
359
+ type_=postgresql.JSON(astext_type=sa.Text()),
360
+ existing_nullable=True)
361
+ batch_op.alter_column('displayname',
362
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
363
+ type_=postgresql.JSON(astext_type=sa.Text()),
364
+ existing_nullable=True)
365
+
366
+ with op.batch_alter_table('permissions', schema=None) as batch_op:
367
+ batch_op.alter_column('allowed_fields_values',
368
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
369
+ type_=postgresql.JSON(astext_type=sa.Text()),
370
+ existing_nullable=True)
371
+ batch_op.alter_column('restricted_fields',
372
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
373
+ type_=postgresql.JSON(astext_type=sa.Text()),
374
+ existing_nullable=True)
375
+ batch_op.alter_column('conditions',
376
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
377
+ type_=postgresql.JSON(astext_type=sa.Text()),
378
+ existing_nullable=False)
379
+ batch_op.alter_column('actions',
380
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
381
+ type_=postgresql.JSON(astext_type=sa.Text()),
382
+ existing_nullable=False)
383
+ batch_op.alter_column('resource_types',
384
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
385
+ type_=postgresql.JSON(astext_type=sa.Text()),
386
+ existing_nullable=False)
387
+ batch_op.alter_column('subpaths',
388
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
389
+ type_=postgresql.JSON(astext_type=sa.Text()),
390
+ existing_nullable=False)
391
+ batch_op.alter_column('relationships',
392
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
393
+ type_=postgresql.JSON(astext_type=sa.Text()),
394
+ existing_nullable=True)
395
+ batch_op.alter_column('payload',
396
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
397
+ type_=postgresql.JSON(astext_type=sa.Text()),
398
+ existing_nullable=True)
399
+ batch_op.alter_column('acl',
400
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
401
+ type_=postgresql.JSON(astext_type=sa.Text()),
402
+ existing_nullable=True)
403
+ batch_op.alter_column('tags',
404
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
405
+ type_=postgresql.JSON(astext_type=sa.Text()),
406
+ existing_nullable=False)
407
+ batch_op.alter_column('description',
408
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
409
+ type_=postgresql.JSON(astext_type=sa.Text()),
410
+ existing_nullable=True)
411
+ batch_op.alter_column('displayname',
412
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
413
+ type_=postgresql.JSON(astext_type=sa.Text()),
414
+ existing_nullable=True)
415
+
416
+ with op.batch_alter_table('locks', schema=None) as batch_op:
417
+ batch_op.alter_column('payload',
418
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
419
+ type_=postgresql.JSON(astext_type=sa.Text()),
420
+ existing_nullable=True)
421
+
422
+ with op.batch_alter_table('histories', schema=None) as batch_op:
423
+ batch_op.alter_column('diff',
424
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
425
+ type_=postgresql.JSON(astext_type=sa.Text()),
426
+ existing_nullable=False)
427
+ batch_op.alter_column('request_headers',
428
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
429
+ type_=postgresql.JSON(astext_type=sa.Text()),
430
+ existing_nullable=False)
431
+
432
+ with op.batch_alter_table('entries', schema=None) as batch_op:
433
+ batch_op.alter_column('collaborators',
434
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
435
+ type_=postgresql.JSON(astext_type=sa.Text()),
436
+ existing_nullable=True)
437
+ batch_op.alter_column('reporter',
438
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
439
+ type_=postgresql.JSON(astext_type=sa.Text()),
440
+ existing_nullable=True)
441
+ batch_op.alter_column('relationships',
442
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
443
+ type_=postgresql.JSON(astext_type=sa.Text()),
444
+ existing_nullable=True)
445
+ batch_op.alter_column('payload',
446
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
447
+ type_=postgresql.JSON(astext_type=sa.Text()),
448
+ existing_nullable=True)
449
+ batch_op.alter_column('acl',
450
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
451
+ type_=postgresql.JSON(astext_type=sa.Text()),
452
+ existing_nullable=True)
453
+ batch_op.alter_column('tags',
454
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
455
+ type_=postgresql.JSON(astext_type=sa.Text()),
456
+ existing_nullable=False)
457
+ batch_op.alter_column('description',
458
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
459
+ type_=postgresql.JSON(astext_type=sa.Text()),
460
+ existing_nullable=True)
461
+ batch_op.alter_column('displayname',
462
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
463
+ type_=postgresql.JSON(astext_type=sa.Text()),
464
+ existing_nullable=True)
465
+
466
+ with op.batch_alter_table('attachments', schema=None) as batch_op:
467
+ batch_op.alter_column('relationships',
468
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
469
+ type_=postgresql.JSON(astext_type=sa.Text()),
470
+ existing_nullable=True)
471
+ batch_op.alter_column('payload',
472
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
473
+ type_=postgresql.JSON(astext_type=sa.Text()),
474
+ existing_nullable=True)
475
+ batch_op.alter_column('acl',
476
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
477
+ type_=postgresql.JSON(astext_type=sa.Text()),
478
+ existing_nullable=True)
479
+ batch_op.alter_column('tags',
480
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
481
+ type_=postgresql.JSON(astext_type=sa.Text()),
482
+ existing_nullable=False)
483
+ batch_op.alter_column('description',
484
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
485
+ type_=postgresql.JSON(astext_type=sa.Text()),
486
+ existing_nullable=True)
487
+ batch_op.alter_column('displayname',
488
+ existing_type=postgresql.JSONB(astext_type=sa.Text()),
489
+ type_=postgresql.JSON(astext_type=sa.Text()),
490
+ existing_nullable=True)
491
+
492
+ # ### end Alembic commands ###
@@ -0,0 +1,36 @@
1
+ """adding user@locked_to_device
2
+
3
+ Revision ID: eb5f1ec65156
4
+ Revises: 8640dcbebf85
5
+ Create Date: 2026-01-05 09:25:55.562667
6
+
7
+ """
8
+ from typing import Sequence, Union
9
+
10
+ from alembic import op
11
+ import sqlalchemy as sa
12
+ import sqlmodel
13
+ import sqlmodel.sql.sqltypes
14
+
15
+
16
+ # revision identifiers, used by Alembic.
17
+ revision: str = 'eb5f1ec65156'
18
+ down_revision: Union[str, None] = '8640dcbebf85'
19
+ branch_labels: Union[str, Sequence[str], None] = None
20
+ depends_on: Union[str, Sequence[str], None] = None
21
+
22
+
23
+ def upgrade() -> None:
24
+ # ### commands auto generated by Alembic - please adjust! ###
25
+ with op.batch_alter_table('users', schema=None) as batch_op:
26
+ batch_op.add_column(sa.Column('locked_to_device', sa.Boolean(), nullable=False))
27
+
28
+ # ### end Alembic commands ###
29
+
30
+
31
+ def downgrade() -> None:
32
+ # ### commands auto generated by Alembic - please adjust! ###
33
+ with op.batch_alter_table('users', schema=None) as batch_op:
34
+ batch_op.drop_column('locked_to_device')
35
+
36
+ # ### end Alembic commands ###
@@ -0,0 +1,60 @@
1
+ """adding query_policies to meta
2
+
3
+ Revision ID: f7a4949eed19
4
+ Revises: 848b623755a4
5
+ Create Date: 2025-01-22 11:37:26.347777
6
+
7
+ """
8
+ from typing import Sequence, Union
9
+
10
+ from alembic import op
11
+ import sqlalchemy as sa
12
+ import sqlmodel
13
+ import sqlmodel.sql.sqltypes
14
+ from sqlalchemy.dialects import postgresql
15
+
16
+ # revision identifiers, used by Alembic.
17
+ revision: str = 'f7a4949eed19'
18
+ down_revision: Union[str, None] = '848b623755a4'
19
+ branch_labels: Union[str, Sequence[str], None] = None
20
+ depends_on: Union[str, Sequence[str], None] = None
21
+
22
+
23
+ def upgrade() -> None:
24
+ # ### commands auto generated by Alembic - please adjust! ###
25
+ with op.batch_alter_table('entries', schema=None) as batch_op:
26
+ batch_op.add_column(sa.Column('query_policies', postgresql.ARRAY(sa.TEXT()), nullable=False, server_default='{}'))
27
+
28
+ with op.batch_alter_table('permissions', schema=None) as batch_op:
29
+ batch_op.add_column(sa.Column('query_policies', postgresql.ARRAY(sa.TEXT()), nullable=False, server_default='{}'))
30
+
31
+ with op.batch_alter_table('roles', schema=None) as batch_op:
32
+ batch_op.add_column(sa.Column('query_policies', postgresql.ARRAY(sa.TEXT()), nullable=False, server_default='{}'))
33
+
34
+ with op.batch_alter_table('spaces', schema=None) as batch_op:
35
+ batch_op.add_column(sa.Column('query_policies', postgresql.ARRAY(sa.TEXT()), nullable=False, server_default='{}'))
36
+
37
+ with op.batch_alter_table('users', schema=None) as batch_op:
38
+ batch_op.add_column(sa.Column('query_policies', postgresql.ARRAY(sa.TEXT()), nullable=False, server_default='{}'))
39
+
40
+ # ### end Alembic commands ###
41
+
42
+
43
+ def downgrade() -> None:
44
+ # ### commands auto generated by Alembic - please adjust! ###
45
+ with op.batch_alter_table('users', schema=None) as batch_op:
46
+ batch_op.drop_column('query_policies')
47
+
48
+ with op.batch_alter_table('spaces', schema=None) as batch_op:
49
+ batch_op.drop_column('query_policies')
50
+
51
+ with op.batch_alter_table('roles', schema=None) as batch_op:
52
+ batch_op.drop_column('query_policies')
53
+
54
+ with op.batch_alter_table('permissions', schema=None) as batch_op:
55
+ batch_op.drop_column('query_policies')
56
+
57
+ with op.batch_alter_table('entries', schema=None) as batch_op:
58
+ batch_op.drop_column('query_policies')
59
+
60
+ # ### end Alembic commands ###
api/__init__.py ADDED
File without changes
api/info/__init__.py ADDED
File without changes