edu-rdm-integration 3.5.7__py3-none-any.whl → 3.5.10__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.
@@ -0,0 +1,281 @@
1
+ Metadata-Version: 2.4
2
+ Name: edu-rdm-integration
3
+ Version: 3.5.10
4
+ Summary: Интеграция с Региональной витриной данных
5
+ Author-email: BARS Group <education_dev@bars.group>
6
+ Project-URL: Homepage, https://stash.bars-open.ru/projects/EDUBASE/repos/edu_rdm_integration/browse
7
+ Project-URL: Repository, https://stash.bars-open.ru/scm/edubase/edu_rdm_integration.git
8
+ Classifier: Development Status :: 5 - Production/Stable
9
+ Classifier: Programming Language :: Python :: 3
10
+ Classifier: Programming Language :: Python :: 3.9
11
+ Classifier: Programming Language :: Python :: 3.10
12
+ Classifier: Programming Language :: Python :: 3.11
13
+ Classifier: Programming Language :: Python :: 3.12
14
+ Classifier: Framework :: Django :: 2.2
15
+ Classifier: Framework :: Django :: 3.0
16
+ Classifier: Framework :: Django :: 3.1
17
+ Classifier: Framework :: Django :: 3.2
18
+ Classifier: Intended Audience :: Developers
19
+ Classifier: Environment :: Web Environment
20
+ Requires-Python: >=3.9
21
+ Description-Content-Type: text/markdown
22
+ License-File: LICENSE
23
+ Requires-Dist: transliterate<2
24
+ Requires-Dist: Django<3.3,>=3.1
25
+ Requires-Dist: celery<5.3,>=4.4.7
26
+ Requires-Dist: asyncpg==0.23.0
27
+ Requires-Dist: educommon<4,>=3.11.0
28
+ Requires-Dist: function-tools<1,>=0.9.0
29
+ Requires-Dist: m3-db-utils<1,>=0.3.10
30
+ Requires-Dist: m3-django-compat<2,>=1.10.2
31
+ Requires-Dist: uploader-client<1,>=0.2.3
32
+ Provides-Extra: dev
33
+ Requires-Dist: isort==5.12.0; extra == "dev"
34
+ Requires-Dist: ruff==0.6.9; extra == "dev"
35
+ Requires-Dist: flake8<7,>=4.0.1; extra == "dev"
36
+ Requires-Dist: pytest<8,>=3.2.5; extra == "dev"
37
+ Requires-Dist: pytest-cov<5; extra == "dev"
38
+ Provides-Extra: docs
39
+ Requires-Dist: sphinx<7.5,>=7; extra == "docs"
40
+ Requires-Dist: sphinx-autodoc-typehints<2.5,>=2; extra == "docs"
41
+ Requires-Dist: myst-parser<3.2,>=3; extra == "docs"
42
+ Requires-Dist: sphinx_design<0.7,>=0.6; extra == "docs"
43
+ Dynamic: license-file
44
+
45
+ # Проект "Интеграция с Региональной витриной данных (РВД)"
46
+
47
+ Для интеграции с Региональной витриной данных был выделен отдельный пакет для использования его компонентов в различных
48
+ продуктах.
49
+
50
+ На текущий момент интеграция реализуется в рамках проектов Электронная школа (ЭШ) и Электронный колледж (ЭК).
51
+
52
+ ## Описание концепции
53
+
54
+ Со стороны Минцифры предоставляется спецификация (ЕФТТ) с требованиями по формату и механизму выгрузки данных.
55
+
56
+ Выбрана модель промежуточного хранения данных на стороне продукта, которые подлежат выгрузке. При помощи такого подхода,
57
+ можно обеспечить формирование не хранящихся в продукте данных и дальнейшее их обновление и удаление. Упрощается процесс
58
+ поиска ошибок в данных, т.к. можно явно определить, в каких записях находятся ошибки и далее анализировать существующие
59
+ данные в продуктах или функционал по формированию данных.
60
+
61
+ ## Принцип работы
62
+
63
+ Весь процесс разделен на сбор и выгрузку данных. Выделяются следующие понятия:
64
+
65
+ Модель продукта
66
+ : Django-модель находящаяся в самом продукте. При помощи нее производится накапливание пользовательских данных;
67
+
68
+ Модель РВД
69
+ : Django-модель находящаяся в пакете РВД продукта. Из моделей РВД формируется схема БД, позволяющая хранить данные для
70
+ дальнейшей выгрузки в нормализованном виде;
71
+
72
+ Сущность РВД
73
+ : Описание формата выгрузки данных в РВД в виде dataclass-а. Хранит в себе описание первичных, внешних ключей,
74
+ обязательность и порядок полей.
75
+
76
+ На этапе сбора данных производится формирование данных моделей РВД на основе данных моделей продуктов. Существуют так
77
+ называемые расчетные модели, для которых данные рассчитываются в процессе сбора.
78
+
79
+ Стоит обратить внимание, что сущности РВД могут содержать в себе данные из нескольких моделей РВД.
80
+
81
+ ## Требования к окружению
82
+
83
+ Для работы требуется Python >=3.9. Так же в зависимостях есть внутренние пакеты:
84
+
85
+ - educommon;
86
+ - function-tools;
87
+ - m3-db-utils;
88
+ - uploader-client.
89
+
90
+ Версии всех пакетов уточнены в файлах с зависимостями.
91
+
92
+ ## Разворачивание
93
+
94
+ Перед внедрением пакета в проект, необходимо убедиться, что:
95
+
96
+ - В проекте используется логирование из educommon;
97
+ - В проект внедрен function-tools;
98
+ - В проект внедрен m3-db-utils;
99
+ - В проект внедрен uploader-client.
100
+
101
+ ## Параметры конфигурационного файла
102
+
103
+ В разных проектах существуют различные способы добавления настроек, где-то через плагины, где-то напрямую в settings.py.
104
+ Будет рассмотрен подход указания настроек в settings.py и указания параметров в конфигурационном файле.
105
+
106
+ Для возможности конфигурирования необходимо проделать ряд действий:
107
+
108
+ - Определение значений по умолчанию настроек в settings.py:
109
+ ```
110
+ PROJECT_DEFAULT_CONFIG.update({
111
+ # Настройки РВД
112
+ ('rdm_general', 'EXPORT_ENTITY_ID_PREFIX'): '', # Дефолтное значение нужно изменить на специфическое системе
113
+ ('rdm_general', 'COLLECT_CHUNK_SIZE'): 500,
114
+ ('rdm_general', 'EXPORT_CHUNK_SIZE'): 500,
115
+ ('rdm_transfer_task', 'MINUTE'): '0',
116
+ ('rdm_transfer_task', 'HOUR'): '*/4',
117
+ ('rdm_transfer_task', 'DAY_OF_WEEK'): '*',
118
+ ('rdm_transfer_task', 'LOCK_EXPIRE_SECONDS'): 21600,
119
+ ('rdm_transfer_task', 'TIMEDELTA'): 3600,
120
+ ('rdm_transfer_task', 'ENTITIES'): '',
121
+ ('rdm_upload_status_task', 'MINUTE'): '*/30',
122
+ ('rdm_upload_status_task', 'HOUR'): '*',
123
+ ('rdm_upload_status_task', 'DAY_OF_WEEK'): '*',
124
+ ('rdm_upload_status_task', 'LOCK_EXPIRE_SECONDS'): 7200,
125
+ ('uploader_client', 'URL'): 'http://localhost:8090',
126
+ ('uploader_client', 'DATAMART_NAME'): '',
127
+ ('uploader_client', 'REQUEST_RETRIES'): 10,
128
+ ('uploader_client', 'REQUEST_TIMEOUT'): 10,
129
+ ('uploader_client', 'ENABLE_REQUEST_EMULATION'): False,
130
+ })
131
+ ```
132
+ - Получение значений настроек из конфигурационного файла в settings.py:
133
+
134
+ ```
135
+ # Ссылка на каталог с файлами для загрузки
136
+ UPLOADS = 'uploads'
137
+
138
+ # =============================================================================
139
+ # Интеграция с Региональной витриной данных (РВД)
140
+ # =============================================================================
141
+
142
+ # Префикс идентификаторов записей сущностей специфический для продукта
143
+ RDM_EXPORT_ENTITY_ID_PREFIX = conf.get('rdm_general', 'EXPORT_ENTITY_ID_PREFIX')
144
+
145
+ # Количество записей моделей ЭШ обрабатываемых за одну итерацию сбора данных
146
+ RDM_COLLECT_CHUNK_SIZE = conf.get_int('rdm_general', 'COLLECT_CHUNK_SIZE')
147
+
148
+ # Количество записей моделей обрабатываемых за одну итерацию экспорта данных
149
+ RDM_EXPORT_CHUNK_SIZE = conf.get_int('rdm_general', 'EXPORT_CHUNK_SIZE')
150
+
151
+ # Количество не экспортированных записей моделей обрабатываемых за одну итерацию обновления поля modified
152
+ RDM_UPDATE_NON_EXPORTED_CHUNK_SIZE = conf.get_int('rdm_general', 'UPDATE_NON_EXPORTED_CHUNK_SIZE')
153
+
154
+ # Настройка запуска периодической задачи выгрузки данных:
155
+ RDM_TRANSFER_TASK_MINUTE = conf.get('rdm_transfer_task', 'MINUTE')
156
+ RDM_TRANSFER_TASK_HOUR = conf.get('rdm_transfer_task', 'HOUR')
157
+ RDM_TRANSFER_TASK_DAY_OF_WEEK = conf.get('rdm_transfer_task', 'DAY_OF_WEEK')
158
+ RDM_TRANSFER_TASK_EXPIRE_SECOND = conf.get('rdm_transfer_task', 'LOCK_EXPIRE_SECONDS')
159
+
160
+ # Настройка запуска периодической задачи статуса загрузки данных в витрину:
161
+ RDM_UPLOAD_STATUS_TASK_MINUTE = conf.get('rdm_upload_status_task', 'MINUTE')
162
+ RDM_UPLOAD_STATUS_TASK_HOUR = conf.get('rdm_upload_status_task', 'HOUR')
163
+ RDM_UPLOAD_STATUS_TASK_DAY_OF_WEEK = conf.get('rdm_upload_status_task', 'DAY_OF_WEEK')
164
+ RDM_UPLOAD_STATUS_TASK_EXPIRE_SECOND = conf.get('rdm_upload_status_task', 'LOCK_EXPIRE_SECONDS')
165
+
166
+ # Настройка запуска периодической задачи поиска зависших этапов экспорта:
167
+ RDM_CHECK_SUSPEND_TASK_MINUTE = conf.get('rdm_check_suspend_task', 'MINUTE')
168
+ RDM_CHECK_SUSPEND_TASK_HOUR = conf.get('rdm_check_suspend_task', 'HOUR')
169
+ RDM_CHECK_SUSPEND_TASK_DAY_OF_WEEK = conf.get('rdm_check_suspend_task', 'DAY_OF_WEEK')
170
+ RDM_CHECK_SUSPEND_TASK_EXPIRE_SECOND = conf.get('rdm_check_suspend_task', 'LOCK_EXPIRE_SECONDS')
171
+ RDM_CHECK_SUSPEND_TASK_TIMEDELTA = conf.get_int('rdm_check_suspend_task', 'TIMEDELTA')
172
+
173
+ # Загрузка данных в Региональную витрину данных (РВД)
174
+ # Адрес витрины (schema://host:port)
175
+ RDM_UPLOADER_CLIENT_URL = conf.get('uploader_client', 'URL')
176
+
177
+ # Мнемоника Витрины
178
+ RDM_UPLOADER_CLIENT_DATAMART_NAME = conf.get('uploader_client', 'DATAMART_NAME')
179
+
180
+ # Количество повторных попыток запроса
181
+ RDM_UPLOADER_CLIENT_REQUEST_RETRIES = conf.get_int('uploader_client', 'REQUEST_RETRIES')
182
+
183
+ # Таймаут запроса, сек
184
+ RDM_UPLOADER_CLIENT_REQUEST_TIMEOUT = conf.get_int('uploader_client', 'REQUEST_TIMEOUT')
185
+
186
+ # Включить эмуляцию отправки запросов
187
+ RDM_UPLOADER_CLIENT_ENABLE_REQUEST_EMULATION = conf.get_bool('uploader_client', 'ENABLE_REQUEST_EMULATION')
188
+
189
+ ```
190
+
191
+ Перечень настроек в settings.py указан в таблице ниже.
192
+
193
+ | Название настройки в settings | Описание | Значение по умолчанию |
194
+ | -------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------- | ----------------------- |
195
+ | UPLOADS | Основная директория в MEDIA, в которой будет создана директория edu_rdm_integration для сохранения файлов для дальнейшей выгрузки | 500 |
196
+ | RDM_COLLECT_CHUNK_SIZE | Количество записей моделей обрабатываемых за одну итерацию сбора данных | 500 |
197
+ | RDM_EXPORT_CHUNK_SIZE | Количество записей моделей обрабатываемых за одну итерацию экспорта | 500 |
198
+ | RDM_UPDATE_NON_EXPORTED_CHUNK_SIZE | # Количество не экспортированных записей моделей обрабатываемых за одну итерацию обновления поля modified | 5000 |
199
+ | RDM_UPLOADER_CLIENT_URL | Адрес витрины (schema://host:port) | 'http://localhost:8090' |
200
+ | RDM_UPLOADER_CLIENT_DATAMART_NAME | Мнемоника Витрины | 'test' |
201
+ | RDM_UPLOADER_CLIENT_REQUEST_RETRIES | Количество повторных попыток запроса | 10 |
202
+ | RDM_UPLOADER_CLIENT_REQUEST_TIMEOUT | Таймаут запроса, сек | 10 |
203
+ | RDM_UPLOADER_CLIENT_ENABLE_REQUEST_EMULATION | Включить эмуляцию отправки запросов | True |
204
+ | RDM_TRANSFER_TASK_MINUTE | Настройка запуска периодической задачи выгрузки данных. Минута | '0' |
205
+ | RDM_TRANSFER_TASK_HOUR | Настройка запуска периодической задачи выгрузки данных. Час | '*/4' |
206
+ | RDM_TRANSFER_TASK_DAY_OF_WEEK | Настройка запуска периодической задачи выгрузки данных. День недели | '*' |
207
+ | RDM_TRANSFER_TASK_LOCK_EXPIRE_SECONDS | Время по истечении которого, блокировка может быть снята (в секунадх) | 21600 |
208
+ | RDM_UPLOAD_STATUS_TASK_MINUTE | Настройка запуска периодической задачи статуса загрузки данных в витрину. Минута | '*/30' |
209
+ | RDM_UPLOAD_STATUS_TASK_HOUR | Настройка запуска периодической задачи статуса загрузки данных в витрину. Час | '*' |
210
+ | RDM_UPLOAD_STATUS_TASK_DAY_OF_WEEK | Настройка запуска периодической задачи статуса загрузки данных в витрину. День недели | '*' |
211
+ | RDM_UPLOAD_STATUS_TASK_LOCK_EXPIRE_SECONDS | Время по истечении которого, блокировка может быть снята (в секунадх) | 3600 |
212
+ | RDM_CHECK_SUSPEND_TASK_STAGE_TIMEOUT | Дельта для определения зависшего подэтапа. Минута | 120 |
213
+
214
+
215
+
216
+ - В дефолтный конфиг проекта необходимо добавить:
217
+
218
+ ```
219
+ # Общие настройки интеграции с РВД
220
+ [rmd_general]
221
+ # Префикс идентификаторов записей сущностей специфический для продукта. Указывается в settings.py и не должен
222
+ # изменяться. Возможность изменения через конфигурационный файл оставлена для экстренных случаев.
223
+ # EXPORT_ENTITY_ID_PREFIX =
224
+ # Количество записей моделей обрабатываемых за одну итерацию экспорта данных
225
+ EXPORT_CHUNK_SIZE = 500
226
+ # Количество записей моделей ЭШ обрабатываемых за одну итерацию сбора данных
227
+ COLLECT_CHUNK_SIZE = 500
228
+ # Количество не экспортированных записей моделей обрабатываемых за одну итерацию обновления поля modified
229
+ UPDATE_NON_EXPORTED_CHUNK_SIZE = 5_000
230
+
231
+ # Настройка запуска периодической задачи выгрузки данных
232
+ [rdm_transfer_task]
233
+ MINUTE=*/2
234
+ HOUR=*
235
+ DAY_OF_WEEK=*
236
+ LOCK_EXPIRE_SECONDS=21600
237
+ # Дельта между прошлым и текущим запуском, сек
238
+ TIMEDELTA=120
239
+ # Сущности, по которым должен производиться сбор и выгрузка данных. Перечисляются через запятую без пробелов.
240
+ ENTITIES =
241
+
242
+ # Настройка запуска периодической задачи статуса загрузки данных в витрину
243
+ [rdm_upload_status_task]
244
+ MINUTE=*/2
245
+ HOUR=*
246
+ DAY_OF_WEEK=*
247
+ LOCK_EXPIRE_SECONDS=7200
248
+
249
+ # Настройка запуска периодической задачи поиска зависших этапов экспорта
250
+ [rdm_check_suspend_task]
251
+ MINUTE=*/10
252
+ HOUR=*
253
+ DAY_OF_WEEK=*
254
+ LOCK_EXPIRE_SECONDS=7200
255
+ # Дельта для определения зависшего подэтапа, мин
256
+ STAGE_TIMEOUT=120
257
+
258
+ [uploader_client]
259
+ # Адрес витрины
260
+ URL = http://localhost:8090
261
+ # Мнемоника Витрины
262
+ DATAMART_NAME = test
263
+ # Количество повторных попыток запроса
264
+ REQUEST_RETRIES = 10
265
+ # Таймаут запроса, сек
266
+ REQUEST_TIMEOUT = 10
267
+ # Включить эмуляцию отправки запросов
268
+ ENABLE_REQUEST_EMULATION = True
269
+ ```
270
+
271
+ На основе дефолтного конфига произвести конфигурирование приложений.
272
+
273
+ ## Сборка и распространение
274
+
275
+ Сборка пакета производится при помощи [Job-а в Jenkins M3.build_dist](http://jenkins.py.bars.group/view/PY/job/M3.packages/job/M3.build_dist/).
276
+
277
+ Пакет выкладывается в глобальный [PYPI](https://pypi.org/project/edu-rdm-integration/) и во внутренний [Nexus](http://nexus.py.bars.group/#browse/browse:pypi-edu-private:edu-rdm-integration)
278
+
279
+ ## Документация
280
+
281
+ С документацией можно ознакомиться по ссылке http://docs.py.bars.group/edu-rdm-integration/
@@ -179,9 +179,8 @@ edu_rdm_integration/uploader_log/enums.py,sha256=rgSO3BL2rh2xpfm0Pt4waQW8fB1VMJL
179
179
  edu_rdm_integration/uploader_log/managers.py,sha256=OFdToWV8qhdfeGNpd-UWAmSEISzixmVQ6LF75EW7gzA,3248
180
180
  edu_rdm_integration/uploader_log/ui.py,sha256=YM9Buqp2wxE95Wf5gvAATBzuYzDOossK1sEmvFk07cI,2110
181
181
  edu_rdm_integration/uploader_log/templates/ui-js/object-grid-buttons.js,sha256=2xyGe0wdVokM0RhpzRzcRvJPBkBmPe3SlZry4oP4Nzs,6201
182
- edu_rdm_integration-3.5.7.dist-info/LICENSE,sha256=uw43Gjjj-1vXWCItfSrNDpbejnOwZMrNerUh8oWbq8Q,3458
183
- edu_rdm_integration-3.5.7.dist-info/METADATA,sha256=vulkiuukw61qOjoU9u84Met068PnWwwBndY7-k-zw9g,81379
184
- edu_rdm_integration-3.5.7.dist-info/WHEEL,sha256=yQN5g4mg4AybRjkgi-9yy4iQEFibGQmlz78Pik5Or-A,92
185
- edu_rdm_integration-3.5.7.dist-info/namespace_packages.txt,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1
186
- edu_rdm_integration-3.5.7.dist-info/top_level.txt,sha256=nRJV0O14UtNE-jGIYG03sohgFnZClvf57H5m6VBXe9Y,20
187
- edu_rdm_integration-3.5.7.dist-info/RECORD,,
182
+ edu_rdm_integration-3.5.10.dist-info/licenses/LICENSE,sha256=uw43Gjjj-1vXWCItfSrNDpbejnOwZMrNerUh8oWbq8Q,3458
183
+ edu_rdm_integration-3.5.10.dist-info/METADATA,sha256=ien3M8dOFq0hl4tzk6-zwJINdEpgdVZnzlaRitgTkyA,20229
184
+ edu_rdm_integration-3.5.10.dist-info/WHEEL,sha256=1tXe9gY0PYatrMPMDd6jXqjfpz_B-Wqm32CPfRC58XU,91
185
+ edu_rdm_integration-3.5.10.dist-info/top_level.txt,sha256=nRJV0O14UtNE-jGIYG03sohgFnZClvf57H5m6VBXe9Y,20
186
+ edu_rdm_integration-3.5.10.dist-info/RECORD,,
@@ -1,5 +1,5 @@
1
1
  Wheel-Version: 1.0
2
- Generator: bdist_wheel (0.41.2)
2
+ Generator: setuptools (77.0.3)
3
3
  Root-Is-Purelib: true
4
4
  Tag: py3-none-any
5
5