메인 콘텐츠로 건너뛰기

경로

서버는 getpost 메소드의 일련을 정의하며, 이는 server.py에서 @routes를 검색하여 찾을 수 있습니다. 웹 클라이언트에서 워크플로우를 제출하면 /prompt로 게시되며, 이는 프롬프트를 검증하고 실행 대기열에 추가한 후 prompt_id와 번호(대기열 내 위치) 또는 검증 실패 시 errornode_errors를 반환합니다. 프롬프트 대기열은 execution.py에 정의되어 있으며, 여기에는 PromptExecutor 클래스도 포함됩니다.

기본 제공 경로

server.py는 다음과 같은 경로를 정의합니다:

핵심 API 경로

경로get/post/ws목적
/get컴피 웹페이지 로드
/wswebsocket서버와 실시간 통신을 위한 WebSocket 엔드포인트
/embeddingsget사용 가능한 임베딩 이름 목록 조회
/extensionsgetWEB_DIRECTORY를 등록하는 확장 프로그램 목록 조회
/featuresget서버 기능 및 역량 조회
/modelsget사용 가능한 모델 유형 목록 조회
/models/{folder}get특정 폴더의 모델 조회
/workflow_templatesget맞춤 노드 모듈과 관련 템플릿 워크플로우 맵 조회
/upload/imagepost이미지 업로드
/upload/maskpost마스크 업로드
/viewget이미지 보기. 다양한 옵션 참조, server.py@routes.get("/view") 확인
/view_metadata/get모델의 메타데이터 조회
/system_statsget시스템 정보 조회 (파이썬 버전, 장치, VRAM 등)
/promptget현재 대기열 상태 및 실행 정보 조회
/promptpost프롬프트를 대기열에 제출
/object_infoget모든 노드 유형의 세부 정보 조회
/object_info/{node_class}get특정 노드 유형의 세부 정보 조회
/historyget대기열의 이력 조회
/history/{prompt_id}get특정 프롬프트의 대기열 이력 조회
/historypost이력을 지우거나 이력 항목 삭제
/queueget현재 실행 대기열 상태 조회
/queuepost대기열 작업 관리 (대기/실행 중인 작업 지우기)
/interruptpost현재 워크플로우 실행 중단
/freepost특정 모델 언로드로 메모리 해제
/userdataget지정된 디렉터리의 사용자 데이터 파일 목록 조회
/v2/userdataget구조화된 형식으로 파일 및 디렉터리를 나열하는 강화된 버전
/userdata/{file}get특정 사용자 데이터 파일 조회
/userdata/{file}post사용자 데이터 파일 업로드 또는 업데이트
/userdata/{file}delete특정 사용자 데이터 파일 삭제
/userdata/{file}/move/{dest}post사용자 데이터 파일 이동 또는 이름 변경
/usersget사용자 정보 조회
/userspost새 사용자 생성 (다중 사용자 모드만 가능)

WebSocket 통신

/ws 엔드포인트는 클라이언트와 서버 간의 양방향 실시간 통신을 제공합니다. 이는 다음을 위해 사용됩니다:
  • 실행 진행 상황 업데이트 수신
  • 노드 실행 상태 실시간 조회
  • 오류 메시지 및 디버깅 정보 수신
  • 대기열 상태 변경 시 라이브 업데이트
WebSocket 연결은 다음과 같은 유형의 JSON 메시지를 전송합니다:
  • status - 전체 시스템 상태 업데이트
  • execution_start - 프롬프트 실행 시작 시
  • execution_cached - 캐시된 결과 사용 시
  • executing - 노드 실행 중 업데이트
  • progress - 장시간 실행 작업의 진행률 업데이트
  • executed - 노드 실행 완료 시

맞춤 경로

실행 중 클라이언트에서 서버로 메시지를 보내고 싶다면 서버에 맞춤 경로를 추가해야 합니다. 복잡한 경우 aiohttp 프레임워크 문서를 살펴봐야 하지만, 대부분의 경우 다음과 같이 처리할 수 있습니다:
from server import PromptServer
from aiohttp import web
routes = PromptServer.instance.routes
@routes.post('/my_new_path')
async def my_function(request):
    the_data = await request.post()
    # the_data는 이제 전송된 값들의 딕셔너리를 담고 있습니다
    MyClass.handle_my_message(the_data)
    return web.json_response({})
무엇을 하는지 잘 알고 있지 않다면, 클래스 내부에 my_function을 정의하지 마세요.
@routes.post 데코레이터는 많은 작업을 수행합니다! 대신 위와 같이 함수를 정의한 후 클래스 메서드를 호출하세요.
변경하지 않는다면 @routes.get도 정의할 수 있습니다.
클라이언트는 다음과 같은 코드와 같은 FormData 객체를 보내면 새로운 경로를 사용할 수 있으며, 이는 위 코드에서 the_datamessagenode_id 키를 포함하게 됩니다:
import { api } from "../../scripts/api.js";
function send_message(node_id, message) {
    const body = new FormData();
    body.append('message', message);
    body.append('node_id', node_id);
    api.fetchApi("/my_new_path", { method: "POST", body, });
}