digitalhub 0.9.0b0__py3-none-any.whl → 0.9.0b1__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.
Potentially problematic release.
This version of digitalhub might be problematic. Click here for more details.
- digitalhub/client/dhcore/client.py +12 -13
- digitalhub/client/dhcore/enums.py +2 -1
- digitalhub/client/dhcore/utils.py +13 -13
- digitalhub/entities/_base/entity/metadata.py +1 -1
- digitalhub/entities/_operations/processor.py +4 -1
- digitalhub/entities/run/_base/spec.py +4 -0
- digitalhub/entities/task/_base/models.py +6 -0
- digitalhub/entities/task/_base/spec.py +6 -0
- digitalhub/runtimes/enums.py +12 -0
- {digitalhub-0.9.0b0.dist-info → digitalhub-0.9.0b1.dist-info}/METADATA +1 -1
- {digitalhub-0.9.0b0.dist-info → digitalhub-0.9.0b1.dist-info}/RECORD +14 -13
- {digitalhub-0.9.0b0.dist-info → digitalhub-0.9.0b1.dist-info}/LICENSE.txt +0 -0
- {digitalhub-0.9.0b0.dist-info → digitalhub-0.9.0b1.dist-info}/WHEEL +0 -0
- {digitalhub-0.9.0b0.dist-info → digitalhub-0.9.0b1.dist-info}/top_level.txt +0 -0
|
@@ -12,7 +12,7 @@ from requests.exceptions import HTTPError, JSONDecodeError, RequestException
|
|
|
12
12
|
|
|
13
13
|
from digitalhub.client._base.client import Client
|
|
14
14
|
from digitalhub.client.dhcore.api_builder import ClientDHCoreApiBuilder
|
|
15
|
-
from digitalhub.client.dhcore.enums import AuthType,
|
|
15
|
+
from digitalhub.client.dhcore.enums import AuthType, DhcoreEnvVar
|
|
16
16
|
from digitalhub.client.dhcore.env import ENV_FILE, FALLBACK_USER, LIB_VERSION, MAX_API_LEVEL, MIN_API_LEVEL
|
|
17
17
|
from digitalhub.client.dhcore.models import BasicAuth, OAuth2TokenAuth
|
|
18
18
|
from digitalhub.utils.exceptions import (
|
|
@@ -520,7 +520,6 @@ class ClientDHCore(Client):
|
|
|
520
520
|
-------
|
|
521
521
|
None
|
|
522
522
|
"""
|
|
523
|
-
|
|
524
523
|
self._get_endpoints_from_env()
|
|
525
524
|
|
|
526
525
|
if config is not None:
|
|
@@ -558,12 +557,12 @@ class ClientDHCore(Client):
|
|
|
558
557
|
Exception
|
|
559
558
|
If the endpoint of DHCore is not set in the env variables.
|
|
560
559
|
"""
|
|
561
|
-
core_endpt = os.getenv(
|
|
560
|
+
core_endpt = os.getenv(DhcoreEnvVar.ENDPOINT.value)
|
|
562
561
|
if core_endpt is None:
|
|
563
562
|
raise BackendError("Endpoint not set as environment variables.")
|
|
564
563
|
self._endpoint_core = self._sanitize_endpoint(core_endpt)
|
|
565
564
|
|
|
566
|
-
issr_endpt = os.getenv(
|
|
565
|
+
issr_endpt = os.getenv(DhcoreEnvVar.ISSUER.value)
|
|
567
566
|
if issr_endpt is not None:
|
|
568
567
|
self._endpoint_issuer = self._sanitize_endpoint(issr_endpt)
|
|
569
568
|
|
|
@@ -589,17 +588,17 @@ class ClientDHCore(Client):
|
|
|
589
588
|
-------
|
|
590
589
|
None
|
|
591
590
|
"""
|
|
592
|
-
self._user = os.getenv(
|
|
593
|
-
self._refresh_token = os.getenv(
|
|
594
|
-
self._client_id = os.getenv(
|
|
591
|
+
self._user = os.getenv(DhcoreEnvVar.USER.value, FALLBACK_USER)
|
|
592
|
+
self._refresh_token = os.getenv(DhcoreEnvVar.REFRESH_TOKEN.value)
|
|
593
|
+
self._client_id = os.getenv(DhcoreEnvVar.CLIENT_ID.value)
|
|
595
594
|
|
|
596
|
-
token = os.getenv(
|
|
595
|
+
token = os.getenv(DhcoreEnvVar.ACCESS_TOKEN.value)
|
|
597
596
|
if token is not None and token != "":
|
|
598
597
|
self._auth_type = AuthType.OAUTH2.value
|
|
599
598
|
self._access_token = token
|
|
600
599
|
return
|
|
601
600
|
|
|
602
|
-
password = os.getenv(
|
|
601
|
+
password = os.getenv(DhcoreEnvVar.PASSWORD.value)
|
|
603
602
|
if self._user is not None and password is not None:
|
|
604
603
|
self._auth_type = AuthType.BASIC.value
|
|
605
604
|
self._password = password
|
|
@@ -619,12 +618,12 @@ class ClientDHCore(Client):
|
|
|
619
618
|
|
|
620
619
|
# Call refresh token endpoint
|
|
621
620
|
# Try token from env
|
|
622
|
-
refresh_token = os.getenv(
|
|
621
|
+
refresh_token = os.getenv(DhcoreEnvVar.REFRESH_TOKEN.value)
|
|
623
622
|
response = self._call_refresh_token_endpoint(url, refresh_token)
|
|
624
623
|
|
|
625
624
|
# Otherwise try token from file
|
|
626
625
|
if response.status_code in (400, 401, 403):
|
|
627
|
-
refresh_token = get_key(ENV_FILE,
|
|
626
|
+
refresh_token = get_key(ENV_FILE, DhcoreEnvVar.REFRESH_TOKEN.value)
|
|
628
627
|
response = self._call_refresh_token_endpoint(url, refresh_token)
|
|
629
628
|
|
|
630
629
|
response.raise_for_status()
|
|
@@ -694,9 +693,9 @@ class ClientDHCore(Client):
|
|
|
694
693
|
"""
|
|
695
694
|
keys = {}
|
|
696
695
|
if self._access_token is not None:
|
|
697
|
-
keys[
|
|
696
|
+
keys[DhcoreEnvVar.ACCESS_TOKEN.value] = self._access_token
|
|
698
697
|
if self._refresh_token is not None:
|
|
699
|
-
keys[
|
|
698
|
+
keys[DhcoreEnvVar.REFRESH_TOKEN.value] = self._refresh_token
|
|
700
699
|
|
|
701
700
|
for k, v in keys.items():
|
|
702
701
|
set_key(dotenv_path=ENV_FILE, key_to_set=k, value_to_set=v)
|
|
@@ -3,7 +3,7 @@ from __future__ import annotations
|
|
|
3
3
|
from enum import Enum
|
|
4
4
|
|
|
5
5
|
|
|
6
|
-
class
|
|
6
|
+
class DhcoreEnvVar(Enum):
|
|
7
7
|
"""
|
|
8
8
|
Environment variables.
|
|
9
9
|
"""
|
|
@@ -15,6 +15,7 @@ class EnvVar(Enum):
|
|
|
15
15
|
CLIENT_ID = "DHCORE_CLIENT_ID"
|
|
16
16
|
ACCESS_TOKEN = "DHCORE_ACCESS_TOKEN"
|
|
17
17
|
REFRESH_TOKEN = "DHCORE_REFRESH_TOKEN"
|
|
18
|
+
WORKFLOW_IMAGE = "DHCORE_WORKFLOW_IMAGE"
|
|
18
19
|
|
|
19
20
|
|
|
20
21
|
class AuthType(Enum):
|
|
@@ -4,7 +4,7 @@ import os
|
|
|
4
4
|
import typing
|
|
5
5
|
|
|
6
6
|
from digitalhub.client.api import get_client
|
|
7
|
-
from digitalhub.client.dhcore.enums import AuthType,
|
|
7
|
+
from digitalhub.client.dhcore.enums import AuthType, DhcoreEnvVar
|
|
8
8
|
|
|
9
9
|
if typing.TYPE_CHECKING:
|
|
10
10
|
from digitalhub.client.dhcore.client import ClientDHCore
|
|
@@ -44,17 +44,17 @@ def set_dhcore_env(
|
|
|
44
44
|
None
|
|
45
45
|
"""
|
|
46
46
|
if endpoint is not None:
|
|
47
|
-
os.environ[
|
|
47
|
+
os.environ[DhcoreEnvVar.ENDPOINT.value] = endpoint
|
|
48
48
|
if user is not None:
|
|
49
|
-
os.environ[
|
|
49
|
+
os.environ[DhcoreEnvVar.USER.value] = user
|
|
50
50
|
if password is not None:
|
|
51
|
-
os.environ[
|
|
51
|
+
os.environ[DhcoreEnvVar.PASSWORD.value] = password
|
|
52
52
|
if access_token is not None:
|
|
53
|
-
os.environ[
|
|
53
|
+
os.environ[DhcoreEnvVar.ACCESS_TOKEN.value] = access_token
|
|
54
54
|
if refresh_token is not None:
|
|
55
|
-
os.environ[
|
|
55
|
+
os.environ[DhcoreEnvVar.REFRESH_TOKEN.value] = refresh_token
|
|
56
56
|
if client_id is not None:
|
|
57
|
-
os.environ[
|
|
57
|
+
os.environ[DhcoreEnvVar.CLIENT_ID.value] = client_id
|
|
58
58
|
|
|
59
59
|
update_client_from_env()
|
|
60
60
|
|
|
@@ -70,16 +70,16 @@ def update_client_from_env() -> None:
|
|
|
70
70
|
client: ClientDHCore = get_client(local=False)
|
|
71
71
|
|
|
72
72
|
# Update endpoint
|
|
73
|
-
endpoint = os.getenv(
|
|
73
|
+
endpoint = os.getenv(DhcoreEnvVar.ENDPOINT.value)
|
|
74
74
|
if endpoint is not None:
|
|
75
75
|
client._endpoint_core = endpoint
|
|
76
76
|
|
|
77
77
|
# Update auth
|
|
78
78
|
|
|
79
79
|
# If token is set, it will override the other auth options
|
|
80
|
-
access_token = os.getenv(
|
|
81
|
-
refresh_token = os.getenv(
|
|
82
|
-
client_id = os.getenv(
|
|
80
|
+
access_token = os.getenv(DhcoreEnvVar.ACCESS_TOKEN.value)
|
|
81
|
+
refresh_token = os.getenv(DhcoreEnvVar.REFRESH_TOKEN.value)
|
|
82
|
+
client_id = os.getenv(DhcoreEnvVar.CLIENT_ID.value)
|
|
83
83
|
|
|
84
84
|
if access_token is not None:
|
|
85
85
|
if refresh_token is not None:
|
|
@@ -91,8 +91,8 @@ def update_client_from_env() -> None:
|
|
|
91
91
|
return
|
|
92
92
|
|
|
93
93
|
# Otherwise, if user and password are set, basic auth will be used
|
|
94
|
-
username = os.getenv(
|
|
95
|
-
password = os.getenv(
|
|
94
|
+
username = os.getenv(DhcoreEnvVar.USER.value)
|
|
95
|
+
password = os.getenv(DhcoreEnvVar.PASSWORD.value)
|
|
96
96
|
if username is not None and password is not None:
|
|
97
97
|
client._user = username
|
|
98
98
|
client._password = password
|
|
@@ -538,7 +538,10 @@ class OperationsProcessor:
|
|
|
538
538
|
new_obj = self._create_context_entity(context, obj.ENTITY_TYPE, obj.to_dict())
|
|
539
539
|
return build_entity_from_dict(new_obj)
|
|
540
540
|
|
|
541
|
-
def log_material_entity(
|
|
541
|
+
def log_material_entity(
|
|
542
|
+
self,
|
|
543
|
+
**kwargs,
|
|
544
|
+
) -> MaterialEntity:
|
|
542
545
|
"""
|
|
543
546
|
Create object in backend and upload file.
|
|
544
547
|
|
|
@@ -21,6 +21,8 @@ class RunSpec(Spec):
|
|
|
21
21
|
envs: list[dict] | None = None,
|
|
22
22
|
secrets: list[str] | None = None,
|
|
23
23
|
profile: str | None = None,
|
|
24
|
+
runtime_class: str | None = None,
|
|
25
|
+
priority_class: str | None = None,
|
|
24
26
|
**kwargs,
|
|
25
27
|
) -> None:
|
|
26
28
|
self.task = task
|
|
@@ -35,6 +37,8 @@ class RunSpec(Spec):
|
|
|
35
37
|
self.envs = envs
|
|
36
38
|
self.secrets = secrets
|
|
37
39
|
self.profile = profile
|
|
40
|
+
self.runtime_class = runtime_class
|
|
41
|
+
self.priority_class = priority_class
|
|
38
42
|
|
|
39
43
|
|
|
40
44
|
class RunValidator(SpecValidator, K8s):
|
|
@@ -210,6 +210,12 @@ class K8s(BaseModel):
|
|
|
210
210
|
profile: str = None
|
|
211
211
|
"""Profile template."""
|
|
212
212
|
|
|
213
|
+
runtime_class: str = None
|
|
214
|
+
"""Runtime class name."""
|
|
215
|
+
|
|
216
|
+
priority_class: str = None
|
|
217
|
+
"""Priority class."""
|
|
218
|
+
|
|
213
219
|
|
|
214
220
|
class CorePort(BaseModel):
|
|
215
221
|
"""
|
|
@@ -22,6 +22,8 @@ class TaskSpecFunction(TaskSpec):
|
|
|
22
22
|
envs: list[dict] | None = None,
|
|
23
23
|
secrets: list[str] | None = None,
|
|
24
24
|
profile: str | None = None,
|
|
25
|
+
runtime_class: str | None = None,
|
|
26
|
+
priority_class: str | None = None,
|
|
25
27
|
**kwargs,
|
|
26
28
|
) -> None:
|
|
27
29
|
self.function = function
|
|
@@ -33,6 +35,8 @@ class TaskSpecFunction(TaskSpec):
|
|
|
33
35
|
self.envs = envs
|
|
34
36
|
self.secrets = secrets
|
|
35
37
|
self.profile = profile
|
|
38
|
+
self.runtime_class = runtime_class
|
|
39
|
+
self.priority_class = priority_class
|
|
36
40
|
|
|
37
41
|
|
|
38
42
|
class TaskSpecWorkflow(TaskSpec):
|
|
@@ -49,6 +53,8 @@ class TaskSpecWorkflow(TaskSpec):
|
|
|
49
53
|
envs: list[dict] | None = None,
|
|
50
54
|
secrets: list[str] | None = None,
|
|
51
55
|
profile: str | None = None,
|
|
56
|
+
runtime_class: str | None = None,
|
|
57
|
+
priority_class: str | None = None,
|
|
52
58
|
**kwargs,
|
|
53
59
|
) -> None:
|
|
54
60
|
self.workflow = workflow
|
|
@@ -7,11 +7,11 @@ digitalhub/client/_base/api_builder.py,sha256=kB0phBqaPTLayyXyA1GbHgnbo4bBkadBti
|
|
|
7
7
|
digitalhub/client/_base/client.py,sha256=wXHfHQANnv_2AlW6yh7dnxI3i0bBASsP_gYSbc-YQHk,2063
|
|
8
8
|
digitalhub/client/dhcore/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
9
9
|
digitalhub/client/dhcore/api_builder.py,sha256=IkRnANGG3dQmu4t1KmSnpDxGqkZDnJpBP9CcUhWZliQ,3652
|
|
10
|
-
digitalhub/client/dhcore/client.py,sha256=
|
|
11
|
-
digitalhub/client/dhcore/enums.py,sha256=
|
|
10
|
+
digitalhub/client/dhcore/client.py,sha256=Vl0ZRX1CHxOg9awR-liFagTMkbNLcW2B4jGfxJt0udk,21149
|
|
11
|
+
digitalhub/client/dhcore/enums.py,sha256=kaVXZTTa2WmsFbcc1CKWNLOM0JtUtcjL-KpspnTOhEE,523
|
|
12
12
|
digitalhub/client/dhcore/env.py,sha256=zBUNbK8G8PyMGAw_65BnX2Z_WUkrmTyQmYhLE6Jqgvk,618
|
|
13
13
|
digitalhub/client/dhcore/models.py,sha256=KiTg5xR8EzI7Xa1pmYmzixabLdnqlnn5kn-IILZDGIw,900
|
|
14
|
-
digitalhub/client/dhcore/utils.py,sha256=
|
|
14
|
+
digitalhub/client/dhcore/utils.py,sha256=I6m26WiGMCEyPa6Yv5hk3nmqWV4jDFjYyI590f86Ebs,3136
|
|
15
15
|
digitalhub/client/local/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
16
16
|
digitalhub/client/local/api_builder.py,sha256=WR24zuWguJqzUkD7xReO12LtvSkn020UG6LKFcKq77g,3592
|
|
17
17
|
digitalhub/client/local/client.py,sha256=WLpEymgxysRLDdMGm9ds4kKOqHqEXk8MmrU01NR938o,17338
|
|
@@ -28,7 +28,7 @@ digitalhub/entities/_base/context/entity.py,sha256=4IWC6f0YKpEBPCXrKlkkvnOqT1urQ
|
|
|
28
28
|
digitalhub/entities/_base/entity/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
29
29
|
digitalhub/entities/_base/entity/builder.py,sha256=vegnR3aBLhuA371vFVQvMXX4KfpVFl-Z7h1ydt6r6Hg,4518
|
|
30
30
|
digitalhub/entities/_base/entity/entity.py,sha256=5QP7ZFZ3fjdC6dL26J4TAc_gAsz4esTYR97PIRiwk04,3162
|
|
31
|
-
digitalhub/entities/_base/entity/metadata.py,sha256=
|
|
31
|
+
digitalhub/entities/_base/entity/metadata.py,sha256=_ogwoo7NOExxVPml9h1vbbAryFiAVpuEuSBQsd_VRjU,2261
|
|
32
32
|
digitalhub/entities/_base/entity/spec.py,sha256=t0sPXHCb8zyWyMW_UvTfGyUkG_CUEGz427kvGhsQ8s0,1500
|
|
33
33
|
digitalhub/entities/_base/entity/status.py,sha256=NHB1kLHefoMhhkt_2BFPNojbWMW_Nc8TTGFQNOiyOt0,1044
|
|
34
34
|
digitalhub/entities/_base/entity/_constructors/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
@@ -58,7 +58,7 @@ digitalhub/entities/_commons/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NM
|
|
|
58
58
|
digitalhub/entities/_commons/enums.py,sha256=pjhbOMzAABRPbV6XNt-2Lyn2kLWIFBAwpeboCtvnz1w,1861
|
|
59
59
|
digitalhub/entities/_commons/utils.py,sha256=_HL6zFSCL_2ug4LpXcxK1MJQQhWL34wj1B2q0Ie0TKU,1792
|
|
60
60
|
digitalhub/entities/_operations/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
61
|
-
digitalhub/entities/_operations/processor.py,sha256=
|
|
61
|
+
digitalhub/entities/_operations/processor.py,sha256=yi-L_mltue3WN8xM5Y-zpwUCb4x4psW5uwd1Lx7Rxo4,46663
|
|
62
62
|
digitalhub/entities/artifact/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
63
63
|
digitalhub/entities/artifact/crud.py,sha256=y69PyoWAYOx-Pl_wnds3M0xSLNbADpdV_xG4zElJ0aI,7824
|
|
64
64
|
digitalhub/entities/artifact/utils.py,sha256=NNzD2AcIJzmV_Jo_8k5ZcSp2arKcZ07CCIYKn2lvoKM,1320
|
|
@@ -146,7 +146,7 @@ digitalhub/entities/run/crud.py,sha256=0_9zlW4aId4x1rGlvjOdAHkNaJwpR5vgLCuMt7rE-
|
|
|
146
146
|
digitalhub/entities/run/_base/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
147
147
|
digitalhub/entities/run/_base/builder.py,sha256=e4P4gegD1DjHv_-Rhe3bIkGfRwgRbC8J6hdSSw2M8b4,2454
|
|
148
148
|
digitalhub/entities/run/_base/entity.py,sha256=-bQqY1vhEsAaBYwXIzQwiFKmwA9FPH3wJ9XtennWvKo,7549
|
|
149
|
-
digitalhub/entities/run/_base/spec.py,sha256=
|
|
149
|
+
digitalhub/entities/run/_base/spec.py,sha256=nAyIAcnIXgGEhyI1TvOhZfKxB2ZC25VuFhAECgG--KU,1673
|
|
150
150
|
digitalhub/entities/run/_base/status.py,sha256=_oqF8AM-N6XGi-xc-xgthdmCpsuI_rGgVaNKgQ4UDJQ,160
|
|
151
151
|
digitalhub/entities/secret/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
152
152
|
digitalhub/entities/secret/crud.py,sha256=tKXNHqpxCsBMOYtHadQz70-mcExskdQ8Lt9lezmiZzU,6816
|
|
@@ -160,8 +160,8 @@ digitalhub/entities/task/crud.py,sha256=_TOgqPvD4bOcfxMPJLCzPe4fz_87AP27RG5cC294
|
|
|
160
160
|
digitalhub/entities/task/_base/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
161
161
|
digitalhub/entities/task/_base/builder.py,sha256=21WEbycCR8yaOPcLLcAITaoQ4ZmBNXJXB-Oy0VfSPrg,2358
|
|
162
162
|
digitalhub/entities/task/_base/entity.py,sha256=KGueJ64puhS7DAzG0_-XZSlUmVIOPOFJbtj1S8iWrpg,3179
|
|
163
|
-
digitalhub/entities/task/_base/models.py,sha256=
|
|
164
|
-
digitalhub/entities/task/_base/spec.py,sha256=
|
|
163
|
+
digitalhub/entities/task/_base/models.py,sha256=lrkQfKEqqMboiDgtqVdTdlFx4FCH_ksJ2Jku1nK6ARw,4741
|
|
164
|
+
digitalhub/entities/task/_base/spec.py,sha256=2p_QmhXdTXFrkwNyXtEgzUmc4YyedjS-zsnWsvxJDjw,2412
|
|
165
165
|
digitalhub/entities/task/_base/status.py,sha256=FCSSQscQ0dHEpXdc5vSrIkTXon9FNNOr0M1KVh2ZVAA,162
|
|
166
166
|
digitalhub/entities/task/_base/utils.py,sha256=P0ajA8SQcDaEC9BBIIc_M8UL1_qBcZE8loUTkP7xVYY,436
|
|
167
167
|
digitalhub/entities/workflow/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
@@ -189,6 +189,7 @@ digitalhub/readers/pandas/reader.py,sha256=pdBKUWiKettQmh6N48LYOfnwqrOWoo-GpHdSB
|
|
|
189
189
|
digitalhub/runtimes/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
190
190
|
digitalhub/runtimes/_base.py,sha256=uDvSXAEytZr-BFpj1BA59vdERBk79j5pTDiG0__tazA,2510
|
|
191
191
|
digitalhub/runtimes/builder.py,sha256=CtwutbxRdLo6Qj5PfvmYnCusRG89yS1jI4Qu-Ha3XGY,705
|
|
192
|
+
digitalhub/runtimes/enums.py,sha256=hhGNyuBcchqCcDKdR_foOyeNJn41nHCNEyRmoxE5dNA,182
|
|
192
193
|
digitalhub/stores/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
193
194
|
digitalhub/stores/api.py,sha256=TwD8WXVuEPwtrmcyhP9SC0i7xkVHov5fpu94nHhZRHg,994
|
|
194
195
|
digitalhub/stores/builder.py,sha256=kraGDfgV5cZ2QivXTWwbyz1FgAehgjlL9dmI6dxEc0U,5927
|
|
@@ -221,8 +222,8 @@ test/local/CRUD/test_artifacts.py,sha256=Y3J_C7SDRSsQd2SGIZjPIOvyTL92B1sTFrUONG3
|
|
|
221
222
|
test/local/CRUD/test_dataitems.py,sha256=LQqTzI59uwTGy4zoq8jL0yWVe2W9vXlatkgDU9aB6xg,2968
|
|
222
223
|
test/local/CRUD/test_models.py,sha256=msosbZuRwIMbZtmi3ZaOva4TjQ4lrzkNu9AguIFhrSo,2929
|
|
223
224
|
test/local/imports/test_imports.py,sha256=W-YugO0rpJwvtWp57MXaXfEmE-f5iWuCiLY-n0ZU4z8,1271
|
|
224
|
-
digitalhub-0.9.
|
|
225
|
-
digitalhub-0.9.
|
|
226
|
-
digitalhub-0.9.
|
|
227
|
-
digitalhub-0.9.
|
|
228
|
-
digitalhub-0.9.
|
|
225
|
+
digitalhub-0.9.0b1.dist-info/LICENSE.txt,sha256=_yVOtnbW7Ss28mp058UEEc1X4Rgj8-kQBP_kj8_Sc88,11585
|
|
226
|
+
digitalhub-0.9.0b1.dist-info/METADATA,sha256=US6XAu95Ktv0yNGQJxqOwkfMLyzPDPsKFS5eb8A-wvk,15316
|
|
227
|
+
digitalhub-0.9.0b1.dist-info/WHEEL,sha256=PZUExdf71Ui_so67QXpySuHtCi3-J3wvF4ORK6k_S8U,91
|
|
228
|
+
digitalhub-0.9.0b1.dist-info/top_level.txt,sha256=ae9pDfCF27ZoaVAxuBKONMP0lm5P-N_I-e-no1WlvD8,16
|
|
229
|
+
digitalhub-0.9.0b1.dist-info/RECORD,,
|
|
File without changes
|
|
File without changes
|
|
File without changes
|