...
This commit is contained in:
91
_archive/openrpc/factory_model.py
Normal file
91
_archive/openrpc/factory_model.py
Normal file
@@ -0,0 +1,91 @@
|
||||
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)
|
Reference in New Issue
Block a user