golem-vm-provider 0.1.33__py3-none-any.whl → 0.1.35__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.
- {golem_vm_provider-0.1.33.dist-info → golem_vm_provider-0.1.35.dist-info}/METADATA +5 -4
- {golem_vm_provider-0.1.33.dist-info → golem_vm_provider-0.1.35.dist-info}/RECORD +6 -6
- provider/api/routes.py +23 -0
- provider/vm/service.py +7 -0
- {golem_vm_provider-0.1.33.dist-info → golem_vm_provider-0.1.35.dist-info}/WHEEL +0 -0
- {golem_vm_provider-0.1.33.dist-info → golem_vm_provider-0.1.35.dist-info}/entry_points.txt +0 -0
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.3
|
2
2
|
Name: golem-vm-provider
|
3
|
-
Version: 0.1.
|
3
|
+
Version: 0.1.35
|
4
4
|
Summary: VM on Golem Provider Node - Run your own provider node to offer VMs on the Golem Network
|
5
5
|
Keywords: golem,vm,provider,cloud,decentralized
|
6
6
|
Author: Phillip Jensen
|
@@ -271,10 +271,11 @@ Response:
|
|
271
271
|
- List VMs: `GET /api/v1/vms`
|
272
272
|
- Get VM Status: `GET /api/v1/vms/{vm_id}`
|
273
273
|
- Delete VM: `DELETE /api/v1/vms/{vm_id}`
|
274
|
+
- Stop VM: `POST /api/v1/vms/{vm_id}/stop`
|
274
275
|
- Get Access Info: `GET /api/v1/vms/{vm_id}/access`
|
275
|
-
|
276
|
-
## Operations
|
277
|
-
|
276
|
+
|
277
|
+
## Operations
|
278
|
+
|
278
279
|
### Starting the Provider
|
279
280
|
|
280
281
|
```bash
|
@@ -1,7 +1,7 @@
|
|
1
1
|
provider/__init__.py,sha256=HO1fkPpZqPO3z8O8-eVIyx8xXSMIVuTR_b1YF0RtXOg,45
|
2
2
|
provider/api/__init__.py,sha256=ssX1ugDqEPt8Fn04IymgmG-Ev8PiXLsCSaiZVvHQnec,344
|
3
3
|
provider/api/models.py,sha256=hTQYzVZHJ-SD_pIpoV0KbPUghR-PUY9YKyUlETstwuQ,3567
|
4
|
-
provider/api/routes.py,sha256=
|
4
|
+
provider/api/routes.py,sha256=7k-RJjig79_4BDQxCBxcUPrCqVSWyRYKKQFCMPqOVpc,6365
|
5
5
|
provider/config.py,sha256=9POtsNbRYDcVW1XGTv6szosKOR5h-41-lHXnJ2_5coM,17856
|
6
6
|
provider/container.py,sha256=u8A1FuG2targtBBqQlSiPW1yCTOm1tbrRQh8sIHstiM,2442
|
7
7
|
provider/discovery/__init__.py,sha256=Y6o8RxGevBpuQS3k32y-zSVbP6HBXG3veBl9ElVPKaU,349
|
@@ -31,8 +31,8 @@ provider/vm/name_mapper.py,sha256=14nKfCjJ1WkXfC4vnCYIxNGQUwcl2vcxrJYUAz4fL40,40
|
|
31
31
|
provider/vm/port_manager.py,sha256=iYSwjTjD_ziOhG8aI7juKHw1OwwRUTJQyQoRUNQvz9w,12514
|
32
32
|
provider/vm/provider.py,sha256=A7QN89EJjcSS40_SmKeinG1Jp_NGffJaLse-XdKciAs,1164
|
33
33
|
provider/vm/proxy_manager.py,sha256=n4NTsyz2rtrvjtf_ceKBk-g2q_mzqPwruB1q7UlQVBc,14928
|
34
|
-
provider/vm/service.py,sha256=
|
35
|
-
golem_vm_provider-0.1.
|
36
|
-
golem_vm_provider-0.1.
|
37
|
-
golem_vm_provider-0.1.
|
38
|
-
golem_vm_provider-0.1.
|
34
|
+
provider/vm/service.py,sha256=4ypVtFeeaG-yYbjoqwunvcbbtrHQExzuu_w8_fiYHX8,3943
|
35
|
+
golem_vm_provider-0.1.35.dist-info/METADATA,sha256=EEHcyl-JT7UseAvZbk3UdYSMoHyVbLOyTs6-PzTYeKI,10943
|
36
|
+
golem_vm_provider-0.1.35.dist-info/WHEEL,sha256=b4K_helf-jlQoXBBETfwnf4B04YC67LOev0jo4fX5m8,88
|
37
|
+
golem_vm_provider-0.1.35.dist-info/entry_points.txt,sha256=iFUajRxfViYkFcPMPv2EIjYm-BLOp86LJj_IjCwwZUw,74
|
38
|
+
golem_vm_provider-0.1.35.dist-info/RECORD,,
|
provider/api/routes.py
CHANGED
@@ -122,6 +122,29 @@ async def get_vm_access(
|
|
122
122
|
raise HTTPException(status_code=500, detail="An unexpected error occurred")
|
123
123
|
|
124
124
|
|
125
|
+
@router.post("/vms/{requestor_name}/stop")
|
126
|
+
@inject
|
127
|
+
async def stop_vm(
|
128
|
+
requestor_name: str,
|
129
|
+
vm_service: VMService = Depends(Provide[Container.vm_service]),
|
130
|
+
) -> None:
|
131
|
+
"""Stop a VM."""
|
132
|
+
try:
|
133
|
+
logger.process(f"🛑 Stopping VM '{requestor_name}'")
|
134
|
+
await vm_service.stop_vm(requestor_name)
|
135
|
+
vm_status_change(requestor_name, "STOPPED", "VM stopped")
|
136
|
+
logger.success(f"✨ Successfully stopped VM '{requestor_name}'")
|
137
|
+
except VMNotFoundError as e:
|
138
|
+
logger.error(f"VM not found: {e}")
|
139
|
+
raise HTTPException(status_code=404, detail=str(e))
|
140
|
+
except MultipassError as e:
|
141
|
+
logger.error(f"Failed to stop VM: {e}")
|
142
|
+
raise HTTPException(status_code=500, detail=str(e))
|
143
|
+
except Exception as e:
|
144
|
+
logger.error(f"An unexpected error occurred: {e}")
|
145
|
+
raise HTTPException(status_code=500, detail="An unexpected error occurred")
|
146
|
+
|
147
|
+
|
125
148
|
@router.delete("/vms/{requestor_name}")
|
126
149
|
@inject
|
127
150
|
async def delete_vm(
|
provider/vm/service.py
CHANGED
@@ -69,6 +69,13 @@ class VMService:
|
|
69
69
|
finally:
|
70
70
|
await self.name_mapper.remove_mapping(vm_id)
|
71
71
|
|
72
|
+
async def stop_vm(self, vm_id: str) -> None:
|
73
|
+
"""Stop a VM."""
|
74
|
+
multipass_name = await self.name_mapper.get_multipass_name(vm_id)
|
75
|
+
if not multipass_name:
|
76
|
+
raise VMNotFoundError(f"VM {vm_id} not found")
|
77
|
+
await self.provider.stop_vm(multipass_name)
|
78
|
+
|
72
79
|
async def list_vms(self) -> List[VMInfo]:
|
73
80
|
"""List all VMs."""
|
74
81
|
return await self.provider.list_vms()
|
File without changes
|
File without changes
|