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.
Files changed (23) hide show
  1. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/PKG-INFO +1 -1
  2. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/pyproject.toml +1 -1
  3. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/cli/commands.py +2 -1
  4. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/config.py +44 -11
  5. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/README.md +0 -0
  6. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/__init__.py +0 -0
  7. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/api/main.py +0 -0
  8. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/cli/__init__.py +0 -0
  9. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/db/__init__.py +0 -0
  10. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/db/sqlite.py +0 -0
  11. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/errors.py +0 -0
  12. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/provider/__init__.py +0 -0
  13. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/provider/client.py +0 -0
  14. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/run.py +0 -0
  15. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/services/__init__.py +0 -0
  16. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/services/database_service.py +0 -0
  17. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/services/provider_service.py +0 -0
  18. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/services/ssh_service.py +0 -0
  19. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/services/vm_service.py +0 -0
  20. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/ssh/__init__.py +0 -0
  21. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/ssh/manager.py +0 -0
  22. {request_vm_on_golem-0.1.36 → request_vm_on_golem-0.1.37}/requestor/utils/logging.py +0 -0
  23. {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
  Metadata-Version: 2.3
2
2
  Name: request-vm-on-golem
3
- Version: 0.1.36
3
+ Version: 0.1.37
4
4
  Summary: VM on Golem Requestor CLI - Create and manage virtual machines on the Golem Network
5
5
  Keywords: golem,vm,cloud,decentralized,cli
6
6
  Author: Phillip Jensen
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "request-vm-on-golem"
3
- version = "0.1.36"
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, validator
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
- class Config:
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
- @validator("discovery_url", always=True)
40
- def set_discovery_url(cls, v: str, values: dict) -> str:
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 values.get("environment") == "development":
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