ominfra 0.0.0.dev406__tar.gz → 0.0.0.dev407__tar.gz
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.
- {ominfra-0.0.0.dev406/ominfra.egg-info → ominfra-0.0.0.dev407}/PKG-INFO +3 -3
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/auth.py +1 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/journald2aws/cursor.py +1 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/journald2aws/poster.py +1 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/commands/runners.py +2 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/commands/ssh.py +3 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/remote/_main.py +1 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/scripts/journald2aws.py +7 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/scripts/manage.py +6 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/scripts/supervisor.py +14 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/events.py +7 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/utils/strings.py +1 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407/ominfra.egg-info}/PKG-INFO +3 -3
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra.egg-info/requires.txt +2 -2
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/pyproject.toml +3 -3
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/LICENSE +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/MANIFEST.in +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/README.md +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/.manifests.json +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/__about__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/__main__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/cli.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/dataclasses.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/instancetypes/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/instancetypes/__main__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/instancetypes/cache.json.gz +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/instancetypes/cache.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/instancetypes/cli.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/journald2aws/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/journald2aws/__main__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/journald2aws/driver.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/journald2aws/main.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/logs.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/metadata.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/models/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/models/base.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/models/gen/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/models/gen/__main__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/models/gen/cli.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/models/gen/gen.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/models/services/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/models/services/ec2.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/models/services/lambda_.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/models/services/rds.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/models/services/s3.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/models/services/services.toml +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/gcp/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/gcp/api.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/gcp/auth.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/commands/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/journald/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/journald/fields.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/journald/genmessages.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/journald/messages.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/journald/tailer.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/__main__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/bootstrap.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/bootstrap_.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/commands/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/commands/base.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/commands/inject.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/commands/injection.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/commands/local.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/commands/marshal.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/commands/ping.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/commands/subprocess.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/commands/types.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/config.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/apps.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/commands.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/conf/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/conf/inject.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/conf/manager.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/conf/specs.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/config.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/deploy.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/git.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/inject.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/injection.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/interp.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/nginx.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/paths/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/paths/inject.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/paths/manager.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/paths/owners.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/paths/paths.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/paths/specs.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/paths/types.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/specs.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/systemd.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/tags.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/tmp.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/types.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/deploy/venvs.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/inject.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/main.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/marshal.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/remote/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/remote/channel.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/remote/config.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/remote/connection.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/remote/execution.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/remote/inject.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/remote/payload.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/remote/spawning.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/system/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/system/commands.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/system/config.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/system/inject.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/system/packages.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/system/platforms.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/targets/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/targets/bestpython.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/targets/bestpython.sh +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/targets/connection.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/targets/inject.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/manage/targets/targets.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/pyremote.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/scripts/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/LICENSE.txt +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/__main__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/configs.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/dispatchers.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/dispatchersimpl.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/errors.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/groups.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/groupsimpl.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/http.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/inject.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/io.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/main.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/pipes.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/privileges.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/process.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/processimpl.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/setup.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/setupimpl.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/signals.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/spawning.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/spawningimpl.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/states.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/supervisor.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/types.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/utils/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/utils/collections.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/utils/diag.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/utils/fds.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/utils/fs.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/utils/os.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/utils/ostypes.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/utils/signals.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/supervisor/utils/users.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/systemd.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/tailscale/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/tailscale/api.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/tailscale/cli.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/threadworkers.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/tools/__init__.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/tools/listresources.py +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra.egg-info/SOURCES.txt +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra.egg-info/dependency_links.txt +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra.egg-info/entry_points.txt +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra.egg-info/top_level.txt +0 -0
- {ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/setup.cfg +0 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.4
|
2
2
|
Name: ominfra
|
3
|
-
Version: 0.0.0.
|
3
|
+
Version: 0.0.0.dev407
|
4
4
|
Summary: ominfra
|
5
5
|
Author: wrmsr
|
6
6
|
License-Expression: BSD-3-Clause
|
@@ -14,8 +14,8 @@ Classifier: Programming Language :: Python :: 3.13
|
|
14
14
|
Requires-Python: >=3.13
|
15
15
|
Description-Content-Type: text/markdown
|
16
16
|
License-File: LICENSE
|
17
|
-
Requires-Dist: omdev==0.0.0.
|
18
|
-
Requires-Dist: omlish==0.0.0.
|
17
|
+
Requires-Dist: omdev==0.0.0.dev407
|
18
|
+
Requires-Dist: omlish==0.0.0.dev407
|
19
19
|
Provides-Extra: all
|
20
20
|
Requires-Dist: paramiko~=4.0; extra == "all"
|
21
21
|
Requires-Dist: asyncssh~=2.21; extra == "all"
|
@@ -38,6 +38,7 @@ class CommandRunner(lang.Abstract):
|
|
38
38
|
class ReturnCodeError(Exception):
|
39
39
|
def __init__(self, result: 'CommandRunner.Result') -> None:
|
40
40
|
super().__init__(f'Bad return code: {result.rc}', result)
|
41
|
+
|
41
42
|
self.result = result
|
42
43
|
|
43
44
|
@abc.abstractmethod
|
@@ -52,6 +53,7 @@ class LocalCommandRunner(CommandRunner):
|
|
52
53
|
|
53
54
|
def __init__(self, cfg: Config = Config()) -> None:
|
54
55
|
super().__init__()
|
56
|
+
|
55
57
|
self._cfg = check.isinstance(cfg, LocalCommandRunner.Config)
|
56
58
|
|
57
59
|
async def run_command(self, cmd: CommandRunner.Command) -> CommandRunner.Result:
|
@@ -56,6 +56,7 @@ class SshSubprocessCommandRunner(CommandRunner):
|
|
56
56
|
lcr: LocalCommandRunner | None = None,
|
57
57
|
) -> None:
|
58
58
|
super().__init__()
|
59
|
+
|
59
60
|
self._cfg = check.isinstance(cfg, SshConfig)
|
60
61
|
self._lcr = check.isinstance(lcr, LocalCommandRunner) if lcr is not None else LocalCommandRunner()
|
61
62
|
|
@@ -89,6 +90,7 @@ class AsyncsshSshCommandRunner(CommandRunner):
|
|
89
90
|
cfg: SshConfig,
|
90
91
|
) -> None:
|
91
92
|
super().__init__()
|
93
|
+
|
92
94
|
self._cfg = check.isinstance(cfg, SshConfig)
|
93
95
|
|
94
96
|
async def run_command(self, cmd: CommandRunner.Command) -> CommandRunner.Result:
|
@@ -122,6 +124,7 @@ class ParamikoSshCommandRunner(CommandRunner):
|
|
122
124
|
cfg: SshConfig,
|
123
125
|
) -> None:
|
124
126
|
super().__init__()
|
127
|
+
|
125
128
|
self._cfg = check.isinstance(cfg, SshConfig)
|
126
129
|
|
127
130
|
def _run_command(self, cmd: CommandRunner.Command) -> CommandRunner.Result:
|
@@ -1071,6 +1071,7 @@ class TomlWriter:
|
|
1071
1071
|
|
1072
1072
|
def __init__(self, out: ta.TextIO) -> None:
|
1073
1073
|
super().__init__()
|
1074
|
+
|
1074
1075
|
self._out = out
|
1075
1076
|
|
1076
1077
|
self._indent = 0
|
@@ -1193,6 +1194,7 @@ class TomlWriter:
|
|
1193
1194
|
class _AbstractCachedNullary:
|
1194
1195
|
def __init__(self, fn):
|
1195
1196
|
super().__init__()
|
1197
|
+
|
1196
1198
|
self._fn = fn
|
1197
1199
|
self._value = self._missing = object()
|
1198
1200
|
functools.update_wrapper(self, fn)
|
@@ -2533,6 +2535,7 @@ class AwsSigner:
|
|
2533
2535
|
service_name: str,
|
2534
2536
|
) -> None:
|
2535
2537
|
super().__init__()
|
2538
|
+
|
2536
2539
|
self._creds = creds
|
2537
2540
|
self._region_name = region_name
|
2538
2541
|
self._service_name = service_name
|
@@ -2888,6 +2891,7 @@ class JournalctlToAwsCursor:
|
|
2888
2891
|
ensure_locked: ta.Optional[ta.Callable[[], None]] = None,
|
2889
2892
|
) -> None:
|
2890
2893
|
super().__init__()
|
2894
|
+
|
2891
2895
|
self._cursor_file = cursor_file
|
2892
2896
|
self._ensure_locked = ensure_locked
|
2893
2897
|
|
@@ -3363,6 +3367,7 @@ class DelimitingBuffer:
|
|
3363
3367
|
class Error(Exception):
|
3364
3368
|
def __init__(self, buffer: 'DelimitingBuffer') -> None:
|
3365
3369
|
super().__init__(buffer)
|
3370
|
+
|
3366
3371
|
self.buffer = buffer
|
3367
3372
|
|
3368
3373
|
def __repr__(self) -> str:
|
@@ -3518,6 +3523,7 @@ class ReadableListBuffer:
|
|
3518
3523
|
|
3519
3524
|
def __init__(self) -> None:
|
3520
3525
|
super().__init__()
|
3526
|
+
|
3521
3527
|
self._lst: list[bytes] = []
|
3522
3528
|
|
3523
3529
|
def __len__(self) -> int:
|
@@ -4816,6 +4822,7 @@ class JournalctlToAwsPosterWorker(ThreadWorker):
|
|
4816
4822
|
**kwargs: ta.Any,
|
4817
4823
|
) -> None:
|
4818
4824
|
super().__init__(**kwargs)
|
4825
|
+
|
4819
4826
|
self._queue = queue
|
4820
4827
|
self._builder = builder
|
4821
4828
|
self._cursor = cursor
|
@@ -2251,6 +2251,7 @@ class TomlWriter:
|
|
2251
2251
|
|
2252
2252
|
def __init__(self, out: ta.TextIO) -> None:
|
2253
2253
|
super().__init__()
|
2254
|
+
|
2254
2255
|
self._out = out
|
2255
2256
|
|
2256
2257
|
self._indent = 0
|
@@ -2373,6 +2374,7 @@ class TomlWriter:
|
|
2373
2374
|
class _AbstractCachedNullary:
|
2374
2375
|
def __init__(self, fn):
|
2375
2376
|
super().__init__()
|
2377
|
+
|
2376
2378
|
self._fn = fn
|
2377
2379
|
self._value = self._missing = object()
|
2378
2380
|
functools.update_wrapper(self, fn)
|
@@ -6690,6 +6692,7 @@ class ContextvarInjectorScope(InjectorScope, abc.ABC):
|
|
6690
6692
|
|
6691
6693
|
def __init_subclass__(cls, **kwargs: ta.Any) -> None:
|
6692
6694
|
super().__init_subclass__(**kwargs)
|
6695
|
+
|
6693
6696
|
check.not_in(abc.ABC, cls.__bases__)
|
6694
6697
|
check.state(not hasattr(cls, '_cv'))
|
6695
6698
|
cls._cv = contextvars.ContextVar(f'{cls.__name__}_cv')
|
@@ -6964,6 +6967,7 @@ class _Injector(Injector):
|
|
6964
6967
|
class _Request:
|
6965
6968
|
def __init__(self, injector: '_Injector') -> None:
|
6966
6969
|
super().__init__()
|
6970
|
+
|
6967
6971
|
self._injector = injector
|
6968
6972
|
self._provisions: ta.Dict[InjectorKey, Maybe] = {}
|
6969
6973
|
self._seen_keys: ta.Set[InjectorKey] = set()
|
@@ -9419,6 +9423,7 @@ class InterpProvider(abc.ABC):
|
|
9419
9423
|
|
9420
9424
|
def __init_subclass__(cls, **kwargs: ta.Any) -> None:
|
9421
9425
|
super().__init_subclass__(**kwargs)
|
9426
|
+
|
9422
9427
|
if abc.ABC not in cls.__bases__ and 'name' not in cls.__dict__:
|
9423
9428
|
sfx = 'InterpProvider'
|
9424
9429
|
if not cls.__name__.endswith(sfx):
|
@@ -10802,6 +10807,7 @@ class SingleDirDeployPathOwner(DeployPathOwner, abc.ABC):
|
|
10802
10807
|
class _RemoteExecutionLogHandler(logging.Handler):
|
10803
10808
|
def __init__(self, fn: ta.Callable[[str], None]) -> None:
|
10804
10809
|
super().__init__()
|
10810
|
+
|
10805
10811
|
self._fn = fn
|
10806
10812
|
|
10807
10813
|
def emit(self, record):
|
@@ -594,6 +594,7 @@ class SuffixMultiplier:
|
|
594
594
|
# case insensitive. Return values are in the fundamental unit.
|
595
595
|
def __init__(self, d, default=1):
|
596
596
|
super().__init__()
|
597
|
+
|
597
598
|
self._d = d
|
598
599
|
self._default = default
|
599
600
|
# all keys must be the same size
|
@@ -1614,6 +1615,7 @@ class TomlWriter:
|
|
1614
1615
|
|
1615
1616
|
def __init__(self, out: ta.TextIO) -> None:
|
1616
1617
|
super().__init__()
|
1618
|
+
|
1617
1619
|
self._out = out
|
1618
1620
|
|
1619
1621
|
self._indent = 0
|
@@ -1968,6 +1970,7 @@ else:
|
|
1968
1970
|
class _AbstractCachedNullary:
|
1969
1971
|
def __init__(self, fn):
|
1970
1972
|
super().__init__()
|
1973
|
+
|
1971
1974
|
self._fn = fn
|
1972
1975
|
self._value = self._missing = object()
|
1973
1976
|
functools.update_wrapper(self, fn)
|
@@ -3240,6 +3243,7 @@ class ProcessLogEvent(Event, abc.ABC):
|
|
3240
3243
|
|
3241
3244
|
def __init__(self, process, pid, data):
|
3242
3245
|
super().__init__()
|
3246
|
+
|
3243
3247
|
self.process = process
|
3244
3248
|
self.pid = pid
|
3245
3249
|
self.data = data
|
@@ -3265,6 +3269,7 @@ class ProcessCommunicationEvent(Event, abc.ABC):
|
|
3265
3269
|
|
3266
3270
|
def __init__(self, process, pid, data):
|
3267
3271
|
super().__init__()
|
3272
|
+
|
3268
3273
|
self.process = process
|
3269
3274
|
self.pid = pid
|
3270
3275
|
self.data = data
|
@@ -3284,6 +3289,7 @@ class ProcessCommunicationStderrEvent(ProcessCommunicationEvent):
|
|
3284
3289
|
class RemoteCommunicationEvent(Event):
|
3285
3290
|
def __init__(self, type, data): # noqa
|
3286
3291
|
super().__init__()
|
3292
|
+
|
3287
3293
|
self.type = type
|
3288
3294
|
self.data = data
|
3289
3295
|
|
@@ -3309,6 +3315,7 @@ class SupervisorStoppingEvent(SupervisorStateChangeEvent):
|
|
3309
3315
|
class EventRejectedEvent: # purposely does not subclass Event
|
3310
3316
|
def __init__(self, process, event):
|
3311
3317
|
super().__init__()
|
3318
|
+
|
3312
3319
|
self.process = process
|
3313
3320
|
self.event = event
|
3314
3321
|
|
@@ -3323,6 +3330,7 @@ class ProcessStateEvent(Event):
|
|
3323
3330
|
|
3324
3331
|
def __init__(self, process, from_state, expected=True):
|
3325
3332
|
super().__init__()
|
3333
|
+
|
3326
3334
|
self.process = process
|
3327
3335
|
self.from_state = from_state
|
3328
3336
|
self.expected = expected
|
@@ -3393,6 +3401,7 @@ PROCESS_STATE_EVENT_MAP: ta.Mapping[ProcessState, ta.Type[ProcessStateEvent]] =
|
|
3393
3401
|
class ProcessGroupEvent(Event):
|
3394
3402
|
def __init__(self, group):
|
3395
3403
|
super().__init__()
|
3404
|
+
|
3396
3405
|
self.group = group
|
3397
3406
|
|
3398
3407
|
|
@@ -3412,6 +3421,7 @@ class TickEvent(Event):
|
|
3412
3421
|
|
3413
3422
|
def __init__(self, when, supervisord):
|
3414
3423
|
super().__init__()
|
3424
|
+
|
3415
3425
|
self.when = when
|
3416
3426
|
self.supervisord = supervisord
|
3417
3427
|
|
@@ -4386,6 +4396,7 @@ class DelimitingBuffer:
|
|
4386
4396
|
class Error(Exception):
|
4387
4397
|
def __init__(self, buffer: 'DelimitingBuffer') -> None:
|
4388
4398
|
super().__init__(buffer)
|
4399
|
+
|
4389
4400
|
self.buffer = buffer
|
4390
4401
|
|
4391
4402
|
def __repr__(self) -> str:
|
@@ -4541,6 +4552,7 @@ class ReadableListBuffer:
|
|
4541
4552
|
|
4542
4553
|
def __init__(self) -> None:
|
4543
4554
|
super().__init__()
|
4555
|
+
|
4544
4556
|
self._lst: list[bytes] = []
|
4545
4557
|
|
4546
4558
|
def __len__(self) -> int:
|
@@ -5223,6 +5235,7 @@ class ContextvarInjectorScope(InjectorScope, abc.ABC):
|
|
5223
5235
|
|
5224
5236
|
def __init_subclass__(cls, **kwargs: ta.Any) -> None:
|
5225
5237
|
super().__init_subclass__(**kwargs)
|
5238
|
+
|
5226
5239
|
check.not_in(abc.ABC, cls.__bases__)
|
5227
5240
|
check.state(not hasattr(cls, '_cv'))
|
5228
5241
|
cls._cv = contextvars.ContextVar(f'{cls.__name__}_cv')
|
@@ -5497,6 +5510,7 @@ class _Injector(Injector):
|
|
5497
5510
|
class _Request:
|
5498
5511
|
def __init__(self, injector: '_Injector') -> None:
|
5499
5512
|
super().__init__()
|
5513
|
+
|
5500
5514
|
self._injector = injector
|
5501
5515
|
self._provisions: ta.Dict[InjectorKey, Maybe] = {}
|
5502
5516
|
self._seen_keys: ta.Set[InjectorKey] = set()
|
@@ -50,6 +50,7 @@ class ProcessLogEvent(Event, abc.ABC):
|
|
50
50
|
|
51
51
|
def __init__(self, process, pid, data):
|
52
52
|
super().__init__()
|
53
|
+
|
53
54
|
self.process = process
|
54
55
|
self.pid = pid
|
55
56
|
self.data = data
|
@@ -75,6 +76,7 @@ class ProcessCommunicationEvent(Event, abc.ABC):
|
|
75
76
|
|
76
77
|
def __init__(self, process, pid, data):
|
77
78
|
super().__init__()
|
79
|
+
|
78
80
|
self.process = process
|
79
81
|
self.pid = pid
|
80
82
|
self.data = data
|
@@ -94,6 +96,7 @@ class ProcessCommunicationStderrEvent(ProcessCommunicationEvent):
|
|
94
96
|
class RemoteCommunicationEvent(Event):
|
95
97
|
def __init__(self, type, data): # noqa
|
96
98
|
super().__init__()
|
99
|
+
|
97
100
|
self.type = type
|
98
101
|
self.data = data
|
99
102
|
|
@@ -119,6 +122,7 @@ class SupervisorStoppingEvent(SupervisorStateChangeEvent):
|
|
119
122
|
class EventRejectedEvent: # purposely does not subclass Event
|
120
123
|
def __init__(self, process, event):
|
121
124
|
super().__init__()
|
125
|
+
|
122
126
|
self.process = process
|
123
127
|
self.event = event
|
124
128
|
|
@@ -133,6 +137,7 @@ class ProcessStateEvent(Event):
|
|
133
137
|
|
134
138
|
def __init__(self, process, from_state, expected=True):
|
135
139
|
super().__init__()
|
140
|
+
|
136
141
|
self.process = process
|
137
142
|
self.from_state = from_state
|
138
143
|
self.expected = expected
|
@@ -203,6 +208,7 @@ PROCESS_STATE_EVENT_MAP: ta.Mapping[ProcessState, ta.Type[ProcessStateEvent]] =
|
|
203
208
|
class ProcessGroupEvent(Event):
|
204
209
|
def __init__(self, group):
|
205
210
|
super().__init__()
|
211
|
+
|
206
212
|
self.group = group
|
207
213
|
|
208
214
|
|
@@ -222,6 +228,7 @@ class TickEvent(Event):
|
|
222
228
|
|
223
229
|
def __init__(self, when, supervisord):
|
224
230
|
super().__init__()
|
231
|
+
|
225
232
|
self.when = when
|
226
233
|
self.supervisord = supervisord
|
227
234
|
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.4
|
2
2
|
Name: ominfra
|
3
|
-
Version: 0.0.0.
|
3
|
+
Version: 0.0.0.dev407
|
4
4
|
Summary: ominfra
|
5
5
|
Author: wrmsr
|
6
6
|
License-Expression: BSD-3-Clause
|
@@ -14,8 +14,8 @@ Classifier: Programming Language :: Python :: 3.13
|
|
14
14
|
Requires-Python: >=3.13
|
15
15
|
Description-Content-Type: text/markdown
|
16
16
|
License-File: LICENSE
|
17
|
-
Requires-Dist: omdev==0.0.0.
|
18
|
-
Requires-Dist: omlish==0.0.0.
|
17
|
+
Requires-Dist: omdev==0.0.0.dev407
|
18
|
+
Requires-Dist: omlish==0.0.0.dev407
|
19
19
|
Provides-Extra: all
|
20
20
|
Requires-Dist: paramiko~=4.0; extra == "all"
|
21
21
|
Requires-Dist: asyncssh~=2.21; extra == "all"
|
@@ -13,7 +13,7 @@ urls = {source = 'https://github.com/wrmsr/omlish'}
|
|
13
13
|
license = 'BSD-3-Clause'
|
14
14
|
readme = 'README.md'
|
15
15
|
requires-python = '>=3.13'
|
16
|
-
version = '0.0.0.
|
16
|
+
version = '0.0.0.dev407'
|
17
17
|
classifiers = [
|
18
18
|
'Development Status :: 2 - Pre-Alpha',
|
19
19
|
'Intended Audience :: Developers',
|
@@ -24,8 +24,8 @@ classifiers = [
|
|
24
24
|
]
|
25
25
|
description = 'ominfra'
|
26
26
|
dependencies = [
|
27
|
-
'omdev == 0.0.0.
|
28
|
-
'omlish == 0.0.0.
|
27
|
+
'omdev == 0.0.0.dev407',
|
28
|
+
'omlish == 0.0.0.dev407',
|
29
29
|
]
|
30
30
|
|
31
31
|
[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
|
{ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/instancetypes/cache.json.gz
RENAMED
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
|
{ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/models/services/__init__.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{ominfra-0.0.0.dev406 → ominfra-0.0.0.dev407}/ominfra/clouds/aws/models/services/services.toml
RENAMED
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
|