edu-rdm-integration 0.6.1__py3-none-any.whl → 0.6.3__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.
- edu_rdm_integration/collect_data/calculated/strategies.py +1 -1
- edu_rdm_integration/collect_data/generators.py +5 -0
- edu_rdm_integration/collect_data/non_calculated/strategies.py +1 -1
- edu_rdm_integration/export_data/strategies.py +1 -1
- edu_rdm_integration/function_templates/__init__.py +0 -0
- edu_rdm_integration/models.py +19 -4
- {edu_rdm_integration-0.6.1.dist-info → edu_rdm_integration-0.6.3.dist-info}/METADATA +143 -80
- {edu_rdm_integration-0.6.1.dist-info → edu_rdm_integration-0.6.3.dist-info}/RECORD +12 -11
- {edu_rdm_integration-0.6.1.dist-info → edu_rdm_integration-0.6.3.dist-info}/LICENSE +0 -0
- {edu_rdm_integration-0.6.1.dist-info → edu_rdm_integration-0.6.3.dist-info}/WHEEL +0 -0
- {edu_rdm_integration-0.6.1.dist-info → edu_rdm_integration-0.6.3.dist-info}/namespace_packages.txt +0 -0
- {edu_rdm_integration-0.6.1.dist-info → edu_rdm_integration-0.6.3.dist-info}/top_level.txt +0 -0
@@ -100,7 +100,7 @@ class CollectingCalculatedExportedDataFunctionImplementationStrategy(
|
|
100
100
|
"""
|
101
101
|
Формирование названия шаблона создания функции.
|
102
102
|
"""
|
103
|
-
return '
|
103
|
+
return 'function_collect_data_template'
|
104
104
|
|
105
105
|
def _prepare_manager_class(self):
|
106
106
|
"""
|
@@ -1,3 +1,4 @@
|
|
1
|
+
import uuid
|
1
2
|
from datetime import (
|
2
3
|
date,
|
3
4
|
datetime,
|
@@ -111,6 +112,8 @@ class BaseFirstCollectModelsDataCommandsGenerator:
|
|
111
112
|
|
112
113
|
self.batch_size = batch_size
|
113
114
|
|
115
|
+
self.generation_id = uuid.uuid4()
|
116
|
+
|
114
117
|
# Правую дату нужно увеличивать на одну секунду, т.к. подрезались миллисекунды
|
115
118
|
self.get_logs_periods_sql = (
|
116
119
|
"""
|
@@ -169,6 +172,7 @@ class BaseFirstCollectModelsDataCommandsGenerator:
|
|
169
172
|
'period_started_at': start_datetime,
|
170
173
|
'period_ended_at': end_datetime,
|
171
174
|
'model': rdm_model.key,
|
175
|
+
'generation_id': self.generation_id,
|
172
176
|
}
|
173
177
|
)
|
174
178
|
|
@@ -214,6 +218,7 @@ class BaseFirstCollectModelsDataCommandsGenerator:
|
|
214
218
|
'period_started_at': period_started_at,
|
215
219
|
'period_ended_at': period_ended_at,
|
216
220
|
'model': rdm_model.key,
|
221
|
+
'generation_id': self.generation_id,
|
217
222
|
}
|
218
223
|
)
|
219
224
|
|
@@ -100,7 +100,7 @@ class CollectingExportedDataFunctionImplementationStrategy(
|
|
100
100
|
"""
|
101
101
|
Формирование названия шаблона создания функции.
|
102
102
|
"""
|
103
|
-
return '
|
103
|
+
return 'function_collect_data_template'
|
104
104
|
|
105
105
|
def _prepare_manager_class(self):
|
106
106
|
"""
|
File without changes
|
edu_rdm_integration/models.py
CHANGED
@@ -1,7 +1,12 @@
|
|
1
|
+
import uuid
|
1
2
|
from datetime import (
|
2
3
|
datetime,
|
3
4
|
)
|
4
5
|
|
6
|
+
import django.utils.timezone
|
7
|
+
from django.contrib.postgres.fields import (
|
8
|
+
JSONField,
|
9
|
+
)
|
5
10
|
from django.db.models import (
|
6
11
|
CASCADE,
|
7
12
|
PROTECT,
|
@@ -11,8 +16,8 @@ from django.db.models import (
|
|
11
16
|
DateTimeField,
|
12
17
|
FileField,
|
13
18
|
ForeignKey,
|
14
|
-
PositiveSmallIntegerField,
|
15
19
|
SmallIntegerField,
|
20
|
+
UUIDField,
|
16
21
|
)
|
17
22
|
from m3.db import (
|
18
23
|
BaseObjectModel,
|
@@ -672,15 +677,25 @@ class AbstractCollectDataCommandProgress(ReprStrPreModelMixin, BaseObjectModel):
|
|
672
677
|
verbose_name='Модель РВД',
|
673
678
|
on_delete=PROTECT,
|
674
679
|
)
|
680
|
+
created = DateTimeField(
|
681
|
+
verbose_name='Дата создания',
|
682
|
+
default=django.utils.timezone.now,
|
683
|
+
)
|
675
684
|
logs_period_started_at = DateTimeField(
|
676
685
|
'Левая граница периода обрабатываемых логов',
|
677
686
|
)
|
678
687
|
logs_period_ended_at = DateTimeField(
|
679
688
|
'Правая граница периода обрабатываемых логов',
|
680
689
|
)
|
681
|
-
|
682
|
-
'
|
683
|
-
default=
|
690
|
+
generation_id = UUIDField(
|
691
|
+
'Идентификатор генерации',
|
692
|
+
default=uuid.uuid4,
|
693
|
+
)
|
694
|
+
institute_ids = JSONField(
|
695
|
+
'id учебного заведения',
|
696
|
+
blank=True,
|
697
|
+
null=True,
|
698
|
+
default=list,
|
684
699
|
)
|
685
700
|
|
686
701
|
class Meta:
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: edu-rdm-integration
|
3
|
-
Version: 0.6.
|
3
|
+
Version: 0.6.3
|
4
4
|
Summary: Интеграция с Региональной витриной данных
|
5
5
|
Home-page:
|
6
6
|
Download-URL:
|
@@ -28,25 +28,70 @@ Requires-Dist: function-tools <1,>=0.5.0
|
|
28
28
|
Requires-Dist: m3-db-utils <1,>=0.3.4
|
29
29
|
Requires-Dist: uploader-client <1,>=0.1.12
|
30
30
|
|
31
|
-
# Проект "Интеграция с Региональной витриной данных"
|
31
|
+
# Проект "Интеграция с Региональной витриной данных (РВД)"
|
32
|
+
|
33
|
+
Для интеграции с Региональной витриной данных был выделен отдельный пакет для использования его компонентов в различных
|
34
|
+
продуктах.
|
35
|
+
|
36
|
+
На текущий момент интеграция реализуется в рамках проектов Электронная школа (ЭШ) и Электронный колледж (ЭК).
|
32
37
|
|
33
38
|
## Описание концепции
|
34
39
|
|
40
|
+
Со стороны Минцифры предоставляется спецификация (ЕФТТ) с требованиями по формату и механизму выгрузки данных.
|
41
|
+
|
42
|
+
Выбрана модель промежуточного хранения данных на стороне продукта, которые подлежат выгрузке. При помощи такого подхода,
|
43
|
+
можно обеспечить формирование не хранящихся в продукте данных и дальнейшее их обновление и удаление. Упрощается процесс
|
44
|
+
поиска ошибок в данных, т.к. можно явно определить, в каких записях находятся ошибки и далее анализировать существующие
|
45
|
+
данные в продуктах или функционал по формированию данных.
|
46
|
+
|
35
47
|
## Принцип работы
|
36
48
|
|
49
|
+
Весь процесс разделен на сбор и выгрузку данных. Выделяются следующие понятия:
|
50
|
+
|
51
|
+
Модель продукта
|
52
|
+
: Django-модель находящаяся в самом продукте. При помощи нее производится накапливание пользовательских данных;
|
53
|
+
|
54
|
+
Модель РВД
|
55
|
+
: Django-модель находящаяся в пакете РВД продукта. Из моделей РВД формируется схема БД, позволяющая хранить данные для
|
56
|
+
дальнейшей выгрузки в нормализованном виде;
|
57
|
+
|
58
|
+
Сущность РВД
|
59
|
+
: Описание формата выгрузки данных в РВД в виде dataclass-а. Хранит в себе описание первичных, внешних ключей,
|
60
|
+
обязательность и порядок полей.
|
61
|
+
|
62
|
+
На этапе сбора данных производится формирование данных моделей РВД на основе данных моделей продуктов. Существуют так
|
63
|
+
называемые расчетные модели, для которых данные рассчитываются в процессе сбора.
|
64
|
+
|
65
|
+
Стоит обратить внимание, что сущности РВД могут содержать в себе данные из нескольких моделей РВД.
|
66
|
+
|
37
67
|
## Требования к окружению
|
38
68
|
|
69
|
+
Для работы требуется Python >=3.7. Так же в зависимостях есть внутренние пакеты:
|
70
|
+
|
71
|
+
- educommon;
|
72
|
+
- function-tools;
|
73
|
+
- m3-db-utils;
|
74
|
+
- uploader-client.
|
75
|
+
|
76
|
+
Версии всех пакетов уточнены в файлах с зависимостями.
|
77
|
+
|
39
78
|
## Разворачивание
|
40
79
|
|
41
|
-
|
80
|
+
Перед внедрением пакета в проект, необходимо убедиться, что:
|
81
|
+
|
82
|
+
- В проекте используется логирование из educommon;
|
83
|
+
- В проект внедрен function-tools;
|
84
|
+
- В проект внедрен m3-db-utils;
|
85
|
+
- В проект внедрен uploader-client.
|
42
86
|
|
87
|
+
## Параметры конфигурационного файла
|
43
88
|
|
44
89
|
В разных проектах существуют различные способы добавления настроек, где-то через плагины, где-то напрямую в settings.py.
|
45
90
|
Будет рассмотрен подход указания настроек в settings.py и указания параметров в конфигурационном файле.
|
46
91
|
|
47
|
-
Для возможности конфигурирования необходимо проделать ряд
|
92
|
+
Для возможности конфигурирования необходимо проделать ряд действий:
|
48
93
|
|
49
|
-
- Определение значений по умолчанию
|
94
|
+
- Определение значений по умолчанию настроек в settings.py:
|
50
95
|
```
|
51
96
|
PROJECT_DEFAULT_CONFIG.update({
|
52
97
|
# Настройки РВД
|
@@ -67,7 +112,7 @@ Requires-Dist: uploader-client <1,>=0.1.12
|
|
67
112
|
('uploader_client', 'ENABLE_REQUEST_EMULATION'): False,
|
68
113
|
})
|
69
114
|
```
|
70
|
-
- Получение значений настроек из конфигурационного
|
115
|
+
- Получение значений настроек из конфигурационного файла в settings.py:
|
71
116
|
|
72
117
|
```
|
73
118
|
# Ссылка на каталог с файлами для загрузки
|
@@ -120,90 +165,89 @@ Requires-Dist: uploader-client <1,>=0.1.12
|
|
120
165
|
RDM_UPLOADER_CLIENT_ENABLE_REQUEST_EMULATION = conf.get_bool('uploader_client', 'ENABLE_REQUEST_EMULATION')
|
121
166
|
|
122
167
|
```
|
168
|
+
|
169
|
+
Перечень настроек в settings.py указан в таблице ниже.
|
170
|
+
|
171
|
+
| Название настройки в settings | Описание | Значение по умолчанию |
|
172
|
+
|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
|
173
|
+
| UPLOADS | Основная директория в MEDIA, в которой будет создана директория edu_rdm_integration для сохранения файлов для дальнейшей выгрузки | 500 |
|
174
|
+
| RDM_COLLECT_CHUNK_SIZE | Количество записей моделей обрабатываемых за одну итерацию сбора данных | 500 |
|
175
|
+
| RDM_EXPORT_CHUNK_SIZE | Количество записей моделей обрабатываемых за одну итерацию экспорта | 500 |
|
176
|
+
| RDM_UPLOADER_CLIENT_URL | Адрес витрины (schema://host:port) | 'http://localhost:8090' |
|
177
|
+
| RDM_UPLOADER_CLIENT_DATAMART_NAME | Мнемоника Витрины | 'test' |
|
178
|
+
| RDM_UPLOADER_CLIENT_REQUEST_RETRIES | Количество повторных попыток запроса | 10 |
|
179
|
+
| RDM_UPLOADER_CLIENT_REQUEST_TIMEOUT | Таймаут запроса, сек | 10 |
|
180
|
+
| RDM_UPLOADER_CLIENT_ENABLE_REQUEST_EMULATION | Включить эмуляцию отправки запросов | True |
|
181
|
+
| RDM_TRANSFER_TASK_MINUTE | Настройка запуска периодической задачи выгрузки данных. Минута | '0' |
|
182
|
+
| RDM_TRANSFER_TASK_HOUR | Настройка запуска периодической задачи выгрузки данных. Час | '*/4' |
|
183
|
+
| RDM_TRANSFER_TASK_DAY_OF_WEEK | Настройка запуска периодической задачи выгрузки данных. День недели | '*' |
|
184
|
+
| RDM_TRANSFER_TASK_TIMEDELTA | Дельта между предыдущим и следующим запуском периодической задачи в секундах | 3600 |
|
185
|
+
| RDM_UPLOAD_STATUS_TASK_MINUTE | Настройка запуска периодической задачи статуса загрузки данных в витрину. Минута | '*/30' |
|
186
|
+
| RDM_UPLOAD_STATUS_TASK_HOUR | Настройка запуска периодической задачи статуса загрузки данных в витрину. Час | '*' |
|
187
|
+
| RDM_UPLOAD_STATUS_TASK_DAY_OF_WEEK | Настройка запуска периодической задачи статуса загрузки данных в витрину. День недели | '*' |
|
188
|
+
| RDM_CHECK_SUSPEND_TASK_STAGE_TIMEOUT | Дельта для определения зависшего подэтапа. Минута | 120 |
|
189
|
+
|
123
190
|
|
124
|
-
В дефолтный конфиг проекта необходимо добавить:
|
125
|
-
|
126
|
-
```
|
127
|
-
# Общие настройки интеграции с РВД
|
128
|
-
[rmd_general]
|
129
|
-
# Префикс идентификаторов записей сущностей специфический для продукта. Указывается в settings.py и не должен
|
130
|
-
# изменяться. Возможность изменения через конфигурационный файл оставлена для экстренных случаев.
|
131
|
-
# EXPORT_ENTITY_ID_PREFIX =
|
132
|
-
# Количество записей моделей обрабатываемых за одну итерацию экспорта данных
|
133
|
-
EXPORT_CHUNK_SIZE = 500
|
134
|
-
# Количество записей моделей ЭШ обрабатываемых за одну итерацию сбора данных
|
135
|
-
COLLECT_CHUNK_SIZE = 500
|
136
|
-
|
137
|
-
# Настройка запуска периодической задачи выгрузки данных
|
138
|
-
[rdm_transfer_task]
|
139
|
-
MINUTE=*/2
|
140
|
-
HOUR=*
|
141
|
-
DAY_OF_WEEK=*
|
142
|
-
# Дельта между прошлым и текущим запуском, сек
|
143
|
-
TIMEDELTA=120
|
144
|
-
|
145
|
-
# Настройка запуска периодической задачи статуса загрузки данных в витрину
|
146
|
-
[rdm_upload_status_task]
|
147
|
-
MINUTE=*/2
|
148
|
-
HOUR=*
|
149
|
-
DAY_OF_WEEK=*
|
150
|
-
|
151
|
-
# Настройка запуска периодической задачи поиска зависших этапов экспорта
|
152
|
-
[rdm_check_suspend_task]
|
153
|
-
MINUTE=*/10
|
154
|
-
HOUR=*
|
155
|
-
DAY_OF_WEEK=*
|
156
|
-
# Дельта для определения зависшего подэтапа, мин
|
157
|
-
STAGE_TIMEOUT=120
|
158
|
-
|
159
|
-
[uploader_client]
|
160
|
-
# Адрес витрины
|
161
|
-
URL = http://localhost:8090
|
162
|
-
# Мнемоника Витрины
|
163
|
-
DATAMART_NAME = test
|
164
|
-
# Количество повторных попыток запроса
|
165
|
-
REQUEST_RETRIES = 10
|
166
|
-
# Таймаут запроса, сек
|
167
|
-
REQUEST_TIMEOUT = 10
|
168
|
-
# Включить эмуляцию отправки запросов
|
169
|
-
ENABLE_REQUEST_EMULATION = True
|
170
|
-
```
|
171
191
|
|
172
|
-
|
192
|
+
- В дефолтный конфиг проекта необходимо добавить:
|
173
193
|
|
174
|
-
|
175
|
-
|
176
|
-
|
177
|
-
|
178
|
-
|
179
|
-
|
180
|
-
|
181
|
-
|
182
|
-
|
183
|
-
|
184
|
-
|
185
|
-
|
186
|
-
|
187
|
-
|
188
|
-
|
189
|
-
|
190
|
-
|
191
|
-
|
192
|
-
|
193
|
-
|
194
|
+
```
|
195
|
+
# Общие настройки интеграции с РВД
|
196
|
+
[rmd_general]
|
197
|
+
# Префикс идентификаторов записей сущностей специфический для продукта. Указывается в settings.py и не должен
|
198
|
+
# изменяться. Возможность изменения через конфигурационный файл оставлена для экстренных случаев.
|
199
|
+
# EXPORT_ENTITY_ID_PREFIX =
|
200
|
+
# Количество записей моделей обрабатываемых за одну итерацию экспорта данных
|
201
|
+
EXPORT_CHUNK_SIZE = 500
|
202
|
+
# Количество записей моделей ЭШ обрабатываемых за одну итерацию сбора данных
|
203
|
+
COLLECT_CHUNK_SIZE = 500
|
204
|
+
|
205
|
+
# Настройка запуска периодической задачи выгрузки данных
|
206
|
+
[rdm_transfer_task]
|
207
|
+
MINUTE=*/2
|
208
|
+
HOUR=*
|
209
|
+
DAY_OF_WEEK=*
|
210
|
+
# Дельта между прошлым и текущим запуском, сек
|
211
|
+
TIMEDELTA=120
|
212
|
+
|
213
|
+
# Настройка запуска периодической задачи статуса загрузки данных в витрину
|
214
|
+
[rdm_upload_status_task]
|
215
|
+
MINUTE=*/2
|
216
|
+
HOUR=*
|
217
|
+
DAY_OF_WEEK=*
|
218
|
+
|
219
|
+
# Настройка запуска периодической задачи поиска зависших этапов экспорта
|
220
|
+
[rdm_check_suspend_task]
|
221
|
+
MINUTE=*/10
|
222
|
+
HOUR=*
|
223
|
+
DAY_OF_WEEK=*
|
224
|
+
# Дельта для определения зависшего подэтапа, мин
|
225
|
+
STAGE_TIMEOUT=120
|
226
|
+
|
227
|
+
[uploader_client]
|
228
|
+
# Адрес витрины
|
229
|
+
URL = http://localhost:8090
|
230
|
+
# Мнемоника Витрины
|
231
|
+
DATAMART_NAME = test
|
232
|
+
# Количество повторных попыток запроса
|
233
|
+
REQUEST_RETRIES = 10
|
234
|
+
# Таймаут запроса, сек
|
235
|
+
REQUEST_TIMEOUT = 10
|
236
|
+
# Включить эмуляцию отправки запросов
|
237
|
+
ENABLE_REQUEST_EMULATION = True
|
238
|
+
```
|
194
239
|
|
240
|
+
На основе дефолтного конфига произвести конфигурирование приложений.
|
195
241
|
|
196
242
|
## Сборка и распространение
|
197
243
|
|
198
|
-
|
199
|
-
|
200
|
-
## Настройка PyCharm для работы
|
244
|
+
Сборка пакета производится при помощи [Job-а в Jenkins M3.build_dist](http://jenkins.py.bars.group/view/PY/job/M3.packages/job/M3.build_dist/).
|
201
245
|
|
202
|
-
|
246
|
+
Пакет выкладывается в глобальный [PYPI](https://pypi.org/project/edu-rdm-integration/) и во внутренний [Nexus](http://nexus.py.bars.group/#browse/browse:pypi-edu-private:edu-rdm-integration)
|
203
247
|
|
204
|
-
##
|
248
|
+
## Документация
|
205
249
|
|
206
|
-
|
250
|
+
С документацией можно ознакомиться по ссылке http://docs.py.bars.group/edu-rdm-integration/
|
207
251
|
# История изменений
|
208
252
|
|
209
253
|
Все изменения проекта должны быть отражены в этом файле.
|
@@ -235,6 +279,25 @@ ENABLE_REQUEST_EMULATION = True
|
|
235
279
|
### Удалено
|
236
280
|
|
237
281
|
|
282
|
+
## [0.6.3] - 2023-10-05
|
283
|
+
|
284
|
+
Доработка модели AbstractCollectDataCommandProgress и класса BaseFirstCollectModelsDataCommandsGenerator.
|
285
|
+
|
286
|
+
### Добавлено
|
287
|
+
|
288
|
+
- [EDUSCHL-20350](https://jira.bars.group/browse/EDUSCHL-20350)
|
289
|
+
PATCH - Добавлено формирование id генерации для команд в классе BaseFirstCollectModelsDataCommandsGenerator.
|
290
|
+
- Добавлены поля created, generation_id и institute_ids в модель AbstractCollectDataCommandProgress.
|
291
|
+
|
292
|
+
|
293
|
+
## [0.6.2] - 2023-10-04
|
294
|
+
|
295
|
+
### Изменено
|
296
|
+
|
297
|
+
- [EDUCLLG-7942](https://jira.bars.group/browse/EDUCLLG-7942)
|
298
|
+
PATCH Доработка сборки документации.
|
299
|
+
|
300
|
+
|
238
301
|
## [0.6.1] - 2023-10-02
|
239
302
|
|
240
303
|
Дополнение поведения BaseExportDataFunctionHelper.
|
@@ -5,7 +5,7 @@ edu_rdm_integration/consts.py,sha256=chOsPOOY4_JLzN-8idg-VjbLWSlp6r3maFWqnvUsapg
|
|
5
5
|
edu_rdm_integration/entities.py,sha256=mI48GExfRrQZsyg8leGJDaiy8Cmf3vlkIttNq2OYJZI,9117
|
6
6
|
edu_rdm_integration/enums.py,sha256=fnDPz6pwOYWS6vp65IAExbpDzn2q9U3_9GGyuf4B468,4876
|
7
7
|
edu_rdm_integration/mapping.py,sha256=bwa2fJCbV4YjQcAgRrgT3hgM6dJhr_uBtQgx3L3F2Ck,473
|
8
|
-
edu_rdm_integration/models.py,sha256=
|
8
|
+
edu_rdm_integration/models.py,sha256=agBoepF0YScpfxo3VZWvw6uy707IteT8CQVJmpUt7M4,22207
|
9
9
|
edu_rdm_integration/signals.py,sha256=3eRlpkDcFCF6TN80-QM8yBYLcyozzcmoPjz6r4_ApWg,73
|
10
10
|
edu_rdm_integration/storages.py,sha256=o5WqUG7SnkeuMt-z8spUi-IraivST-7KHzfY-M3v7FA,6807
|
11
11
|
edu_rdm_integration/utils.py,sha256=CgFrW1mEQim3wcCX6q9o9mvIm79ASQ92HojXyuN3dc0,5558
|
@@ -28,7 +28,7 @@ edu_rdm_integration/adapters/tests.py,sha256=MoRY-a75Ow-7EjeQYxkXWunwqTGuBMaUyEk
|
|
28
28
|
edu_rdm_integration/adapters/validators.py,sha256=LJWnCY8PtXDOj-fm3fBWjQYsHsSLfyKf_D97pqPv73s,496
|
29
29
|
edu_rdm_integration/collect_data/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
30
30
|
edu_rdm_integration/collect_data/collect.py,sha256=3sicEiX9v_EQtd5vFOyclSV-kYNV7FNxx09DdyIWIAk,12843
|
31
|
-
edu_rdm_integration/collect_data/generators.py,sha256=
|
31
|
+
edu_rdm_integration/collect_data/generators.py,sha256=lmXbptKxirEXw8yEYyFf3tRTjmg_zzbQn8Ox76cxAuY,8870
|
32
32
|
edu_rdm_integration/collect_data/helpers.py,sha256=EftJ8R-tn1r7Y_P6tGZmqxJ9-g89m12p9kA8NYmwwbQ,3009
|
33
33
|
edu_rdm_integration/collect_data/base/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
34
34
|
edu_rdm_integration/collect_data/base/caches.py,sha256=3BaJxYBk9fi0aiAVzym-Jz8aNP1eSOqh4Y8OVw1HnSg,763
|
@@ -37,7 +37,7 @@ edu_rdm_integration/collect_data/base/managers.py,sha256=UkiFhyD3Gn3drErXc0NjQkS
|
|
37
37
|
edu_rdm_integration/collect_data/base/mixins.py,sha256=Rp3ECccl3vOWZH2QHR_ArAbibQMq92IMGPoP5XAfgVc,3180
|
38
38
|
edu_rdm_integration/collect_data/base/runners.py,sha256=mqrdVUMud7ss-0Iufj3DHEdy7BDHgbkZ7ZEGJfUaslc,2835
|
39
39
|
edu_rdm_integration/collect_data/calculated/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
40
|
-
edu_rdm_integration/collect_data/calculated/strategies.py,sha256=
|
40
|
+
edu_rdm_integration/collect_data/calculated/strategies.py,sha256=W9f-MlLENSoa9jHMLWTP7ktZL-7FVtkt2FLXrbmds-o,7629
|
41
41
|
edu_rdm_integration/collect_data/calculated/base/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
42
42
|
edu_rdm_integration/collect_data/calculated/base/caches.py,sha256=KOlCKlERUM-2gBTzrevLwQcgkOWULY0_CyxPXJ4pZOw,2672
|
43
43
|
edu_rdm_integration/collect_data/calculated/base/consts.py,sha256=DsgPOF_2iCzZTPity27oDDkpS6Axdhd5C94uSkIwA1g,84
|
@@ -53,7 +53,7 @@ edu_rdm_integration/collect_data/calculated/base/strings.py,sha256=-k9dex8A7hCpk
|
|
53
53
|
edu_rdm_integration/collect_data/calculated/base/tests.py,sha256=MoRY-a75Ow-7EjeQYxkXWunwqTGuBMaUyEkEV2oy05I,59
|
54
54
|
edu_rdm_integration/collect_data/calculated/base/validators.py,sha256=xIaSIE9oKbEeoOZPmO2O7NosukNnUjhwYmgn-Q4zPI0,1057
|
55
55
|
edu_rdm_integration/collect_data/non_calculated/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
56
|
-
edu_rdm_integration/collect_data/non_calculated/strategies.py,sha256=
|
56
|
+
edu_rdm_integration/collect_data/non_calculated/strategies.py,sha256=eR-z94U0XN8BBuFS789PzxCPPfUoL3a2mcZb10Psqeg,7431
|
57
57
|
edu_rdm_integration/collect_data/non_calculated/base/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
58
58
|
edu_rdm_integration/collect_data/non_calculated/base/caches.py,sha256=qRC92vy-oUcyokAF279CcZgWTl_x-PxsGAK-5Rb31-g,6821
|
59
59
|
edu_rdm_integration/collect_data/non_calculated/base/consts.py,sha256=pds1t4eHzovm7Yz2o5je3UHqRE8gqfT2sL-IwpoBN_o,66
|
@@ -73,7 +73,7 @@ edu_rdm_integration/export_data/consts.py,sha256=Z6Uho8oViMc0t1tyQFZfrPFBwPx6Knh
|
|
73
73
|
edu_rdm_integration/export_data/export.py,sha256=jqJYXg-Vm_IwkOxposZKk5QY8d4aBhNmGJOw4PRFJjk,14935
|
74
74
|
edu_rdm_integration/export_data/generators.py,sha256=huonSRK5arfBzU09BnLAHC7AsSFYU0sCz5utCtejdJk,3950
|
75
75
|
edu_rdm_integration/export_data/helpers.py,sha256=hU346RmQ17Ra2etFvxXI7JQlLyp_0KxH1jm-eeCqejc,2933
|
76
|
-
edu_rdm_integration/export_data/strategies.py,sha256=
|
76
|
+
edu_rdm_integration/export_data/strategies.py,sha256=ocHskG-x54U-ESX56OlZPgOibkGkuv7VKmK7hVmqj_0,6725
|
77
77
|
edu_rdm_integration/export_data/base/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
78
78
|
edu_rdm_integration/export_data/base/caches.py,sha256=dj8LGB7TMtX3cSfp-1UB3dnzcTGMt8aLtOn0YdNPsyQ,1541
|
79
79
|
edu_rdm_integration/export_data/base/consts.py,sha256=jLuy2y7YQ921OrEuzDld3F0k6YxgCnr5yorWBQJiLLw,519
|
@@ -89,6 +89,7 @@ edu_rdm_integration/export_data/base/runners.py,sha256=WFTAIHeBIzY86_0G6kUSXRadA
|
|
89
89
|
edu_rdm_integration/export_data/base/strings.py,sha256=-k9dex8A7hCpkzUkudVkKRAbNRuuqog2hYl2xmibl8I,181
|
90
90
|
edu_rdm_integration/export_data/base/tests.py,sha256=MoRY-a75Ow-7EjeQYxkXWunwqTGuBMaUyEkEV2oy05I,59
|
91
91
|
edu_rdm_integration/export_data/base/validators.py,sha256=hfeNU6Y47ZCg-PQNk5CyBf3-nMclMJSdvvLQBxVLUdk,961
|
92
|
+
edu_rdm_integration/function_templates/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
92
93
|
edu_rdm_integration/management/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
93
94
|
edu_rdm_integration/management/general.py,sha256=foOc5LJt7DFJSRqRzjQwlK-gyQEt-wSvz0Y4WA-W2Es,9056
|
94
95
|
edu_rdm_integration/management/commands/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
@@ -97,9 +98,9 @@ edu_rdm_integration/management/commands/export_entities_data.py,sha256=Mas1zwsH-
|
|
97
98
|
edu_rdm_integration/migrations/0001_initial.py,sha256=toNuYoHZePe5wJ6AKEW9oPOdt2OefmxDEDDJGYQIrFk,18719
|
98
99
|
edu_rdm_integration/migrations/0002_init_data_uploadstatus.py,sha256=kht966YNuDbC3qTGrcWswJPsVuAtNO59Ck15G2eS2bU,944
|
99
100
|
edu_rdm_integration/migrations/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
100
|
-
edu_rdm_integration-0.6.
|
101
|
-
edu_rdm_integration-0.6.
|
102
|
-
edu_rdm_integration-0.6.
|
103
|
-
edu_rdm_integration-0.6.
|
104
|
-
edu_rdm_integration-0.6.
|
105
|
-
edu_rdm_integration-0.6.
|
101
|
+
edu_rdm_integration-0.6.3.dist-info/LICENSE,sha256=uw43Gjjj-1vXWCItfSrNDpbejnOwZMrNerUh8oWbq8Q,3458
|
102
|
+
edu_rdm_integration-0.6.3.dist-info/METADATA,sha256=68SWwZHVWqJflkmFxkiI_8PDQAmnVpGioOf_cLk4YG0,34465
|
103
|
+
edu_rdm_integration-0.6.3.dist-info/WHEEL,sha256=yQN5g4mg4AybRjkgi-9yy4iQEFibGQmlz78Pik5Or-A,92
|
104
|
+
edu_rdm_integration-0.6.3.dist-info/namespace_packages.txt,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1
|
105
|
+
edu_rdm_integration-0.6.3.dist-info/top_level.txt,sha256=nRJV0O14UtNE-jGIYG03sohgFnZClvf57H5m6VBXe9Y,20
|
106
|
+
edu_rdm_integration-0.6.3.dist-info/RECORD,,
|
File without changes
|
File without changes
|
{edu_rdm_integration-0.6.1.dist-info → edu_rdm_integration-0.6.3.dist-info}/namespace_packages.txt
RENAMED
File without changes
|
File without changes
|