140 lines
5.5 KiB
TypeScript
140 lines
5.5 KiB
TypeScript
import { Type } from "@sinclair/typebox";
|
|
import { NonEmptyString, SessionLabelString } from "./primitives.js";
|
|
|
|
export const SessionsListParamsSchema = Type.Object(
|
|
{
|
|
limit: Type.Optional(Type.Integer({ minimum: 1 })),
|
|
activeMinutes: Type.Optional(Type.Integer({ minimum: 1 })),
|
|
includeGlobal: Type.Optional(Type.Boolean()),
|
|
includeUnknown: Type.Optional(Type.Boolean()),
|
|
/**
|
|
* Read first 8KB of each session transcript to derive title from first user message.
|
|
* Performs a file read per session - use `limit` to bound result set on large stores.
|
|
*/
|
|
includeDerivedTitles: Type.Optional(Type.Boolean()),
|
|
/**
|
|
* Read last 16KB of each session transcript to extract most recent message preview.
|
|
* Performs a file read per session - use `limit` to bound result set on large stores.
|
|
*/
|
|
includeLastMessage: Type.Optional(Type.Boolean()),
|
|
label: Type.Optional(SessionLabelString),
|
|
spawnedBy: Type.Optional(NonEmptyString),
|
|
agentId: Type.Optional(NonEmptyString),
|
|
search: Type.Optional(Type.String()),
|
|
},
|
|
{ additionalProperties: false },
|
|
);
|
|
|
|
export const SessionsPreviewParamsSchema = Type.Object(
|
|
{
|
|
keys: Type.Array(NonEmptyString, { minItems: 1 }),
|
|
limit: Type.Optional(Type.Integer({ minimum: 1 })),
|
|
maxChars: Type.Optional(Type.Integer({ minimum: 20 })),
|
|
},
|
|
{ additionalProperties: false },
|
|
);
|
|
|
|
export const SessionsResolveParamsSchema = Type.Object(
|
|
{
|
|
key: Type.Optional(NonEmptyString),
|
|
sessionId: Type.Optional(NonEmptyString),
|
|
label: Type.Optional(SessionLabelString),
|
|
agentId: Type.Optional(NonEmptyString),
|
|
spawnedBy: Type.Optional(NonEmptyString),
|
|
includeGlobal: Type.Optional(Type.Boolean()),
|
|
includeUnknown: Type.Optional(Type.Boolean()),
|
|
},
|
|
{ additionalProperties: false },
|
|
);
|
|
|
|
export const SessionsPatchParamsSchema = Type.Object(
|
|
{
|
|
key: NonEmptyString,
|
|
label: Type.Optional(Type.Union([SessionLabelString, Type.Null()])),
|
|
thinkingLevel: Type.Optional(Type.Union([NonEmptyString, Type.Null()])),
|
|
fastMode: Type.Optional(Type.Union([Type.Boolean(), Type.Null()])),
|
|
verboseLevel: Type.Optional(Type.Union([NonEmptyString, Type.Null()])),
|
|
reasoningLevel: Type.Optional(Type.Union([NonEmptyString, Type.Null()])),
|
|
responseUsage: Type.Optional(
|
|
Type.Union([
|
|
Type.Literal("off"),
|
|
Type.Literal("tokens"),
|
|
Type.Literal("full"),
|
|
// Backward compat with older clients/stores.
|
|
Type.Literal("on"),
|
|
Type.Null(),
|
|
]),
|
|
),
|
|
elevatedLevel: Type.Optional(Type.Union([NonEmptyString, Type.Null()])),
|
|
execHost: Type.Optional(Type.Union([NonEmptyString, Type.Null()])),
|
|
execSecurity: Type.Optional(Type.Union([NonEmptyString, Type.Null()])),
|
|
execAsk: Type.Optional(Type.Union([NonEmptyString, Type.Null()])),
|
|
execNode: Type.Optional(Type.Union([NonEmptyString, Type.Null()])),
|
|
model: Type.Optional(Type.Union([NonEmptyString, Type.Null()])),
|
|
spawnedBy: Type.Optional(Type.Union([NonEmptyString, Type.Null()])),
|
|
spawnedWorkspaceDir: Type.Optional(Type.Union([NonEmptyString, Type.Null()])),
|
|
spawnDepth: Type.Optional(Type.Union([Type.Integer({ minimum: 0 }), Type.Null()])),
|
|
subagentRole: Type.Optional(
|
|
Type.Union([Type.Literal("orchestrator"), Type.Literal("leaf"), Type.Null()]),
|
|
),
|
|
subagentControlScope: Type.Optional(
|
|
Type.Union([Type.Literal("children"), Type.Literal("none"), Type.Null()]),
|
|
),
|
|
sendPolicy: Type.Optional(
|
|
Type.Union([Type.Literal("allow"), Type.Literal("deny"), Type.Null()]),
|
|
),
|
|
groupActivation: Type.Optional(
|
|
Type.Union([Type.Literal("mention"), Type.Literal("always"), Type.Null()]),
|
|
),
|
|
},
|
|
{ additionalProperties: false },
|
|
);
|
|
|
|
export const SessionsResetParamsSchema = Type.Object(
|
|
{
|
|
key: NonEmptyString,
|
|
reason: Type.Optional(Type.Union([Type.Literal("new"), Type.Literal("reset")])),
|
|
},
|
|
{ additionalProperties: false },
|
|
);
|
|
|
|
export const SessionsDeleteParamsSchema = Type.Object(
|
|
{
|
|
key: NonEmptyString,
|
|
deleteTranscript: Type.Optional(Type.Boolean()),
|
|
// Internal control: when false, still unbind thread bindings but skip hook emission.
|
|
emitLifecycleHooks: Type.Optional(Type.Boolean()),
|
|
},
|
|
{ additionalProperties: false },
|
|
);
|
|
|
|
export const SessionsCompactParamsSchema = Type.Object(
|
|
{
|
|
key: NonEmptyString,
|
|
maxLines: Type.Optional(Type.Integer({ minimum: 1 })),
|
|
},
|
|
{ additionalProperties: false },
|
|
);
|
|
|
|
export const SessionsUsageParamsSchema = Type.Object(
|
|
{
|
|
/** Specific session key to analyze; if omitted returns all sessions. */
|
|
key: Type.Optional(NonEmptyString),
|
|
/** Start date for range filter (YYYY-MM-DD). */
|
|
startDate: Type.Optional(Type.String({ pattern: "^\\d{4}-\\d{2}-\\d{2}$" })),
|
|
/** End date for range filter (YYYY-MM-DD). */
|
|
endDate: Type.Optional(Type.String({ pattern: "^\\d{4}-\\d{2}-\\d{2}$" })),
|
|
/** How start/end dates should be interpreted. Defaults to UTC when omitted. */
|
|
mode: Type.Optional(
|
|
Type.Union([Type.Literal("utc"), Type.Literal("gateway"), Type.Literal("specific")]),
|
|
),
|
|
/** UTC offset to use when mode is `specific` (for example, UTC-4 or UTC+5:30). */
|
|
utcOffset: Type.Optional(Type.String({ pattern: "^UTC[+-]\\d{1,2}(?::[0-5]\\d)?$" })),
|
|
/** Maximum sessions to return (default 50). */
|
|
limit: Type.Optional(Type.Integer({ minimum: 1 })),
|
|
/** Include context weight breakdown (systemPromptReport). */
|
|
includeContextWeight: Type.Optional(Type.Boolean()),
|
|
},
|
|
{ additionalProperties: false },
|
|
);
|