Skip to main content

Rainbow Python Flow Manager

Project description

rb_flow_manager 사용 설명서

rb_flow_managerStep 트리를 멀티프로세스로 실행하고, 실행 상태/일시정지/재개/중지 제어를 제공하는 워크플로우 엔진입니다.

1. 핵심 구성요소

  • Step 계열 (step.py)
    • 기본: Step
    • 제어 구조: FolderStep, RepeatStep, ConditionStep, BreakStep, JumpToStep
    • 고급: SubTaskStep, CallEventStep, SyncStep
  • 실행기: ScriptExecutor (executor.py)
    • 다중 프로세스 실행
    • 상태 조회/제어 API 제공
  • 컨트롤러 인터페이스: BaseController
    • 실행 이벤트 훅(on_start, on_pause, on_error 등) 구현 가능
  • 기본 컨트롤러 구현 예시: Zenoh_Controller

2. 최소 실행 예제

from rb_flow_manager.step import Step
from rb_flow_manager.executor import ScriptExecutor
from rb_flow_manager.schema import MakeProcessArgs

def hello_step():
    print("hello step")

root = Step(
    step_id="root",
    name="Root",
    children=[
        Step(step_id="s1", name="Hello", func=hello_step),
    ],
)

executor = ScriptExecutor()

args: MakeProcessArgs = {
    "process_id": "script_1",
    "step": root,
    "repeat_count": 1,
    "robot_model": "C500920",
    "category": "manipulate",
    "step_mode": False,
    "min_step_interval": 0.0,
    "is_ui_execution": False,
    "post_tree": None,
    "parent_process_id": None,
    "event_sub_tree_list": [],
}

executor.start(args)
executor.wait_all()
print(executor.get_all_states())

3. Step 작성 방식

Step는 두 방식으로 함수 실행을 지원합니다.

  • 직접 함수 연결
    • func=<callable>
  • 문자열 함수명 방식
    • func_name="rb_manipulate_sdk.point"
    • 런타임에 import/호출

또한 args를 통해 스텝 인자를 전달하고, children으로 트리를 구성합니다.

4. 실행 제어 API

ScriptExecutor 주요 메서드:

  • start(args: MakeProcessArgs | list[MakeProcessArgs]) -> bool
  • pause(process_id: str) -> bool
  • resume(process_id: str) -> bool
  • stop(process_id: str) -> bool
  • wait_all(timeout: float | None = None) -> bool
  • get_all_states() -> dict[str, dict]

5. 상태 모델

RB_Flow_Manager_ProgramState:

  • IDLE
  • RUNNING
  • PAUSED
  • WAITING
  • STOPPED
  • POST_START
  • COMPLETED
  • ERROR

각 프로세스별 상세 실행 상태는 ExecutorState TypedDict 구조로 관리됩니다.

6. 컨트롤러 연동

커스텀 컨트롤러를 사용하려면 BaseController를 구현한 뒤 ScriptExecutor(controller=...)로 전달합니다.

from rb_flow_manager.controller.base_controller import BaseController

class MyController(BaseController):
    def on_init(self, state_dicts): ...
    def on_start(self, task_id): ...
    def on_stop(self, task_id, step_id): ...
    def on_pause(self, task_id, step_id): ...
    def on_wait(self, task_id, step_id): ...
    def on_resume(self, task_id, step_id): ...
    def on_next(self, task_id, step_id): ...
    def on_sub_task_start(self, task_id, sub_task_id, sub_task_type): ...
    def on_sub_task_done(self, task_id, sub_task_id, sub_task_type): ...
    def on_done(self, task_id, step_id): ...
    def on_error(self, task_id, step_id, error): ...
    def on_post_start(self, task_id): ...
    def on_complete(self, task_id): ...
    def on_close(self): ...
    def on_all_complete(self): ...
    def on_all_stop(self): ...
    def on_all_pause(self): ...
    def on_all_wait(self): ...
    def on_all_resume(self): ...

7. 실무 팁

  • process_id는 서비스 내에서 유일하게 관리하세요.
  • 긴 실행 트리는 min_step_interval을 사용해 과도한 호출을 방지하세요.
  • 다중 트리 병렬 실행 시 start([...]) 형태를 사용하면 일괄 시작 제어가 쉽습니다.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

rainbow_rb_flow_manager-0.0.9.dev14.tar.gz (43.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

rainbow_rb_flow_manager-0.0.9.dev14-py3-none-any.whl (46.7 kB view details)

Uploaded Python 3

File details

Details for the file rainbow_rb_flow_manager-0.0.9.dev14.tar.gz.

File metadata

File hashes

Hashes for rainbow_rb_flow_manager-0.0.9.dev14.tar.gz
Algorithm Hash digest
SHA256 7999b97321f303954f2c9a11519f4f6996d3dd0e6d8fbf4f22a27d9c13bb97d9
MD5 97b7f71731ec1470c581e72f27ec71ad
BLAKE2b-256 2d20454d8e0d1d0c35b022db5ad212930052aa84c16fdac9a07681e6ef72555f

See more details on using hashes here.

File details

Details for the file rainbow_rb_flow_manager-0.0.9.dev14-py3-none-any.whl.

File metadata

File hashes

Hashes for rainbow_rb_flow_manager-0.0.9.dev14-py3-none-any.whl
Algorithm Hash digest
SHA256 21e300e358ff7ed7112f6a465f597e12f4b4d0c43b870911e171d1eaa5173775
MD5 1a8af8c225e15cc133df7adcde0aff47
BLAKE2b-256 ed2f274bb8ca532e579b402a5dfb57077974fad0aa62dcaadf7c84d2909fb415

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page