ff1ede47a0
* refactor: overhaul workflow and chat architecture - Separate Chat and Workflow API endpoints and database models - Use JSONB to store workflow execution context in Postgres - Convert workflow engine to use pydantic-ai execution graphs inside a Ray task - Update frontend React components to support standalone workflow creation - Remove obsolete and broken workflow runner tests Co-authored-by: zhaoxi826 <198742034+zhaoxi826@users.noreply.github.com> * refactor: overhaul workflow and chat architecture - Separate Chat and Workflow API endpoints and database models - Use JSONB to store workflow execution context in Postgres - Convert workflow engine to use pydantic-ai execution graphs inside a Ray task - Update frontend React components to support standalone workflow creation - Remove obsolete and broken workflow runner tests Co-authored-by: zhaoxi826 <198742034+zhaoxi826@users.noreply.github.com> * refactor: overhaul workflow and chat architecture - Separate Chat and Workflow API endpoints and database models - Use JSONB to store workflow execution context in Postgres - Convert workflow engine to use pydantic-ai execution graphs inside a Ray task - Update frontend React components to support standalone workflow creation - Move workflow_engine inside workflow package to keep core root clean - Remove obsolete and broken workflow runner tests Co-authored-by: zhaoxi826 <198742034+zhaoxi826@users.noreply.github.com> --------- Co-authored-by: google-labs-jules[bot] <161369871+google-labs-jules[bot]@users.noreply.github.com> Co-authored-by: zhaoxi826 <198742034+zhaoxi826@users.noreply.github.com>
44 lines
1.8 KiB
Python
44 lines
1.8 KiB
Python
# Copyright 2026 zhaoxi826
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
from typing import List, Optional
|
|
from sqlalchemy import String, Text, Boolean, text
|
|
from sqlalchemy.dialects.postgresql import JSONB # 针对供应商模型列表优化
|
|
from sqlalchemy.orm import Mapped, mapped_column
|
|
from .base import BaseDataModel
|
|
|
|
|
|
class ProviderModel(BaseDataModel):
|
|
"""
|
|
Provider 物理模型。
|
|
作为模型/服务提供商适配器,标准化不同供应商(OpenAI, Anthropic 等)的配置。
|
|
"""
|
|
|
|
__tablename__ = "provider"
|
|
provider_id: Mapped[str] = mapped_column(String(64), primary_key=True)
|
|
provider_title: Mapped[str] = mapped_column(String(100), index=True, nullable=False)
|
|
provider_type: Mapped[str] = mapped_column(String(50), nullable=False)
|
|
provider_url: Mapped[Optional[str]] = mapped_column(Text)
|
|
provider_apikey: Mapped[Optional[str]] = mapped_column(Text)
|
|
provider_models: Mapped[List[str]] = mapped_column(
|
|
JSONB, default=list, server_default=text("'[]'::jsonb")
|
|
)
|
|
provider_owner: Mapped[str] = mapped_column(String(64), index=True)
|
|
is_active: Mapped[bool] = mapped_column(
|
|
Boolean,
|
|
default=True,
|
|
server_default=text("true"),
|
|
comment="该服务商节点是否在线/启用",
|
|
)
|