fix: integrate dev background_output task_id title resolution
This commit is contained in:
parent
9353ac5b9d
commit
f67a4df07e
@ -1,4 +1,6 @@
|
|||||||
import { tool, type ToolDefinition } from "@opencode-ai/plugin"
|
import { tool, type ToolDefinition } from "@opencode-ai/plugin"
|
||||||
|
import type { BackgroundTask } from "../../features/background-agent"
|
||||||
|
import { storeToolMetadata } from "../../features/tool-metadata-store"
|
||||||
import type { BackgroundOutputArgs } from "./types"
|
import type { BackgroundOutputArgs } from "./types"
|
||||||
import type { BackgroundOutputClient, BackgroundOutputManager } from "./clients"
|
import type { BackgroundOutputClient, BackgroundOutputManager } from "./clients"
|
||||||
import { BACKGROUND_OUTPUT_DESCRIPTION } from "./constants"
|
import { BACKGROUND_OUTPUT_DESCRIPTION } from "./constants"
|
||||||
@ -7,6 +9,28 @@ import { formatFullSession } from "./full-session-format"
|
|||||||
import { formatTaskResult } from "./task-result-format"
|
import { formatTaskResult } from "./task-result-format"
|
||||||
import { formatTaskStatus } from "./task-status-format"
|
import { formatTaskStatus } from "./task-status-format"
|
||||||
|
|
||||||
|
const SISYPHUS_JUNIOR_AGENT = "sisyphus-junior"
|
||||||
|
|
||||||
|
type ToolContextWithMetadata = {
|
||||||
|
sessionID: string
|
||||||
|
metadata?: (input: { title?: string; metadata?: Record<string, unknown> }) => void
|
||||||
|
callID?: string
|
||||||
|
callId?: string
|
||||||
|
call_id?: string
|
||||||
|
}
|
||||||
|
|
||||||
|
function resolveToolCallID(ctx: ToolContextWithMetadata): string | undefined {
|
||||||
|
if (typeof ctx.callID === "string" && ctx.callID.trim() !== "") return ctx.callID
|
||||||
|
if (typeof ctx.callId === "string" && ctx.callId.trim() !== "") return ctx.callId
|
||||||
|
if (typeof ctx.call_id === "string" && ctx.call_id.trim() !== "") return ctx.call_id
|
||||||
|
return undefined
|
||||||
|
}
|
||||||
|
|
||||||
|
function formatResolvedTitle(task: BackgroundTask): string {
|
||||||
|
const label = task.agent === SISYPHUS_JUNIOR_AGENT && task.category ? task.category : task.agent
|
||||||
|
return `${label} - ${task.description}`
|
||||||
|
}
|
||||||
|
|
||||||
export function createBackgroundOutput(manager: BackgroundOutputManager, client: BackgroundOutputClient): ToolDefinition {
|
export function createBackgroundOutput(manager: BackgroundOutputManager, client: BackgroundOutputClient): ToolDefinition {
|
||||||
return tool({
|
return tool({
|
||||||
description: BACKGROUND_OUTPUT_DESCRIPTION,
|
description: BACKGROUND_OUTPUT_DESCRIPTION,
|
||||||
@ -26,13 +50,31 @@ export function createBackgroundOutput(manager: BackgroundOutputManager, client:
|
|||||||
include_tool_results: tool.schema.boolean().optional().describe("Include tool results in full_session output (default: false)"),
|
include_tool_results: tool.schema.boolean().optional().describe("Include tool results in full_session output (default: false)"),
|
||||||
thinking_max_chars: tool.schema.number().optional().describe("Max characters for thinking content (default: 2000)"),
|
thinking_max_chars: tool.schema.number().optional().describe("Max characters for thinking content (default: 2000)"),
|
||||||
},
|
},
|
||||||
async execute(args: BackgroundOutputArgs) {
|
async execute(args: BackgroundOutputArgs, toolContext) {
|
||||||
try {
|
try {
|
||||||
|
const ctx = toolContext as ToolContextWithMetadata
|
||||||
const task = manager.getTask(args.task_id)
|
const task = manager.getTask(args.task_id)
|
||||||
if (!task) {
|
if (!task) {
|
||||||
return `Task not found: ${args.task_id}`
|
return `Task not found: ${args.task_id}`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const meta = {
|
||||||
|
title: formatResolvedTitle(task),
|
||||||
|
metadata: {
|
||||||
|
task_id: task.id,
|
||||||
|
agent: task.agent,
|
||||||
|
category: task.category,
|
||||||
|
description: task.description,
|
||||||
|
sessionId: task.sessionID ?? "pending",
|
||||||
|
} as Record<string, unknown>,
|
||||||
|
}
|
||||||
|
ctx.metadata?.(meta)
|
||||||
|
|
||||||
|
const callID = resolveToolCallID(ctx)
|
||||||
|
if (callID) {
|
||||||
|
storeToolMetadata(ctx.sessionID, callID, meta)
|
||||||
|
}
|
||||||
|
|
||||||
if (args.full_session === true) {
|
if (args.full_session === true) {
|
||||||
return await formatFullSession(task, client, {
|
return await formatFullSession(task, client, {
|
||||||
includeThinking: args.include_thinking === true,
|
includeThinking: args.include_thinking === true,
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user