fractal-server 1.4.6__py3-none-any.whl → 2.0.0__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 (139) hide show
  1. fractal_server/__init__.py +1 -1
  2. fractal_server/app/db/__init__.py +0 -1
  3. fractal_server/app/models/__init__.py +6 -8
  4. fractal_server/app/models/linkuserproject.py +9 -0
  5. fractal_server/app/models/security.py +6 -0
  6. fractal_server/app/models/v1/__init__.py +12 -0
  7. fractal_server/app/models/{dataset.py → v1/dataset.py} +5 -5
  8. fractal_server/app/models/{job.py → v1/job.py} +5 -5
  9. fractal_server/app/models/{project.py → v1/project.py} +5 -5
  10. fractal_server/app/models/{state.py → v1/state.py} +2 -2
  11. fractal_server/app/models/{task.py → v1/task.py} +7 -2
  12. fractal_server/app/models/{workflow.py → v1/workflow.py} +5 -5
  13. fractal_server/app/models/v2/__init__.py +22 -0
  14. fractal_server/app/models/v2/collection_state.py +21 -0
  15. fractal_server/app/models/v2/dataset.py +54 -0
  16. fractal_server/app/models/v2/job.py +51 -0
  17. fractal_server/app/models/v2/project.py +30 -0
  18. fractal_server/app/models/v2/task.py +93 -0
  19. fractal_server/app/models/v2/workflow.py +35 -0
  20. fractal_server/app/models/v2/workflowtask.py +49 -0
  21. fractal_server/app/routes/admin/__init__.py +0 -0
  22. fractal_server/app/routes/{admin.py → admin/v1.py} +42 -42
  23. fractal_server/app/routes/admin/v2.py +309 -0
  24. fractal_server/app/routes/api/v1/__init__.py +7 -7
  25. fractal_server/app/routes/api/v1/_aux_functions.py +8 -8
  26. fractal_server/app/routes/api/v1/dataset.py +48 -41
  27. fractal_server/app/routes/api/v1/job.py +14 -14
  28. fractal_server/app/routes/api/v1/project.py +30 -27
  29. fractal_server/app/routes/api/v1/task.py +26 -16
  30. fractal_server/app/routes/api/v1/task_collection.py +28 -16
  31. fractal_server/app/routes/api/v1/workflow.py +28 -28
  32. fractal_server/app/routes/api/v1/workflowtask.py +11 -11
  33. fractal_server/app/routes/api/v2/__init__.py +34 -0
  34. fractal_server/app/routes/api/v2/_aux_functions.py +502 -0
  35. fractal_server/app/routes/api/v2/dataset.py +293 -0
  36. fractal_server/app/routes/api/v2/images.py +279 -0
  37. fractal_server/app/routes/api/v2/job.py +200 -0
  38. fractal_server/app/routes/api/v2/project.py +186 -0
  39. fractal_server/app/routes/api/v2/status.py +150 -0
  40. fractal_server/app/routes/api/v2/submit.py +210 -0
  41. fractal_server/app/routes/api/v2/task.py +222 -0
  42. fractal_server/app/routes/api/v2/task_collection.py +239 -0
  43. fractal_server/app/routes/api/v2/task_legacy.py +59 -0
  44. fractal_server/app/routes/api/v2/workflow.py +380 -0
  45. fractal_server/app/routes/api/v2/workflowtask.py +265 -0
  46. fractal_server/app/routes/aux/_job.py +2 -2
  47. fractal_server/app/runner/__init__.py +0 -379
  48. fractal_server/app/runner/async_wrap.py +27 -0
  49. fractal_server/app/runner/components.py +5 -0
  50. fractal_server/app/runner/exceptions.py +129 -0
  51. fractal_server/app/runner/executors/__init__.py +0 -0
  52. fractal_server/app/runner/executors/slurm/__init__.py +3 -0
  53. fractal_server/app/runner/{_slurm → executors/slurm}/_batching.py +1 -1
  54. fractal_server/app/runner/executors/slurm/_check_jobs_status.py +72 -0
  55. fractal_server/app/runner/{_slurm → executors/slurm}/_executor_wait_thread.py +3 -4
  56. fractal_server/app/runner/{_slurm → executors/slurm}/_slurm_config.py +3 -152
  57. fractal_server/app/runner/{_slurm → executors/slurm}/_subprocess_run_as_user.py +42 -1
  58. fractal_server/app/runner/{_slurm → executors/slurm}/executor.py +46 -27
  59. fractal_server/app/runner/filenames.py +6 -0
  60. fractal_server/app/runner/set_start_and_last_task_index.py +39 -0
  61. fractal_server/app/runner/task_files.py +103 -0
  62. fractal_server/app/runner/v1/__init__.py +366 -0
  63. fractal_server/app/runner/{_common.py → v1/_common.py} +56 -111
  64. fractal_server/app/runner/{_local → v1/_local}/__init__.py +5 -4
  65. fractal_server/app/runner/{_local → v1/_local}/_local_config.py +6 -7
  66. fractal_server/app/runner/{_local → v1/_local}/_submit_setup.py +1 -5
  67. fractal_server/app/runner/v1/_slurm/__init__.py +312 -0
  68. fractal_server/app/runner/{_slurm → v1/_slurm}/_submit_setup.py +5 -11
  69. fractal_server/app/runner/v1/_slurm/get_slurm_config.py +163 -0
  70. fractal_server/app/runner/v1/common.py +117 -0
  71. fractal_server/app/runner/{handle_failed_job.py → v1/handle_failed_job.py} +8 -8
  72. fractal_server/app/runner/v2/__init__.py +336 -0
  73. fractal_server/app/runner/v2/_local/__init__.py +162 -0
  74. fractal_server/app/runner/v2/_local/_local_config.py +118 -0
  75. fractal_server/app/runner/v2/_local/_submit_setup.py +52 -0
  76. fractal_server/app/runner/v2/_local/executor.py +100 -0
  77. fractal_server/app/runner/{_slurm → v2/_slurm}/__init__.py +38 -47
  78. fractal_server/app/runner/v2/_slurm/_submit_setup.py +82 -0
  79. fractal_server/app/runner/v2/_slurm/get_slurm_config.py +182 -0
  80. fractal_server/app/runner/v2/deduplicate_list.py +23 -0
  81. fractal_server/app/runner/v2/handle_failed_job.py +165 -0
  82. fractal_server/app/runner/v2/merge_outputs.py +38 -0
  83. fractal_server/app/runner/v2/runner.py +343 -0
  84. fractal_server/app/runner/v2/runner_functions.py +374 -0
  85. fractal_server/app/runner/v2/runner_functions_low_level.py +130 -0
  86. fractal_server/app/runner/v2/task_interface.py +62 -0
  87. fractal_server/app/runner/v2/v1_compat.py +31 -0
  88. fractal_server/app/schemas/__init__.py +1 -42
  89. fractal_server/app/schemas/_validators.py +28 -5
  90. fractal_server/app/schemas/v1/__init__.py +36 -0
  91. fractal_server/app/schemas/{applyworkflow.py → v1/applyworkflow.py} +18 -18
  92. fractal_server/app/schemas/{dataset.py → v1/dataset.py} +30 -30
  93. fractal_server/app/schemas/{dumps.py → v1/dumps.py} +8 -8
  94. fractal_server/app/schemas/{manifest.py → v1/manifest.py} +5 -5
  95. fractal_server/app/schemas/{project.py → v1/project.py} +9 -9
  96. fractal_server/app/schemas/{task.py → v1/task.py} +12 -12
  97. fractal_server/app/schemas/{task_collection.py → v1/task_collection.py} +7 -7
  98. fractal_server/app/schemas/{workflow.py → v1/workflow.py} +38 -38
  99. fractal_server/app/schemas/v2/__init__.py +37 -0
  100. fractal_server/app/schemas/v2/dataset.py +126 -0
  101. fractal_server/app/schemas/v2/dumps.py +87 -0
  102. fractal_server/app/schemas/v2/job.py +114 -0
  103. fractal_server/app/schemas/v2/manifest.py +159 -0
  104. fractal_server/app/schemas/v2/project.py +34 -0
  105. fractal_server/app/schemas/v2/status.py +16 -0
  106. fractal_server/app/schemas/v2/task.py +151 -0
  107. fractal_server/app/schemas/v2/task_collection.py +109 -0
  108. fractal_server/app/schemas/v2/workflow.py +79 -0
  109. fractal_server/app/schemas/v2/workflowtask.py +208 -0
  110. fractal_server/config.py +13 -10
  111. fractal_server/images/__init__.py +4 -0
  112. fractal_server/images/models.py +136 -0
  113. fractal_server/images/tools.py +84 -0
  114. fractal_server/main.py +11 -3
  115. fractal_server/migrations/env.py +0 -2
  116. fractal_server/migrations/versions/5bf02391cfef_v2.py +245 -0
  117. fractal_server/tasks/__init__.py +0 -5
  118. fractal_server/tasks/endpoint_operations.py +13 -19
  119. fractal_server/tasks/utils.py +35 -0
  120. fractal_server/tasks/{_TaskCollectPip.py → v1/_TaskCollectPip.py} +3 -3
  121. fractal_server/tasks/v1/__init__.py +0 -0
  122. fractal_server/tasks/{background_operations.py → v1/background_operations.py} +20 -52
  123. fractal_server/tasks/v1/get_collection_data.py +14 -0
  124. fractal_server/tasks/v2/_TaskCollectPip.py +103 -0
  125. fractal_server/tasks/v2/__init__.py +0 -0
  126. fractal_server/tasks/v2/background_operations.py +381 -0
  127. fractal_server/tasks/v2/get_collection_data.py +14 -0
  128. fractal_server/urls.py +13 -0
  129. {fractal_server-1.4.6.dist-info → fractal_server-2.0.0.dist-info}/METADATA +11 -12
  130. fractal_server-2.0.0.dist-info/RECORD +169 -0
  131. fractal_server/app/runner/_slurm/.gitignore +0 -2
  132. fractal_server/app/runner/common.py +0 -307
  133. fractal_server/app/schemas/json_schemas/manifest.json +0 -81
  134. fractal_server-1.4.6.dist-info/RECORD +0 -97
  135. /fractal_server/app/runner/{_slurm → executors/slurm}/remote.py +0 -0
  136. /fractal_server/app/runner/{_local → v1/_local}/executor.py +0 -0
  137. {fractal_server-1.4.6.dist-info → fractal_server-2.0.0.dist-info}/LICENSE +0 -0
  138. {fractal_server-1.4.6.dist-info → fractal_server-2.0.0.dist-info}/WHEEL +0 -0
  139. {fractal_server-1.4.6.dist-info → fractal_server-2.0.0.dist-info}/entry_points.txt +0 -0
@@ -1,6 +1,8 @@
1
1
  import os
2
2
  from datetime import datetime
3
3
  from datetime import timezone
4
+ from typing import Any
5
+ from typing import Optional
4
6
 
5
7
 
6
8
  def valstr(attribute: str, accept_none: bool = False):
@@ -11,7 +13,7 @@ def valstr(attribute: str, accept_none: bool = False):
11
13
  If `accept_none`, the validator also accepts `None`.
12
14
  """
13
15
 
14
- def val(string: str):
16
+ def val(string: Optional[str]) -> Optional[str]:
15
17
  if string is None:
16
18
  if accept_none:
17
19
  return string
@@ -27,13 +29,34 @@ def valstr(attribute: str, accept_none: bool = False):
27
29
  return val
28
30
 
29
31
 
32
+ def valdictkeys(attribute: str):
33
+ def val(d: Optional[dict[str, Any]]) -> Optional[dict[str, Any]]:
34
+ """
35
+ Apply valstr to every key of the dictionary, and fail if there are
36
+ identical keys.
37
+ """
38
+ if d is not None:
39
+ old_keys = list(d.keys())
40
+ new_keys = [valstr(f"{attribute}[{key}]")(key) for key in old_keys]
41
+ if len(new_keys) != len(set(new_keys)):
42
+ raise ValueError(
43
+ f"Dictionary contains multiple identical keys: {d}."
44
+ )
45
+ for old_key, new_key in zip(old_keys, new_keys):
46
+ if new_key != old_key:
47
+ d[new_key] = d.pop(old_key)
48
+ return d
49
+
50
+ return val
51
+
52
+
30
53
  def valint(attribute: str, min_val: int = 1):
31
54
  """
32
55
  Check that an integer attribute (e.g. if it is meant to be the ID of a
33
56
  database entry) is greater or equal to min_val.
34
57
  """
35
58
 
36
- def val(integer: int):
59
+ def val(integer: Optional[int]) -> Optional[int]:
37
60
  if integer is None:
38
61
  raise ValueError(f"Integer attribute '{attribute}' cannot be None")
39
62
  if integer < min_val:
@@ -51,7 +74,7 @@ def val_absolute_path(attribute: str):
51
74
  Check that a string attribute is an absolute path
52
75
  """
53
76
 
54
- def val(string: str):
77
+ def val(string: Optional[str]) -> str:
55
78
  if string is None:
56
79
  raise ValueError(f"String attribute '{attribute}' cannot be None")
57
80
  s = string.strip()
@@ -68,7 +91,7 @@ def val_absolute_path(attribute: str):
68
91
 
69
92
 
70
93
  def val_unique_list(attribute: str):
71
- def val(must_be_unique: list):
94
+ def val(must_be_unique: Optional[list]) -> Optional[list]:
72
95
  if must_be_unique is not None:
73
96
  if len(set(must_be_unique)) != len(must_be_unique):
74
97
  raise ValueError(f"`{attribute}` list has repetitions")
@@ -78,7 +101,7 @@ def val_unique_list(attribute: str):
78
101
 
79
102
 
80
103
  def valutc(attribute: str):
81
- def val(timestamp: datetime):
104
+ def val(timestamp: Optional[datetime]) -> Optional[datetime]:
82
105
  """
83
106
  Replacing `tzinfo` with `timezone.utc` is just required by SQLite data.
84
107
  If using Postgres, this function leaves the datetime exactly as it is.
@@ -0,0 +1,36 @@
1
+ """
2
+ Schemas for API request/response bodies
3
+ """
4
+ from .applyworkflow import ApplyWorkflowCreateV1 # noqa: F401
5
+ from .applyworkflow import ApplyWorkflowReadV1 # noqa: F401
6
+ from .applyworkflow import ApplyWorkflowUpdateV1 # noqa: F401
7
+ from .applyworkflow import JobStatusTypeV1 # noqa: F401
8
+ from .dataset import DatasetCreateV1 # noqa: F401
9
+ from .dataset import DatasetReadV1 # noqa: F401
10
+ from .dataset import DatasetStatusReadV1 # noqa: F401
11
+ from .dataset import DatasetUpdateV1 # noqa: F401
12
+ from .dataset import ResourceCreateV1 # noqa: F401
13
+ from .dataset import ResourceReadV1 # noqa: F401
14
+ from .dataset import ResourceUpdateV1 # noqa: F401
15
+ from .manifest import ManifestV1 # noqa: F401
16
+ from .manifest import TaskManifestV1 # noqa: F401
17
+ from .project import ProjectCreateV1 # noqa: F401
18
+ from .project import ProjectReadV1 # noqa: F401
19
+ from .project import ProjectUpdateV1 # noqa: F401
20
+ from .task import TaskCreateV1 # noqa: F401
21
+ from .task import TaskImportV1 # noqa: F401
22
+ from .task import TaskReadV1 # noqa: F401
23
+ from .task import TaskUpdateV1 # noqa: F401
24
+ from .task_collection import TaskCollectPipV1 # noqa: F401
25
+ from .task_collection import TaskCollectStatusV1 # noqa: F401
26
+ from .workflow import WorkflowCreateV1 # noqa: F401
27
+ from .workflow import WorkflowExportV1 # noqa: F401
28
+ from .workflow import WorkflowImportV1 # noqa: F401
29
+ from .workflow import WorkflowReadV1 # noqa: F401
30
+ from .workflow import WorkflowTaskCreateV1 # noqa: F401
31
+ from .workflow import WorkflowTaskExportV1 # noqa: F401
32
+ from .workflow import WorkflowTaskImportV1 # noqa: F401
33
+ from .workflow import WorkflowTaskReadV1 # noqa: F401
34
+ from .workflow import WorkflowTaskStatusTypeV1 # noqa: F401
35
+ from .workflow import WorkflowTaskUpdateV1 # noqa: F401
36
+ from .workflow import WorkflowUpdateV1 # noqa: F401
@@ -6,21 +6,21 @@ from pydantic import BaseModel
6
6
  from pydantic import validator
7
7
  from pydantic.types import StrictStr
8
8
 
9
- from ._validators import valstr
10
- from ._validators import valutc
11
- from .dumps import DatasetDump
12
- from .dumps import ProjectDump
13
- from .dumps import WorkflowDump
9
+ from .._validators import valstr
10
+ from .._validators import valutc
11
+ from .dumps import DatasetDumpV1
12
+ from .dumps import ProjectDumpV1
13
+ from .dumps import WorkflowDumpV1
14
14
 
15
15
 
16
16
  __all__ = (
17
- "_ApplyWorkflowBase",
18
- "ApplyWorkflowCreate",
19
- "ApplyWorkflowRead",
17
+ "_ApplyWorkflowBaseV1",
18
+ "ApplyWorkflowCreateV1",
19
+ "ApplyWorkflowReadV1",
20
20
  )
21
21
 
22
22
 
23
- class JobStatusType(str, Enum):
23
+ class JobStatusTypeV1(str, Enum):
24
24
  """
25
25
  Define the available job statuses
26
26
 
@@ -41,7 +41,7 @@ class JobStatusType(str, Enum):
41
41
  FAILED = "failed"
42
42
 
43
43
 
44
- class _ApplyWorkflowBase(BaseModel):
44
+ class _ApplyWorkflowBaseV1(BaseModel):
45
45
  """
46
46
  Base class for `ApplyWorkflow`.
47
47
 
@@ -52,7 +52,7 @@ class _ApplyWorkflowBase(BaseModel):
52
52
  worker_init: Optional[str]
53
53
 
54
54
 
55
- class ApplyWorkflowCreate(_ApplyWorkflowBase):
55
+ class ApplyWorkflowCreateV1(_ApplyWorkflowBaseV1):
56
56
  """
57
57
  Class for `ApplyWorkflow` creation.
58
58
 
@@ -104,7 +104,7 @@ class ApplyWorkflowCreate(_ApplyWorkflowBase):
104
104
  return v
105
105
 
106
106
 
107
- class ApplyWorkflowRead(_ApplyWorkflowBase):
107
+ class ApplyWorkflowReadV1(_ApplyWorkflowBaseV1):
108
108
  """
109
109
  Class for `ApplyWorkflow` read from database.
110
110
 
@@ -132,15 +132,15 @@ class ApplyWorkflowRead(_ApplyWorkflowBase):
132
132
 
133
133
  id: int
134
134
  project_id: Optional[int]
135
- project_dump: ProjectDump
135
+ project_dump: ProjectDumpV1
136
136
  user_email: str
137
137
  slurm_account: Optional[str]
138
138
  workflow_id: Optional[int]
139
- workflow_dump: WorkflowDump
139
+ workflow_dump: WorkflowDumpV1
140
140
  input_dataset_id: Optional[int]
141
- input_dataset_dump: DatasetDump
141
+ input_dataset_dump: DatasetDumpV1
142
142
  output_dataset_id: Optional[int]
143
- output_dataset_dump: DatasetDump
143
+ output_dataset_dump: DatasetDumpV1
144
144
  start_timestamp: datetime
145
145
  end_timestamp: Optional[datetime]
146
146
  status: str
@@ -158,7 +158,7 @@ class ApplyWorkflowRead(_ApplyWorkflowBase):
158
158
  )
159
159
 
160
160
 
161
- class ApplyWorkflowUpdate(BaseModel):
161
+ class ApplyWorkflowUpdateV1(BaseModel):
162
162
  """
163
163
  Class for updating a job status.
164
164
 
@@ -166,4 +166,4 @@ class ApplyWorkflowUpdate(BaseModel):
166
166
  status: New job status.
167
167
  """
168
168
 
169
- status: JobStatusType
169
+ status: JobStatusTypeV1
@@ -6,25 +6,25 @@ from pydantic import BaseModel
6
6
  from pydantic import Field
7
7
  from pydantic import validator
8
8
 
9
- from ._validators import val_absolute_path
10
- from ._validators import valstr
11
- from ._validators import valutc
12
- from .dumps import WorkflowTaskDump
13
- from .project import ProjectRead
14
- from .workflow import WorkflowTaskStatusType
9
+ from .._validators import val_absolute_path
10
+ from .._validators import valstr
11
+ from .._validators import valutc
12
+ from .dumps import WorkflowTaskDumpV1
13
+ from .project import ProjectReadV1
14
+ from .workflow import WorkflowTaskStatusTypeV1
15
15
 
16
16
  __all__ = (
17
- "DatasetUpdate",
18
- "DatasetCreate",
19
- "DatasetRead",
20
- "ResourceCreate",
21
- "ResourceRead",
22
- "ResourceUpdate",
23
- "DatasetStatusRead",
17
+ "DatasetUpdateV1",
18
+ "DatasetCreateV1",
19
+ "DatasetReadV1",
20
+ "ResourceCreateV1",
21
+ "ResourceReadV1",
22
+ "ResourceUpdateV1",
23
+ "DatasetStatusReadV1",
24
24
  )
25
25
 
26
26
 
27
- class _ResourceBase(BaseModel):
27
+ class _ResourceBaseV1(BaseModel):
28
28
  """
29
29
  Base class for `Resource`.
30
30
 
@@ -35,7 +35,7 @@ class _ResourceBase(BaseModel):
35
35
  path: str
36
36
 
37
37
 
38
- class ResourceCreate(_ResourceBase):
38
+ class ResourceCreateV1(_ResourceBaseV1):
39
39
  """
40
40
  Class for `Resource` creation.
41
41
  """
@@ -44,7 +44,7 @@ class ResourceCreate(_ResourceBase):
44
44
  _path = validator("path", allow_reuse=True)(val_absolute_path("path"))
45
45
 
46
46
 
47
- class ResourceUpdate(_ResourceBase):
47
+ class ResourceUpdateV1(_ResourceBaseV1):
48
48
  """
49
49
  Class for `Resource` update.
50
50
  """
@@ -53,7 +53,7 @@ class ResourceUpdate(_ResourceBase):
53
53
  _path = validator("path", allow_reuse=True)(val_absolute_path("path"))
54
54
 
55
55
 
56
- class ResourceRead(_ResourceBase):
56
+ class ResourceReadV1(_ResourceBaseV1):
57
57
  """
58
58
  Class for `Resource` read from database.
59
59
 
@@ -66,7 +66,7 @@ class ResourceRead(_ResourceBase):
66
66
  dataset_id: int
67
67
 
68
68
 
69
- class _DatasetHistoryItem(BaseModel):
69
+ class _DatasetHistoryItemV1(BaseModel):
70
70
  """
71
71
  Class for an item of `Dataset.history`.
72
72
 
@@ -77,12 +77,12 @@ class _DatasetHistoryItem(BaseModel):
77
77
  and `component_list`.
78
78
  """
79
79
 
80
- workflowtask: WorkflowTaskDump
81
- status: WorkflowTaskStatusType
80
+ workflowtask: WorkflowTaskDumpV1
81
+ status: WorkflowTaskStatusTypeV1
82
82
  parallelization: Optional[dict]
83
83
 
84
84
 
85
- class _DatasetBase(BaseModel):
85
+ class _DatasetBaseV1(BaseModel):
86
86
  """
87
87
  Base class for `Dataset`.
88
88
 
@@ -97,11 +97,11 @@ class _DatasetBase(BaseModel):
97
97
  name: str
98
98
  type: Optional[str]
99
99
  meta: dict[str, Any] = Field(default={})
100
- history: list[_DatasetHistoryItem] = Field(default=[])
100
+ history: list[_DatasetHistoryItemV1] = Field(default=[])
101
101
  read_only: bool = False
102
102
 
103
103
 
104
- class DatasetUpdate(_DatasetBase):
104
+ class DatasetUpdateV1(_DatasetBaseV1):
105
105
  """
106
106
  Class for `Dataset` update.
107
107
 
@@ -114,7 +114,7 @@ class DatasetUpdate(_DatasetBase):
114
114
 
115
115
  name: Optional[str]
116
116
  meta: Optional[dict[str, Any]] = None
117
- history: Optional[list[_DatasetHistoryItem]] = None
117
+ history: Optional[list[_DatasetHistoryItemV1]] = None
118
118
  read_only: Optional[bool]
119
119
 
120
120
  # Validators
@@ -122,7 +122,7 @@ class DatasetUpdate(_DatasetBase):
122
122
  _type = validator("type", allow_reuse=True)(valstr("type"))
123
123
 
124
124
 
125
- class DatasetCreate(_DatasetBase):
125
+ class DatasetCreateV1(_DatasetBaseV1):
126
126
  """
127
127
  Class for `Dataset` creation.
128
128
  """
@@ -132,7 +132,7 @@ class DatasetCreate(_DatasetBase):
132
132
  _type = validator("type", allow_reuse=True)(valstr("type"))
133
133
 
134
134
 
135
- class DatasetRead(_DatasetBase):
135
+ class DatasetReadV1(_DatasetBaseV1):
136
136
  """
137
137
  Class for `Dataset` read from database.
138
138
 
@@ -145,10 +145,10 @@ class DatasetRead(_DatasetBase):
145
145
  """
146
146
 
147
147
  id: int
148
- resource_list: list[ResourceRead]
148
+ resource_list: list[ResourceReadV1]
149
149
  project_id: int
150
150
  read_only: bool
151
- project: ProjectRead
151
+ project: ProjectReadV1
152
152
  timestamp_created: datetime
153
153
 
154
154
  _timestamp_created = validator("timestamp_created", allow_reuse=True)(
@@ -156,7 +156,7 @@ class DatasetRead(_DatasetBase):
156
156
  )
157
157
 
158
158
 
159
- class DatasetStatusRead(BaseModel):
159
+ class DatasetStatusReadV1(BaseModel):
160
160
  """
161
161
  Response type for the
162
162
  `/project/{project_id}/dataset/{dataset_id}/status/` endpoint
@@ -165,6 +165,6 @@ class DatasetStatusRead(BaseModel):
165
165
  status: Optional[
166
166
  dict[
167
167
  int,
168
- WorkflowTaskStatusType,
168
+ WorkflowTaskStatusTypeV1,
169
169
  ]
170
170
  ] = None
@@ -14,7 +14,7 @@ from pydantic import BaseModel
14
14
  from pydantic import Extra
15
15
 
16
16
 
17
- class ProjectDump(BaseModel, extra=Extra.forbid):
17
+ class ProjectDumpV1(BaseModel, extra=Extra.forbid):
18
18
 
19
19
  id: int
20
20
  name: str
@@ -22,7 +22,7 @@ class ProjectDump(BaseModel, extra=Extra.forbid):
22
22
  timestamp_created: str
23
23
 
24
24
 
25
- class TaskDump(BaseModel):
25
+ class TaskDumpV1(BaseModel):
26
26
  id: int
27
27
  source: str
28
28
  name: str
@@ -33,32 +33,32 @@ class TaskDump(BaseModel):
33
33
  version: Optional[str]
34
34
 
35
35
 
36
- class WorkflowTaskDump(BaseModel):
36
+ class WorkflowTaskDumpV1(BaseModel):
37
37
  id: int
38
38
  order: Optional[int]
39
39
  workflow_id: int
40
40
  task_id: int
41
- task: TaskDump
41
+ task: TaskDumpV1
42
42
 
43
43
 
44
- class WorkflowDump(BaseModel):
44
+ class WorkflowDumpV1(BaseModel):
45
45
  id: int
46
46
  name: str
47
47
  project_id: int
48
48
  timestamp_created: str
49
49
 
50
50
 
51
- class ResourceDump(BaseModel):
51
+ class ResourceDumpV1(BaseModel):
52
52
  id: int
53
53
  path: str
54
54
  dataset_id: int
55
55
 
56
56
 
57
- class DatasetDump(BaseModel):
57
+ class DatasetDumpV1(BaseModel):
58
58
  id: int
59
59
  name: str
60
60
  type: Optional[str]
61
61
  read_only: bool
62
- resource_list: list[ResourceDump]
62
+ resource_list: list[ResourceDumpV1]
63
63
  project_id: int
64
64
  timestamp_created: str
@@ -12,7 +12,7 @@ from pydantic import validator
12
12
  __all__ = ("TaskManifestV1", "ManifestV1")
13
13
 
14
14
 
15
- class _TaskManifestBase(BaseModel):
15
+ class _TaskManifestBaseV1(BaseModel):
16
16
  """
17
17
  Base class for `TaskManifestV1`.
18
18
 
@@ -54,10 +54,10 @@ class _TaskManifestBase(BaseModel):
54
54
  docs_link: Optional[HttpUrl]
55
55
 
56
56
 
57
- TaskManifestType = TypeVar("TaskManifestType", bound=_TaskManifestBase)
57
+ TaskManifestType = TypeVar("TaskManifestType", bound=_TaskManifestBaseV1)
58
58
 
59
59
 
60
- class _ManifestBase(BaseModel):
60
+ class _ManifestBaseV1(BaseModel):
61
61
  """
62
62
  Base class for `ManifestV1`.
63
63
 
@@ -102,7 +102,7 @@ class _ManifestBase(BaseModel):
102
102
  return values
103
103
 
104
104
 
105
- class TaskManifestV1(_TaskManifestBase):
105
+ class TaskManifestV1(_TaskManifestBaseV1):
106
106
  """
107
107
  Task manifest schema version 1.
108
108
  """
@@ -110,7 +110,7 @@ class TaskManifestV1(_TaskManifestBase):
110
110
  pass
111
111
 
112
112
 
113
- class ManifestV1(_ManifestBase):
113
+ class ManifestV1(_ManifestBaseV1):
114
114
  """
115
115
  Manifest schema version 1.
116
116
 
@@ -4,18 +4,18 @@ from typing import Optional
4
4
  from pydantic import BaseModel
5
5
  from pydantic import validator
6
6
 
7
- from ._validators import valstr
8
- from ._validators import valutc
7
+ from .._validators import valstr
8
+ from .._validators import valutc
9
9
 
10
10
 
11
11
  __all__ = (
12
- "ProjectCreate",
13
- "ProjectRead",
14
- "ProjectUpdate",
12
+ "ProjectCreateV1",
13
+ "ProjectReadV1",
14
+ "ProjectUpdateV1",
15
15
  )
16
16
 
17
17
 
18
- class _ProjectBase(BaseModel):
18
+ class _ProjectBaseV1(BaseModel):
19
19
  """
20
20
  Base class for `Project`.
21
21
 
@@ -28,7 +28,7 @@ class _ProjectBase(BaseModel):
28
28
  read_only: bool = False
29
29
 
30
30
 
31
- class ProjectCreate(_ProjectBase):
31
+ class ProjectCreateV1(_ProjectBaseV1):
32
32
  """
33
33
  Class for `Project` creation.
34
34
  """
@@ -37,7 +37,7 @@ class ProjectCreate(_ProjectBase):
37
37
  _name = validator("name", allow_reuse=True)(valstr("name"))
38
38
 
39
39
 
40
- class ProjectRead(_ProjectBase):
40
+ class ProjectReadV1(_ProjectBaseV1):
41
41
  """
42
42
  Class for `Project` read from database.
43
43
 
@@ -55,7 +55,7 @@ class ProjectRead(_ProjectBase):
55
55
  )
56
56
 
57
57
 
58
- class ProjectUpdate(_ProjectBase):
58
+ class ProjectUpdateV1(_ProjectBaseV1):
59
59
  """
60
60
  Class for `Project` update.
61
61
 
@@ -6,18 +6,18 @@ from pydantic import Field
6
6
  from pydantic import HttpUrl
7
7
  from pydantic import validator
8
8
 
9
- from ._validators import valstr
9
+ from .._validators import valstr
10
10
 
11
11
  __all__ = (
12
- "TaskCreate",
13
- "TaskUpdate",
14
- "TaskRead",
15
- "TaskImport",
16
- "TaskExport",
12
+ "TaskCreateV1",
13
+ "TaskUpdateV1",
14
+ "TaskReadV1",
15
+ "TaskImportV1",
16
+ "TaskExportV1",
17
17
  )
18
18
 
19
19
 
20
- class _TaskBase(BaseModel):
20
+ class _TaskBaseV1(BaseModel):
21
21
  """
22
22
 
23
23
  Base class for `Task`.
@@ -32,7 +32,7 @@ class _TaskBase(BaseModel):
32
32
  _source = validator("source", allow_reuse=True)(valstr("source"))
33
33
 
34
34
 
35
- class TaskUpdate(_TaskBase):
35
+ class TaskUpdateV1(_TaskBaseV1):
36
36
  """
37
37
  Class for `Task` update.
38
38
 
@@ -76,7 +76,7 @@ class TaskUpdate(_TaskBase):
76
76
  )
77
77
 
78
78
 
79
- class TaskImport(_TaskBase):
79
+ class TaskImportV1(_TaskBaseV1):
80
80
  """
81
81
  Class for `Task` import.
82
82
  """
@@ -84,7 +84,7 @@ class TaskImport(_TaskBase):
84
84
  pass
85
85
 
86
86
 
87
- class TaskExport(_TaskBase):
87
+ class TaskExportV1(_TaskBaseV1):
88
88
  """
89
89
  Class for `Task` export.
90
90
  """
@@ -92,7 +92,7 @@ class TaskExport(_TaskBase):
92
92
  pass
93
93
 
94
94
 
95
- class TaskRead(_TaskBase):
95
+ class TaskReadV1(_TaskBaseV1):
96
96
  """
97
97
  Class for `Task` read from database.
98
98
 
@@ -124,7 +124,7 @@ class TaskRead(_TaskBase):
124
124
  docs_link: Optional[HttpUrl]
125
125
 
126
126
 
127
- class TaskCreate(_TaskBase):
127
+ class TaskCreateV1(_TaskBaseV1):
128
128
  """
129
129
  Class for `Task` creation.
130
130
 
@@ -6,16 +6,16 @@ from pydantic import BaseModel
6
6
  from pydantic import Field
7
7
  from pydantic import validator
8
8
 
9
- from ._validators import valstr
10
- from .task import TaskRead
9
+ from .._validators import valstr
10
+ from .task import TaskReadV1
11
11
 
12
12
  __all__ = (
13
- "TaskCollectPip",
14
- "TaskCollectStatus",
13
+ "TaskCollectPipV1",
14
+ "TaskCollectStatusV1",
15
15
  )
16
16
 
17
17
 
18
- class TaskCollectPip(BaseModel):
18
+ class TaskCollectPipV1(BaseModel):
19
19
  """
20
20
  TaskCollectPip class
21
21
 
@@ -81,7 +81,7 @@ class TaskCollectPip(BaseModel):
81
81
  return v
82
82
 
83
83
 
84
- class TaskCollectStatus(BaseModel):
84
+ class TaskCollectStatusV1(BaseModel):
85
85
  """
86
86
  TaskCollectStatus class
87
87
 
@@ -97,7 +97,7 @@ class TaskCollectStatus(BaseModel):
97
97
  status: Literal["pending", "installing", "collecting", "fail", "OK"]
98
98
  package: str
99
99
  venv_path: Path
100
- task_list: Optional[list[TaskRead]] = Field(default=[])
100
+ task_list: Optional[list[TaskReadV1]] = Field(default=[])
101
101
  log: Optional[str]
102
102
  info: Optional[str]
103
103