herolib_python/_archive/openrpc/factory_model.py
2025-08-05 15:15:36 +02:00

92 lines
3.4 KiB
Python

import os
from pathlib import Path
from typing import Dict, Optional
from heroserver.openrpc.factory import openrpc_dict, openrpc_spec, openrpc_spec_write
from heroserver.openrpc.model.openrpc_spec import OpenRPCSpec
class OpenRPCFactory:
def __init__(self, generation_path: str, spec_path: str):
"""
Initialize the OpenRPCFactory with a generation path and a spec path.
:param generation_path: The path where the generation will occur.
:param spec_path: The path to the OpenRPC specification (in vlang format).
"""
import os.path
self.actors: Dict[str, OpenRPCActor] = {}
self.generation_path: str = os.path.expanduser(generation_path)
self.spec_path: str = os.path.expanduser(spec_path)
def add_actor(self, actor: "OpenRPCActor"):
self.actors[actor.name] = actor
def get_actor(self, name: str) -> Optional["OpenRPCActor"]:
return self.actors.get(name)
def remove_actor(self, name: str) -> None:
self.actors.pop(name, None)
def scan(self):
for subdir in os.listdir(self.spec_path):
subdir_path = os.path.join(self.spec_path, subdir)
if os.path.isdir(subdir_path):
actor = OpenRPCActor(name=subdir, path_ourspec=subdir_path, parent=self)
self.add_actor(actor)
class OpenRPCActor:
def __init__(self, name: str, path_ourspec: str, parent: OpenRPCFactory):
self.name: str = name
self.path_ourspec: str = path_ourspec # the directory where we parse & generate
self.path_openrpc: str = os.path.join(parent.generation_path, self.name) # the file which represents openrpc spec
self.parent = parent
self.openrpc_spec: OpenRPCSpec = openrpc_spec(path=path_ourspec)
def openrpc_dict(self) -> dict:
return openrpc_dict(path=self.path_ourspec)
def openrpc_spec_write(self) -> dict:
return openrpc_spec_write(path=self.path_ourspec, dest=self.path_openrpc)
def openrpc_spec_yaml_path(self) -> str:
yaml_path = os.path.join(self.path_openrpc, "openrpc_spec.yaml")
if not os.path.exists(yaml_path):
self.openrpc_spec_write()
return yaml_path
def openrpc_spec_json_path(self) -> str:
json_path = os.path.join(self.path_openrpc, "openrpc_spec.json")
if not os.path.exists(json_path):
self.openrpc_spec_write()
return json_path
def generate_rest_server(self):
from heroserver.openrpc.generator.rest_server.python.rest_server_generator import RestServerGenerator
rest_server_generator = RestServerGenerator(self.openrpc_spec, Path(self.path_openrpc))
rest_server_generator.generate()
def new(generation_path: str, spec_path: str) -> OpenRPCFactory:
"""
Create a new OpenRPCFactory and return OpenRPCActors, starting from a path.
:param generation_path: The path where the generation will occur.
:param spec_path: The path to the OpenRPC specification.
:return: An instance of OpenRPCFactory with actors initialized.
"""
factory = OpenRPCFactory(generation_path=generation_path, spec_path=spec_path)
factory.scan()
return factory
# Usage example:
# spec = OpenRPCSpec(...) # Create an OpenRPCSpec instance
# actor = OpenRPCActor("MyActor", "/path/to/actor", spec, "/path/to/openrpc.json")
# actors = OpenRPCActors()
# actors.add_actor(actor)