request-vm-on-golem 0.1.36__tar.gz → 0.1.37__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.
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/PKG-INFO +1 -1
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/pyproject.toml +1 -1
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/cli/commands.py +2 -1
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/config.py +44 -11
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/README.md +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/__init__.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/api/main.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/cli/__init__.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/db/__init__.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/db/sqlite.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/errors.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/provider/__init__.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/provider/client.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/run.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/services/__init__.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/services/database_service.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/services/provider_service.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/services/ssh_service.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/services/vm_service.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/ssh/__init__.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/ssh/manager.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/utils/logging.py +0 -0
- {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/utils/spinner.py +0 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
[tool.poetry]
|
2
2
|
name = "request-vm-on-golem"
|
3
|
-
version = "0.1.
|
3
|
+
version = "0.1.37"
|
4
4
|
description = "VM on Golem Requestor CLI - Create and manage virtual machines on the Golem Network"
|
5
5
|
authors = ["Phillip Jensen <phillip+vm-on-golem@golemgrid.com>"]
|
6
6
|
readme = "README.md"
|
@@ -14,7 +14,7 @@ except ImportError:
|
|
14
14
|
# Python < 3.8
|
15
15
|
import importlib_metadata as metadata
|
16
16
|
|
17
|
-
from ..config import config
|
17
|
+
from ..config import config, ensure_config
|
18
18
|
from ..provider.client import ProviderClient
|
19
19
|
from ..errors import RequestorError
|
20
20
|
from ..utils.logging import setup_logger
|
@@ -56,6 +56,7 @@ def print_version(ctx, param, value):
|
|
56
56
|
expose_value=False, is_eager=True, help="Show the version and exit.")
|
57
57
|
def cli():
|
58
58
|
"""VM on Golem management CLI"""
|
59
|
+
ensure_config()
|
59
60
|
pass
|
60
61
|
|
61
62
|
|
@@ -1,14 +1,46 @@
|
|
1
1
|
from pathlib import Path
|
2
2
|
from typing import Optional, Dict
|
3
3
|
import os
|
4
|
-
from pydantic_settings import BaseSettings
|
5
|
-
from pydantic import Field,
|
4
|
+
from pydantic_settings import BaseSettings, SettingsConfigDict
|
5
|
+
from pydantic import Field, field_validator, ValidationInfo
|
6
|
+
|
7
|
+
|
8
|
+
def ensure_config() -> None:
|
9
|
+
"""Ensure the requestor configuration directory and defaults exist."""
|
10
|
+
base_dir = Path.home() / ".golem" / "requestor"
|
11
|
+
ssh_dir = base_dir / "ssh"
|
12
|
+
env_file = base_dir / ".env"
|
13
|
+
created = False
|
14
|
+
|
15
|
+
if not base_dir.exists():
|
16
|
+
base_dir.mkdir(parents=True, exist_ok=True)
|
17
|
+
created = True
|
18
|
+
if not ssh_dir.exists():
|
19
|
+
ssh_dir.mkdir(parents=True, exist_ok=True)
|
20
|
+
created = True
|
21
|
+
|
22
|
+
if not env_file.exists():
|
23
|
+
env_file.write_text("GOLEM_REQUESTOR_ENVIRONMENT=production\n")
|
24
|
+
created = True
|
25
|
+
|
26
|
+
private_key = ssh_dir / "id_rsa"
|
27
|
+
public_key = ssh_dir / "id_rsa.pub"
|
28
|
+
if not private_key.exists():
|
29
|
+
private_key.write_text("placeholder-private-key")
|
30
|
+
private_key.chmod(0o600)
|
31
|
+
public_key.write_text("placeholder-public-key")
|
32
|
+
created = True
|
33
|
+
|
34
|
+
if created:
|
35
|
+
print("Using default settings – run with --help to customize")
|
36
|
+
|
37
|
+
|
38
|
+
ensure_config()
|
6
39
|
|
7
40
|
class RequestorConfig(BaseSettings):
|
8
41
|
"""Configuration settings for the requestor node."""
|
9
|
-
|
10
|
-
|
11
|
-
env_prefix = "GOLEM_REQUESTOR_"
|
42
|
+
|
43
|
+
model_config = SettingsConfigDict(env_prefix="GOLEM_REQUESTOR_")
|
12
44
|
|
13
45
|
# Environment
|
14
46
|
environment: str = Field(
|
@@ -36,10 +68,11 @@ class RequestorConfig(BaseSettings):
|
|
36
68
|
description="URL of the discovery service (for 'central' driver)"
|
37
69
|
)
|
38
70
|
|
39
|
-
@
|
40
|
-
|
71
|
+
@field_validator("discovery_url")
|
72
|
+
@classmethod
|
73
|
+
def set_discovery_url(cls, v: str, info: ValidationInfo) -> str:
|
41
74
|
"""Prefix discovery URL with DEVMODE if in development."""
|
42
|
-
if
|
75
|
+
if info.data.get("environment") == "development":
|
43
76
|
return f"DEVMODE-{v}"
|
44
77
|
return v
|
45
78
|
|
@@ -63,7 +96,7 @@ class RequestorConfig(BaseSettings):
|
|
63
96
|
|
64
97
|
# Base Directory
|
65
98
|
base_dir: Path = Field(
|
66
|
-
default_factory=lambda: Path.home() / ".golem",
|
99
|
+
default_factory=lambda: Path.home() / ".golem" / "requestor",
|
67
100
|
description="Base directory for all Golem requestor files"
|
68
101
|
)
|
69
102
|
|
@@ -86,10 +119,10 @@ class RequestorConfig(BaseSettings):
|
|
86
119
|
|
87
120
|
# Set dependent paths before validation
|
88
121
|
if 'ssh_key_dir' not in kwargs:
|
89
|
-
base_dir = kwargs.get('base_dir', Path.home() / ".golem")
|
122
|
+
base_dir = kwargs.get('base_dir', Path.home() / ".golem" / "requestor")
|
90
123
|
kwargs['ssh_key_dir'] = base_dir / "ssh"
|
91
124
|
if 'db_path' not in kwargs:
|
92
|
-
base_dir = kwargs.get('base_dir', Path.home() / ".golem")
|
125
|
+
base_dir = kwargs.get('base_dir', Path.home() / ".golem" / "requestor")
|
93
126
|
kwargs['db_path'] = base_dir / "vms.db"
|
94
127
|
super().__init__(**kwargs)
|
95
128
|
|
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
|
{request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/services/database_service.py
RENAMED
File without changes
|
{request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/services/provider_service.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|