228 lines
11 KiB
Thrift
228 lines
11 KiB
Thrift
include "../../base.thrift"
|
|
|
|
namespace go ocean.cloud.workflow
|
|
|
|
enum FrontedTagType {
|
|
TEXT = 0 // 文本
|
|
TIME = 1 // 时间,用时间戳,单位是毫秒
|
|
TIME_DURATION = 2 // 时间间隔,单位是毫秒
|
|
}
|
|
|
|
// Tag
|
|
struct TraceTag {
|
|
1: string Key (go.tag = "json:\"key\"", agw.key = "key")
|
|
2: TagType TagType (go.tag = "json:\"tag_type\"", agw.key = "tag_type")
|
|
3: Value Value (go.tag = "json:\"value\"", agw.key = "value")
|
|
}
|
|
|
|
struct FilterTag {
|
|
1: optional string DataType (go.tag = "json:\"data_type\"", agw.key = "data_type")
|
|
2: optional string TagKey (go.tag = "json:\"tag_key\"", agw.key = "tag_key")
|
|
3: optional list<string> MultiTagKeys (go.tag = "json:\"multi_tag_keys\"", agw.key = "multi_tag_keys")
|
|
4: optional list<string> Values (go.tag = "json:\"values\"", agw.key = "values")
|
|
5: optional QueryTypeEnum QueryType (go.tag = "json:\"query_type\"", agw.key = "query_type")
|
|
}
|
|
|
|
enum QueryTypeEnum {
|
|
Undefined = 0
|
|
Match = 1
|
|
Term = 2
|
|
Range = 3
|
|
Exist = 4
|
|
NotExist = 5
|
|
}
|
|
|
|
enum SpanStatus{
|
|
Unknown = 0
|
|
Success = 1
|
|
Fail = 2
|
|
}
|
|
|
|
struct ListRootSpansRequest {
|
|
2: required i64 StartAt (go.tag = "json:\"start_at\"", api.body = "start_at") // 单位是毫秒
|
|
3: required i64 EndAt (go.tag = "json:\"end_at\"", api.body = "end_at") // 单位是毫秒
|
|
4: optional i16 Limit (go.tag = "json:\"limit\"", api.body = "limit")
|
|
5: optional bool DescByStartTime (go.tag = "json:\"desc_by_start_time\"", api.body = "desc_by_start_time")
|
|
6: optional i32 Offset (go.tag = "json:\"offset\"", api.body = "offset")
|
|
7: required string WorkflowID(go.tag = "json:\"workflow_id\"", api.body = "workflow_id")
|
|
8: optional string Input(go.tag = "json:\"input\"", api.body = "input")
|
|
9: optional SpanStatus Status(go.tag = "json:\"status\"", api.body = "status")
|
|
10: optional i32 ExecuteMode (go.tag = "json:\"execute_mode\"", api.body = "execute_mode") // 正式运行/试运行/节点Debug
|
|
|
|
255: optional base.Base Base
|
|
}
|
|
|
|
struct Span {
|
|
1: string TraceID (go.tag = "json:\"trace_id\"", agw.key = "trace_id")
|
|
2: string LogID (go.tag = "json:\"log_id\"", agw.key = "log_id")
|
|
3: string PSM (go.tag = "json:\"psm\"", agw.key = "psm")
|
|
4: string DC (go.tag = "json:\"dc\"", agw.key = "dc")
|
|
5: string PodName (go.tag = "json:\"pod_name\"", agw.key = "pod_name")
|
|
6: string SpanID (go.tag = "json:\"span_id\"", agw.key = "span_id")
|
|
7: string Type (go.tag = "json:\"type\"", agw.key = "type")
|
|
8: string Name (go.tag = "json:\"name\"", agw.key = "name")
|
|
9: string ParentID (go.tag = "json:\"parent_id\"", agw.key = "parent_id")
|
|
10: i64 Duration (go.tag = "json:\"duration\"", agw.key = "duration") // 单位是毫秒
|
|
11: i64 StartTime (go.tag = "json:\"start_time\"", agw.key = "start_time") // 单位是毫秒
|
|
12: i32 StatusCode (go.tag = "json:\"status_code\"", agw.key = "status_code")
|
|
13: list<TraceTag> Tags (go.tag = "json:\"tags\"", agw.key = "tags")
|
|
}
|
|
|
|
struct Value {
|
|
1: optional string VStr (go.tag = "json:\"v_str\"", agw.key = "v_str")
|
|
2: optional double VDouble (go.tag = "json:\"v_double\"", agw.key = "v_double")
|
|
3: optional bool VBool (go.tag = "json:\"v_bool\"", agw.key = "v_bool")
|
|
4: optional i64 VLong (go.tag = "json:\"v_long\"", agw.key = "v_long")
|
|
5: optional binary VBytes (go.tag = "json:\"v_bytes\"", agw.key = "v_bytes")
|
|
}
|
|
|
|
enum TagType {
|
|
STRING = 0
|
|
DOUBLE = 1
|
|
BOOL = 2
|
|
LONG = 3
|
|
BYTES = 4
|
|
}
|
|
|
|
struct ListRootSpansResponse {
|
|
1: optional list<Span> Spans (go.tag = "json:\"spans\"", api.body = "spans")
|
|
|
|
255: optional base.BaseResp BaseResp
|
|
}
|
|
|
|
|
|
struct GetTraceSDKRequest {
|
|
2: optional string LogID (go.tag = "json:\"log_id\"", api.query = "log_id")
|
|
4: optional i64 StartAt (go.tag = "json:\"start_at\"", api.query = "start_at") // 单位是毫秒
|
|
5: optional i64 EndAt (go.tag = "json:\"end_at\"", api.query = "end_at") // 单位是毫秒
|
|
6: optional i64 WorkflowID (go.tag = "json:\"workflow_id\"", api.query = "workflow_id")
|
|
7: optional i64 ExecuteID (go.tag = "json:\"execute_id\"", api.query = "execute_id")
|
|
|
|
255: optional base.Base Base
|
|
}
|
|
|
|
enum QueryScene {
|
|
ALICE_OP = 0 // doubao cici 全链路调试台
|
|
DOUBAO_CICI_DEBUG = 1 // doubao cici debug 功能
|
|
WORKFLOW_DEBUG = 2 // workflow debug 功能
|
|
}
|
|
|
|
enum TenantLevel {
|
|
Ordinary = 0
|
|
AdvancedWhitelist = 1
|
|
}
|
|
|
|
struct GetTraceSDKResponse {
|
|
1: optional TraceFrontend data
|
|
255: optional base.BaseResp BaseResp
|
|
}
|
|
|
|
|
|
struct KeyScene {
|
|
1: optional string Scene (go.tag = "json:\"scene\"", agw.key = "scene") // 场景,如"拆分搜索词"\"搜索"
|
|
2: optional string StatusMessage (go.tag = "json:\"status_message\"", agw.key = "status_message") // 状态信息
|
|
3: optional string System (go.tag = "json:\"system\"", agw.key = "system")
|
|
4: optional list<MessageItem> HistoryMessages (go.tag = "json:\"history_messages\"", agw.key = "history_messages") // 历史消息
|
|
5: optional KeySceneInput Input (go.tag = "json:\"input\"", agw.key = "input") // 输入
|
|
6: optional KeySceneOutput Output (go.tag = "json:\"output\"", agw.key = "output") // 输出
|
|
7: optional i64 Duration (go.tag = "json:\"duration\"", agw.key = "duration") // 单位是毫秒
|
|
8: optional i64 StartTime (go.tag = "json:\"start_time\"", api.body = "start_time") // 开始时间,用于排序,单位是毫秒
|
|
9: optional list<KeyScene> SubKeyScenes (go.tag = "json:\"sub_key_scenes\"", agw.key = "sub_key_scenes") // 子场景
|
|
}
|
|
|
|
struct KeySceneInput {
|
|
1: optional string Role (go.tag = "json:\"role\"", agw.key = "role")
|
|
2: optional list<TraceSummaryContent> contentList (go.tag = "json:\"content_list\"", agw.key = "content_list")
|
|
}
|
|
|
|
struct KeySceneOutput {
|
|
1: optional string Role (go.tag = "json:\"role\"", agw.key = "role")
|
|
2: optional list<TraceSummaryContent> contentList (go.tag = "json:\"content_list\"", agw.key = "content_list")
|
|
}
|
|
|
|
struct TraceSummaryContent {
|
|
1: optional string Key (go.tag = "json:\"key\"", agw.key = "key") // 键
|
|
2: optional string Content (go.tag = "json:\"content\"", agw.key = "content") // 内容
|
|
}
|
|
|
|
struct MessageItem {
|
|
1: optional string Role (go.tag = "json:\"role\"", agw.key = "role") // 角色
|
|
2: optional string Content (go.tag = "json:\"content\"", agw.key = "content") // 内容
|
|
}
|
|
|
|
struct SpanSummary {
|
|
1: optional list<FrontendTag> Tags (go.tag = "json:\"tags\"", agw.key = "tags")
|
|
}
|
|
|
|
|
|
struct FrontendTag {
|
|
1: required string Key (go.tag = "json:\"key\"", agw.key = "key")
|
|
2: optional string KeyAlias (go.tag = "json:\"key_alias\"", agw.key = "key_alias") // 多语,如无配置时值沿用 key
|
|
3: required TagType TagType (go.tag = "json:\"tag_type\"", agw.key = "tag_type")
|
|
4: optional Value Value (go.tag = "json:\"value\"", agw.key = "value")
|
|
5: optional FrontedTagType FrontendTagType (go.tag = "json:\"frontend_tag_type\"", agw.key = "frontend_tag_type") // 前端类型,用于前端处理
|
|
6: optional bool canCopy (go.tag = "json:\"can_copy\"", agw.key = "can_copy") // 是否可复制
|
|
}
|
|
|
|
|
|
struct TraceSummary{
|
|
1: optional string System (go.tag = "json:\"system\"", agw.key = "system") // 一级 System 的文本
|
|
2: optional list<MessageItem> HistoryMessages (go.tag = "json:\"history_messages\"", agw.key = "history_messages") // 一级历史消息
|
|
3: optional list<KeyScene> KeyScenes (go.tag = "json:\"key_scenes\"", agw.key = "key_scenes")
|
|
4: optional string Input (go.tag = "json:\"input\"", agw.key = "input") // 输入
|
|
5: optional string Output (go.tag = "json:\"output\"", agw.key = "output") // 输出
|
|
6: optional i64 Duration (go.tag = "json:\"duration\"", agw.key = "duration") // 一级当前对话的耗时, 单位是毫秒
|
|
7: optional string UserID (go.tag = "json:\"user_id\"", agw.key = "user_id") // 用户ID
|
|
}
|
|
|
|
struct TraceHeader {
|
|
1: optional i64 Duration (go.tag = "json:\"duration\"", agw.key = "duration") // 单位是毫秒
|
|
2: optional i32 Tokens (agw.key = "tokens") // 输入消耗token数
|
|
3: optional i32 StatusCode (go.tag = "json:\"status_code\"", agw.key = "status_code")
|
|
4: optional list<FrontendTag> Tags (go.tag = "json:\"tags\"", agw.key = "tags")
|
|
5: optional string MessageID (go.tag = "json:\"message_id\"", agw.key = "message_id") // 消息ID
|
|
6: optional i64 StartTime (go.tag = "json:\"start_time\"", agw.key = "start_time") // 单位是毫秒
|
|
}
|
|
|
|
|
|
struct TraceFrontend {
|
|
1: optional list<TraceFrontendSpan> spans (go.tag = "json:\"spans\"", api.body = "spans")
|
|
2: optional TraceHeader header (go.tag = "json:\"header\"", agw.key = "header")
|
|
}
|
|
|
|
struct TraceFrontendDoubaoCiciDebug {
|
|
1: optional list<TraceFrontendSpan> spans (go.tag = "json:\"spans\"", api.body = "spans")
|
|
2: optional TraceHeader header (go.tag = "json:\"header\"", agw.key = "header")
|
|
3: optional TraceSummary summary (go.tag = "json:\"summary\"", agw.key = "summary")
|
|
}
|
|
enum InputOutputType {
|
|
TEXT = 0 // 文本类型
|
|
}
|
|
|
|
struct SpanInputOutput {
|
|
1: optional InputOutputType Type (go.tag = "json:\"type\"", agw.key = "type") // TEXT
|
|
2: optional string Content (go.tag = "json:\"content\"", agw.key = "content")
|
|
}
|
|
|
|
struct TraceFrontendSpan {
|
|
1: string TraceID (go.tag = "json:\"trace_id\"", agw.key = "trace_id")
|
|
2: string LogID (go.tag = "json:\"log_id\"", agw.key = "log_id")
|
|
3: string SpanID (go.tag = "json:\"span_id\"", agw.key = "span_id")
|
|
4: string Type (go.tag = "json:\"type\"", agw.key = "type")
|
|
5: string Name (go.tag = "json:\"name\"", agw.key = "name")
|
|
6: string AliasName (go.tag = "json:\"alias_name\"", agw.key = "alias_name")
|
|
7: string ParentID (go.tag = "json:\"parent_id\"", agw.key = "parent_id")
|
|
8: i64 Duration (go.tag = "json:\"duration\"", agw.key = "duration") // 单位是毫秒
|
|
9: i64 StartTime (go.tag = "json:\"start_time\"", agw.key = "start_time") // 单位是毫秒
|
|
10: i32 StatusCode (go.tag = "json:\"status_code\"", agw.key = "status_code")
|
|
11: optional list<TraceTag> Tags (go.tag = "json:\"tags\"", agw.key = "tags")
|
|
12: optional SpanSummary summary (go.tag = "json:\"summary\"", agw.key = "summary") // 节点详情
|
|
13: optional SpanInputOutput Input (go.tag = "json:\"input\"", agw.key = "input")
|
|
14: optional SpanInputOutput Output (go.tag = "json:\"output\"", agw.key = "output")
|
|
15: optional bool IsEntry (go.tag = "json:\"is_entry\"", agw.key = "is_entry") // 是否是入口节点
|
|
16: optional string ProductLine (go.tag = "json:\"product_line\"", agw.key = "product_line") // 产品线
|
|
17: optional bool IsKeySpan (go.tag = "json:\"is_key_span\"", agw.key = "is_key_span") // 是否是关键节点
|
|
18: optional list<string> OwnerList (go.tag = "json:\"owner_list\"", agw.key = "owner_list") // 节点负责人列表, 邮箱前缀
|
|
19: optional string RundownDocURL (go.tag = "json:\"rundown_doc_url\"", agw.key = "rundown_doc_url") // 节点详情文档
|
|
}
|