feat: all models

This commit is contained in:
TheNoxium
2025-09-26 14:59:59 +05:00
parent 5bae8b41b2
commit 8e01072ff6
26 changed files with 1464 additions and 119 deletions

View File

@@ -1,18 +1,71 @@
from typing import Dict, Any
from core import VorkNode
from core.form_descriptors import get_form_descriptor
from model_nodes.node_trigger_models import (
TriggerNodeData,
TriggerNodeLinks,
TriggerNodeCoreSchema,
TriggerNodeCoreSchemaData
)
class VorkNodeTrigger(VorkNode):
def __init__(self, data: Dict[str, Any], links: Dict[str, Any] = None):
"""
Инициализация узла trigger
"""
super().__init__(data, links or {})
@property
def id(self) -> str:
return "node_trigger"
return "TRIGGER"
@classmethod
def form(cls):
pass
def form(cls) -> Dict[str, Any]:
"""
Возвращает статический дескриптор формы для узла Trigger
"""
return get_form_descriptor("TRIGGER")
def validate(self) -> bool:
return True
def validate(self) -> TriggerNodeCoreSchema:
"""
Валидирует данные узла trigger и возвращает схему
"""
try:
# Валидируем данные узла
validated_data = self.validate_data()
# Валидируем связи узла
validated_links = self.validate_links()
node_data = TriggerNodeCoreSchemaData(
then_port_number=0
)
# Создаем схему с валидированными данными
return TriggerNodeCoreSchema(
ps_id=validated_data.ps_id,
node_type=validated_data.node_type,
parent_id=validated_links.parent_id,
parent_port_number=validated_links.parent_port_number,
data=node_data
)
except Exception as e:
print(f"Trigger node validation error: {e}")
raise
def validate_data(self) -> TriggerNodeData:
"""
Валидирует данные узла trigger
"""
return TriggerNodeData(**self.data)
def validate_links(self) -> TriggerNodeLinks:
"""
Валидирует связи узла trigger
"""
return TriggerNodeLinks(**self.links)
def process(self, context):
pass