ominfra 0.0.0.dev161__tar.gz → 0.0.0.dev163__tar.gz
Sign up to get free protection for your applications and to get access to all the features.
- {ominfra-0.0.0.dev161/ominfra.egg-info → ominfra-0.0.0.dev163}/PKG-INFO +3 -3
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/deploy/apps.py +3 -2
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/deploy/specs.py +18 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/deploy/venvs.py +9 -4
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/scripts/manage.py +45 -35
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/scripts/supervisor.py +16 -29
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163/ominfra.egg-info}/PKG-INFO +3 -3
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra.egg-info/requires.txt +2 -2
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/pyproject.toml +3 -3
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/LICENSE +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/MANIFEST.in +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/README.rst +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/.manifests.json +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/__about__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/clouds/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/clouds/aws/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/clouds/aws/__main__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/clouds/aws/auth.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/clouds/aws/cli.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/clouds/aws/dataclasses.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/clouds/aws/journald2aws/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/clouds/aws/journald2aws/__main__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/clouds/aws/journald2aws/cursor.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/clouds/aws/journald2aws/driver.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/clouds/aws/journald2aws/main.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/clouds/aws/journald2aws/poster.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/clouds/aws/logs.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/clouds/aws/metadata.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/clouds/gcp/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/clouds/gcp/auth.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/cmds.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/configs.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/journald/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/journald/fields.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/journald/genmessages.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/journald/messages.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/journald/tailer.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/__main__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/bootstrap.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/bootstrap_.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/commands/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/commands/base.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/commands/inject.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/commands/local.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/commands/marshal.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/commands/ping.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/commands/subprocess.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/commands/types.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/config.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/deploy/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/deploy/commands.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/deploy/config.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/deploy/git.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/deploy/inject.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/deploy/interp.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/deploy/paths.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/deploy/tmp.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/deploy/types.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/inject.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/main.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/marshal.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/remote/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/remote/_main.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/remote/channel.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/remote/config.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/remote/connection.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/remote/execution.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/remote/inject.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/remote/payload.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/remote/spawning.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/system/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/system/commands.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/system/config.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/system/inject.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/system/packages.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/system/platforms.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/targets/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/targets/connection.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/targets/inject.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/manage/targets/targets.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/pyremote.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/scripts/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/scripts/journald2aws.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/ssh.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/LICENSE.txt +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/__main__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/configs.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/dispatchers.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/dispatchersimpl.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/events.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/exceptions.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/groups.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/groupsimpl.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/http.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/inject.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/io.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/main.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/pipes.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/privileges.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/process.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/processimpl.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/setup.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/setupimpl.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/signals.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/spawning.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/spawningimpl.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/states.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/supervisor.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/types.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/utils/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/utils/collections.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/utils/diag.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/utils/fds.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/utils/fs.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/utils/os.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/utils/ostypes.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/utils/signals.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/utils/strings.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/supervisor/utils/users.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/tailscale/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/tailscale/api.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/tailscale/cli.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/threadworkers.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/tools/__init__.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra/tools/listresources.py +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra.egg-info/SOURCES.txt +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra.egg-info/dependency_links.txt +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra.egg-info/entry_points.txt +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/ominfra.egg-info/top_level.txt +0 -0
- {ominfra-0.0.0.dev161 → ominfra-0.0.0.dev163}/setup.cfg +0 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: ominfra
|
3
|
-
Version: 0.0.0.
|
3
|
+
Version: 0.0.0.dev163
|
4
4
|
Summary: ominfra
|
5
5
|
Author: wrmsr
|
6
6
|
License: BSD-3-Clause
|
@@ -12,8 +12,8 @@ Classifier: Operating System :: OS Independent
|
|
12
12
|
Classifier: Operating System :: POSIX
|
13
13
|
Requires-Python: >=3.12
|
14
14
|
License-File: LICENSE
|
15
|
-
Requires-Dist: omdev==0.0.0.
|
16
|
-
Requires-Dist: omlish==0.0.0.
|
15
|
+
Requires-Dist: omdev==0.0.0.dev163
|
16
|
+
Requires-Dist: omlish==0.0.0.dev163
|
17
17
|
Provides-Extra: all
|
18
18
|
Requires-Dist: paramiko~=3.5; extra == "all"
|
19
19
|
Requires-Dist: asyncssh~=2.18; extra == "all"
|
@@ -51,7 +51,7 @@ class DeployAppManager(DeployPathOwner):
|
|
51
51
|
|
52
52
|
def get_owned_deploy_paths(self) -> ta.AbstractSet[DeployPath]:
|
53
53
|
return {
|
54
|
-
DeployPath.parse('apps/@app/@tag'),
|
54
|
+
DeployPath.parse('apps/@app/@tag/'),
|
55
55
|
}
|
56
56
|
|
57
57
|
async def prepare_app(
|
@@ -70,4 +70,5 @@ class DeployAppManager(DeployPathOwner):
|
|
70
70
|
|
71
71
|
#
|
72
72
|
|
73
|
-
|
73
|
+
if spec.venv is not None:
|
74
|
+
await self._venvs.setup_app_venv(app_tag, spec.venv)
|
@@ -43,11 +43,29 @@ class DeployGitCheckout:
|
|
43
43
|
##
|
44
44
|
|
45
45
|
|
46
|
+
@dc.dataclass(frozen=True)
|
47
|
+
class DeployVenvSpec:
|
48
|
+
interp: ta.Optional[str] = None
|
49
|
+
|
50
|
+
requirements_files: ta.Optional[ta.Sequence[str]] = None
|
51
|
+
extra_dependencies: ta.Optional[ta.Sequence[str]] = None
|
52
|
+
|
53
|
+
use_uv: bool = False
|
54
|
+
|
55
|
+
def __post_init__(self) -> None:
|
56
|
+
hash(self)
|
57
|
+
|
58
|
+
|
59
|
+
##
|
60
|
+
|
61
|
+
|
46
62
|
@dc.dataclass(frozen=True)
|
47
63
|
class DeploySpec:
|
48
64
|
app: DeployApp
|
49
65
|
checkout: DeployGitCheckout
|
50
66
|
|
67
|
+
venv: ta.Optional[DeployVenvSpec] = None
|
68
|
+
|
51
69
|
def __post_init__(self) -> None:
|
52
70
|
hash(self)
|
53
71
|
|
@@ -14,6 +14,7 @@ from omlish.os.atomics import AtomicPathSwapping
|
|
14
14
|
|
15
15
|
from .paths import DeployPath
|
16
16
|
from .paths import DeployPathOwner
|
17
|
+
from .specs import DeployVenvSpec
|
17
18
|
from .types import DeployAppTag
|
18
19
|
from .types import DeployHome
|
19
20
|
|
@@ -43,8 +44,7 @@ class DeployVenvManager(DeployPathOwner):
|
|
43
44
|
self,
|
44
45
|
app_dir: str,
|
45
46
|
venv_dir: str,
|
46
|
-
|
47
|
-
use_uv: bool = True,
|
47
|
+
spec: DeployVenvSpec,
|
48
48
|
) -> None:
|
49
49
|
sys_exe = 'python3'
|
50
50
|
|
@@ -61,7 +61,7 @@ class DeployVenvManager(DeployPathOwner):
|
|
61
61
|
reqs_txt = os.path.join(app_dir, 'requirements.txt')
|
62
62
|
|
63
63
|
if os.path.isfile(reqs_txt):
|
64
|
-
if use_uv:
|
64
|
+
if spec.use_uv:
|
65
65
|
await asyncio_subprocesses.check_call(venv_exe, '-m', 'pip', 'install', 'uv')
|
66
66
|
pip_cmd = ['-m', 'uv', 'pip']
|
67
67
|
else:
|
@@ -69,8 +69,13 @@ class DeployVenvManager(DeployPathOwner):
|
|
69
69
|
|
70
70
|
await asyncio_subprocesses.check_call(venv_exe, *pip_cmd,'install', '-r', reqs_txt)
|
71
71
|
|
72
|
-
async def setup_app_venv(
|
72
|
+
async def setup_app_venv(
|
73
|
+
self,
|
74
|
+
app_tag: DeployAppTag,
|
75
|
+
spec: DeployVenvSpec,
|
76
|
+
) -> None:
|
73
77
|
await self.setup_venv(
|
74
78
|
os.path.join(check.non_empty_str(self._deploy_home), 'apps', app_tag.app, app_tag.tag),
|
75
79
|
os.path.join(self._dir(), app_tag.app, app_tag.tag),
|
80
|
+
spec,
|
76
81
|
)
|
@@ -4329,11 +4329,29 @@ class DeployGitCheckout:
|
|
4329
4329
|
##
|
4330
4330
|
|
4331
4331
|
|
4332
|
+
@dc.dataclass(frozen=True)
|
4333
|
+
class DeployVenvSpec:
|
4334
|
+
interp: ta.Optional[str] = None
|
4335
|
+
|
4336
|
+
requirements_files: ta.Optional[ta.Sequence[str]] = None
|
4337
|
+
extra_dependencies: ta.Optional[ta.Sequence[str]] = None
|
4338
|
+
|
4339
|
+
use_uv: bool = False
|
4340
|
+
|
4341
|
+
def __post_init__(self) -> None:
|
4342
|
+
hash(self)
|
4343
|
+
|
4344
|
+
|
4345
|
+
##
|
4346
|
+
|
4347
|
+
|
4332
4348
|
@dc.dataclass(frozen=True)
|
4333
4349
|
class DeploySpec:
|
4334
4350
|
app: DeployApp
|
4335
4351
|
checkout: DeployGitCheckout
|
4336
4352
|
|
4353
|
+
venv: ta.Optional[DeployVenvSpec] = None
|
4354
|
+
|
4337
4355
|
def __post_init__(self) -> None:
|
4338
4356
|
hash(self)
|
4339
4357
|
|
@@ -5489,7 +5507,7 @@ class InjectorBinder:
|
|
5489
5507
|
def __new__(cls, *args, **kwargs): # noqa
|
5490
5508
|
raise TypeError
|
5491
5509
|
|
5492
|
-
_FN_TYPES: ta.Tuple[type, ...] = (
|
5510
|
+
_FN_TYPES: ta.ClassVar[ta.Tuple[type, ...]] = (
|
5493
5511
|
types.FunctionType,
|
5494
5512
|
types.MethodType,
|
5495
5513
|
|
@@ -5511,7 +5529,7 @@ class InjectorBinder:
|
|
5511
5529
|
cls._FN_TYPES = (*cls._FN_TYPES, icls)
|
5512
5530
|
return icls
|
5513
5531
|
|
5514
|
-
_BANNED_BIND_TYPES: ta.Tuple[type, ...] = (
|
5532
|
+
_BANNED_BIND_TYPES: ta.ClassVar[ta.Tuple[type, ...]] = (
|
5515
5533
|
InjectorProvider,
|
5516
5534
|
)
|
5517
5535
|
|
@@ -5690,45 +5708,35 @@ def bind_injector_eager_key(key: ta.Any) -> InjectorBinding:
|
|
5690
5708
|
##
|
5691
5709
|
|
5692
5710
|
|
5693
|
-
class
|
5694
|
-
def __new__(cls, *args, **kwargs): # noqa
|
5695
|
-
raise TypeError
|
5696
|
-
|
5711
|
+
class InjectionApi:
|
5697
5712
|
# keys
|
5698
5713
|
|
5699
|
-
|
5700
|
-
def as_key(cls, o: ta.Any) -> InjectorKey:
|
5714
|
+
def as_key(self, o: ta.Any) -> InjectorKey:
|
5701
5715
|
return as_injector_key(o)
|
5702
5716
|
|
5703
|
-
|
5704
|
-
def array(cls, o: ta.Any) -> InjectorKey:
|
5717
|
+
def array(self, o: ta.Any) -> InjectorKey:
|
5705
5718
|
return dc.replace(as_injector_key(o), array=True)
|
5706
5719
|
|
5707
|
-
|
5708
|
-
def tag(cls, o: ta.Any, t: ta.Any) -> InjectorKey:
|
5720
|
+
def tag(self, o: ta.Any, t: ta.Any) -> InjectorKey:
|
5709
5721
|
return dc.replace(as_injector_key(o), tag=t)
|
5710
5722
|
|
5711
5723
|
# bindings
|
5712
5724
|
|
5713
|
-
|
5714
|
-
def as_bindings(cls, *args: InjectorBindingOrBindings) -> InjectorBindings:
|
5725
|
+
def as_bindings(self, *args: InjectorBindingOrBindings) -> InjectorBindings:
|
5715
5726
|
return as_injector_bindings(*args)
|
5716
5727
|
|
5717
|
-
|
5718
|
-
def override(cls, p: InjectorBindings, *args: InjectorBindingOrBindings) -> InjectorBindings:
|
5728
|
+
def override(self, p: InjectorBindings, *args: InjectorBindingOrBindings) -> InjectorBindings:
|
5719
5729
|
return injector_override(p, *args)
|
5720
5730
|
|
5721
5731
|
# injector
|
5722
5732
|
|
5723
|
-
|
5724
|
-
def create_injector(cls, *args: InjectorBindingOrBindings, parent: ta.Optional[Injector] = None) -> Injector:
|
5733
|
+
def create_injector(self, *args: InjectorBindingOrBindings, parent: ta.Optional[Injector] = None) -> Injector:
|
5725
5734
|
return _Injector(as_injector_bindings(*args), parent)
|
5726
5735
|
|
5727
5736
|
# binder
|
5728
5737
|
|
5729
|
-
@classmethod
|
5730
5738
|
def bind(
|
5731
|
-
|
5739
|
+
self,
|
5732
5740
|
obj: ta.Any,
|
5733
5741
|
*,
|
5734
5742
|
key: ta.Any = None,
|
@@ -5763,35 +5771,32 @@ class Injection:
|
|
5763
5771
|
|
5764
5772
|
# helpers
|
5765
5773
|
|
5766
|
-
@classmethod
|
5767
5774
|
def bind_factory(
|
5768
|
-
|
5775
|
+
self,
|
5769
5776
|
fn: ta.Callable[..., T],
|
5770
5777
|
cls_: U,
|
5771
5778
|
ann: ta.Any = None,
|
5772
5779
|
) -> InjectorBindingOrBindings:
|
5773
|
-
return
|
5780
|
+
return self.bind(make_injector_factory(fn, cls_, ann))
|
5774
5781
|
|
5775
|
-
@classmethod
|
5776
5782
|
def bind_array(
|
5777
|
-
|
5783
|
+
self,
|
5778
5784
|
obj: ta.Any = None,
|
5779
5785
|
*,
|
5780
5786
|
tag: ta.Any = None,
|
5781
5787
|
) -> InjectorBindingOrBindings:
|
5782
5788
|
return bind_injector_array(obj, tag=tag)
|
5783
5789
|
|
5784
|
-
@classmethod
|
5785
5790
|
def bind_array_type(
|
5786
|
-
|
5791
|
+
self,
|
5787
5792
|
ele: ta.Union[InjectorKey, InjectorKeyCls],
|
5788
5793
|
cls_: U,
|
5789
5794
|
ann: ta.Any = None,
|
5790
5795
|
) -> InjectorBindingOrBindings:
|
5791
|
-
return
|
5796
|
+
return self.bind(make_injector_array_type(ele, cls_, ann))
|
5792
5797
|
|
5793
5798
|
|
5794
|
-
inj =
|
5799
|
+
inj = InjectionApi()
|
5795
5800
|
|
5796
5801
|
|
5797
5802
|
########################################
|
@@ -8297,8 +8302,7 @@ class DeployVenvManager(DeployPathOwner):
|
|
8297
8302
|
self,
|
8298
8303
|
app_dir: str,
|
8299
8304
|
venv_dir: str,
|
8300
|
-
|
8301
|
-
use_uv: bool = True,
|
8305
|
+
spec: DeployVenvSpec,
|
8302
8306
|
) -> None:
|
8303
8307
|
sys_exe = 'python3'
|
8304
8308
|
|
@@ -8315,7 +8319,7 @@ class DeployVenvManager(DeployPathOwner):
|
|
8315
8319
|
reqs_txt = os.path.join(app_dir, 'requirements.txt')
|
8316
8320
|
|
8317
8321
|
if os.path.isfile(reqs_txt):
|
8318
|
-
if use_uv:
|
8322
|
+
if spec.use_uv:
|
8319
8323
|
await asyncio_subprocesses.check_call(venv_exe, '-m', 'pip', 'install', 'uv')
|
8320
8324
|
pip_cmd = ['-m', 'uv', 'pip']
|
8321
8325
|
else:
|
@@ -8323,10 +8327,15 @@ class DeployVenvManager(DeployPathOwner):
|
|
8323
8327
|
|
8324
8328
|
await asyncio_subprocesses.check_call(venv_exe, *pip_cmd,'install', '-r', reqs_txt)
|
8325
8329
|
|
8326
|
-
async def setup_app_venv(
|
8330
|
+
async def setup_app_venv(
|
8331
|
+
self,
|
8332
|
+
app_tag: DeployAppTag,
|
8333
|
+
spec: DeployVenvSpec,
|
8334
|
+
) -> None:
|
8327
8335
|
await self.setup_venv(
|
8328
8336
|
os.path.join(check.non_empty_str(self._deploy_home), 'apps', app_tag.app, app_tag.tag),
|
8329
8337
|
os.path.join(self._dir(), app_tag.app, app_tag.tag),
|
8338
|
+
spec,
|
8330
8339
|
)
|
8331
8340
|
|
8332
8341
|
|
@@ -8892,7 +8901,7 @@ class DeployAppManager(DeployPathOwner):
|
|
8892
8901
|
|
8893
8902
|
def get_owned_deploy_paths(self) -> ta.AbstractSet[DeployPath]:
|
8894
8903
|
return {
|
8895
|
-
DeployPath.parse('apps/@app/@tag'),
|
8904
|
+
DeployPath.parse('apps/@app/@tag/'),
|
8896
8905
|
}
|
8897
8906
|
|
8898
8907
|
async def prepare_app(
|
@@ -8911,7 +8920,8 @@ class DeployAppManager(DeployPathOwner):
|
|
8911
8920
|
|
8912
8921
|
#
|
8913
8922
|
|
8914
|
-
|
8923
|
+
if spec.venv is not None:
|
8924
|
+
await self._venvs.setup_app_venv(app_tag, spec.venv)
|
8915
8925
|
|
8916
8926
|
|
8917
8927
|
########################################
|
@@ -4548,7 +4548,7 @@ class InjectorBinder:
|
|
4548
4548
|
def __new__(cls, *args, **kwargs): # noqa
|
4549
4549
|
raise TypeError
|
4550
4550
|
|
4551
|
-
_FN_TYPES: ta.Tuple[type, ...] = (
|
4551
|
+
_FN_TYPES: ta.ClassVar[ta.Tuple[type, ...]] = (
|
4552
4552
|
types.FunctionType,
|
4553
4553
|
types.MethodType,
|
4554
4554
|
|
@@ -4570,7 +4570,7 @@ class InjectorBinder:
|
|
4570
4570
|
cls._FN_TYPES = (*cls._FN_TYPES, icls)
|
4571
4571
|
return icls
|
4572
4572
|
|
4573
|
-
_BANNED_BIND_TYPES: ta.Tuple[type, ...] = (
|
4573
|
+
_BANNED_BIND_TYPES: ta.ClassVar[ta.Tuple[type, ...]] = (
|
4574
4574
|
InjectorProvider,
|
4575
4575
|
)
|
4576
4576
|
|
@@ -4749,45 +4749,35 @@ def bind_injector_eager_key(key: ta.Any) -> InjectorBinding:
|
|
4749
4749
|
##
|
4750
4750
|
|
4751
4751
|
|
4752
|
-
class
|
4753
|
-
def __new__(cls, *args, **kwargs): # noqa
|
4754
|
-
raise TypeError
|
4755
|
-
|
4752
|
+
class InjectionApi:
|
4756
4753
|
# keys
|
4757
4754
|
|
4758
|
-
|
4759
|
-
def as_key(cls, o: ta.Any) -> InjectorKey:
|
4755
|
+
def as_key(self, o: ta.Any) -> InjectorKey:
|
4760
4756
|
return as_injector_key(o)
|
4761
4757
|
|
4762
|
-
|
4763
|
-
def array(cls, o: ta.Any) -> InjectorKey:
|
4758
|
+
def array(self, o: ta.Any) -> InjectorKey:
|
4764
4759
|
return dc.replace(as_injector_key(o), array=True)
|
4765
4760
|
|
4766
|
-
|
4767
|
-
def tag(cls, o: ta.Any, t: ta.Any) -> InjectorKey:
|
4761
|
+
def tag(self, o: ta.Any, t: ta.Any) -> InjectorKey:
|
4768
4762
|
return dc.replace(as_injector_key(o), tag=t)
|
4769
4763
|
|
4770
4764
|
# bindings
|
4771
4765
|
|
4772
|
-
|
4773
|
-
def as_bindings(cls, *args: InjectorBindingOrBindings) -> InjectorBindings:
|
4766
|
+
def as_bindings(self, *args: InjectorBindingOrBindings) -> InjectorBindings:
|
4774
4767
|
return as_injector_bindings(*args)
|
4775
4768
|
|
4776
|
-
|
4777
|
-
def override(cls, p: InjectorBindings, *args: InjectorBindingOrBindings) -> InjectorBindings:
|
4769
|
+
def override(self, p: InjectorBindings, *args: InjectorBindingOrBindings) -> InjectorBindings:
|
4778
4770
|
return injector_override(p, *args)
|
4779
4771
|
|
4780
4772
|
# injector
|
4781
4773
|
|
4782
|
-
|
4783
|
-
def create_injector(cls, *args: InjectorBindingOrBindings, parent: ta.Optional[Injector] = None) -> Injector:
|
4774
|
+
def create_injector(self, *args: InjectorBindingOrBindings, parent: ta.Optional[Injector] = None) -> Injector:
|
4784
4775
|
return _Injector(as_injector_bindings(*args), parent)
|
4785
4776
|
|
4786
4777
|
# binder
|
4787
4778
|
|
4788
|
-
@classmethod
|
4789
4779
|
def bind(
|
4790
|
-
|
4780
|
+
self,
|
4791
4781
|
obj: ta.Any,
|
4792
4782
|
*,
|
4793
4783
|
key: ta.Any = None,
|
@@ -4822,35 +4812,32 @@ class Injection:
|
|
4822
4812
|
|
4823
4813
|
# helpers
|
4824
4814
|
|
4825
|
-
@classmethod
|
4826
4815
|
def bind_factory(
|
4827
|
-
|
4816
|
+
self,
|
4828
4817
|
fn: ta.Callable[..., T],
|
4829
4818
|
cls_: U,
|
4830
4819
|
ann: ta.Any = None,
|
4831
4820
|
) -> InjectorBindingOrBindings:
|
4832
|
-
return
|
4821
|
+
return self.bind(make_injector_factory(fn, cls_, ann))
|
4833
4822
|
|
4834
|
-
@classmethod
|
4835
4823
|
def bind_array(
|
4836
|
-
|
4824
|
+
self,
|
4837
4825
|
obj: ta.Any = None,
|
4838
4826
|
*,
|
4839
4827
|
tag: ta.Any = None,
|
4840
4828
|
) -> InjectorBindingOrBindings:
|
4841
4829
|
return bind_injector_array(obj, tag=tag)
|
4842
4830
|
|
4843
|
-
@classmethod
|
4844
4831
|
def bind_array_type(
|
4845
|
-
|
4832
|
+
self,
|
4846
4833
|
ele: ta.Union[InjectorKey, InjectorKeyCls],
|
4847
4834
|
cls_: U,
|
4848
4835
|
ann: ta.Any = None,
|
4849
4836
|
) -> InjectorBindingOrBindings:
|
4850
|
-
return
|
4837
|
+
return self.bind(make_injector_array_type(ele, cls_, ann))
|
4851
4838
|
|
4852
4839
|
|
4853
|
-
inj =
|
4840
|
+
inj = InjectionApi()
|
4854
4841
|
|
4855
4842
|
|
4856
4843
|
########################################
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.1
|
2
2
|
Name: ominfra
|
3
|
-
Version: 0.0.0.
|
3
|
+
Version: 0.0.0.dev163
|
4
4
|
Summary: ominfra
|
5
5
|
Author: wrmsr
|
6
6
|
License: BSD-3-Clause
|
@@ -12,8 +12,8 @@ Classifier: Operating System :: OS Independent
|
|
12
12
|
Classifier: Operating System :: POSIX
|
13
13
|
Requires-Python: >=3.12
|
14
14
|
License-File: LICENSE
|
15
|
-
Requires-Dist: omdev==0.0.0.
|
16
|
-
Requires-Dist: omlish==0.0.0.
|
15
|
+
Requires-Dist: omdev==0.0.0.dev163
|
16
|
+
Requires-Dist: omlish==0.0.0.dev163
|
17
17
|
Provides-Extra: all
|
18
18
|
Requires-Dist: paramiko~=3.5; extra == "all"
|
19
19
|
Requires-Dist: asyncssh~=2.18; extra == "all"
|
@@ -12,7 +12,7 @@ authors = [
|
|
12
12
|
urls = {source = 'https://github.com/wrmsr/omlish'}
|
13
13
|
license = {text = 'BSD-3-Clause'}
|
14
14
|
requires-python = '>=3.12'
|
15
|
-
version = '0.0.0.
|
15
|
+
version = '0.0.0.dev163'
|
16
16
|
classifiers = [
|
17
17
|
'License :: OSI Approved :: BSD License',
|
18
18
|
'Development Status :: 2 - Pre-Alpha',
|
@@ -22,8 +22,8 @@ classifiers = [
|
|
22
22
|
]
|
23
23
|
description = 'ominfra'
|
24
24
|
dependencies = [
|
25
|
-
'omdev == 0.0.0.
|
26
|
-
'omlish == 0.0.0.
|
25
|
+
'omdev == 0.0.0.dev163',
|
26
|
+
'omlish == 0.0.0.dev163',
|
27
27
|
]
|
28
28
|
|
29
29
|
[project.optional-dependencies]
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|