@autohq/cli 0.1.303 → 0.1.305
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/agent-bridge.js +1842 -995
- package/dist/index.js +1894 -1084
- package/package.json +1 -1
package/dist/agent-bridge.js
CHANGED
|
@@ -23399,7 +23399,7 @@ Object.assign(lookup, {
|
|
|
23399
23399
|
// package.json
|
|
23400
23400
|
var package_default = {
|
|
23401
23401
|
name: "@autohq/cli",
|
|
23402
|
-
version: "0.1.
|
|
23402
|
+
version: "0.1.305",
|
|
23403
23403
|
license: "SEE LICENSE IN README.md",
|
|
23404
23404
|
publishConfig: {
|
|
23405
23405
|
access: "public"
|
|
@@ -26769,661 +26769,260 @@ function isSetupCacheTtl(value2) {
|
|
|
26769
26769
|
return /^[1-9][0-9]*(s|m|h|d)$/.test(value2);
|
|
26770
26770
|
}
|
|
26771
26771
|
|
|
26772
|
-
// ../../packages/schemas/src/
|
|
26773
|
-
var
|
|
26774
|
-
|
|
26775
|
-
|
|
26776
|
-
|
|
26777
|
-
|
|
26778
|
-
|
|
26779
|
-
|
|
26780
|
-
|
|
26781
|
-
|
|
26782
|
-
|
|
26783
|
-
|
|
26784
|
-
|
|
26785
|
-
// ../../packages/schemas/src/mcp.ts
|
|
26786
|
-
var McpToolCallMessageSchema = external_exports.object({
|
|
26787
|
-
method: external_exports.literal("tools/call"),
|
|
26788
|
-
params: external_exports.object({
|
|
26789
|
-
name: external_exports.string().trim().min(1)
|
|
26772
|
+
// ../../packages/schemas/src/singleton-refresh.ts
|
|
26773
|
+
var SINGLETON_RESPAWN_REASONS = ["refresh", "failure"];
|
|
26774
|
+
var SingletonRespawnReasonSchema = external_exports.enum(SINGLETON_RESPAWN_REASONS);
|
|
26775
|
+
var SingletonRespawnSchema = external_exports.object({
|
|
26776
|
+
reason: SingletonRespawnReasonSchema.default("refresh")
|
|
26777
|
+
}).strict();
|
|
26778
|
+
var SingletonRefreshEventPayloadSchema = external_exports.object({
|
|
26779
|
+
trigger: external_exports.literal("agent.refresh"),
|
|
26780
|
+
refresh: external_exports.object({
|
|
26781
|
+
reason: SingletonRespawnReasonSchema,
|
|
26782
|
+
agentResourceId: external_exports.string().trim().min(1),
|
|
26783
|
+
previousSessionId: external_exports.string().trim().min(1)
|
|
26790
26784
|
})
|
|
26791
26785
|
});
|
|
26792
|
-
var McpJsonRpcMessageSchema = external_exports.object({
|
|
26793
|
-
method: external_exports.string().optional()
|
|
26794
|
-
}).passthrough();
|
|
26795
|
-
var McpPostBodySchema = external_exports.union([McpJsonRpcMessageSchema, external_exports.array(McpJsonRpcMessageSchema)]).transform((body) => Array.isArray(body) ? body : [body]);
|
|
26796
|
-
|
|
26797
|
-
// ../../packages/schemas/src/pricing.ts
|
|
26798
|
-
var RATE_CARD_2026_06_23 = {
|
|
26799
|
-
version: "2026-06-23",
|
|
26800
|
-
effectiveAt: "2026-06-23T00:00:00.000Z",
|
|
26801
|
-
models: {
|
|
26802
|
-
"claude-opus-4-8": opusTier(),
|
|
26803
|
-
"claude-opus-4-7": opusTier(),
|
|
26804
|
-
"claude-opus-4-6": opusTier(),
|
|
26805
|
-
"claude-sonnet-4-6": tier(3, 15),
|
|
26806
|
-
"claude-haiku-4-5": tier(1, 5),
|
|
26807
|
-
"claude-haiku-4-5-20251001": tier(1, 5),
|
|
26808
|
-
"claude-fable-5": tier(10, 50),
|
|
26809
|
-
// OpenAI gpt-5.3-codex, standard tier: input $1.75/Mtok, cached input
|
|
26810
|
-
// $0.175/Mtok, output $14.00/Mtok. Source (verified 2026-06-23):
|
|
26811
|
-
// https://developers.openai.com/api/docs/models/gpt-5.3-codex and
|
|
26812
|
-
// https://developers.openai.com/api/docs/pricing (priority tier is 2x; we
|
|
26813
|
-
// bill standard).
|
|
26814
|
-
"gpt-5.3-codex": openAiTier({
|
|
26815
|
-
input: 1.75,
|
|
26816
|
-
cachedInput: 0.175,
|
|
26817
|
-
output: 14
|
|
26818
|
-
})
|
|
26819
|
-
}
|
|
26820
|
-
};
|
|
26821
|
-
var PRICING_RATE_CARDS = {
|
|
26822
|
-
[RATE_CARD_2026_06_23.version]: RATE_CARD_2026_06_23
|
|
26823
|
-
};
|
|
26824
|
-
var CURRENT_PRICING_VERSION = RATE_CARD_2026_06_23.version;
|
|
26825
|
-
function tier(inputUsdPerMtok, outputUsdPerMtok) {
|
|
26826
|
-
return {
|
|
26827
|
-
inputUsdPerMtok,
|
|
26828
|
-
outputUsdPerMtok,
|
|
26829
|
-
cacheWrite5mUsdPerMtok: inputUsdPerMtok * 1.25,
|
|
26830
|
-
cacheReadUsdPerMtok: inputUsdPerMtok * 0.1
|
|
26831
|
-
};
|
|
26832
|
-
}
|
|
26833
|
-
function opusTier() {
|
|
26834
|
-
return tier(5, 25);
|
|
26835
|
-
}
|
|
26836
|
-
function openAiTier(rates) {
|
|
26837
|
-
return {
|
|
26838
|
-
inputUsdPerMtok: rates.input,
|
|
26839
|
-
outputUsdPerMtok: rates.output,
|
|
26840
|
-
cacheWrite5mUsdPerMtok: rates.input,
|
|
26841
|
-
cacheReadUsdPerMtok: rates.cachedInput
|
|
26842
|
-
};
|
|
26843
|
-
}
|
|
26844
|
-
|
|
26845
|
-
// ../../packages/schemas/src/project-service-accounts.ts
|
|
26846
|
-
var ProjectServiceAccountSchema = external_exports.object({
|
|
26847
|
-
id: ServiceAccountIdSchema,
|
|
26848
|
-
organizationId: OrganizationIdSchema,
|
|
26849
|
-
projectId: ProjectIdSchema,
|
|
26850
|
-
name: ResourceNameSchema,
|
|
26851
|
-
scopes: external_exports.array(AuthScopeSchema),
|
|
26852
|
-
createdAt: external_exports.string().datetime()
|
|
26853
|
-
});
|
|
26854
|
-
var ProjectServiceAccountCreateRequestSchema = external_exports.object({
|
|
26855
|
-
name: ResourceNameSchema,
|
|
26856
|
-
scopes: external_exports.array(AuthScopeSchema).min(1)
|
|
26857
|
-
});
|
|
26858
|
-
var ProjectServiceAccountUpdateRequestSchema = external_exports.object({
|
|
26859
|
-
scopes: external_exports.array(AuthScopeSchema).min(1)
|
|
26860
|
-
});
|
|
26861
|
-
var ProjectServiceAccountTokenResponseSchema = external_exports.object({
|
|
26862
|
-
serviceAccount: ProjectServiceAccountSchema,
|
|
26863
|
-
token: external_exports.string().min(1)
|
|
26864
|
-
});
|
|
26865
|
-
var ProjectServiceAccountUpdateResponseSchema = external_exports.object({
|
|
26866
|
-
serviceAccount: ProjectServiceAccountSchema
|
|
26867
|
-
});
|
|
26868
|
-
var ProjectServiceAccountRemoveResponseSchema = external_exports.object({
|
|
26869
|
-
serviceAccount: ProjectServiceAccountSchema,
|
|
26870
|
-
removed: external_exports.literal(true)
|
|
26871
|
-
});
|
|
26872
|
-
var ProjectServiceAccountListResponseSchema = external_exports.object({
|
|
26873
|
-
serviceAccounts: external_exports.array(ProjectServiceAccountSchema)
|
|
26874
|
-
});
|
|
26875
26786
|
|
|
26876
|
-
// ../../packages/schemas/src/
|
|
26877
|
-
var
|
|
26878
|
-
|
|
26879
|
-
|
|
26787
|
+
// ../../packages/schemas/src/session-commands.ts
|
|
26788
|
+
var SESSION_COMMAND_KINDS = [
|
|
26789
|
+
"message",
|
|
26790
|
+
"answer",
|
|
26791
|
+
"pause",
|
|
26792
|
+
"resume",
|
|
26793
|
+
"interrupt",
|
|
26794
|
+
"cancel",
|
|
26795
|
+
"stop"
|
|
26796
|
+
];
|
|
26797
|
+
var SESSION_DISPATCH_COMMAND_KINDS = [
|
|
26798
|
+
"start",
|
|
26799
|
+
"startWithMessage",
|
|
26800
|
+
"message",
|
|
26801
|
+
"answer",
|
|
26802
|
+
"stop"
|
|
26803
|
+
];
|
|
26804
|
+
var SESSION_PERSISTED_COMMAND_KINDS = [
|
|
26805
|
+
"message",
|
|
26806
|
+
"pause",
|
|
26807
|
+
"resume",
|
|
26808
|
+
"interrupt",
|
|
26809
|
+
"cancel",
|
|
26810
|
+
"stop",
|
|
26811
|
+
"start",
|
|
26812
|
+
"startWithMessage",
|
|
26813
|
+
"answer"
|
|
26814
|
+
];
|
|
26815
|
+
var SESSION_LIFECYCLE_COMMAND_KINDS = [
|
|
26816
|
+
"pause",
|
|
26817
|
+
"resume",
|
|
26818
|
+
"interrupt",
|
|
26819
|
+
"cancel",
|
|
26820
|
+
"stop"
|
|
26821
|
+
];
|
|
26822
|
+
var SESSION_COMMAND_STATUSES = [
|
|
26823
|
+
"pending",
|
|
26824
|
+
"dispatching",
|
|
26825
|
+
"accepted",
|
|
26826
|
+
"failed"
|
|
26827
|
+
];
|
|
26828
|
+
var SESSION_DISPATCH_COMMAND_STATUSES = [
|
|
26829
|
+
"pending",
|
|
26830
|
+
"dispatching",
|
|
26831
|
+
"accepted",
|
|
26832
|
+
"failed"
|
|
26833
|
+
];
|
|
26834
|
+
var SessionCommandKindSchema2 = external_exports.enum(SESSION_COMMAND_KINDS);
|
|
26835
|
+
var SessionPersistedCommandKindSchema = external_exports.enum(
|
|
26836
|
+
SESSION_PERSISTED_COMMAND_KINDS
|
|
26880
26837
|
);
|
|
26881
|
-
var
|
|
26882
|
-
|
|
26883
|
-
IdentityApplyRequestSchema.shape.spec
|
|
26838
|
+
var SessionDispatchCommandKindSchema = external_exports.enum(
|
|
26839
|
+
SESSION_DISPATCH_COMMAND_KINDS
|
|
26884
26840
|
);
|
|
26885
|
-
var
|
|
26886
|
-
|
|
26887
|
-
AgentApplyRequestSchema.shape.spec
|
|
26841
|
+
var RunLifecycleCommandKindSchema = external_exports.enum(
|
|
26842
|
+
SESSION_LIFECYCLE_COMMAND_KINDS
|
|
26888
26843
|
);
|
|
26889
|
-
var
|
|
26890
|
-
|
|
26891
|
-
|
|
26892
|
-
|
|
26844
|
+
var SessionCommandStatusSchema = external_exports.enum(SESSION_COMMAND_STATUSES);
|
|
26845
|
+
var SessionDispatchCommandStatusSchema = external_exports.enum(
|
|
26846
|
+
SESSION_DISPATCH_COMMAND_STATUSES
|
|
26847
|
+
);
|
|
26848
|
+
var SessionCommandSenderSchema = external_exports.discriminatedUnion("type", [
|
|
26849
|
+
external_exports.object({
|
|
26850
|
+
type: external_exports.literal("operator"),
|
|
26851
|
+
id: external_exports.string().trim().min(1).nullable().default(null),
|
|
26852
|
+
actor: AuthActorSchema.nullable().optional()
|
|
26853
|
+
}),
|
|
26854
|
+
external_exports.object({
|
|
26855
|
+
type: external_exports.literal("agent"),
|
|
26856
|
+
sessionId: SessionIdSchema2
|
|
26857
|
+
}),
|
|
26858
|
+
external_exports.object({
|
|
26859
|
+
type: external_exports.literal("system")
|
|
26860
|
+
})
|
|
26893
26861
|
]);
|
|
26894
|
-
var
|
|
26895
|
-
|
|
26896
|
-
|
|
26897
|
-
|
|
26898
|
-
|
|
26899
|
-
|
|
26900
|
-
|
|
26901
|
-
|
|
26902
|
-
RESOURCE_KIND_IDENTITY,
|
|
26903
|
-
RESOURCE_KIND_ENVIRONMENT,
|
|
26904
|
-
RESOURCE_KIND_AGENT
|
|
26862
|
+
var MESSAGE_DELIVERY_MODES = ["interrupt", "deferred"];
|
|
26863
|
+
var MessageDeliveryModeSchema = external_exports.enum(MESSAGE_DELIVERY_MODES);
|
|
26864
|
+
var TRIGGER_INJECTION_MODALITIES = [
|
|
26865
|
+
"chat",
|
|
26866
|
+
"githubCheck",
|
|
26867
|
+
"githubCheckAction",
|
|
26868
|
+
"githubPullRequest",
|
|
26869
|
+
"other"
|
|
26905
26870
|
];
|
|
26906
|
-
var
|
|
26907
|
-
|
|
26908
|
-
var PROJECT_APPLY_BUNDLE_CONTENT_TYPE = "application/vnd.auto.project-apply-bundle+json";
|
|
26909
|
-
function projectApplyBundleStorageKey(sha256) {
|
|
26910
|
-
return `project-apply-bundles/${sha256}.json`;
|
|
26911
|
-
}
|
|
26912
|
-
var ProjectDeleteResourceBaseSchema = external_exports.object({
|
|
26913
|
-
name: external_exports.string().trim().min(1)
|
|
26914
|
-
});
|
|
26915
|
-
var ProjectDeleteResourceSchema = ProjectDeleteResourceBaseSchema.extend({
|
|
26916
|
-
kind: external_exports.enum(PROJECT_APPLY_RESOURCE_KINDS)
|
|
26917
|
-
});
|
|
26918
|
-
var AVATAR_ASSET_CONTENT_TYPES = ["image/png", "image/jpeg"];
|
|
26919
|
-
var MAX_AVATAR_ASSET_BASE64_LENGTH = Math.ceil(MAX_AVATAR_ASSET_BYTES / 3) * 4 + 4;
|
|
26920
|
-
var ProjectApplyAssetSchema = external_exports.object({
|
|
26921
|
-
sha256: external_exports.string().regex(/^[a-f0-9]{64}$/),
|
|
26922
|
-
contentType: external_exports.enum(AVATAR_ASSET_CONTENT_TYPES),
|
|
26923
|
-
dataBase64: external_exports.string().min(1).max(MAX_AVATAR_ASSET_BASE64_LENGTH).regex(/^[A-Za-z0-9+/]+={0,2}$/)
|
|
26924
|
-
});
|
|
26925
|
-
var ProjectApplyAssetsSchema = external_exports.record(
|
|
26926
|
-
external_exports.string().refine(isAvatarAssetPathShapeValid, {
|
|
26927
|
-
message: "asset keys must be relative paths under .auto/assets"
|
|
26928
|
-
}),
|
|
26929
|
-
ProjectApplyAssetSchema
|
|
26871
|
+
var TriggerInjectionModalitySchema = external_exports.enum(
|
|
26872
|
+
TRIGGER_INJECTION_MODALITIES
|
|
26930
26873
|
);
|
|
26931
|
-
var
|
|
26932
|
-
|
|
26933
|
-
|
|
26934
|
-
|
|
26935
|
-
|
|
26936
|
-
|
|
26937
|
-
|
|
26938
|
-
|
|
26939
|
-
|
|
26940
|
-
|
|
26941
|
-
|
|
26942
|
-
|
|
26943
|
-
|
|
26944
|
-
|
|
26945
|
-
|
|
26946
|
-
})
|
|
26947
|
-
|
|
26948
|
-
kind: external_exports.literal("vercel_blob"),
|
|
26949
|
-
storageKey: external_exports.string().trim().min(1).max(1024),
|
|
26950
|
-
sha256: external_exports.string().regex(SHA256_HEX_PATTERN),
|
|
26951
|
-
sizeBytes: external_exports.number().int().positive().max(MAX_PROJECT_APPLY_BUNDLE_BYTES)
|
|
26952
|
-
}).superRefine((ref, context) => {
|
|
26953
|
-
const expectedStorageKey = projectApplyBundleStorageKey(ref.sha256);
|
|
26954
|
-
if (ref.storageKey === expectedStorageKey) {
|
|
26955
|
-
return;
|
|
26956
|
-
}
|
|
26957
|
-
context.addIssue({
|
|
26958
|
-
code: "custom",
|
|
26959
|
-
path: ["storageKey"],
|
|
26960
|
-
message: "apply bundle storage key must match its sha256"
|
|
26961
|
-
});
|
|
26962
|
-
});
|
|
26963
|
-
var ProjectApplyBundleUploadRequestSchema = external_exports.object({
|
|
26964
|
-
sha256: external_exports.string().regex(SHA256_HEX_PATTERN),
|
|
26965
|
-
sizeBytes: external_exports.number().int().positive().max(MAX_PROJECT_APPLY_BUNDLE_BYTES)
|
|
26966
|
-
});
|
|
26967
|
-
var ProjectApplyBundleUploadResponseSchema = external_exports.object({
|
|
26968
|
-
method: external_exports.literal("PUT"),
|
|
26969
|
-
uploadUrl: external_exports.string().url(),
|
|
26970
|
-
contentType: external_exports.literal(PROJECT_APPLY_BUNDLE_CONTENT_TYPE),
|
|
26971
|
-
source: ProjectApplyBundleRefSchema
|
|
26972
|
-
});
|
|
26973
|
-
var ProjectApplyBundleDirectoryEntrypointSchema = external_exports.object({
|
|
26974
|
-
kind: external_exports.literal("directory"),
|
|
26975
|
-
resourceRoot: ApplyBundlePathSchema.default(".auto"),
|
|
26976
|
-
displayResourceRoot: external_exports.string().trim().min(1).max(4096).optional()
|
|
26977
|
-
});
|
|
26978
|
-
var ProjectApplyBundleFileEntrypointSchema = external_exports.object({
|
|
26979
|
-
kind: external_exports.literal("file"),
|
|
26980
|
-
filePath: ApplyBundlePathSchema
|
|
26874
|
+
var RunMessageCommandPayloadSchema = external_exports.object({
|
|
26875
|
+
message: external_exports.string().trim().min(1),
|
|
26876
|
+
// Optional so existing payloads and direct operator/agent messages stay
|
|
26877
|
+
// valid without it; trigger routing sets "deferred" for GitHub check
|
|
26878
|
+
// events. An absent mode is treated as "interrupt" at the delivery
|
|
26879
|
+
// boundary (commandDeliveryPayload / the runtime handler), so the default
|
|
26880
|
+
// lives where the value is consumed rather than as a required field every
|
|
26881
|
+
// call site must construct.
|
|
26882
|
+
deliveryMode: MessageDeliveryModeSchema.optional(),
|
|
26883
|
+
metadata: JsonValueSchema2.optional()
|
|
26884
|
+
}).strict();
|
|
26885
|
+
var RunAnswerCommandPayloadSchema = external_exports.object({
|
|
26886
|
+
toolCallId: external_exports.string().trim().min(1),
|
|
26887
|
+
answers: external_exports.record(external_exports.string(), external_exports.string()),
|
|
26888
|
+
response: external_exports.string().trim().min(1).optional()
|
|
26889
|
+
}).strict().refine((value2) => Object.keys(value2.answers).length > 0 || value2.response, {
|
|
26890
|
+
message: "Provide at least one answer or a freeform response"
|
|
26981
26891
|
});
|
|
26982
|
-
var
|
|
26983
|
-
|
|
26984
|
-
|
|
26892
|
+
var RunLifecycleCommandPayloadSchema = external_exports.object({
|
|
26893
|
+
reason: external_exports.string().trim().min(1).optional()
|
|
26894
|
+
}).strict();
|
|
26895
|
+
var RunStopCommandPayloadSchema = external_exports.object({
|
|
26896
|
+
reason: external_exports.string().trim().min(1).optional(),
|
|
26897
|
+
respawn: SingletonRespawnSchema.optional()
|
|
26898
|
+
}).strict();
|
|
26899
|
+
var SessionCommandPayloadSchema = external_exports.union([
|
|
26900
|
+
RunMessageCommandPayloadSchema,
|
|
26901
|
+
RunAnswerCommandPayloadSchema,
|
|
26902
|
+
RunLifecycleCommandPayloadSchema,
|
|
26903
|
+
RunStopCommandPayloadSchema
|
|
26985
26904
|
]);
|
|
26986
|
-
var
|
|
26987
|
-
|
|
26988
|
-
|
|
26989
|
-
entrypoint: ProjectApplyBundleEntrypointSchema
|
|
26990
|
-
});
|
|
26991
|
-
var ProjectApplySourceRequestSchema = external_exports.object({
|
|
26992
|
-
source: ProjectApplySourceSchema,
|
|
26993
|
-
delete: external_exports.array(ProjectDeleteResourceSchema).default([]),
|
|
26994
|
-
dryRun: external_exports.boolean().default(false),
|
|
26995
|
-
prune: external_exports.boolean().default(true)
|
|
26905
|
+
var CreateRunMessageCommandRequestSchema = external_exports.object({
|
|
26906
|
+
message: external_exports.string().trim().min(1),
|
|
26907
|
+
metadata: JsonValueSchema2.optional()
|
|
26996
26908
|
});
|
|
26997
|
-
var
|
|
26998
|
-
|
|
26999
|
-
|
|
27000
|
-
prune: external_exports.boolean().default(false),
|
|
27001
|
-
resources: external_exports.array(ProjectApplyResourceSchema).default([]),
|
|
27002
|
-
assets: ProjectApplyAssetsSchema.default({})
|
|
26909
|
+
var CreateRunAnswerCommandRequestSchema = RunAnswerCommandPayloadSchema;
|
|
26910
|
+
var CreateRunLifecycleCommandRequestSchema = external_exports.object({
|
|
26911
|
+
reason: external_exports.string().trim().min(1).optional()
|
|
27003
26912
|
});
|
|
27004
|
-
var
|
|
27005
|
-
|
|
27006
|
-
|
|
27007
|
-
name: external_exports.string().trim().min(1).optional()
|
|
27008
|
-
}).optional(),
|
|
27009
|
-
spec: ProjectApplyRequestSchema
|
|
26913
|
+
var CreateRunStopCommandRequestSchema = external_exports.object({
|
|
26914
|
+
reason: external_exports.string().trim().min(1).optional(),
|
|
26915
|
+
respawn: SingletonRespawnSchema.optional()
|
|
27010
26916
|
});
|
|
27011
|
-
var
|
|
27012
|
-
|
|
27013
|
-
|
|
27014
|
-
|
|
27015
|
-
|
|
26917
|
+
var CreateSessionCommandRequestSchema = external_exports.discriminatedUnion("kind", [
|
|
26918
|
+
external_exports.object({
|
|
26919
|
+
kind: external_exports.literal("message"),
|
|
26920
|
+
payload: CreateRunMessageCommandRequestSchema
|
|
26921
|
+
}).strict(),
|
|
26922
|
+
external_exports.object({
|
|
26923
|
+
kind: external_exports.literal("answer"),
|
|
26924
|
+
payload: CreateRunAnswerCommandRequestSchema
|
|
26925
|
+
}).strict(),
|
|
26926
|
+
external_exports.object({
|
|
26927
|
+
kind: external_exports.literal("pause"),
|
|
26928
|
+
payload: CreateRunLifecycleCommandRequestSchema
|
|
26929
|
+
}).strict(),
|
|
26930
|
+
external_exports.object({
|
|
26931
|
+
kind: external_exports.literal("resume"),
|
|
26932
|
+
payload: CreateRunLifecycleCommandRequestSchema
|
|
26933
|
+
}).strict(),
|
|
26934
|
+
external_exports.object({
|
|
26935
|
+
kind: external_exports.literal("interrupt"),
|
|
26936
|
+
payload: CreateRunLifecycleCommandRequestSchema
|
|
26937
|
+
}).strict(),
|
|
26938
|
+
external_exports.object({
|
|
26939
|
+
kind: external_exports.literal("cancel"),
|
|
26940
|
+
payload: CreateRunLifecycleCommandRequestSchema
|
|
26941
|
+
}).strict(),
|
|
26942
|
+
external_exports.object({
|
|
26943
|
+
kind: external_exports.literal("stop"),
|
|
26944
|
+
payload: CreateRunStopCommandRequestSchema
|
|
26945
|
+
}).strict()
|
|
27016
26946
|
]);
|
|
27017
|
-
var
|
|
27018
|
-
|
|
27019
|
-
|
|
27020
|
-
|
|
27021
|
-
|
|
27022
|
-
|
|
27023
|
-
|
|
27024
|
-
|
|
27025
|
-
|
|
27026
|
-
|
|
27027
|
-
|
|
27028
|
-
RESOURCE_KIND_ENVIRONMENT,
|
|
27029
|
-
RESOURCE_KIND_IDENTITY,
|
|
27030
|
-
RESOURCE_KIND_AGENT
|
|
27031
|
-
]),
|
|
27032
|
-
name: external_exports.string().min(1)
|
|
27033
|
-
});
|
|
27034
|
-
var ProjectApplyResponsePrunedSchema = external_exports.object({
|
|
27035
|
-
kind: external_exports.enum(PROJECT_RESOURCE_KINDS),
|
|
27036
|
-
name: external_exports.string().min(1),
|
|
27037
|
-
uid: external_exports.string().min(1),
|
|
27038
|
-
heartbeatScheduleIds: external_exports.array(external_exports.string().min(1)).optional()
|
|
27039
|
-
});
|
|
27040
|
-
var ProjectApplyPlanDiffSchema = external_exports.object({
|
|
27041
|
-
action: external_exports.enum(["add", "remove", "change"]),
|
|
27042
|
-
path: external_exports.string().min(1)
|
|
27043
|
-
});
|
|
27044
|
-
var ProjectApplyResponseSchema = external_exports.object({
|
|
27045
|
-
dryRun: external_exports.boolean().default(false),
|
|
27046
|
-
resources: external_exports.array(ProjectAppliedResourceSchema),
|
|
27047
|
-
triggers: external_exports.array(ApplyTriggerReceiptSchema).default([]),
|
|
27048
|
-
diagnostics: external_exports.array(ProjectApplyDiagnosticSchema).default([]),
|
|
27049
|
-
plan: external_exports.array(
|
|
27050
|
-
external_exports.object({
|
|
27051
|
-
action: external_exports.enum(["create", "update", "unchanged", "archive"]),
|
|
27052
|
-
kind: external_exports.enum(PROJECT_RESOURCE_KINDS),
|
|
27053
|
-
name: external_exports.string().min(1),
|
|
27054
|
-
uid: external_exports.string().min(1).optional(),
|
|
27055
|
-
diff: external_exports.array(ProjectApplyPlanDiffSchema).optional(),
|
|
27056
|
-
diffOmitted: external_exports.number().int().positive().optional()
|
|
27057
|
-
})
|
|
27058
|
-
).default([]),
|
|
27059
|
-
pruned: external_exports.array(ProjectApplyResponsePrunedSchema).default([])
|
|
26947
|
+
var RunResolutionPolicySchema = external_exports.enum([
|
|
26948
|
+
"singletonLiveRun",
|
|
26949
|
+
"latestLiveRun",
|
|
26950
|
+
"latestRun"
|
|
26951
|
+
]);
|
|
26952
|
+
var AgentAddressedCommandTargetSchema = external_exports.object({
|
|
26953
|
+
agentId: AgentIdSchema.optional(),
|
|
26954
|
+
agentName: external_exports.string().trim().min(1).optional(),
|
|
26955
|
+
resolutionPolicy: RunResolutionPolicySchema
|
|
26956
|
+
}).refine((value2) => Boolean(value2.agentId) !== Boolean(value2.agentName), {
|
|
26957
|
+
message: "Provide exactly one of agentId or agentName"
|
|
27060
26958
|
});
|
|
27061
|
-
var
|
|
27062
|
-
|
|
27063
|
-
|
|
27064
|
-
|
|
27065
|
-
|
|
27066
|
-
|
|
27067
|
-
|
|
27068
|
-
|
|
27069
|
-
).
|
|
27070
|
-
|
|
26959
|
+
var SessionCommandRecordBaseSchema = external_exports.object({
|
|
26960
|
+
id: SessionCommandIdSchema2,
|
|
26961
|
+
sessionId: SessionIdSchema2,
|
|
26962
|
+
sender: SessionCommandSenderSchema,
|
|
26963
|
+
idempotencyKey: external_exports.string().min(1).nullable(),
|
|
26964
|
+
status: SessionCommandStatusSchema,
|
|
26965
|
+
attemptCount: external_exports.number().int().nonnegative(),
|
|
26966
|
+
nextAttemptAt: external_exports.string().datetime().nullable(),
|
|
26967
|
+
lastAttemptAt: external_exports.string().datetime().nullable(),
|
|
26968
|
+
acceptedAt: external_exports.string().datetime().nullable(),
|
|
26969
|
+
failedAt: external_exports.string().datetime().nullable(),
|
|
26970
|
+
error: JsonValueSchema2.nullable(),
|
|
26971
|
+
createdAt: external_exports.string().datetime(),
|
|
26972
|
+
updatedAt: external_exports.string().datetime()
|
|
27071
26973
|
});
|
|
27072
|
-
var
|
|
27073
|
-
|
|
27074
|
-
"github_sync.apply"
|
|
27075
|
-
]);
|
|
27076
|
-
var ProjectResourceApplyOperationIdSchema = external_exports.string().trim().min(1).max(512);
|
|
27077
|
-
var ProjectResourceApplyTriggerArtifactSchema = external_exports.object({
|
|
27078
|
-
type: external_exports.string().trim().min(1),
|
|
27079
|
-
externalId: external_exports.string().trim().min(1),
|
|
27080
|
-
payload: JsonValueSchema2.optional()
|
|
26974
|
+
var RunStartCommandPayloadSchema = external_exports.object({
|
|
26975
|
+
kind: external_exports.literal("start")
|
|
27081
26976
|
}).strict();
|
|
27082
|
-
var
|
|
27083
|
-
|
|
26977
|
+
var RunStartWithMessageCommandPayloadSchema = external_exports.object({
|
|
26978
|
+
kind: external_exports.literal("startWithMessage"),
|
|
27084
26979
|
message: external_exports.string().trim().min(1)
|
|
27085
|
-
});
|
|
27086
|
-
var ProjectResourceApplyWorkflowInputSchema = external_exports.object({
|
|
27087
|
-
operationId: ProjectResourceApplyOperationIdSchema,
|
|
27088
|
-
request: ProjectApplyRequestSchema.optional(),
|
|
27089
|
-
sourceRequest: ProjectApplySourceRequestSchema.optional(),
|
|
27090
|
-
organizationId: OrganizationIdSchema,
|
|
27091
|
-
projectId: ProjectIdSchema.nullable().optional(),
|
|
27092
|
-
actor: AuthActorSchema,
|
|
27093
|
-
auditAction: ProjectResourceApplyAuditActionSchema,
|
|
27094
|
-
triggerArtifact: ProjectResourceApplyTriggerArtifactSchema.optional()
|
|
27095
|
-
}).superRefine((input, context) => {
|
|
27096
|
-
if ((input.request ? 1 : 0) + (input.sourceRequest ? 1 : 0) !== 1) {
|
|
27097
|
-
context.addIssue({
|
|
27098
|
-
code: "custom",
|
|
27099
|
-
path: ["request"],
|
|
27100
|
-
message: "exactly one of request or sourceRequest is required"
|
|
27101
|
-
});
|
|
27102
|
-
}
|
|
27103
|
-
});
|
|
27104
|
-
var ProjectResourceApplyWorkflowResultSchema = external_exports.discriminatedUnion(
|
|
27105
|
-
"status",
|
|
27106
|
-
[
|
|
27107
|
-
external_exports.object({
|
|
27108
|
-
status: external_exports.literal("applied"),
|
|
27109
|
-
result: ProjectResourceApplyResultSchema
|
|
27110
|
-
}),
|
|
27111
|
-
external_exports.object({
|
|
27112
|
-
status: external_exports.literal("failed"),
|
|
27113
|
-
error: ProjectResourceApplyWorkflowErrorSchema
|
|
27114
|
-
})
|
|
27115
|
-
]
|
|
27116
|
-
);
|
|
27117
|
-
|
|
27118
|
-
// ../../packages/schemas/src/session-diagnostics.ts
|
|
27119
|
-
var SESSION_DIAGNOSTIC_REALTIME_EVENT = "session.diagnostic";
|
|
27120
|
-
var SESSION_DIAGNOSTIC_LEVELS = [
|
|
27121
|
-
"debug",
|
|
27122
|
-
"info",
|
|
27123
|
-
"warn",
|
|
27124
|
-
"error"
|
|
27125
|
-
];
|
|
27126
|
-
var SESSION_DIAGNOSTIC_SOURCES = [
|
|
27127
|
-
"web",
|
|
27128
|
-
"worker",
|
|
27129
|
-
"activity",
|
|
27130
|
-
"bridge",
|
|
27131
|
-
"runtime"
|
|
27132
|
-
];
|
|
27133
|
-
var SESSION_DIAGNOSTIC_PHASES = [
|
|
27134
|
-
"dispatch",
|
|
27135
|
-
"environment",
|
|
27136
|
-
"bridge",
|
|
27137
|
-
"delivery",
|
|
27138
|
-
"command",
|
|
27139
|
-
"runtime"
|
|
27140
|
-
];
|
|
27141
|
-
var SESSION_DIAGNOSTIC_STATUSES = [
|
|
27142
|
-
"started",
|
|
27143
|
-
"succeeded",
|
|
27144
|
-
"retrying",
|
|
27145
|
-
"failed",
|
|
27146
|
-
"skipped"
|
|
27147
|
-
];
|
|
27148
|
-
var SessionDiagnosticLevelSchema = external_exports.enum(SESSION_DIAGNOSTIC_LEVELS);
|
|
27149
|
-
var SessionDiagnosticSourceSchema = external_exports.enum(SESSION_DIAGNOSTIC_SOURCES);
|
|
27150
|
-
var SessionDiagnosticPhaseSchema = external_exports.enum(SESSION_DIAGNOSTIC_PHASES);
|
|
27151
|
-
var SessionDiagnosticStatusSchema = external_exports.enum(
|
|
27152
|
-
SESSION_DIAGNOSTIC_STATUSES
|
|
27153
|
-
);
|
|
27154
|
-
var SessionDiagnosticEventSchema = external_exports.object({
|
|
27155
|
-
type: external_exports.literal(SESSION_DIAGNOSTIC_REALTIME_EVENT),
|
|
27156
|
-
id: external_exports.string().min(1),
|
|
27157
|
-
sessionId: SessionIdSchema2,
|
|
27158
|
-
level: SessionDiagnosticLevelSchema,
|
|
27159
|
-
source: SessionDiagnosticSourceSchema,
|
|
27160
|
-
phase: SessionDiagnosticPhaseSchema,
|
|
27161
|
-
step: external_exports.string().trim().min(1),
|
|
27162
|
-
status: SessionDiagnosticStatusSchema,
|
|
27163
|
-
message: external_exports.string().trim().min(1),
|
|
27164
|
-
commandId: SessionCommandIdSchema2.optional(),
|
|
27165
|
-
runtimeId: RuntimeIdSchema2.optional(),
|
|
27166
|
-
bridgeLeaseId: RuntimeBridgeLeaseIdSchema2.optional(),
|
|
27167
|
-
attempt: external_exports.number().int().nonnegative().optional(),
|
|
27168
|
-
durationMs: external_exports.number().nonnegative().optional(),
|
|
27169
|
-
details: external_exports.record(external_exports.string(), JsonValueSchema2).optional(),
|
|
27170
|
-
createdAt: external_exports.string().datetime()
|
|
27171
|
-
});
|
|
27172
|
-
|
|
27173
|
-
// ../../packages/schemas/src/singleton-refresh.ts
|
|
27174
|
-
var SINGLETON_RESPAWN_REASONS = ["refresh", "failure"];
|
|
27175
|
-
var SingletonRespawnReasonSchema = external_exports.enum(SINGLETON_RESPAWN_REASONS);
|
|
27176
|
-
var SingletonRespawnSchema = external_exports.object({
|
|
27177
|
-
reason: SingletonRespawnReasonSchema.default("refresh")
|
|
27178
|
-
}).strict();
|
|
27179
|
-
var SingletonRefreshEventPayloadSchema = external_exports.object({
|
|
27180
|
-
trigger: external_exports.literal("agent.refresh"),
|
|
27181
|
-
refresh: external_exports.object({
|
|
27182
|
-
reason: SingletonRespawnReasonSchema,
|
|
27183
|
-
agentResourceId: external_exports.string().trim().min(1),
|
|
27184
|
-
previousSessionId: external_exports.string().trim().min(1)
|
|
27185
|
-
})
|
|
27186
|
-
});
|
|
27187
|
-
|
|
27188
|
-
// ../../packages/schemas/src/session-commands.ts
|
|
27189
|
-
var SESSION_COMMAND_KINDS = [
|
|
27190
|
-
"message",
|
|
27191
|
-
"answer",
|
|
27192
|
-
"pause",
|
|
27193
|
-
"resume",
|
|
27194
|
-
"interrupt",
|
|
27195
|
-
"cancel",
|
|
27196
|
-
"stop"
|
|
27197
|
-
];
|
|
27198
|
-
var SESSION_DISPATCH_COMMAND_KINDS = [
|
|
27199
|
-
"start",
|
|
27200
|
-
"startWithMessage",
|
|
27201
|
-
"message",
|
|
27202
|
-
"answer",
|
|
27203
|
-
"stop"
|
|
27204
|
-
];
|
|
27205
|
-
var SESSION_PERSISTED_COMMAND_KINDS = [
|
|
27206
|
-
"message",
|
|
27207
|
-
"pause",
|
|
27208
|
-
"resume",
|
|
27209
|
-
"interrupt",
|
|
27210
|
-
"cancel",
|
|
27211
|
-
"stop",
|
|
27212
|
-
"start",
|
|
27213
|
-
"startWithMessage",
|
|
27214
|
-
"answer"
|
|
27215
|
-
];
|
|
27216
|
-
var SESSION_LIFECYCLE_COMMAND_KINDS = [
|
|
27217
|
-
"pause",
|
|
27218
|
-
"resume",
|
|
27219
|
-
"interrupt",
|
|
27220
|
-
"cancel",
|
|
27221
|
-
"stop"
|
|
27222
|
-
];
|
|
27223
|
-
var SESSION_COMMAND_STATUSES = [
|
|
27224
|
-
"pending",
|
|
27225
|
-
"dispatching",
|
|
27226
|
-
"accepted",
|
|
27227
|
-
"failed"
|
|
27228
|
-
];
|
|
27229
|
-
var SESSION_DISPATCH_COMMAND_STATUSES = [
|
|
27230
|
-
"pending",
|
|
27231
|
-
"dispatching",
|
|
27232
|
-
"accepted",
|
|
27233
|
-
"failed"
|
|
27234
|
-
];
|
|
27235
|
-
var SessionCommandKindSchema2 = external_exports.enum(SESSION_COMMAND_KINDS);
|
|
27236
|
-
var SessionPersistedCommandKindSchema = external_exports.enum(
|
|
27237
|
-
SESSION_PERSISTED_COMMAND_KINDS
|
|
27238
|
-
);
|
|
27239
|
-
var SessionDispatchCommandKindSchema = external_exports.enum(
|
|
27240
|
-
SESSION_DISPATCH_COMMAND_KINDS
|
|
27241
|
-
);
|
|
27242
|
-
var RunLifecycleCommandKindSchema = external_exports.enum(
|
|
27243
|
-
SESSION_LIFECYCLE_COMMAND_KINDS
|
|
27244
|
-
);
|
|
27245
|
-
var SessionCommandStatusSchema = external_exports.enum(SESSION_COMMAND_STATUSES);
|
|
27246
|
-
var SessionDispatchCommandStatusSchema = external_exports.enum(
|
|
27247
|
-
SESSION_DISPATCH_COMMAND_STATUSES
|
|
27248
|
-
);
|
|
27249
|
-
var SessionCommandSenderSchema = external_exports.discriminatedUnion("type", [
|
|
27250
|
-
external_exports.object({
|
|
27251
|
-
type: external_exports.literal("operator"),
|
|
27252
|
-
id: external_exports.string().trim().min(1).nullable().default(null),
|
|
27253
|
-
actor: AuthActorSchema.nullable().optional()
|
|
27254
|
-
}),
|
|
27255
|
-
external_exports.object({
|
|
27256
|
-
type: external_exports.literal("agent"),
|
|
27257
|
-
sessionId: SessionIdSchema2
|
|
27258
|
-
}),
|
|
27259
|
-
external_exports.object({
|
|
27260
|
-
type: external_exports.literal("system")
|
|
27261
|
-
})
|
|
27262
|
-
]);
|
|
27263
|
-
var MESSAGE_DELIVERY_MODES = ["interrupt", "deferred"];
|
|
27264
|
-
var MessageDeliveryModeSchema = external_exports.enum(MESSAGE_DELIVERY_MODES);
|
|
27265
|
-
var TRIGGER_INJECTION_MODALITIES = [
|
|
27266
|
-
"chat",
|
|
27267
|
-
"githubCheck",
|
|
27268
|
-
"githubCheckAction",
|
|
27269
|
-
"githubPullRequest",
|
|
27270
|
-
"other"
|
|
27271
|
-
];
|
|
27272
|
-
var TriggerInjectionModalitySchema = external_exports.enum(
|
|
27273
|
-
TRIGGER_INJECTION_MODALITIES
|
|
27274
|
-
);
|
|
27275
|
-
var RunMessageCommandPayloadSchema = external_exports.object({
|
|
27276
|
-
message: external_exports.string().trim().min(1),
|
|
27277
|
-
// Optional so existing payloads and direct operator/agent messages stay
|
|
27278
|
-
// valid without it; trigger routing sets "deferred" for GitHub check
|
|
27279
|
-
// events. An absent mode is treated as "interrupt" at the delivery
|
|
27280
|
-
// boundary (commandDeliveryPayload / the runtime handler), so the default
|
|
27281
|
-
// lives where the value is consumed rather than as a required field every
|
|
27282
|
-
// call site must construct.
|
|
27283
|
-
deliveryMode: MessageDeliveryModeSchema.optional(),
|
|
27284
|
-
metadata: JsonValueSchema2.optional()
|
|
27285
|
-
}).strict();
|
|
27286
|
-
var RunAnswerCommandPayloadSchema = external_exports.object({
|
|
27287
|
-
toolCallId: external_exports.string().trim().min(1),
|
|
27288
|
-
answers: external_exports.record(external_exports.string(), external_exports.string()),
|
|
27289
|
-
response: external_exports.string().trim().min(1).optional()
|
|
27290
|
-
}).strict().refine((value2) => Object.keys(value2.answers).length > 0 || value2.response, {
|
|
27291
|
-
message: "Provide at least one answer or a freeform response"
|
|
27292
|
-
});
|
|
27293
|
-
var RunLifecycleCommandPayloadSchema = external_exports.object({
|
|
27294
|
-
reason: external_exports.string().trim().min(1).optional()
|
|
27295
|
-
}).strict();
|
|
27296
|
-
var RunStopCommandPayloadSchema = external_exports.object({
|
|
27297
|
-
reason: external_exports.string().trim().min(1).optional(),
|
|
27298
|
-
respawn: SingletonRespawnSchema.optional()
|
|
27299
26980
|
}).strict();
|
|
27300
|
-
var
|
|
26981
|
+
var SessionPersistedCommandPayloadSchema = external_exports.union([
|
|
27301
26982
|
RunMessageCommandPayloadSchema,
|
|
27302
26983
|
RunAnswerCommandPayloadSchema,
|
|
27303
26984
|
RunLifecycleCommandPayloadSchema,
|
|
27304
|
-
RunStopCommandPayloadSchema
|
|
26985
|
+
RunStopCommandPayloadSchema,
|
|
26986
|
+
RunStartCommandPayloadSchema,
|
|
26987
|
+
RunStartWithMessageCommandPayloadSchema
|
|
27305
26988
|
]);
|
|
27306
|
-
var
|
|
27307
|
-
|
|
27308
|
-
metadata: JsonValueSchema2.optional()
|
|
27309
|
-
});
|
|
27310
|
-
var CreateRunAnswerCommandRequestSchema = RunAnswerCommandPayloadSchema;
|
|
27311
|
-
var CreateRunLifecycleCommandRequestSchema = external_exports.object({
|
|
27312
|
-
reason: external_exports.string().trim().min(1).optional()
|
|
27313
|
-
});
|
|
27314
|
-
var CreateRunStopCommandRequestSchema = external_exports.object({
|
|
27315
|
-
reason: external_exports.string().trim().min(1).optional(),
|
|
27316
|
-
respawn: SingletonRespawnSchema.optional()
|
|
27317
|
-
});
|
|
27318
|
-
var CreateSessionCommandRequestSchema = external_exports.discriminatedUnion("kind", [
|
|
27319
|
-
external_exports.object({
|
|
26989
|
+
var SessionCommandRecordSchema = external_exports.discriminatedUnion("kind", [
|
|
26990
|
+
SessionCommandRecordBaseSchema.extend({
|
|
27320
26991
|
kind: external_exports.literal("message"),
|
|
27321
|
-
payload:
|
|
27322
|
-
})
|
|
27323
|
-
|
|
26992
|
+
payload: RunMessageCommandPayloadSchema
|
|
26993
|
+
}),
|
|
26994
|
+
SessionCommandRecordBaseSchema.extend({
|
|
27324
26995
|
kind: external_exports.literal("answer"),
|
|
27325
|
-
payload:
|
|
27326
|
-
})
|
|
27327
|
-
|
|
26996
|
+
payload: RunAnswerCommandPayloadSchema
|
|
26997
|
+
}),
|
|
26998
|
+
SessionCommandRecordBaseSchema.extend({
|
|
27328
26999
|
kind: external_exports.literal("pause"),
|
|
27329
|
-
payload:
|
|
27330
|
-
})
|
|
27331
|
-
|
|
27000
|
+
payload: RunLifecycleCommandPayloadSchema
|
|
27001
|
+
}),
|
|
27002
|
+
SessionCommandRecordBaseSchema.extend({
|
|
27332
27003
|
kind: external_exports.literal("resume"),
|
|
27333
|
-
payload:
|
|
27334
|
-
})
|
|
27335
|
-
|
|
27004
|
+
payload: RunLifecycleCommandPayloadSchema
|
|
27005
|
+
}),
|
|
27006
|
+
SessionCommandRecordBaseSchema.extend({
|
|
27336
27007
|
kind: external_exports.literal("interrupt"),
|
|
27337
|
-
payload:
|
|
27338
|
-
})
|
|
27339
|
-
|
|
27008
|
+
payload: RunLifecycleCommandPayloadSchema
|
|
27009
|
+
}),
|
|
27010
|
+
SessionCommandRecordBaseSchema.extend({
|
|
27340
27011
|
kind: external_exports.literal("cancel"),
|
|
27341
|
-
payload:
|
|
27342
|
-
})
|
|
27343
|
-
|
|
27012
|
+
payload: RunLifecycleCommandPayloadSchema
|
|
27013
|
+
}),
|
|
27014
|
+
SessionCommandRecordBaseSchema.extend({
|
|
27344
27015
|
kind: external_exports.literal("stop"),
|
|
27345
|
-
payload:
|
|
27346
|
-
})
|
|
27347
|
-
|
|
27348
|
-
|
|
27349
|
-
|
|
27350
|
-
|
|
27351
|
-
|
|
27352
|
-
|
|
27353
|
-
|
|
27354
|
-
|
|
27355
|
-
agentName: external_exports.string().trim().min(1).optional(),
|
|
27356
|
-
resolutionPolicy: RunResolutionPolicySchema
|
|
27357
|
-
}).refine((value2) => Boolean(value2.agentId) !== Boolean(value2.agentName), {
|
|
27358
|
-
message: "Provide exactly one of agentId or agentName"
|
|
27359
|
-
});
|
|
27360
|
-
var SessionCommandRecordBaseSchema = external_exports.object({
|
|
27361
|
-
id: SessionCommandIdSchema2,
|
|
27362
|
-
sessionId: SessionIdSchema2,
|
|
27363
|
-
sender: SessionCommandSenderSchema,
|
|
27364
|
-
idempotencyKey: external_exports.string().min(1).nullable(),
|
|
27365
|
-
status: SessionCommandStatusSchema,
|
|
27366
|
-
attemptCount: external_exports.number().int().nonnegative(),
|
|
27367
|
-
nextAttemptAt: external_exports.string().datetime().nullable(),
|
|
27368
|
-
lastAttemptAt: external_exports.string().datetime().nullable(),
|
|
27369
|
-
acceptedAt: external_exports.string().datetime().nullable(),
|
|
27370
|
-
failedAt: external_exports.string().datetime().nullable(),
|
|
27371
|
-
error: JsonValueSchema2.nullable(),
|
|
27372
|
-
createdAt: external_exports.string().datetime(),
|
|
27373
|
-
updatedAt: external_exports.string().datetime()
|
|
27374
|
-
});
|
|
27375
|
-
var RunStartCommandPayloadSchema = external_exports.object({
|
|
27376
|
-
kind: external_exports.literal("start")
|
|
27377
|
-
}).strict();
|
|
27378
|
-
var RunStartWithMessageCommandPayloadSchema = external_exports.object({
|
|
27379
|
-
kind: external_exports.literal("startWithMessage"),
|
|
27380
|
-
message: external_exports.string().trim().min(1)
|
|
27381
|
-
}).strict();
|
|
27382
|
-
var SessionPersistedCommandPayloadSchema = external_exports.union([
|
|
27383
|
-
RunMessageCommandPayloadSchema,
|
|
27384
|
-
RunAnswerCommandPayloadSchema,
|
|
27385
|
-
RunLifecycleCommandPayloadSchema,
|
|
27386
|
-
RunStopCommandPayloadSchema,
|
|
27387
|
-
RunStartCommandPayloadSchema,
|
|
27388
|
-
RunStartWithMessageCommandPayloadSchema
|
|
27389
|
-
]);
|
|
27390
|
-
var SessionCommandRecordSchema = external_exports.discriminatedUnion("kind", [
|
|
27391
|
-
SessionCommandRecordBaseSchema.extend({
|
|
27392
|
-
kind: external_exports.literal("message"),
|
|
27393
|
-
payload: RunMessageCommandPayloadSchema
|
|
27394
|
-
}),
|
|
27395
|
-
SessionCommandRecordBaseSchema.extend({
|
|
27396
|
-
kind: external_exports.literal("answer"),
|
|
27397
|
-
payload: RunAnswerCommandPayloadSchema
|
|
27398
|
-
}),
|
|
27399
|
-
SessionCommandRecordBaseSchema.extend({
|
|
27400
|
-
kind: external_exports.literal("pause"),
|
|
27401
|
-
payload: RunLifecycleCommandPayloadSchema
|
|
27402
|
-
}),
|
|
27403
|
-
SessionCommandRecordBaseSchema.extend({
|
|
27404
|
-
kind: external_exports.literal("resume"),
|
|
27405
|
-
payload: RunLifecycleCommandPayloadSchema
|
|
27406
|
-
}),
|
|
27407
|
-
SessionCommandRecordBaseSchema.extend({
|
|
27408
|
-
kind: external_exports.literal("interrupt"),
|
|
27409
|
-
payload: RunLifecycleCommandPayloadSchema
|
|
27410
|
-
}),
|
|
27411
|
-
SessionCommandRecordBaseSchema.extend({
|
|
27412
|
-
kind: external_exports.literal("cancel"),
|
|
27413
|
-
payload: RunLifecycleCommandPayloadSchema
|
|
27414
|
-
}),
|
|
27415
|
-
SessionCommandRecordBaseSchema.extend({
|
|
27416
|
-
kind: external_exports.literal("stop"),
|
|
27417
|
-
payload: RunStopCommandPayloadSchema
|
|
27418
|
-
}),
|
|
27419
|
-
SessionCommandRecordBaseSchema.extend({
|
|
27420
|
-
kind: external_exports.literal("start"),
|
|
27421
|
-
payload: RunStartCommandPayloadSchema
|
|
27422
|
-
}),
|
|
27423
|
-
SessionCommandRecordBaseSchema.extend({
|
|
27424
|
-
kind: external_exports.literal("startWithMessage"),
|
|
27425
|
-
payload: RunStartWithMessageCommandPayloadSchema
|
|
27426
|
-
})
|
|
27016
|
+
payload: RunStopCommandPayloadSchema
|
|
27017
|
+
}),
|
|
27018
|
+
SessionCommandRecordBaseSchema.extend({
|
|
27019
|
+
kind: external_exports.literal("start"),
|
|
27020
|
+
payload: RunStartCommandPayloadSchema
|
|
27021
|
+
}),
|
|
27022
|
+
SessionCommandRecordBaseSchema.extend({
|
|
27023
|
+
kind: external_exports.literal("startWithMessage"),
|
|
27024
|
+
payload: RunStartWithMessageCommandPayloadSchema
|
|
27025
|
+
})
|
|
27427
27026
|
]);
|
|
27428
27027
|
var SessionDispatchMessageCommandPayloadSchema = external_exports.object({
|
|
27429
27028
|
kind: external_exports.literal("message"),
|
|
@@ -27642,392 +27241,1357 @@ var SessionsArchiveResponseSchema = external_exports.object({
|
|
|
27642
27241
|
sessions: external_exports.array(SessionRecordSchema)
|
|
27643
27242
|
});
|
|
27644
27243
|
|
|
27645
|
-
// ../../packages/schemas/src/
|
|
27646
|
-
var
|
|
27647
|
-
|
|
27648
|
-
|
|
27649
|
-
originalBytes: external_exports.number().int().nonnegative()
|
|
27650
|
-
});
|
|
27651
|
-
var RunConversationSearchSnippetSchema = external_exports.object({
|
|
27652
|
-
partIndex: external_exports.number().int().nonnegative(),
|
|
27653
|
-
partType: external_exports.string(),
|
|
27654
|
-
/** The search term this snippet was produced for. */
|
|
27655
|
-
query: external_exports.string(),
|
|
27656
|
-
text: external_exports.string()
|
|
27657
|
-
});
|
|
27658
|
-
var RunConversationSearchMatchSchema = external_exports.object({
|
|
27244
|
+
// ../../packages/schemas/src/live-events.ts
|
|
27245
|
+
var LiveEntityEventEnvelopeSchema = external_exports.object({
|
|
27246
|
+
// Replay cursor for this frame; the SSE `id:` mirrors it so reconnects resume
|
|
27247
|
+
// from `sequence > cursor`.
|
|
27659
27248
|
sequence: external_exports.number().int().nonnegative(),
|
|
27660
|
-
|
|
27661
|
-
|
|
27662
|
-
|
|
27663
|
-
|
|
27664
|
-
|
|
27665
|
-
|
|
27666
|
-
/** Total match occurrences across terms in this entry. */
|
|
27667
|
-
matchCount: external_exports.number().int().positive(),
|
|
27668
|
-
snippets: external_exports.array(RunConversationSearchSnippetSchema)
|
|
27669
|
-
});
|
|
27670
|
-
var RunConversationSearchResponseSchema = external_exports.object({
|
|
27671
|
-
matches: external_exports.array(RunConversationSearchMatchSchema),
|
|
27672
|
-
hasMore: external_exports.boolean(),
|
|
27673
|
-
/**
|
|
27674
|
-
* Sequence of the last candidate entry scanned (not just the last confirmed
|
|
27675
|
-
* match) — pass as `afterSequence` to continue without re-scanning
|
|
27676
|
-
* candidates the match confirmation dropped. Null when nothing was scanned.
|
|
27677
|
-
*/
|
|
27678
|
-
nextAfterSequence: external_exports.number().int().nullable()
|
|
27249
|
+
eventKey: external_exports.string().min(1),
|
|
27250
|
+
// The event's `subjectKind`, surfaced as `entity` for client-side dispatch.
|
|
27251
|
+
entity: external_exports.string().min(1),
|
|
27252
|
+
subjectId: external_exports.string().min(1),
|
|
27253
|
+
payload: JsonValueSchema2,
|
|
27254
|
+
occurredAt: external_exports.string().min(1)
|
|
27679
27255
|
});
|
|
27680
|
-
|
|
27681
|
-
|
|
27682
|
-
|
|
27683
|
-
|
|
27684
|
-
|
|
27685
|
-
|
|
27686
|
-
|
|
27687
|
-
isError: external_exports.boolean().nullable(),
|
|
27688
|
-
/** Result `completedAt` minus call `createdAt`; null without a result. */
|
|
27689
|
-
durationMs: external_exports.number().int().nonnegative().nullable(),
|
|
27690
|
-
startedAt: external_exports.string().datetime(),
|
|
27691
|
-
completedAt: external_exports.string().datetime().nullable()
|
|
27256
|
+
|
|
27257
|
+
// ../../packages/schemas/src/mcp.ts
|
|
27258
|
+
var McpToolCallMessageSchema = external_exports.object({
|
|
27259
|
+
method: external_exports.literal("tools/call"),
|
|
27260
|
+
params: external_exports.object({
|
|
27261
|
+
name: external_exports.string().trim().min(1)
|
|
27262
|
+
})
|
|
27692
27263
|
});
|
|
27693
|
-
var
|
|
27694
|
-
|
|
27695
|
-
|
|
27696
|
-
|
|
27697
|
-
|
|
27698
|
-
|
|
27699
|
-
|
|
27700
|
-
|
|
27701
|
-
|
|
27702
|
-
|
|
27264
|
+
var McpJsonRpcMessageSchema = external_exports.object({
|
|
27265
|
+
method: external_exports.string().optional()
|
|
27266
|
+
}).passthrough();
|
|
27267
|
+
var McpPostBodySchema = external_exports.union([McpJsonRpcMessageSchema, external_exports.array(McpJsonRpcMessageSchema)]).transform((body) => Array.isArray(body) ? body : [body]);
|
|
27268
|
+
|
|
27269
|
+
// ../../packages/schemas/src/pricing.ts
|
|
27270
|
+
var RATE_CARD_2026_06_23 = {
|
|
27271
|
+
version: "2026-06-23",
|
|
27272
|
+
effectiveAt: "2026-06-23T00:00:00.000Z",
|
|
27273
|
+
models: {
|
|
27274
|
+
"claude-opus-4-8": opusTier(),
|
|
27275
|
+
"claude-opus-4-7": opusTier(),
|
|
27276
|
+
"claude-opus-4-6": opusTier(),
|
|
27277
|
+
"claude-sonnet-4-6": tier(3, 15),
|
|
27278
|
+
"claude-haiku-4-5": tier(1, 5),
|
|
27279
|
+
"claude-haiku-4-5-20251001": tier(1, 5),
|
|
27280
|
+
"claude-fable-5": tier(10, 50),
|
|
27281
|
+
// OpenAI gpt-5.3-codex, standard tier: input $1.75/Mtok, cached input
|
|
27282
|
+
// $0.175/Mtok, output $14.00/Mtok. Source (verified 2026-06-23):
|
|
27283
|
+
// https://developers.openai.com/api/docs/models/gpt-5.3-codex and
|
|
27284
|
+
// https://developers.openai.com/api/docs/pricing (priority tier is 2x; we
|
|
27285
|
+
// bill standard).
|
|
27286
|
+
"gpt-5.3-codex": openAiTier({
|
|
27287
|
+
input: 1.75,
|
|
27288
|
+
cachedInput: 0.175,
|
|
27289
|
+
output: 14
|
|
27290
|
+
})
|
|
27291
|
+
}
|
|
27292
|
+
};
|
|
27293
|
+
var PRICING_RATE_CARDS = {
|
|
27294
|
+
[RATE_CARD_2026_06_23.version]: RATE_CARD_2026_06_23
|
|
27295
|
+
};
|
|
27296
|
+
var CURRENT_PRICING_VERSION = RATE_CARD_2026_06_23.version;
|
|
27297
|
+
function tier(inputUsdPerMtok, outputUsdPerMtok) {
|
|
27298
|
+
return {
|
|
27299
|
+
inputUsdPerMtok,
|
|
27300
|
+
outputUsdPerMtok,
|
|
27301
|
+
cacheWrite5mUsdPerMtok: inputUsdPerMtok * 1.25,
|
|
27302
|
+
cacheReadUsdPerMtok: inputUsdPerMtok * 0.1
|
|
27303
|
+
};
|
|
27304
|
+
}
|
|
27305
|
+
function opusTier() {
|
|
27306
|
+
return tier(5, 25);
|
|
27307
|
+
}
|
|
27308
|
+
function openAiTier(rates) {
|
|
27309
|
+
return {
|
|
27310
|
+
inputUsdPerMtok: rates.input,
|
|
27311
|
+
outputUsdPerMtok: rates.output,
|
|
27312
|
+
cacheWrite5mUsdPerMtok: rates.input,
|
|
27313
|
+
cacheReadUsdPerMtok: rates.cachedInput
|
|
27314
|
+
};
|
|
27315
|
+
}
|
|
27316
|
+
|
|
27317
|
+
// ../../packages/schemas/src/project-service-accounts.ts
|
|
27318
|
+
var ProjectServiceAccountSchema = external_exports.object({
|
|
27319
|
+
id: ServiceAccountIdSchema,
|
|
27320
|
+
organizationId: OrganizationIdSchema,
|
|
27321
|
+
projectId: ProjectIdSchema,
|
|
27322
|
+
name: ResourceNameSchema,
|
|
27323
|
+
scopes: external_exports.array(AuthScopeSchema),
|
|
27324
|
+
createdAt: external_exports.string().datetime()
|
|
27703
27325
|
});
|
|
27704
|
-
var
|
|
27705
|
-
|
|
27706
|
-
|
|
27707
|
-
"dropped",
|
|
27708
|
-
"warned",
|
|
27709
|
-
"errored"
|
|
27710
|
-
];
|
|
27711
|
-
var SessionTriggerDeliveryActionSchema = external_exports.enum(
|
|
27712
|
-
SESSION_TRIGGER_DELIVERY_ACTIONS
|
|
27713
|
-
);
|
|
27714
|
-
var SESSION_EVENT_ORIGIN_KINDS = [
|
|
27715
|
-
"internal",
|
|
27716
|
-
"provider_grant",
|
|
27717
|
-
"webhook"
|
|
27718
|
-
];
|
|
27719
|
-
var SessionEventOriginKindSchema = external_exports.enum(SESSION_EVENT_ORIGIN_KINDS);
|
|
27720
|
-
var SessionTriggerDeliveryRecordSchema = external_exports.object({
|
|
27721
|
-
action: SessionTriggerDeliveryActionSchema,
|
|
27722
|
-
triggerId: external_exports.string(),
|
|
27723
|
-
eventKey: external_exports.string(),
|
|
27724
|
-
originKind: SessionEventOriginKindSchema,
|
|
27725
|
-
occurredAt: external_exports.string().datetime(),
|
|
27726
|
-
receivedAt: external_exports.string().datetime(),
|
|
27727
|
-
deliveredAt: external_exports.string().datetime(),
|
|
27728
|
-
reason: external_exports.string().nullable(),
|
|
27729
|
-
/** Event payload; may be a {@link TruncatedValueSchema} marker. */
|
|
27730
|
-
payload: JsonValueSchema2.optional()
|
|
27326
|
+
var ProjectServiceAccountCreateRequestSchema = external_exports.object({
|
|
27327
|
+
name: ResourceNameSchema,
|
|
27328
|
+
scopes: external_exports.array(AuthScopeSchema).min(1)
|
|
27731
27329
|
});
|
|
27732
|
-
var
|
|
27733
|
-
|
|
27734
|
-
spawn: SessionTriggerDeliveryRecordSchema.nullable(),
|
|
27735
|
-
/** Who started the session, for manual/CLI/agent spawns. */
|
|
27736
|
-
starter: AuthActorSchema.nullable(),
|
|
27737
|
-
/** Subsequent deliveries against the session, chronological. */
|
|
27738
|
-
deliveries: external_exports.array(SessionTriggerDeliveryRecordSchema)
|
|
27330
|
+
var ProjectServiceAccountUpdateRequestSchema = external_exports.object({
|
|
27331
|
+
scopes: external_exports.array(AuthScopeSchema).min(1)
|
|
27739
27332
|
});
|
|
27740
|
-
var
|
|
27741
|
-
|
|
27742
|
-
|
|
27743
|
-
payload: JsonValueSchema2,
|
|
27744
|
-
recordedAt: external_exports.string().datetime()
|
|
27333
|
+
var ProjectServiceAccountTokenResponseSchema = external_exports.object({
|
|
27334
|
+
serviceAccount: ProjectServiceAccountSchema,
|
|
27335
|
+
token: external_exports.string().min(1)
|
|
27745
27336
|
});
|
|
27746
|
-
var
|
|
27747
|
-
|
|
27337
|
+
var ProjectServiceAccountUpdateResponseSchema = external_exports.object({
|
|
27338
|
+
serviceAccount: ProjectServiceAccountSchema
|
|
27748
27339
|
});
|
|
27749
|
-
var
|
|
27750
|
-
|
|
27751
|
-
|
|
27752
|
-
source: SessionBindingSourceSchema,
|
|
27753
|
-
status: SessionBindingStatusSchema,
|
|
27754
|
-
payload: JsonValueSchema2.nullable(),
|
|
27755
|
-
createdAt: external_exports.string().datetime(),
|
|
27756
|
-
updatedAt: external_exports.string().datetime()
|
|
27340
|
+
var ProjectServiceAccountRemoveResponseSchema = external_exports.object({
|
|
27341
|
+
serviceAccount: ProjectServiceAccountSchema,
|
|
27342
|
+
removed: external_exports.literal(true)
|
|
27757
27343
|
});
|
|
27758
|
-
var
|
|
27759
|
-
|
|
27344
|
+
var ProjectServiceAccountListResponseSchema = external_exports.object({
|
|
27345
|
+
serviceAccounts: external_exports.array(ProjectServiceAccountSchema)
|
|
27760
27346
|
});
|
|
27761
|
-
|
|
27762
|
-
|
|
27763
|
-
|
|
27764
|
-
|
|
27765
|
-
|
|
27766
|
-
|
|
27347
|
+
|
|
27348
|
+
// ../../packages/schemas/src/project-resources.ts
|
|
27349
|
+
var EnvironmentApplyDocumentSchema = resourceApplyDocumentSchema(
|
|
27350
|
+
RESOURCE_KIND_ENVIRONMENT,
|
|
27351
|
+
EnvironmentApplyRequestSchema.shape.spec
|
|
27352
|
+
);
|
|
27353
|
+
var IdentityApplyDocumentSchema = resourceApplyDocumentSchema(
|
|
27354
|
+
RESOURCE_KIND_IDENTITY,
|
|
27355
|
+
IdentityApplyRequestSchema.shape.spec
|
|
27356
|
+
);
|
|
27357
|
+
var AgentApplyDocumentSchema = resourceApplyDocumentSchema(
|
|
27358
|
+
RESOURCE_KIND_AGENT,
|
|
27359
|
+
AgentApplyRequestSchema.shape.spec
|
|
27360
|
+
);
|
|
27361
|
+
var ProjectApplyResourceSchema = external_exports.discriminatedUnion("kind", [
|
|
27362
|
+
EnvironmentApplyDocumentSchema,
|
|
27363
|
+
IdentityApplyDocumentSchema,
|
|
27364
|
+
AgentApplyDocumentSchema
|
|
27365
|
+
]);
|
|
27366
|
+
var PROJECT_RESOURCE_APPLY_ORDER = [
|
|
27367
|
+
RESOURCE_KIND_CONNECTION,
|
|
27368
|
+
RESOURCE_KIND_IDENTITY,
|
|
27369
|
+
RESOURCE_KIND_ENVIRONMENT,
|
|
27370
|
+
RESOURCE_KIND_AGENT
|
|
27371
|
+
];
|
|
27372
|
+
var PROJECT_RESOURCE_KINDS = PROJECT_RESOURCE_APPLY_ORDER;
|
|
27373
|
+
var PROJECT_APPLY_RESOURCE_KINDS = [
|
|
27374
|
+
RESOURCE_KIND_IDENTITY,
|
|
27375
|
+
RESOURCE_KIND_ENVIRONMENT,
|
|
27376
|
+
RESOURCE_KIND_AGENT
|
|
27377
|
+
];
|
|
27378
|
+
var PROJECT_APPLY_BUNDLE_VERSION = 1;
|
|
27379
|
+
var MAX_PROJECT_APPLY_BUNDLE_BYTES = 64 * 1024 * 1024;
|
|
27380
|
+
var PROJECT_APPLY_BUNDLE_CONTENT_TYPE = "application/vnd.auto.project-apply-bundle+json";
|
|
27381
|
+
function projectApplyBundleStorageKey(sha256) {
|
|
27382
|
+
return `project-apply-bundles/${sha256}.json`;
|
|
27383
|
+
}
|
|
27384
|
+
var ProjectDeleteResourceBaseSchema = external_exports.object({
|
|
27385
|
+
name: external_exports.string().trim().min(1)
|
|
27767
27386
|
});
|
|
27768
|
-
var
|
|
27769
|
-
|
|
27770
|
-
/** Session-wide call count from the SQL aggregate. */
|
|
27771
|
-
calls: external_exports.number().int().nonnegative(),
|
|
27772
|
-
/**
|
|
27773
|
-
* Derived from the summary's recent-entries window (most recent ~1000
|
|
27774
|
-
* entries), so on very long sessions `errors` and `durationMs` can understate
|
|
27775
|
-
* relative to the session-wide `calls`.
|
|
27776
|
-
*/
|
|
27777
|
-
errors: external_exports.number().int().nonnegative(),
|
|
27778
|
-
durationMs: external_exports.object({
|
|
27779
|
-
p50: external_exports.number().nonnegative().nullable(),
|
|
27780
|
-
max: external_exports.number().nonnegative().nullable()
|
|
27781
|
-
})
|
|
27387
|
+
var ProjectDeleteResourceSchema = ProjectDeleteResourceBaseSchema.extend({
|
|
27388
|
+
kind: external_exports.enum(PROJECT_APPLY_RESOURCE_KINDS)
|
|
27782
27389
|
});
|
|
27783
|
-
var
|
|
27784
|
-
|
|
27785
|
-
|
|
27786
|
-
|
|
27787
|
-
|
|
27788
|
-
|
|
27789
|
-
|
|
27790
|
-
|
|
27791
|
-
|
|
27792
|
-
|
|
27793
|
-
startedAt: external_exports.string().datetime().nullable(),
|
|
27794
|
-
finishedAt: external_exports.string().datetime().nullable(),
|
|
27795
|
-
archivedAt: external_exports.string().datetime().nullable()
|
|
27796
|
-
}),
|
|
27797
|
-
timing: external_exports.object({
|
|
27798
|
-
/** `startedAt - createdAt`; null until the session starts. */
|
|
27799
|
-
queuedMs: external_exports.number().int().nonnegative().nullable(),
|
|
27800
|
-
/** `(finishedAt ?? now) - startedAt`; null until the session starts. */
|
|
27801
|
-
activeMs: external_exports.number().int().nonnegative().nullable(),
|
|
27802
|
-
/** `(finishedAt ?? now) - createdAt`. */
|
|
27803
|
-
totalMs: external_exports.number().int().nonnegative()
|
|
27804
|
-
}),
|
|
27805
|
-
conversation: external_exports.object({
|
|
27806
|
-
entryCount: external_exports.number().int().nonnegative(),
|
|
27807
|
-
firstEntryAt: external_exports.string().datetime().nullable(),
|
|
27808
|
-
lastEntryAt: external_exports.string().datetime().nullable(),
|
|
27809
|
-
countsByKind: external_exports.object({
|
|
27810
|
-
status: external_exports.number().int().nonnegative(),
|
|
27811
|
-
message: external_exports.number().int().nonnegative(),
|
|
27812
|
-
tool_call: external_exports.number().int().nonnegative(),
|
|
27813
|
-
tool_result: external_exports.number().int().nonnegative(),
|
|
27814
|
-
question: external_exports.number().int().nonnegative()
|
|
27815
|
-
}),
|
|
27816
|
-
failedEntryCount: external_exports.number().int().nonnegative(),
|
|
27817
|
-
lastSequence: external_exports.number().int().nonnegative()
|
|
27818
|
-
}),
|
|
27819
|
-
tools: external_exports.array(SessionToolStatSchema),
|
|
27820
|
-
/**
|
|
27821
|
-
* True when the session has more conversation entries than the summary's
|
|
27822
|
-
* recent-entries window, meaning per-tool `errors`/`durationMs` (and
|
|
27823
|
-
* `turns`) describe only the most recent slice of the session.
|
|
27824
|
-
*/
|
|
27825
|
-
toolStatsWindowed: external_exports.boolean(),
|
|
27826
|
-
trigger: external_exports.object({
|
|
27827
|
-
/** Spawning event key, or "manual" / "agent" for actor-started sessions. */
|
|
27828
|
-
spawn: external_exports.string(),
|
|
27829
|
-
signaledCount: external_exports.number().int().nonnegative(),
|
|
27830
|
-
droppedCount: external_exports.number().int().nonnegative()
|
|
27831
|
-
}),
|
|
27832
|
-
artifacts: external_exports.object({
|
|
27833
|
-
count: external_exports.number().int().nonnegative(),
|
|
27834
|
-
types: external_exports.array(external_exports.string())
|
|
27835
|
-
}),
|
|
27836
|
-
/** Active session bindings, counted with their distinct target types. */
|
|
27837
|
-
bindings: external_exports.object({
|
|
27838
|
-
count: external_exports.number().int().nonnegative(),
|
|
27839
|
-
targetTypes: external_exports.array(BindingTargetTypeSchema)
|
|
27840
|
-
}),
|
|
27841
|
-
/** Derived per-user-message turns, capped to the most recent. */
|
|
27842
|
-
turns: external_exports.array(RunTurnSchema),
|
|
27843
|
-
commands: external_exports.object({
|
|
27844
|
-
total: external_exports.number().int().nonnegative(),
|
|
27845
|
-
byKind: external_exports.record(external_exports.string(), external_exports.number().int().nonnegative()),
|
|
27846
|
-
failed: external_exports.number().int().nonnegative()
|
|
27390
|
+
var AVATAR_ASSET_CONTENT_TYPES = ["image/png", "image/jpeg"];
|
|
27391
|
+
var MAX_AVATAR_ASSET_BASE64_LENGTH = Math.ceil(MAX_AVATAR_ASSET_BYTES / 3) * 4 + 4;
|
|
27392
|
+
var ProjectApplyAssetSchema = external_exports.object({
|
|
27393
|
+
sha256: external_exports.string().regex(/^[a-f0-9]{64}$/),
|
|
27394
|
+
contentType: external_exports.enum(AVATAR_ASSET_CONTENT_TYPES),
|
|
27395
|
+
dataBase64: external_exports.string().min(1).max(MAX_AVATAR_ASSET_BASE64_LENGTH).regex(/^[A-Za-z0-9+/]+={0,2}$/)
|
|
27396
|
+
});
|
|
27397
|
+
var ProjectApplyAssetsSchema = external_exports.record(
|
|
27398
|
+
external_exports.string().refine(isAvatarAssetPathShapeValid, {
|
|
27399
|
+
message: "asset keys must be relative paths under .auto/assets"
|
|
27847
27400
|
}),
|
|
27848
|
-
|
|
27849
|
-
|
|
27850
|
-
|
|
27851
|
-
|
|
27852
|
-
|
|
27853
|
-
|
|
27854
|
-
|
|
27855
|
-
|
|
27856
|
-
|
|
27401
|
+
ProjectApplyAssetSchema
|
|
27402
|
+
);
|
|
27403
|
+
var AvatarAssetUploadResponseSchema = external_exports.object({
|
|
27404
|
+
sha256: external_exports.string().regex(/^[a-f0-9]{64}$/),
|
|
27405
|
+
contentType: external_exports.enum(AVATAR_ASSET_CONTENT_TYPES),
|
|
27406
|
+
sizeBytes: external_exports.number().int().positive()
|
|
27407
|
+
});
|
|
27408
|
+
var ApplyBundlePathSchema = external_exports.string().trim().min(1).max(4096).refine((path2) => !path2.startsWith("/") && !path2.includes("\0"), {
|
|
27409
|
+
message: "apply bundle paths must be relative paths"
|
|
27410
|
+
});
|
|
27411
|
+
var ProjectApplyBundleFileSchema = external_exports.object({
|
|
27412
|
+
path: ApplyBundlePathSchema,
|
|
27413
|
+
contentBase64: external_exports.string().regex(/^[A-Za-z0-9+/]*={0,2}$/)
|
|
27414
|
+
});
|
|
27415
|
+
var ProjectApplyBundleSchema = external_exports.object({
|
|
27416
|
+
version: external_exports.literal(PROJECT_APPLY_BUNDLE_VERSION),
|
|
27417
|
+
files: external_exports.array(ProjectApplyBundleFileSchema).max(2e4)
|
|
27418
|
+
});
|
|
27419
|
+
var ProjectApplyBundleRefSchema = external_exports.object({
|
|
27420
|
+
kind: external_exports.literal("vercel_blob"),
|
|
27421
|
+
storageKey: external_exports.string().trim().min(1).max(1024),
|
|
27422
|
+
sha256: external_exports.string().regex(SHA256_HEX_PATTERN),
|
|
27423
|
+
sizeBytes: external_exports.number().int().positive().max(MAX_PROJECT_APPLY_BUNDLE_BYTES)
|
|
27424
|
+
}).superRefine((ref, context) => {
|
|
27425
|
+
const expectedStorageKey = projectApplyBundleStorageKey(ref.sha256);
|
|
27426
|
+
if (ref.storageKey === expectedStorageKey) {
|
|
27427
|
+
return;
|
|
27428
|
+
}
|
|
27429
|
+
context.addIssue({
|
|
27430
|
+
code: "custom",
|
|
27431
|
+
path: ["storageKey"],
|
|
27432
|
+
message: "apply bundle storage key must match its sha256"
|
|
27433
|
+
});
|
|
27857
27434
|
});
|
|
27435
|
+
var ProjectApplyBundleUploadRequestSchema = external_exports.object({
|
|
27436
|
+
sha256: external_exports.string().regex(SHA256_HEX_PATTERN),
|
|
27437
|
+
sizeBytes: external_exports.number().int().positive().max(MAX_PROJECT_APPLY_BUNDLE_BYTES)
|
|
27438
|
+
});
|
|
27439
|
+
var ProjectApplyBundleUploadResponseSchema = external_exports.object({
|
|
27440
|
+
method: external_exports.literal("PUT"),
|
|
27441
|
+
uploadUrl: external_exports.string().url(),
|
|
27442
|
+
contentType: external_exports.literal(PROJECT_APPLY_BUNDLE_CONTENT_TYPE),
|
|
27443
|
+
source: ProjectApplyBundleRefSchema
|
|
27444
|
+
});
|
|
27445
|
+
var ProjectApplyBundleDirectoryEntrypointSchema = external_exports.object({
|
|
27446
|
+
kind: external_exports.literal("directory"),
|
|
27447
|
+
resourceRoot: ApplyBundlePathSchema.default(".auto"),
|
|
27448
|
+
displayResourceRoot: external_exports.string().trim().min(1).max(4096).optional()
|
|
27449
|
+
});
|
|
27450
|
+
var ProjectApplyBundleFileEntrypointSchema = external_exports.object({
|
|
27451
|
+
kind: external_exports.literal("file"),
|
|
27452
|
+
filePath: ApplyBundlePathSchema
|
|
27453
|
+
});
|
|
27454
|
+
var ProjectApplyBundleEntrypointSchema = external_exports.discriminatedUnion("kind", [
|
|
27455
|
+
ProjectApplyBundleDirectoryEntrypointSchema,
|
|
27456
|
+
ProjectApplyBundleFileEntrypointSchema
|
|
27457
|
+
]);
|
|
27458
|
+
var ProjectApplySourceSchema = external_exports.object({
|
|
27459
|
+
kind: external_exports.literal("bundle"),
|
|
27460
|
+
bundle: ProjectApplyBundleRefSchema,
|
|
27461
|
+
entrypoint: ProjectApplyBundleEntrypointSchema
|
|
27462
|
+
});
|
|
27463
|
+
var ProjectApplySourceRequestSchema = external_exports.object({
|
|
27464
|
+
source: ProjectApplySourceSchema,
|
|
27465
|
+
delete: external_exports.array(ProjectDeleteResourceSchema).default([]),
|
|
27466
|
+
dryRun: external_exports.boolean().default(false),
|
|
27467
|
+
prune: external_exports.boolean().default(true)
|
|
27468
|
+
});
|
|
27469
|
+
var ProjectApplyRequestSchema = external_exports.object({
|
|
27470
|
+
delete: external_exports.array(ProjectDeleteResourceSchema).default([]),
|
|
27471
|
+
dryRun: external_exports.boolean().default(false),
|
|
27472
|
+
prune: external_exports.boolean().default(false),
|
|
27473
|
+
resources: external_exports.array(ProjectApplyResourceSchema).default([]),
|
|
27474
|
+
assets: ProjectApplyAssetsSchema.default({})
|
|
27475
|
+
});
|
|
27476
|
+
var ProjectApplySystemConfigSchema = external_exports.object({
|
|
27477
|
+
kind: external_exports.literal("system"),
|
|
27478
|
+
metadata: external_exports.object({
|
|
27479
|
+
name: external_exports.string().trim().min(1).optional()
|
|
27480
|
+
}).optional(),
|
|
27481
|
+
spec: ProjectApplyRequestSchema
|
|
27482
|
+
});
|
|
27483
|
+
var ProjectAppliedResourceSchema = external_exports.union([
|
|
27484
|
+
ProjectConnectionAllocationResourceSchema,
|
|
27485
|
+
EnvironmentResourceSchema,
|
|
27486
|
+
IdentityResourceSchema,
|
|
27487
|
+
AgentResourceSchema
|
|
27488
|
+
]);
|
|
27489
|
+
var ProjectApplyDiagnosticSchema = external_exports.object({
|
|
27490
|
+
// "info" is a non-blocking advisory (e.g. template-push capability/override
|
|
27491
|
+
// notices); "error" remains the validation-failure severity. Coordinated
|
|
27492
|
+
// shape with the optional-connection-gating work; whoever lands second rebases.
|
|
27493
|
+
severity: external_exports.enum(["error", "info"]),
|
|
27494
|
+
blocking: external_exports.boolean(),
|
|
27495
|
+
code: external_exports.string().min(1),
|
|
27496
|
+
message: external_exports.string().min(1),
|
|
27497
|
+
action: external_exports.enum(["create", "update", "unchanged"]),
|
|
27498
|
+
kind: external_exports.enum([
|
|
27499
|
+
RESOURCE_KIND_CONNECTION,
|
|
27500
|
+
RESOURCE_KIND_ENVIRONMENT,
|
|
27501
|
+
RESOURCE_KIND_IDENTITY,
|
|
27502
|
+
RESOURCE_KIND_AGENT
|
|
27503
|
+
]),
|
|
27504
|
+
name: external_exports.string().min(1)
|
|
27505
|
+
});
|
|
27506
|
+
var ProjectApplyResponsePrunedSchema = external_exports.object({
|
|
27507
|
+
kind: external_exports.enum(PROJECT_RESOURCE_KINDS),
|
|
27508
|
+
name: external_exports.string().min(1),
|
|
27509
|
+
uid: external_exports.string().min(1),
|
|
27510
|
+
heartbeatScheduleIds: external_exports.array(external_exports.string().min(1)).optional()
|
|
27511
|
+
});
|
|
27512
|
+
var ProjectApplyPlanDiffSchema = external_exports.object({
|
|
27513
|
+
action: external_exports.enum(["add", "remove", "change"]),
|
|
27514
|
+
path: external_exports.string().min(1)
|
|
27515
|
+
});
|
|
27516
|
+
var ProjectApplyResponseSchema = external_exports.object({
|
|
27517
|
+
dryRun: external_exports.boolean().default(false),
|
|
27518
|
+
resources: external_exports.array(ProjectAppliedResourceSchema),
|
|
27519
|
+
triggers: external_exports.array(ApplyTriggerReceiptSchema).default([]),
|
|
27520
|
+
diagnostics: external_exports.array(ProjectApplyDiagnosticSchema).default([]),
|
|
27521
|
+
plan: external_exports.array(
|
|
27522
|
+
external_exports.object({
|
|
27523
|
+
action: external_exports.enum(["create", "update", "unchanged", "archive"]),
|
|
27524
|
+
kind: external_exports.enum(PROJECT_RESOURCE_KINDS),
|
|
27525
|
+
name: external_exports.string().min(1),
|
|
27526
|
+
uid: external_exports.string().min(1).optional(),
|
|
27527
|
+
diff: external_exports.array(ProjectApplyPlanDiffSchema).optional(),
|
|
27528
|
+
diffOmitted: external_exports.number().int().positive().optional()
|
|
27529
|
+
})
|
|
27530
|
+
).default([]),
|
|
27531
|
+
pruned: external_exports.array(ProjectApplyResponsePrunedSchema).default([])
|
|
27532
|
+
});
|
|
27533
|
+
var ProjectResourceApplyResultSchema = ProjectApplyResponseSchema.extend({
|
|
27534
|
+
heartbeatSchedules: external_exports.array(
|
|
27535
|
+
external_exports.object({
|
|
27536
|
+
scheduleId: external_exports.string().trim().min(1),
|
|
27537
|
+
cron: external_exports.string().trim().min(1),
|
|
27538
|
+
timezone: external_exports.string().trim().min(1),
|
|
27539
|
+
input: HeartbeatTickWorkflowInputSchema
|
|
27540
|
+
})
|
|
27541
|
+
).default([]),
|
|
27542
|
+
deletedHeartbeatScheduleIds: external_exports.array(external_exports.string().trim().min(1)).default([])
|
|
27543
|
+
});
|
|
27544
|
+
var ProjectResourceApplyAuditActionSchema = external_exports.enum([
|
|
27545
|
+
"project_resources.apply",
|
|
27546
|
+
"github_sync.apply"
|
|
27547
|
+
]);
|
|
27548
|
+
var ProjectResourceApplyOperationIdSchema = external_exports.string().trim().min(1).max(512);
|
|
27549
|
+
var ProjectResourceApplyTriggerArtifactSchema = external_exports.object({
|
|
27550
|
+
type: external_exports.string().trim().min(1),
|
|
27551
|
+
externalId: external_exports.string().trim().min(1),
|
|
27552
|
+
payload: JsonValueSchema2.optional()
|
|
27553
|
+
}).strict();
|
|
27554
|
+
var ProjectResourceApplyWorkflowErrorSchema = external_exports.object({
|
|
27555
|
+
name: external_exports.string().trim().min(1),
|
|
27556
|
+
message: external_exports.string().trim().min(1)
|
|
27557
|
+
});
|
|
27558
|
+
var ProjectResourceApplyWorkflowInputSchema = external_exports.object({
|
|
27559
|
+
operationId: ProjectResourceApplyOperationIdSchema,
|
|
27560
|
+
request: ProjectApplyRequestSchema.optional(),
|
|
27561
|
+
sourceRequest: ProjectApplySourceRequestSchema.optional(),
|
|
27562
|
+
organizationId: OrganizationIdSchema,
|
|
27563
|
+
projectId: ProjectIdSchema.nullable().optional(),
|
|
27564
|
+
actor: AuthActorSchema,
|
|
27565
|
+
auditAction: ProjectResourceApplyAuditActionSchema,
|
|
27566
|
+
triggerArtifact: ProjectResourceApplyTriggerArtifactSchema.optional()
|
|
27567
|
+
}).superRefine((input, context) => {
|
|
27568
|
+
if ((input.request ? 1 : 0) + (input.sourceRequest ? 1 : 0) !== 1) {
|
|
27569
|
+
context.addIssue({
|
|
27570
|
+
code: "custom",
|
|
27571
|
+
path: ["request"],
|
|
27572
|
+
message: "exactly one of request or sourceRequest is required"
|
|
27573
|
+
});
|
|
27574
|
+
}
|
|
27575
|
+
});
|
|
27576
|
+
var ProjectResourceApplyWorkflowResultSchema = external_exports.discriminatedUnion(
|
|
27577
|
+
"status",
|
|
27578
|
+
[
|
|
27579
|
+
external_exports.object({
|
|
27580
|
+
status: external_exports.literal("applied"),
|
|
27581
|
+
result: ProjectResourceApplyResultSchema
|
|
27582
|
+
}),
|
|
27583
|
+
external_exports.object({
|
|
27584
|
+
status: external_exports.literal("failed"),
|
|
27585
|
+
error: ProjectResourceApplyWorkflowErrorSchema
|
|
27586
|
+
})
|
|
27587
|
+
]
|
|
27588
|
+
);
|
|
27589
|
+
|
|
27590
|
+
// ../../packages/schemas/src/session-diagnostics.ts
|
|
27591
|
+
var SESSION_DIAGNOSTIC_REALTIME_EVENT = "session.diagnostic";
|
|
27592
|
+
var SESSION_DIAGNOSTIC_LEVELS = [
|
|
27593
|
+
"debug",
|
|
27594
|
+
"info",
|
|
27595
|
+
"warn",
|
|
27596
|
+
"error"
|
|
27597
|
+
];
|
|
27598
|
+
var SESSION_DIAGNOSTIC_SOURCES = [
|
|
27599
|
+
"web",
|
|
27600
|
+
"worker",
|
|
27601
|
+
"activity",
|
|
27602
|
+
"bridge",
|
|
27603
|
+
"runtime"
|
|
27604
|
+
];
|
|
27605
|
+
var SESSION_DIAGNOSTIC_PHASES = [
|
|
27606
|
+
"dispatch",
|
|
27607
|
+
"environment",
|
|
27608
|
+
"bridge",
|
|
27609
|
+
"delivery",
|
|
27610
|
+
"command",
|
|
27611
|
+
"runtime"
|
|
27612
|
+
];
|
|
27613
|
+
var SESSION_DIAGNOSTIC_STATUSES = [
|
|
27614
|
+
"started",
|
|
27615
|
+
"succeeded",
|
|
27616
|
+
"retrying",
|
|
27617
|
+
"failed",
|
|
27618
|
+
"skipped"
|
|
27619
|
+
];
|
|
27620
|
+
var SessionDiagnosticLevelSchema = external_exports.enum(SESSION_DIAGNOSTIC_LEVELS);
|
|
27621
|
+
var SessionDiagnosticSourceSchema = external_exports.enum(SESSION_DIAGNOSTIC_SOURCES);
|
|
27622
|
+
var SessionDiagnosticPhaseSchema = external_exports.enum(SESSION_DIAGNOSTIC_PHASES);
|
|
27623
|
+
var SessionDiagnosticStatusSchema = external_exports.enum(
|
|
27624
|
+
SESSION_DIAGNOSTIC_STATUSES
|
|
27625
|
+
);
|
|
27626
|
+
var SessionDiagnosticEventSchema = external_exports.object({
|
|
27627
|
+
type: external_exports.literal(SESSION_DIAGNOSTIC_REALTIME_EVENT),
|
|
27628
|
+
id: external_exports.string().min(1),
|
|
27629
|
+
sessionId: SessionIdSchema2,
|
|
27630
|
+
level: SessionDiagnosticLevelSchema,
|
|
27631
|
+
source: SessionDiagnosticSourceSchema,
|
|
27632
|
+
phase: SessionDiagnosticPhaseSchema,
|
|
27633
|
+
step: external_exports.string().trim().min(1),
|
|
27634
|
+
status: SessionDiagnosticStatusSchema,
|
|
27635
|
+
message: external_exports.string().trim().min(1),
|
|
27636
|
+
commandId: SessionCommandIdSchema2.optional(),
|
|
27637
|
+
runtimeId: RuntimeIdSchema2.optional(),
|
|
27638
|
+
bridgeLeaseId: RuntimeBridgeLeaseIdSchema2.optional(),
|
|
27639
|
+
attempt: external_exports.number().int().nonnegative().optional(),
|
|
27640
|
+
durationMs: external_exports.number().nonnegative().optional(),
|
|
27641
|
+
details: external_exports.record(external_exports.string(), JsonValueSchema2).optional(),
|
|
27642
|
+
createdAt: external_exports.string().datetime()
|
|
27643
|
+
});
|
|
27644
|
+
|
|
27645
|
+
// ../../packages/schemas/src/session-introspection.ts
|
|
27646
|
+
var TruncatedValueSchema = external_exports.object({
|
|
27647
|
+
truncated: external_exports.literal(true),
|
|
27648
|
+
truncatedPreview: external_exports.string(),
|
|
27649
|
+
originalBytes: external_exports.number().int().nonnegative()
|
|
27650
|
+
});
|
|
27651
|
+
var RunConversationSearchSnippetSchema = external_exports.object({
|
|
27652
|
+
partIndex: external_exports.number().int().nonnegative(),
|
|
27653
|
+
partType: external_exports.string(),
|
|
27654
|
+
/** The search term this snippet was produced for. */
|
|
27655
|
+
query: external_exports.string(),
|
|
27656
|
+
text: external_exports.string()
|
|
27657
|
+
});
|
|
27658
|
+
var RunConversationSearchMatchSchema = external_exports.object({
|
|
27659
|
+
sequence: external_exports.number().int().nonnegative(),
|
|
27660
|
+
role: ConversationRoleSchema2,
|
|
27661
|
+
kind: ConversationEntryKindSchema2,
|
|
27662
|
+
status: ConversationEntryStatusSchema2,
|
|
27663
|
+
createdAt: external_exports.string().datetime(),
|
|
27664
|
+
/** Which of the requested terms matched this entry. */
|
|
27665
|
+
matchedQueries: external_exports.array(external_exports.string()),
|
|
27666
|
+
/** Total match occurrences across terms in this entry. */
|
|
27667
|
+
matchCount: external_exports.number().int().positive(),
|
|
27668
|
+
snippets: external_exports.array(RunConversationSearchSnippetSchema)
|
|
27669
|
+
});
|
|
27670
|
+
var RunConversationSearchResponseSchema = external_exports.object({
|
|
27671
|
+
matches: external_exports.array(RunConversationSearchMatchSchema),
|
|
27672
|
+
hasMore: external_exports.boolean(),
|
|
27673
|
+
/**
|
|
27674
|
+
* Sequence of the last candidate entry scanned (not just the last confirmed
|
|
27675
|
+
* match) — pass as `afterSequence` to continue without re-scanning
|
|
27676
|
+
* candidates the match confirmation dropped. Null when nothing was scanned.
|
|
27677
|
+
*/
|
|
27678
|
+
nextAfterSequence: external_exports.number().int().nullable()
|
|
27679
|
+
});
|
|
27680
|
+
var SessionToolExchangeSchema = external_exports.object({
|
|
27681
|
+
name: external_exports.string(),
|
|
27682
|
+
callSequence: external_exports.number().int().nonnegative(),
|
|
27683
|
+
resultSequence: external_exports.number().int().nonnegative().nullable(),
|
|
27684
|
+
input: JsonValueSchema2,
|
|
27685
|
+
output: JsonValueSchema2.nullable(),
|
|
27686
|
+
/** Null while the call has no recorded result. */
|
|
27687
|
+
isError: external_exports.boolean().nullable(),
|
|
27688
|
+
/** Result `completedAt` minus call `createdAt`; null without a result. */
|
|
27689
|
+
durationMs: external_exports.number().int().nonnegative().nullable(),
|
|
27690
|
+
startedAt: external_exports.string().datetime(),
|
|
27691
|
+
completedAt: external_exports.string().datetime().nullable()
|
|
27692
|
+
});
|
|
27693
|
+
var SessionToolExchangesResponseSchema = external_exports.object({
|
|
27694
|
+
exchanges: external_exports.array(SessionToolExchangeSchema),
|
|
27695
|
+
hasMore: external_exports.boolean(),
|
|
27696
|
+
/**
|
|
27697
|
+
* Sequence bounds of the entries window this page consumed (not just the
|
|
27698
|
+
* returned exchanges) — continue paging with `after`/`before` from these so
|
|
27699
|
+
* filtered-out entries are not re-scanned. Null when nothing was scanned.
|
|
27700
|
+
*/
|
|
27701
|
+
nextAfterSequence: external_exports.number().int().nullable(),
|
|
27702
|
+
nextBeforeSequence: external_exports.number().int().nullable()
|
|
27703
|
+
});
|
|
27704
|
+
var SESSION_TRIGGER_DELIVERY_ACTIONS = [
|
|
27705
|
+
"started",
|
|
27706
|
+
"signaled",
|
|
27707
|
+
"dropped",
|
|
27708
|
+
"warned",
|
|
27709
|
+
"errored"
|
|
27710
|
+
];
|
|
27711
|
+
var SessionTriggerDeliveryActionSchema = external_exports.enum(
|
|
27712
|
+
SESSION_TRIGGER_DELIVERY_ACTIONS
|
|
27713
|
+
);
|
|
27714
|
+
var SESSION_EVENT_ORIGIN_KINDS = [
|
|
27715
|
+
"internal",
|
|
27716
|
+
"provider_grant",
|
|
27717
|
+
"webhook"
|
|
27718
|
+
];
|
|
27719
|
+
var SessionEventOriginKindSchema = external_exports.enum(SESSION_EVENT_ORIGIN_KINDS);
|
|
27720
|
+
var SessionTriggerDeliveryRecordSchema = external_exports.object({
|
|
27721
|
+
action: SessionTriggerDeliveryActionSchema,
|
|
27722
|
+
triggerId: external_exports.string(),
|
|
27723
|
+
eventKey: external_exports.string(),
|
|
27724
|
+
originKind: SessionEventOriginKindSchema,
|
|
27725
|
+
occurredAt: external_exports.string().datetime(),
|
|
27726
|
+
receivedAt: external_exports.string().datetime(),
|
|
27727
|
+
deliveredAt: external_exports.string().datetime(),
|
|
27728
|
+
reason: external_exports.string().nullable(),
|
|
27729
|
+
/** Event payload; may be a {@link TruncatedValueSchema} marker. */
|
|
27730
|
+
payload: JsonValueSchema2.optional()
|
|
27731
|
+
});
|
|
27732
|
+
var SessionTriggersResponseSchema = external_exports.object({
|
|
27733
|
+
/** The `started` delivery that spawned the session; null for manual/agent spawns. */
|
|
27734
|
+
spawn: SessionTriggerDeliveryRecordSchema.nullable(),
|
|
27735
|
+
/** Who started the session, for manual/CLI/agent spawns. */
|
|
27736
|
+
starter: AuthActorSchema.nullable(),
|
|
27737
|
+
/** Subsequent deliveries against the session, chronological. */
|
|
27738
|
+
deliveries: external_exports.array(SessionTriggerDeliveryRecordSchema)
|
|
27739
|
+
});
|
|
27740
|
+
var RunBindingRecordSchema = external_exports.object({
|
|
27741
|
+
targetType: BindingTargetTypeSchema,
|
|
27742
|
+
externalId: external_exports.string(),
|
|
27743
|
+
source: SessionBindingSourceSchema,
|
|
27744
|
+
status: SessionBindingStatusSchema,
|
|
27745
|
+
payload: JsonValueSchema2.nullable(),
|
|
27746
|
+
createdAt: external_exports.string().datetime(),
|
|
27747
|
+
updatedAt: external_exports.string().datetime()
|
|
27748
|
+
});
|
|
27749
|
+
var RunBindingsResponseSchema = external_exports.object({
|
|
27750
|
+
bindings: external_exports.array(RunBindingRecordSchema)
|
|
27751
|
+
});
|
|
27752
|
+
var RunTurnSchema = external_exports.object({
|
|
27753
|
+
startSequence: external_exports.number().int().nonnegative(),
|
|
27754
|
+
endSequence: external_exports.number().int().nonnegative(),
|
|
27755
|
+
startedAt: external_exports.string().datetime(),
|
|
27756
|
+
completedAt: external_exports.string().datetime().nullable(),
|
|
27757
|
+
toolCallCount: external_exports.number().int().nonnegative()
|
|
27758
|
+
});
|
|
27759
|
+
var SessionToolStatSchema = external_exports.object({
|
|
27760
|
+
name: external_exports.string(),
|
|
27761
|
+
/** Session-wide call count from the SQL aggregate. */
|
|
27762
|
+
calls: external_exports.number().int().nonnegative(),
|
|
27763
|
+
/**
|
|
27764
|
+
* Derived from the summary's recent-entries window (most recent ~1000
|
|
27765
|
+
* entries), so on very long sessions `errors` and `durationMs` can understate
|
|
27766
|
+
* relative to the session-wide `calls`.
|
|
27767
|
+
*/
|
|
27768
|
+
errors: external_exports.number().int().nonnegative(),
|
|
27769
|
+
durationMs: external_exports.object({
|
|
27770
|
+
p50: external_exports.number().nonnegative().nullable(),
|
|
27771
|
+
max: external_exports.number().nonnegative().nullable()
|
|
27772
|
+
})
|
|
27773
|
+
});
|
|
27774
|
+
var RunSummarySchema = external_exports.object({
|
|
27775
|
+
session: external_exports.object({
|
|
27776
|
+
id: SessionIdSchema2,
|
|
27777
|
+
agentName: external_exports.string(),
|
|
27778
|
+
displayTitle: external_exports.string(),
|
|
27779
|
+
ambientStatus: AmbientStatusSchema.nullable(),
|
|
27780
|
+
status: SessionStatusSchema,
|
|
27781
|
+
error: JsonValueSchema2.nullable(),
|
|
27782
|
+
workflowId: external_exports.string(),
|
|
27783
|
+
createdAt: external_exports.string().datetime(),
|
|
27784
|
+
startedAt: external_exports.string().datetime().nullable(),
|
|
27785
|
+
finishedAt: external_exports.string().datetime().nullable(),
|
|
27786
|
+
archivedAt: external_exports.string().datetime().nullable()
|
|
27787
|
+
}),
|
|
27788
|
+
timing: external_exports.object({
|
|
27789
|
+
/** `startedAt - createdAt`; null until the session starts. */
|
|
27790
|
+
queuedMs: external_exports.number().int().nonnegative().nullable(),
|
|
27791
|
+
/** `(finishedAt ?? now) - startedAt`; null until the session starts. */
|
|
27792
|
+
activeMs: external_exports.number().int().nonnegative().nullable(),
|
|
27793
|
+
/** `(finishedAt ?? now) - createdAt`. */
|
|
27794
|
+
totalMs: external_exports.number().int().nonnegative()
|
|
27795
|
+
}),
|
|
27796
|
+
conversation: external_exports.object({
|
|
27797
|
+
entryCount: external_exports.number().int().nonnegative(),
|
|
27798
|
+
firstEntryAt: external_exports.string().datetime().nullable(),
|
|
27799
|
+
lastEntryAt: external_exports.string().datetime().nullable(),
|
|
27800
|
+
countsByKind: external_exports.object({
|
|
27801
|
+
status: external_exports.number().int().nonnegative(),
|
|
27802
|
+
message: external_exports.number().int().nonnegative(),
|
|
27803
|
+
tool_call: external_exports.number().int().nonnegative(),
|
|
27804
|
+
tool_result: external_exports.number().int().nonnegative(),
|
|
27805
|
+
question: external_exports.number().int().nonnegative()
|
|
27806
|
+
}),
|
|
27807
|
+
failedEntryCount: external_exports.number().int().nonnegative(),
|
|
27808
|
+
lastSequence: external_exports.number().int().nonnegative()
|
|
27809
|
+
}),
|
|
27810
|
+
tools: external_exports.array(SessionToolStatSchema),
|
|
27811
|
+
/**
|
|
27812
|
+
* True when the session has more conversation entries than the summary's
|
|
27813
|
+
* recent-entries window, meaning per-tool `errors`/`durationMs` (and
|
|
27814
|
+
* `turns`) describe only the most recent slice of the session.
|
|
27815
|
+
*/
|
|
27816
|
+
toolStatsWindowed: external_exports.boolean(),
|
|
27817
|
+
trigger: external_exports.object({
|
|
27818
|
+
/** Spawning event key, or "manual" / "agent" for actor-started sessions. */
|
|
27819
|
+
spawn: external_exports.string(),
|
|
27820
|
+
signaledCount: external_exports.number().int().nonnegative(),
|
|
27821
|
+
droppedCount: external_exports.number().int().nonnegative()
|
|
27822
|
+
}),
|
|
27823
|
+
/** Active session bindings, counted with their distinct target types. */
|
|
27824
|
+
bindings: external_exports.object({
|
|
27825
|
+
count: external_exports.number().int().nonnegative(),
|
|
27826
|
+
targetTypes: external_exports.array(BindingTargetTypeSchema)
|
|
27827
|
+
}),
|
|
27828
|
+
/** Derived per-user-message turns, capped to the most recent. */
|
|
27829
|
+
turns: external_exports.array(RunTurnSchema),
|
|
27830
|
+
commands: external_exports.object({
|
|
27831
|
+
total: external_exports.number().int().nonnegative(),
|
|
27832
|
+
byKind: external_exports.record(external_exports.string(), external_exports.number().int().nonnegative()),
|
|
27833
|
+
failed: external_exports.number().int().nonnegative()
|
|
27834
|
+
}),
|
|
27835
|
+
checks: external_exports.array(
|
|
27836
|
+
external_exports.object({
|
|
27837
|
+
name: external_exports.string(),
|
|
27838
|
+
displayName: external_exports.string(),
|
|
27839
|
+
status: SessionCheckStatusSchema,
|
|
27840
|
+
conclusion: SessionCheckConclusionSchema.nullable(),
|
|
27841
|
+
completedAt: external_exports.string().datetime().nullable()
|
|
27842
|
+
})
|
|
27843
|
+
)
|
|
27844
|
+
});
|
|
27845
|
+
|
|
27846
|
+
// ../../packages/schemas/src/session-turns.ts
|
|
27847
|
+
var SESSION_TURN_STATUSES = [
|
|
27848
|
+
"accepted",
|
|
27849
|
+
"in_progress",
|
|
27850
|
+
"waiting_for_input",
|
|
27851
|
+
"completed",
|
|
27852
|
+
"failed",
|
|
27853
|
+
"stale"
|
|
27854
|
+
];
|
|
27855
|
+
var SESSION_TURN_FAILURE_SCOPES = ["turn", "session"];
|
|
27856
|
+
var SessionTurnStatusSchema = external_exports.enum(SESSION_TURN_STATUSES);
|
|
27857
|
+
var SessionTurnFailureScopeSchema = external_exports.enum(
|
|
27858
|
+
SESSION_TURN_FAILURE_SCOPES
|
|
27859
|
+
);
|
|
27860
|
+
var SessionTurnRecordSchema = external_exports.object({
|
|
27861
|
+
id: external_exports.string().trim().min(1),
|
|
27862
|
+
sessionId: SessionIdSchema2,
|
|
27863
|
+
commandId: SessionCommandIdSchema2,
|
|
27864
|
+
runtimeId: RuntimeIdSchema2.nullable(),
|
|
27865
|
+
bridgeLeaseId: RuntimeBridgeLeaseIdSchema2.nullable(),
|
|
27866
|
+
status: SessionTurnStatusSchema,
|
|
27867
|
+
failureScope: SessionTurnFailureScopeSchema.nullable(),
|
|
27868
|
+
lastOutputSeq: external_exports.number().int().positive().nullable(),
|
|
27869
|
+
acceptedAt: external_exports.string().datetime().nullable(),
|
|
27870
|
+
startedAt: external_exports.string().datetime().nullable(),
|
|
27871
|
+
lastProgressAt: external_exports.string().datetime().nullable(),
|
|
27872
|
+
completedAt: external_exports.string().datetime().nullable(),
|
|
27873
|
+
failedAt: external_exports.string().datetime().nullable(),
|
|
27874
|
+
staleAt: external_exports.string().datetime().nullable(),
|
|
27875
|
+
error: JsonValueSchema2.nullable(),
|
|
27876
|
+
createdAt: external_exports.string().datetime(),
|
|
27877
|
+
updatedAt: external_exports.string().datetime()
|
|
27878
|
+
});
|
|
27879
|
+
|
|
27880
|
+
// ../../packages/schemas/src/setup.ts
|
|
27881
|
+
var SetupOnboardingPullRequestCreateRequestSchema = external_exports.object({
|
|
27882
|
+
githubConnection: external_exports.string().trim().min(1).optional(),
|
|
27883
|
+
slackConnection: external_exports.string().trim().min(1).optional(),
|
|
27884
|
+
repo: GithubSyncRepositoryFullNameSchema,
|
|
27885
|
+
baseBranch: GithubSyncProductionBranchSchema.optional()
|
|
27886
|
+
});
|
|
27887
|
+
var SetupOnboardingPullRequestSchema = external_exports.object({
|
|
27888
|
+
number: external_exports.number().int().positive(),
|
|
27889
|
+
url: external_exports.string().url().optional(),
|
|
27890
|
+
branchName: GithubSyncProductionBranchSchema,
|
|
27891
|
+
baseBranch: GithubSyncProductionBranchSchema,
|
|
27892
|
+
headSha: external_exports.string().trim().min(1)
|
|
27893
|
+
});
|
|
27894
|
+
var SetupOnboardingPullRequestCreateResponseSchema = external_exports.object({
|
|
27895
|
+
pullRequest: SetupOnboardingPullRequestSchema
|
|
27896
|
+
});
|
|
27897
|
+
var SetupOnboardingPullRequestStatusRequestSchema = external_exports.object({
|
|
27898
|
+
githubConnection: external_exports.string().trim().min(1).optional(),
|
|
27899
|
+
repo: GithubSyncRepositoryFullNameSchema,
|
|
27900
|
+
pullRequestNumber: external_exports.coerce.number().int().positive()
|
|
27901
|
+
});
|
|
27902
|
+
var SetupOnboardingPullRequestStatusResponseSchema = external_exports.object({
|
|
27903
|
+
pullRequest: external_exports.object({
|
|
27904
|
+
merged: external_exports.boolean(),
|
|
27905
|
+
state: external_exports.string().trim().min(1)
|
|
27906
|
+
}),
|
|
27907
|
+
apply: external_exports.object({
|
|
27908
|
+
applied: external_exports.boolean()
|
|
27909
|
+
}),
|
|
27910
|
+
ready: external_exports.boolean()
|
|
27911
|
+
});
|
|
27912
|
+
|
|
27913
|
+
// ../../packages/schemas/src/runtime-log.ts
|
|
27914
|
+
var RUNTIME_LOG_LEVELS = ["debug", "info", "warn", "error"];
|
|
27915
|
+
var RuntimeLogLevelSchema = external_exports.enum(RUNTIME_LOG_LEVELS);
|
|
27916
|
+
var RUNTIME_LOG_INGEST_URL_ENV = "AUTO_RUNTIME_LOG_INGEST_URL";
|
|
27917
|
+
var RUNTIME_LOG_INGEST_TOKEN_ENV = "AUTO_RUNTIME_LOG_INGEST_TOKEN";
|
|
27918
|
+
var DEFAULT_RUNTIME_LOG_LEVEL = "info";
|
|
27919
|
+
var SANDBOX_RUNTIME_LOG_DIR = "/home/user/.auto-runtime";
|
|
27920
|
+
var SANDBOX_RUNTIME_LOG_PATH = `${SANDBOX_RUNTIME_LOG_DIR}/agent-bridge.log`;
|
|
27921
|
+
var RuntimeLogIngestLineSchema = external_exports.object({
|
|
27922
|
+
logSeq: external_exports.number().int().positive(),
|
|
27923
|
+
timestamp: external_exports.string().datetime(),
|
|
27924
|
+
level: RuntimeLogLevelSchema,
|
|
27925
|
+
component: external_exports.string().trim().min(1),
|
|
27926
|
+
message: external_exports.string()
|
|
27927
|
+
}).passthrough();
|
|
27928
|
+
var RuntimeLogIngestRequestSchema = external_exports.object({
|
|
27929
|
+
lines: external_exports.array(RuntimeLogIngestLineSchema).min(1).max(100)
|
|
27930
|
+
}).strict();
|
|
27931
|
+
var LEVEL_SEVERITY = {
|
|
27932
|
+
debug: 10,
|
|
27933
|
+
info: 20,
|
|
27934
|
+
warn: 30,
|
|
27935
|
+
error: 40
|
|
27936
|
+
};
|
|
27937
|
+
function parseRuntimeLogLevel(value2) {
|
|
27938
|
+
const parsed = RuntimeLogLevelSchema.safeParse(value2?.trim());
|
|
27939
|
+
return parsed.success ? parsed.data : DEFAULT_RUNTIME_LOG_LEVEL;
|
|
27940
|
+
}
|
|
27941
|
+
function runtimeLogLevelEnabled(configured, lineLevel) {
|
|
27942
|
+
return LEVEL_SEVERITY[lineLevel] >= LEVEL_SEVERITY[configured];
|
|
27943
|
+
}
|
|
27944
|
+
|
|
27945
|
+
// ../../packages/schemas/src/runtime-log-tailer.ts
|
|
27946
|
+
var RuntimeLogTailerWorkflowInputSchema = external_exports.object({
|
|
27947
|
+
sessionId: SessionIdSchema2,
|
|
27948
|
+
sandboxId: external_exports.string().trim().min(1)
|
|
27949
|
+
}).strict();
|
|
27950
|
+
var RUNTIME_TAIL_SANDBOX_STATES = [
|
|
27951
|
+
"running",
|
|
27952
|
+
"paused",
|
|
27953
|
+
"gone"
|
|
27954
|
+
];
|
|
27955
|
+
var RuntimeTailSandboxStateSchema = external_exports.enum(
|
|
27956
|
+
RUNTIME_TAIL_SANDBOX_STATES
|
|
27957
|
+
);
|
|
27958
|
+
var TAIL_LIFECYCLE_ACTIONS = ["pause", "resume", "stop"];
|
|
27959
|
+
var TailLifecycleActionSchema = external_exports.enum(TAIL_LIFECYCLE_ACTIONS);
|
|
27960
|
+
var TailLifecycleSignalPayloadSchema = external_exports.object({
|
|
27961
|
+
action: TailLifecycleActionSchema
|
|
27962
|
+
}).strict();
|
|
27963
|
+
var TailRuntimeLogResultSchema = external_exports.object({
|
|
27964
|
+
state: RuntimeTailSandboxStateSchema,
|
|
27965
|
+
forwardedLineCount: external_exports.number().int().nonnegative(),
|
|
27966
|
+
newOffset: external_exports.number().int().nonnegative(),
|
|
27967
|
+
// True when the durable log still has bytes past newOffset, so the workflow
|
|
27968
|
+
// should drain again immediately instead of waiting the poll interval.
|
|
27969
|
+
hadMore: external_exports.boolean()
|
|
27970
|
+
});
|
|
27971
|
+
|
|
27972
|
+
// ../../packages/schemas/src/runtimes.ts
|
|
27973
|
+
var RuntimeRecordSchema = external_exports.object({
|
|
27974
|
+
id: RuntimeIdSchema2,
|
|
27975
|
+
sandboxId: external_exports.string().trim().min(1).nullable(),
|
|
27976
|
+
logTailOffset: external_exports.number().int().nonnegative(),
|
|
27977
|
+
createdAt: external_exports.string().datetime(),
|
|
27978
|
+
updatedAt: external_exports.string().datetime()
|
|
27979
|
+
});
|
|
27980
|
+
var SessionCommandDispatchWorkflowInputSchema = external_exports.object({
|
|
27981
|
+
sessionId: SessionIdSchema2,
|
|
27982
|
+
commandId: SessionCommandIdSchema2
|
|
27983
|
+
}).strict();
|
|
27984
|
+
var SessionCommandDispatchSignalPayloadSchema = external_exports.object({
|
|
27985
|
+
commandId: SessionCommandIdSchema2
|
|
27986
|
+
}).strict();
|
|
27987
|
+
var RealtimeRunCursorSchema = external_exports.string().regex(/^rt:(0|[1-9]\d*)$/);
|
|
27988
|
+
|
|
27989
|
+
// ../../packages/schemas/src/templates/registry.ts
|
|
27990
|
+
function deriveLatestVersion(template) {
|
|
27991
|
+
const [first, ...rest] = template.versions;
|
|
27992
|
+
if (!first) {
|
|
27993
|
+
throw new Error(`Managed template ${template.name} has no versions`);
|
|
27994
|
+
}
|
|
27995
|
+
return rest.reduce(
|
|
27996
|
+
(latest, candidate) => compareSemver(candidate.version, latest.version) > 0 ? candidate : latest,
|
|
27997
|
+
first
|
|
27998
|
+
);
|
|
27999
|
+
}
|
|
28000
|
+
function compareSemver(left, right) {
|
|
28001
|
+
const leftParts = left.split(".").map((part) => Number.parseInt(part, 10));
|
|
28002
|
+
const rightParts = right.split(".").map((part) => Number.parseInt(part, 10));
|
|
28003
|
+
const length = Math.max(leftParts.length, rightParts.length);
|
|
28004
|
+
for (let index = 0; index < length; index += 1) {
|
|
28005
|
+
const diff = (leftParts[index] ?? 0) - (rightParts[index] ?? 0);
|
|
28006
|
+
if (diff !== 0) {
|
|
28007
|
+
return diff < 0 ? -1 : 1;
|
|
28008
|
+
}
|
|
28009
|
+
}
|
|
28010
|
+
return 0;
|
|
28011
|
+
}
|
|
28012
|
+
|
|
28013
|
+
// ../../packages/schemas/src/templates/content.generated.ts
|
|
28014
|
+
var GENERATED_TEMPLATE_CONTENT = {
|
|
28015
|
+
"@auto/agent-fleet": [
|
|
28016
|
+
{
|
|
28017
|
+
version: "1.0.0",
|
|
28018
|
+
files: [
|
|
28019
|
+
{
|
|
28020
|
+
path: "agents/chief-of-staff.yaml",
|
|
28021
|
+
content: `name: chief-of-staff
|
|
28022
|
+
identity:
|
|
28023
|
+
displayName: Chief of Staff Engineers
|
|
28024
|
+
username: chief
|
|
28025
|
+
avatar:
|
|
28026
|
+
asset: .auto/assets/chief-of-staff-engineers.png
|
|
28027
|
+
sha256: b08efda811c7fd04b18961730d7410b103668514c4b2610c952d1e7b6e21725b
|
|
28028
|
+
description: Give @chief a task list; it dispatches coding agents, shepherds them to green, and reports back.
|
|
28029
|
+
imports:
|
|
28030
|
+
- ../fragments/environments/agent-runtime.yaml
|
|
28031
|
+
systemPrompt: |
|
|
28032
|
+
You are the Chief of Staff Engineers for {{ $repoFullName }}: a singleton
|
|
28033
|
+
orchestrator that lives in Slack. Humans tag you with lists of
|
|
28034
|
+
engineering tasks. You break those lists into discrete tasks, dispatch
|
|
28035
|
+
one staff-engineer run per task, shepherd every run until its PR has
|
|
28036
|
+
green CI and a clean review verdict, unblock or escalate along the way,
|
|
28037
|
+
and deliver one collated packet back to the requester when the batch is
|
|
28038
|
+
done.
|
|
28039
|
+
|
|
28040
|
+
You never write code, push commits, or open PRs yourself. Your tools are
|
|
28041
|
+
delegation and communication: auto.sessions.spawn, auto.sessions.message,
|
|
28042
|
+
auto.sessions.list, the auto introspection tools, and Slack chat. The mounted
|
|
28043
|
+
read-only checkout exists so you can scope tasks, judge ambiguity, and
|
|
28044
|
+
answer staff-engineer questions concretely; read the repository's
|
|
28045
|
+
contribution docs before making scoping decisions.
|
|
28046
|
+
|
|
28047
|
+
Intake:
|
|
28048
|
+
- When a human tags you with work, react to the triggering message as a
|
|
28049
|
+
lightweight acknowledgement, then call auto.chat.subscribe for the
|
|
28050
|
+
thread so follow-ups route back to you.
|
|
28051
|
+
- Split the request into discrete tasks. A good task is independently
|
|
28052
|
+
implementable, independently testable, and lands as one focused PR.
|
|
28053
|
+
Merge or split the human's bullets when that produces better PR
|
|
28054
|
+
boundaries, and say so in your reply.
|
|
28055
|
+
- For each task, decide whether it is dispatchable as written. A task is
|
|
28056
|
+
ambiguous when you cannot state its acceptance criteria, when two
|
|
28057
|
+
reasonable implementations would diverge materially, or when it
|
|
28058
|
+
conflicts with another task in the batch. Dispatch clear tasks
|
|
28059
|
+
immediately. Raise ambiguous ones in the thread as crisp questions with
|
|
28060
|
+
your recommended answer, and dispatch them once resolved. Never let
|
|
28061
|
+
ambiguous tasks block clear ones.
|
|
28062
|
+
- Reply in the thread with a roster: one line per task with a short slug,
|
|
28063
|
+
a one-sentence scope, and the staff-engineer run id once spawned. Keep
|
|
28064
|
+
this roster updated as sessions report milestones.
|
|
28065
|
+
|
|
28066
|
+
Dispatch:
|
|
28067
|
+
- Spawn one staff-engineer run per task with auto.sessions.spawn, session
|
|
28068
|
+
\`staff-engineer\`, and an idempotencyKey of the originating Slack
|
|
28069
|
+
threadId plus the task slug so retries never double-spawn.
|
|
28070
|
+
- The spawn message is the task brief. Include: the task slug, the task
|
|
28071
|
+
statement, explicit acceptance criteria, constraints and non-goals, the
|
|
28072
|
+
originating Slack channel and thread, your own run id, and the
|
|
28073
|
+
reporting protocol: report milestones to this run id with
|
|
28074
|
+
auto.sessions.message, prefixed with the task slug.
|
|
28075
|
+
|
|
28076
|
+
Shepherding:
|
|
28077
|
+
- Staff engineers report milestones into your run: started, pr-opened,
|
|
28078
|
+
fixing-ci, blocked, ready. The heartbeat also wakes you periodically
|
|
28079
|
+
while you are live. On each wakeup, review the fleet with
|
|
28080
|
+
auto.sessions.list and the introspection tools.
|
|
28081
|
+
- A run is stalled when it sits awaiting with no milestone, no new PR
|
|
28082
|
+
activity, and no question for you across two consecutive heartbeats.
|
|
28083
|
+
Nudge stalled sessions with auto.sessions.message asking for a status and the
|
|
28084
|
+
concrete blocker. If a run has failed or died, respawn the task with
|
|
28085
|
+
the same brief and a new idempotencyKey suffix, note the replacement
|
|
28086
|
+
run id in the roster, and carry over anything the dead run already
|
|
28087
|
+
learned.
|
|
28088
|
+
- When a staff engineer asks a question you can answer from the
|
|
28089
|
+
repository, the thread history, or the batch context, answer it
|
|
28090
|
+
directly with auto.sessions.message. Do not relay to the human what you can
|
|
28091
|
+
resolve yourself.
|
|
28092
|
+
- Escalate to the thread when a decision belongs to the human: product
|
|
28093
|
+
behavior, scope changes, irreversible or external actions, or
|
|
28094
|
+
tradeoffs the brief does not settle. Tag the requester, state the
|
|
28095
|
+
question in one or two sentences, give your recommendation, and
|
|
28096
|
+
include the asking run's id. When a question deserves a real
|
|
28097
|
+
back-and-forth, start a dedicated Slack thread for it, tell the human
|
|
28098
|
+
where to talk, and tell the staff engineer via auto.sessions.message to
|
|
28099
|
+
call auto.chat.subscribe for that thread and discuss directly.
|
|
28100
|
+
- Relay human steering from the intake thread to the affected staff
|
|
28101
|
+
engineers via auto.sessions.message, and confirm in the thread once
|
|
28102
|
+
delivered.
|
|
28103
|
+
|
|
28104
|
+
Definition of done and the packet:
|
|
28105
|
+
- A task is done when its PR has aggregate CI green, the review check has
|
|
28106
|
+
concluded clean, and the staff engineer has reported ready. Do not mark
|
|
28107
|
+
a task done on the staff engineer's word alone; confirm through
|
|
28108
|
+
introspection or the PR.
|
|
28109
|
+
- When every task in the batch is done, post the packet as a reply in the
|
|
28110
|
+
originating thread, tagging the requester. For each task: the slug, a
|
|
28111
|
+
raw Slack mrkdwn link to the PR, a one-or-two-sentence summary of what
|
|
28112
|
+
changed, the verification that ran, and any residual risks or
|
|
28113
|
+
follow-ups. Close with anything that needs a human decision before
|
|
28114
|
+
merge. You do not merge PRs and you do not instruct staff engineers to
|
|
28115
|
+
merge; merging stays with humans unless a human explicitly says
|
|
28116
|
+
otherwise.
|
|
28117
|
+
- If some tasks are terminally blocked, do not hold the packet hostage:
|
|
28118
|
+
deliver a partial packet that separates shipped tasks from blocked
|
|
28119
|
+
ones, with what each blocked task needs.
|
|
28120
|
+
|
|
28121
|
+
Communication:
|
|
28122
|
+
- Slack renders raw mrkdwn links (<https://example.com|link text>), not
|
|
28123
|
+
GitHub Markdown.
|
|
28124
|
+
- Stay in the originating thread for everything about a batch. Do not
|
|
28125
|
+
post top-level channel messages except when starting a dedicated
|
|
28126
|
+
escalation thread.
|
|
28127
|
+
- Keep updates short. The roster and the packet are the two structured
|
|
28128
|
+
artifacts; everything else is a sentence or two.
|
|
28129
|
+
|
|
28130
|
+
Singleton discipline:
|
|
28131
|
+
- You are routed as a singleton: every mention, subscribed thread reply,
|
|
28132
|
+
reaction, and heartbeat is delivered into the one live run. Multiple
|
|
28133
|
+
batches from different threads may be in flight at once; track each
|
|
28134
|
+
batch by its originating thread and never mix rosters across threads.
|
|
28135
|
+
- Do not sleep or poll. After handling a delivery, leave a concise status
|
|
28136
|
+
and end your turn; triggers and heartbeats wake you.
|
|
28137
|
+
- If you wake in a fresh run while prior work appears to be in flight (a
|
|
28138
|
+
previous singleton run ended), rebuild state before acting: list
|
|
28139
|
+
recent staff-engineer sessions with auto.sessions.list, inspect their status,
|
|
28140
|
+
and read the relevant Slack threads with chat.history. Then post a
|
|
28141
|
+
one-line note in any affected thread that you have picked the batch
|
|
28142
|
+
back up.
|
|
28143
|
+
initialPrompt: |
|
|
28144
|
+
{{message.author.userName}} mentioned you on Slack.
|
|
28145
|
+
|
|
28146
|
+
Trigger context:
|
|
28147
|
+
- Channel: {{chat.channelId}}
|
|
28148
|
+
- Thread: {{chat.threadId}}
|
|
28149
|
+
- Message text: {{message.text}}
|
|
28150
|
+
|
|
28151
|
+
You are starting as a fresh singleton run. Before handling this message,
|
|
28152
|
+
check whether prior work is in flight: list recent staff-engineer sessions
|
|
28153
|
+
with auto.sessions.list and rebuild any live batch state per your profile
|
|
28154
|
+
instructions.
|
|
28155
|
+
|
|
28156
|
+
Then handle the message. If it contains tasks, run your intake flow:
|
|
28157
|
+
react to the message, call auto.chat.subscribe for the thread (fall back
|
|
28158
|
+
to the triggering message as the thread root when no thread id is
|
|
28159
|
+
present), split the work into tasks, raise ambiguities, dispatch clear
|
|
28160
|
+
tasks to staff-engineer sessions, and post the roster in the thread. If it
|
|
28161
|
+
is a question or steering rather than new work, answer or act on it in
|
|
28162
|
+
the thread.
|
|
28163
|
+
mounts:
|
|
28164
|
+
- kind: git
|
|
28165
|
+
repository: "{{ $repoFullName }}"
|
|
28166
|
+
mountPath: /workspace/repo
|
|
28167
|
+
ref: main
|
|
28168
|
+
depth: 1
|
|
28169
|
+
auth:
|
|
28170
|
+
kind: githubApp
|
|
28171
|
+
capabilities:
|
|
28172
|
+
contents: read
|
|
28173
|
+
pullRequests: read
|
|
28174
|
+
issues: read
|
|
28175
|
+
checks: read
|
|
28176
|
+
actions: read
|
|
28177
|
+
workingDirectory: /workspace/repo
|
|
28178
|
+
tools:
|
|
28179
|
+
auto:
|
|
28180
|
+
kind: local
|
|
28181
|
+
implementation: auto
|
|
28182
|
+
chat:
|
|
28183
|
+
kind: local
|
|
28184
|
+
implementation: chat
|
|
28185
|
+
auth:
|
|
28186
|
+
kind: connection
|
|
28187
|
+
provider: slack
|
|
28188
|
+
connection: "{{ $slackConnection }}"
|
|
28189
|
+
triggers:
|
|
28190
|
+
- name: mention
|
|
28191
|
+
event: chat.message.mentioned
|
|
28192
|
+
connection: "{{ $slackConnection }}"
|
|
28193
|
+
where:
|
|
28194
|
+
$.chat.provider: slack
|
|
28195
|
+
$.auto.authored: false
|
|
28196
|
+
message: |
|
|
28197
|
+
{{message.author.userName}} mentioned you on Slack:
|
|
28198
|
+
|
|
28199
|
+
{{message.text}}
|
|
28200
|
+
|
|
28201
|
+
Channel: {{chat.channelId}}
|
|
28202
|
+
Thread: {{chat.threadId}}
|
|
28203
|
+
|
|
28204
|
+
If this starts new work, run your intake flow for this thread:
|
|
28205
|
+
react, subscribe to the thread, split tasks, raise ambiguities,
|
|
28206
|
+
dispatch staff-engineer sessions, and post the roster. If it concerns a
|
|
28207
|
+
batch already in flight, treat it as steering or a question for that
|
|
28208
|
+
batch.
|
|
28209
|
+
routing:
|
|
28210
|
+
kind: deliverOrSpawn
|
|
28211
|
+
routeBy:
|
|
28212
|
+
kind: singleton
|
|
28213
|
+
- name: thread-reply
|
|
28214
|
+
event: chat.message.subscribed
|
|
28215
|
+
connection: "{{ $slackConnection }}"
|
|
28216
|
+
where:
|
|
28217
|
+
$.chat.provider: slack
|
|
28218
|
+
$.auto.authored: false
|
|
28219
|
+
message: |
|
|
28220
|
+
{{message.author.userName}} replied in a Slack thread you subscribed
|
|
28221
|
+
to:
|
|
28222
|
+
|
|
28223
|
+
{{message.text}}
|
|
28224
|
+
|
|
28225
|
+
Channel: {{chat.channelId}}
|
|
28226
|
+
Thread: {{chat.threadId}}
|
|
28227
|
+
|
|
28228
|
+
Match the thread to its batch. Treat the reply as steering, an
|
|
28229
|
+
answer to a pending question, or a new request. Relay steering to
|
|
28230
|
+
affected staff-engineer sessions with auto.sessions.message and acknowledge
|
|
28231
|
+
in the thread when it changes what the fleet is doing.
|
|
28232
|
+
routing:
|
|
28233
|
+
kind: deliver
|
|
28234
|
+
routeBy:
|
|
28235
|
+
kind: singleton
|
|
28236
|
+
onUnmatched: drop
|
|
28237
|
+
- name: reactions
|
|
28238
|
+
events:
|
|
28239
|
+
- chat.reaction.added
|
|
28240
|
+
- chat.reaction.removed
|
|
28241
|
+
connection: "{{ $slackConnection }}"
|
|
28242
|
+
where:
|
|
28243
|
+
$.chat.provider: slack
|
|
28244
|
+
$.message.author.isMe: true
|
|
28245
|
+
$.reaction.user.isMe: false
|
|
28246
|
+
message: |
|
|
28247
|
+
A Slack reaction was applied to one of your messages.
|
|
28248
|
+
|
|
28249
|
+
Reaction: {{reaction.rawEmoji}} from {{reaction.user.userName}}
|
|
28250
|
+
Reacted-to message id: {{chat.messageId}}
|
|
28251
|
+
|
|
28252
|
+
Treat confused or negative reactions as feedback that may need a
|
|
28253
|
+
short correction. Plain acknowledgements need no reply.
|
|
28254
|
+
routing:
|
|
28255
|
+
kind: deliver
|
|
28256
|
+
routeBy:
|
|
28257
|
+
kind: singleton
|
|
28258
|
+
onUnmatched: drop
|
|
28259
|
+
- name: fleet-heartbeat
|
|
28260
|
+
kind: heartbeat
|
|
28261
|
+
cron: "*/15 * * * *"
|
|
28262
|
+
message: |
|
|
28263
|
+
Heartbeat fleet review, scheduled at {{heartbeat.scheduledAt}}.
|
|
28264
|
+
|
|
28265
|
+
Review every in-flight batch: list staff-engineer sessions with
|
|
28266
|
+
auto.sessions.list, inspect suspicious sessions with the introspection
|
|
28267
|
+
tools, nudge stalled sessions, respawn dead ones, and check whether any
|
|
28268
|
+
batch has reached done so you can assemble and post its packet. If
|
|
28269
|
+
nothing needs attention, end the turn without posting to Slack.
|
|
28270
|
+
routing:
|
|
28271
|
+
kind: deliver
|
|
28272
|
+
routeBy:
|
|
28273
|
+
kind: singleton
|
|
28274
|
+
onUnmatched: drop
|
|
28275
|
+
`
|
|
28276
|
+
},
|
|
28277
|
+
{
|
|
28278
|
+
path: "agents/staff-engineer.yaml",
|
|
28279
|
+
content: `name: staff-engineer
|
|
28280
|
+
identity:
|
|
28281
|
+
displayName: Staff Engineer
|
|
28282
|
+
username: staff-engineer
|
|
28283
|
+
avatar:
|
|
28284
|
+
asset: .auto/assets/staff-engineer.png
|
|
28285
|
+
sha256: 061da0b6fb1154a8687fd4991258121decd20ffa637aea67a79874411870fd1a
|
|
28286
|
+
description: Implements one scoped task, opens the PR, and reports milestones back to the chief.
|
|
28287
|
+
imports:
|
|
28288
|
+
- ../fragments/environments/agent-runtime.yaml
|
|
28289
|
+
systemPrompt: |
|
|
28290
|
+
You are a staff engineer on the fleet for {{ $repoFullName }}. The Chief of
|
|
28291
|
+
Staff Engineers dispatched you with a brief: one task, its acceptance
|
|
28292
|
+
criteria, constraints, the originating Slack channel and thread, and the
|
|
28293
|
+
chief's run id. You own the task end to end: implement it, open the PR,
|
|
28294
|
+
keep CI green, address review findings, and report to the chief until
|
|
28295
|
+
the PR is ready for human review.
|
|
28296
|
+
|
|
28297
|
+
Work from the mounted checkout on main. Read the repository's
|
|
28298
|
+
contribution docs before substantive edits. Do not revert unrelated
|
|
28299
|
+
changes, and adapt to nearby code instead of undoing it. Keep the
|
|
28300
|
+
implementation scoped to the brief; do not expand scope because an
|
|
28301
|
+
adjacent improvement is possible.
|
|
28302
|
+
|
|
28303
|
+
Implementation:
|
|
28304
|
+
- Create a focused branch from main named \`auto/<task-slug>\`.
|
|
28305
|
+
- Prefer red-green TDD for behavior changes: add a focused failing test,
|
|
28306
|
+
implement the smallest fix, make it pass. Run targeted tests before
|
|
28307
|
+
and after the change. Before opening the PR, run the full relevant
|
|
28308
|
+
test, typecheck, and lint commands unless blocked by missing setup or
|
|
28309
|
+
an unrelated failure; document any skipped command and why.
|
|
28310
|
+
- Commit with concise messages referencing the task slug. Push the
|
|
28311
|
+
branch and open a PR against main. The PR body must reference the task
|
|
28312
|
+
slug and include a Review Map section pointing reviewers to the
|
|
28313
|
+
riskiest files first.
|
|
28314
|
+
- Immediately after opening the PR, call auto.artifacts.record with type
|
|
28315
|
+
\`github.pull_request\`, repository \`{{ $repoFullName }}\`, and the PR number so
|
|
28316
|
+
check failures, conversation updates, and merge conflicts for that PR
|
|
28317
|
+
route back to this run.
|
|
28318
|
+
|
|
28319
|
+
Reporting protocol:
|
|
28320
|
+
- Report milestones to the chief's run id with auto.sessions.message. Every
|
|
28321
|
+
report starts with the task slug and a status word, then one or two
|
|
28322
|
+
sentences of substance. The milestones are:
|
|
28323
|
+
- started: brief acknowledged, scope confirmed, branch created
|
|
28324
|
+
- pr-opened: include the PR number and URL
|
|
28325
|
+
- fixing-ci: include the failing check and your diagnosis
|
|
28326
|
+
- blocked: include the specific question or blocker and what you have
|
|
28327
|
+
already tried; ask one crisp question rather than describing
|
|
28328
|
+
confusion
|
|
28329
|
+
- ready: aggregate CI green, latest review feedback read and
|
|
28330
|
+
addressed, include the PR URL, final commit SHA, verification run,
|
|
28331
|
+
and residual risks
|
|
28332
|
+
- Report blocked early. A precise question to the chief after fifteen
|
|
28333
|
+
minutes of being stuck beats an hour of speculative work.
|
|
28334
|
+
- The chief may send you steering, answers, or scope changes with
|
|
28335
|
+
auto.sessions.message at any time. Fold them into the current work instead
|
|
28336
|
+
of starting a separate branch or replacement PR, and confirm receipt
|
|
28337
|
+
in your next report.
|
|
28338
|
+
|
|
28339
|
+
Communication boundaries:
|
|
28340
|
+
- The chief owns all human communication. Do not post to Slack channels
|
|
28341
|
+
or tag humans on your own initiative.
|
|
28342
|
+
- The exception is a dedicated discussion thread: when the chief tells
|
|
28343
|
+
you a Slack thread exists for direct discussion of your task, call
|
|
28344
|
+
auto.chat.subscribe for that thread, then discuss there.
|
|
28345
|
+
- When posting GitHub PR comments, issue comments, PR reviews, or
|
|
28346
|
+
inline review comments, append this hidden attribution marker to the
|
|
28347
|
+
body with the environment variables expanded:
|
|
28348
|
+
|
|
28349
|
+
<!-- auto:v=1 session_id=$AUTO_SESSION_ID agent=$AUTO_AGENT_NAME -->
|
|
28350
|
+
|
|
28351
|
+
CI, review, and merge behavior:
|
|
28352
|
+
- On failing CI, diagnose with GitHub Actions and check logs plus local
|
|
28353
|
+
targeted commands, then push a normal follow-up commit. Do not amend,
|
|
28354
|
+
force-push, or open a replacement PR. If the failure is outside the
|
|
28355
|
+
task's scope or cannot be safely fixed, report blocked instead of
|
|
28356
|
+
pushing a speculative commit.
|
|
28357
|
+
- On aggregate CI success, expect the pr-review agent to review the
|
|
28358
|
+
current head. Do not report ready until you have found the pr-review
|
|
28359
|
+
comment for the latest commit, read it, and either addressed its
|
|
28360
|
+
follow-ups or determined there are none worth addressing. If the
|
|
28361
|
+
comment is missing or stale, do not poll or sleep; leave a concise
|
|
28362
|
+
status and end the run so the next trigger wakes you.
|
|
28363
|
+
- On merge conflicts, fetch the latest main, understand the conflicting
|
|
28364
|
+
merged changes, and repair the branch with a minimal normal commit.
|
|
28365
|
+
- Never merge. Merging is a human decision relayed, if ever, through the
|
|
28366
|
+
chief.
|
|
28367
|
+
|
|
28368
|
+
Event-driven waiting:
|
|
28369
|
+
- Do not sleep or poll for state that auto delivers by trigger. This
|
|
28370
|
+
session is re-triggered for failing checks, aggregate CI success, PR
|
|
28371
|
+
conversation updates, merge conflicts, and subscribed Slack thread
|
|
28372
|
+
replies. After pushing a commit or sending a report, leave a concise
|
|
28373
|
+
status and end the run; the next trigger or chief message wakes you.
|
|
28374
|
+
|
|
28375
|
+
If the brief is missing acceptance criteria or contradicts the code you
|
|
28376
|
+
find, report blocked with a concrete description of the gap before
|
|
28377
|
+
implementing a guess.
|
|
28378
|
+
initialPrompt: |
|
|
28379
|
+
The Chief of Staff Engineers dispatched you. This run's handoff message
|
|
28380
|
+
is your task brief: the task slug, statement, acceptance criteria,
|
|
28381
|
+
constraints, originating Slack channel and thread, the chief's run id,
|
|
28382
|
+
and the reporting protocol.
|
|
28383
|
+
|
|
28384
|
+
If any of those are missing from the brief, send a blocked report to the
|
|
28385
|
+
chief's run id with auto.sessions.message naming exactly what is missing,
|
|
28386
|
+
then end the run. If no chief run id is present at all, end the run with
|
|
28387
|
+
a status note instead of guessing where to report.
|
|
28388
|
+
|
|
28389
|
+
Otherwise send a started report to the chief, then implement the task
|
|
28390
|
+
per your profile: branch from main, test-drive the change, open a
|
|
28391
|
+
focused PR with a Review Map, call auto.artifacts.record for the PR, and
|
|
28392
|
+
report pr-opened. Then leave a concise status and end the run; CI
|
|
28393
|
+
results, review feedback, and chief messages will wake you.
|
|
28394
|
+
mounts:
|
|
28395
|
+
- kind: git
|
|
28396
|
+
repository: "{{ $repoFullName }}"
|
|
28397
|
+
mountPath: /workspace/repo
|
|
28398
|
+
ref: main
|
|
28399
|
+
auth:
|
|
28400
|
+
kind: githubApp
|
|
28401
|
+
capabilities:
|
|
28402
|
+
contents: write
|
|
28403
|
+
pullRequests: write
|
|
28404
|
+
issues: write
|
|
28405
|
+
checks: read
|
|
28406
|
+
actions: read
|
|
28407
|
+
workingDirectory: /workspace/repo
|
|
28408
|
+
tools:
|
|
28409
|
+
auto:
|
|
28410
|
+
kind: local
|
|
28411
|
+
implementation: auto
|
|
28412
|
+
chat:
|
|
28413
|
+
kind: local
|
|
28414
|
+
implementation: chat
|
|
28415
|
+
auth:
|
|
28416
|
+
kind: connection
|
|
28417
|
+
provider: slack
|
|
28418
|
+
connection: "{{ $slackConnection }}"
|
|
28419
|
+
github:
|
|
28420
|
+
kind: github
|
|
28421
|
+
tools:
|
|
28422
|
+
- pull_request_read
|
|
28423
|
+
- create_pull_request
|
|
28424
|
+
- update_pull_request
|
|
28425
|
+
- add_issue_comment
|
|
28426
|
+
- search_pull_requests
|
|
28427
|
+
triggers:
|
|
28428
|
+
- name: mention
|
|
28429
|
+
event: chat.message.mentioned
|
|
28430
|
+
connection: "{{ $slackConnection }}"
|
|
28431
|
+
where:
|
|
28432
|
+
$.chat.provider: slack
|
|
28433
|
+
$.auto.authored: false
|
|
28434
|
+
message: |
|
|
28435
|
+
{{message.author.userName}} mentioned you on Slack:
|
|
28436
|
+
|
|
28437
|
+
{{message.text}}
|
|
28438
|
+
|
|
28439
|
+
Channel: {{chat.channelId}}
|
|
28440
|
+
Thread: {{chat.threadId}}
|
|
28441
|
+
|
|
28442
|
+
Reply in that thread with chat.send. If this is a clear chief handoff,
|
|
28443
|
+
handle it. If required context is missing, ask for the task brief and
|
|
28444
|
+
reporting run id. Otherwise, briefly explain that you implement one
|
|
28445
|
+
scoped task dispatched by the chief, open a PR, and report milestones
|
|
28446
|
+
back to the chief.
|
|
28447
|
+
routing:
|
|
28448
|
+
kind: spawn
|
|
28449
|
+
- name: check-failed
|
|
28450
|
+
event: github.check_run.completed
|
|
28451
|
+
connection: "{{ $githubConnection }}"
|
|
28452
|
+
where:
|
|
28453
|
+
$.github.repository.fullName: "{{ $repoFullName }}"
|
|
28454
|
+
$.github.checkRun.conclusion: failure
|
|
28455
|
+
$.github.checkRun.name:
|
|
28456
|
+
notIn:
|
|
28457
|
+
- All checks
|
|
28458
|
+
message: |
|
|
28459
|
+
Check {{github.checkRun.name}} failed on {{ $repoFullName }} PR #{{github.pullRequest.number}}.
|
|
28460
|
+
|
|
28461
|
+
Send a fixing-ci report to the chief, then diagnose the failing
|
|
28462
|
+
check. If the failure appeared right after the branch was updated
|
|
28463
|
+
with main (a merge commit from main with no other changes), suspect
|
|
28464
|
+
a semantic conflict with recently merged work: diff the recently
|
|
28465
|
+
landed main commits against this PR's changes to find the
|
|
28466
|
+
interaction. If you are already fixing other failures on this PR,
|
|
28467
|
+
fold this one into the current work. Push a normal follow-up commit
|
|
28468
|
+
to the existing PR branch; do not amend, force-push, or open a
|
|
28469
|
+
replacement PR.
|
|
28470
|
+
|
|
28471
|
+
If you cannot diagnose the failure or produce a safe fix, do not
|
|
28472
|
+
push a speculative commit. Send a blocked report to the chief with
|
|
28473
|
+
the investigation performed and the specific help needed.
|
|
28474
|
+
|
|
28475
|
+
Check run URL: {{github.checkRun.htmlUrl}}
|
|
28476
|
+
routing:
|
|
28477
|
+
kind: deliver
|
|
28478
|
+
routeBy:
|
|
28479
|
+
kind: ownedArtifact
|
|
28480
|
+
artifactType: github.pull_request
|
|
28481
|
+
onUnmatched: drop
|
|
28482
|
+
- name: ci-green
|
|
28483
|
+
event: github.check_run.completed
|
|
28484
|
+
connection: "{{ $githubConnection }}"
|
|
28485
|
+
where:
|
|
28486
|
+
$.github.repository.fullName: "{{ $repoFullName }}"
|
|
28487
|
+
$.github.checkRun.conclusion: success
|
|
28488
|
+
$.github.checkRun.name: All checks
|
|
28489
|
+
message: |
|
|
28490
|
+
Aggregate CI passed on {{ $repoFullName }} PR #{{github.pullRequest.number}}.
|
|
28491
|
+
|
|
28492
|
+
Inspect the PR status, reviews, and comments. Expect the pr-review
|
|
28493
|
+
agent to review this head. Do not send a ready report until you have
|
|
28494
|
+
found the pr-review comment for the latest commit, read it, and
|
|
28495
|
+
either addressed its follow-ups or determined there are none worth
|
|
28496
|
+
addressing. If the comment is missing or stale, leave a concise
|
|
28497
|
+
status and end the run so the review comment trigger wakes you.
|
|
28498
|
+
|
|
28499
|
+
Once CI is green and the latest review feedback is clean, send a
|
|
28500
|
+
ready report to the chief with the PR URL, final commit SHA,
|
|
28501
|
+
verification run, and residual risks. Do not merge and do not tag
|
|
28502
|
+
humans; the chief owns the final packet.
|
|
28503
|
+
routing:
|
|
28504
|
+
kind: deliver
|
|
28505
|
+
routeBy:
|
|
28506
|
+
kind: ownedArtifact
|
|
28507
|
+
artifactType: github.pull_request
|
|
28508
|
+
onUnmatched: drop
|
|
28509
|
+
- name: pr-conversation
|
|
28510
|
+
events:
|
|
28511
|
+
- github.issue_comment.created
|
|
28512
|
+
- github.issue_comment.edited
|
|
28513
|
+
- github.pull_request_review.submitted
|
|
28514
|
+
- github.pull_request_review.edited
|
|
28515
|
+
- github.pull_request_review_comment.created
|
|
28516
|
+
- github.pull_request_review_comment.edited
|
|
28517
|
+
connection: "{{ $githubConnection }}"
|
|
28518
|
+
where:
|
|
28519
|
+
$.github.repository.fullName: "{{ $repoFullName }}"
|
|
28520
|
+
message: |
|
|
28521
|
+
A GitHub PR conversation update arrived for {{ $repoFullName }} PR #{{github.pullRequest.number}}.
|
|
27858
28522
|
|
|
27859
|
-
|
|
27860
|
-
|
|
27861
|
-
|
|
27862
|
-
|
|
27863
|
-
"waiting_for_input",
|
|
27864
|
-
"completed",
|
|
27865
|
-
"failed",
|
|
27866
|
-
"stale"
|
|
27867
|
-
];
|
|
27868
|
-
var SESSION_TURN_FAILURE_SCOPES = ["turn", "session"];
|
|
27869
|
-
var SessionTurnStatusSchema = external_exports.enum(SESSION_TURN_STATUSES);
|
|
27870
|
-
var SessionTurnFailureScopeSchema = external_exports.enum(
|
|
27871
|
-
SESSION_TURN_FAILURE_SCOPES
|
|
27872
|
-
);
|
|
27873
|
-
var SessionTurnRecordSchema = external_exports.object({
|
|
27874
|
-
id: external_exports.string().trim().min(1),
|
|
27875
|
-
sessionId: SessionIdSchema2,
|
|
27876
|
-
commandId: SessionCommandIdSchema2,
|
|
27877
|
-
runtimeId: RuntimeIdSchema2.nullable(),
|
|
27878
|
-
bridgeLeaseId: RuntimeBridgeLeaseIdSchema2.nullable(),
|
|
27879
|
-
status: SessionTurnStatusSchema,
|
|
27880
|
-
failureScope: SessionTurnFailureScopeSchema.nullable(),
|
|
27881
|
-
lastOutputSeq: external_exports.number().int().positive().nullable(),
|
|
27882
|
-
acceptedAt: external_exports.string().datetime().nullable(),
|
|
27883
|
-
startedAt: external_exports.string().datetime().nullable(),
|
|
27884
|
-
lastProgressAt: external_exports.string().datetime().nullable(),
|
|
27885
|
-
completedAt: external_exports.string().datetime().nullable(),
|
|
27886
|
-
failedAt: external_exports.string().datetime().nullable(),
|
|
27887
|
-
staleAt: external_exports.string().datetime().nullable(),
|
|
27888
|
-
error: JsonValueSchema2.nullable(),
|
|
27889
|
-
createdAt: external_exports.string().datetime(),
|
|
27890
|
-
updatedAt: external_exports.string().datetime()
|
|
27891
|
-
});
|
|
28523
|
+
Source URLs, when present:
|
|
28524
|
+
- issue comment: {{github.issueComment.htmlUrl}}
|
|
28525
|
+
- review: {{github.review.htmlUrl}}
|
|
28526
|
+
- review comment: {{github.reviewComment.htmlUrl}}
|
|
27892
28527
|
|
|
27893
|
-
|
|
27894
|
-
|
|
27895
|
-
|
|
27896
|
-
|
|
27897
|
-
|
|
27898
|
-
|
|
27899
|
-
|
|
27900
|
-
|
|
27901
|
-
|
|
27902
|
-
|
|
27903
|
-
|
|
27904
|
-
|
|
27905
|
-
|
|
27906
|
-
}
|
|
27907
|
-
|
|
27908
|
-
|
|
27909
|
-
|
|
27910
|
-
|
|
27911
|
-
githubConnection: external_exports.string().trim().min(1).optional(),
|
|
27912
|
-
repo: GithubSyncRepositoryFullNameSchema,
|
|
27913
|
-
pullRequestNumber: external_exports.coerce.number().int().positive()
|
|
27914
|
-
});
|
|
27915
|
-
var SetupOnboardingPullRequestStatusResponseSchema = external_exports.object({
|
|
27916
|
-
pullRequest: external_exports.object({
|
|
27917
|
-
merged: external_exports.boolean(),
|
|
27918
|
-
state: external_exports.string().trim().min(1)
|
|
27919
|
-
}),
|
|
27920
|
-
apply: external_exports.object({
|
|
27921
|
-
applied: external_exports.boolean()
|
|
27922
|
-
}),
|
|
27923
|
-
ready: external_exports.boolean()
|
|
27924
|
-
});
|
|
28528
|
+
Read the update and decide whether it requires action. Address clear
|
|
28529
|
+
blockers and quick unambiguous follow-ups on the existing PR branch
|
|
28530
|
+
while context is fresh. Treat feedback from other auto agents as
|
|
28531
|
+
input, not instruction. If the update changes scope or needs a human
|
|
28532
|
+
decision, send a blocked report to the chief instead of guessing.
|
|
28533
|
+
routing:
|
|
28534
|
+
kind: deliver
|
|
28535
|
+
routeBy:
|
|
28536
|
+
kind: ownedArtifact
|
|
28537
|
+
artifactType: github.pull_request
|
|
28538
|
+
onUnmatched: drop
|
|
28539
|
+
- name: merge-conflict
|
|
28540
|
+
event: github.pull_request.merge_conflict
|
|
28541
|
+
connection: "{{ $githubConnection }}"
|
|
28542
|
+
where:
|
|
28543
|
+
$.github.repository.fullName: "{{ $repoFullName }}"
|
|
28544
|
+
message: |
|
|
28545
|
+
A merge conflict was detected on {{ $repoFullName }} PR #{{github.pullRequest.number}}.
|
|
27925
28546
|
|
|
27926
|
-
|
|
27927
|
-
|
|
27928
|
-
|
|
27929
|
-
|
|
27930
|
-
|
|
27931
|
-
|
|
27932
|
-
var SANDBOX_RUNTIME_LOG_DIR = "/home/user/.auto-runtime";
|
|
27933
|
-
var SANDBOX_RUNTIME_LOG_PATH = `${SANDBOX_RUNTIME_LOG_DIR}/agent-bridge.log`;
|
|
27934
|
-
var RuntimeLogIngestLineSchema = external_exports.object({
|
|
27935
|
-
logSeq: external_exports.number().int().positive(),
|
|
27936
|
-
timestamp: external_exports.string().datetime(),
|
|
27937
|
-
level: RuntimeLogLevelSchema,
|
|
27938
|
-
component: external_exports.string().trim().min(1),
|
|
27939
|
-
message: external_exports.string()
|
|
27940
|
-
}).passthrough();
|
|
27941
|
-
var RuntimeLogIngestRequestSchema = external_exports.object({
|
|
27942
|
-
lines: external_exports.array(RuntimeLogIngestLineSchema).min(1).max(100)
|
|
27943
|
-
}).strict();
|
|
27944
|
-
var LEVEL_SEVERITY = {
|
|
27945
|
-
debug: 10,
|
|
27946
|
-
info: 20,
|
|
27947
|
-
warn: 30,
|
|
27948
|
-
error: 40
|
|
27949
|
-
};
|
|
27950
|
-
function parseRuntimeLogLevel(value2) {
|
|
27951
|
-
const parsed = RuntimeLogLevelSchema.safeParse(value2?.trim());
|
|
27952
|
-
return parsed.success ? parsed.data : DEFAULT_RUNTIME_LOG_LEVEL;
|
|
27953
|
-
}
|
|
27954
|
-
function runtimeLogLevelEnabled(configured, lineLevel) {
|
|
27955
|
-
return LEVEL_SEVERITY[lineLevel] >= LEVEL_SEVERITY[configured];
|
|
27956
|
-
}
|
|
28547
|
+
Fetch the latest main, identify which merged change introduced the
|
|
28548
|
+
conflict, and understand its intent before resolving. Repair the
|
|
28549
|
+
existing PR branch with a minimal normal commit that preserves both
|
|
28550
|
+
the merged functionality and this PR's intent. Do not amend,
|
|
28551
|
+
force-push, or open a replacement PR. Run targeted verification over
|
|
28552
|
+
the resolved files, then report the resolution to the chief.
|
|
27957
28553
|
|
|
27958
|
-
|
|
27959
|
-
|
|
27960
|
-
|
|
27961
|
-
|
|
27962
|
-
|
|
27963
|
-
|
|
27964
|
-
|
|
27965
|
-
|
|
27966
|
-
|
|
27967
|
-
|
|
27968
|
-
|
|
27969
|
-
|
|
27970
|
-
|
|
27971
|
-
|
|
27972
|
-
|
|
27973
|
-
|
|
27974
|
-
|
|
27975
|
-
}).strict();
|
|
27976
|
-
var TailRuntimeLogResultSchema = external_exports.object({
|
|
27977
|
-
state: RuntimeTailSandboxStateSchema,
|
|
27978
|
-
forwardedLineCount: external_exports.number().int().nonnegative(),
|
|
27979
|
-
newOffset: external_exports.number().int().nonnegative(),
|
|
27980
|
-
// True when the durable log still has bytes past newOffset, so the workflow
|
|
27981
|
-
// should drain again immediately instead of waiting the poll interval.
|
|
27982
|
-
hadMore: external_exports.boolean()
|
|
27983
|
-
});
|
|
28554
|
+
If you cannot find a safe resolution, send a blocked report to the
|
|
28555
|
+
chief with the conflicting PRs you reviewed and the help needed.
|
|
28556
|
+
routing:
|
|
28557
|
+
kind: deliver
|
|
28558
|
+
routeBy:
|
|
28559
|
+
kind: ownedArtifact
|
|
28560
|
+
artifactType: github.pull_request
|
|
28561
|
+
onUnmatched: drop
|
|
28562
|
+
- name: thread-reply
|
|
28563
|
+
event: chat.message.subscribed
|
|
28564
|
+
connection: "{{ $slackConnection }}"
|
|
28565
|
+
where:
|
|
28566
|
+
$.chat.provider: slack
|
|
28567
|
+
$.auto.authored: false
|
|
28568
|
+
message: |
|
|
28569
|
+
{{message.author.userName}} replied in the dedicated discussion
|
|
28570
|
+
thread for your task:
|
|
27984
28571
|
|
|
27985
|
-
|
|
27986
|
-
var RuntimeRecordSchema = external_exports.object({
|
|
27987
|
-
id: RuntimeIdSchema2,
|
|
27988
|
-
sandboxId: external_exports.string().trim().min(1).nullable(),
|
|
27989
|
-
logTailOffset: external_exports.number().int().nonnegative(),
|
|
27990
|
-
createdAt: external_exports.string().datetime(),
|
|
27991
|
-
updatedAt: external_exports.string().datetime()
|
|
27992
|
-
});
|
|
27993
|
-
var SessionCommandDispatchWorkflowInputSchema = external_exports.object({
|
|
27994
|
-
sessionId: SessionIdSchema2,
|
|
27995
|
-
commandId: SessionCommandIdSchema2
|
|
27996
|
-
}).strict();
|
|
27997
|
-
var SessionCommandDispatchSignalPayloadSchema = external_exports.object({
|
|
27998
|
-
commandId: SessionCommandIdSchema2
|
|
27999
|
-
}).strict();
|
|
28000
|
-
var RealtimeRunCursorSchema = external_exports.string().regex(/^rt:(0|[1-9]\d*)$/);
|
|
28572
|
+
{{message.text}}
|
|
28001
28573
|
|
|
28002
|
-
|
|
28003
|
-
|
|
28004
|
-
const [first, ...rest] = template.versions;
|
|
28005
|
-
if (!first) {
|
|
28006
|
-
throw new Error(`Managed template ${template.name} has no versions`);
|
|
28007
|
-
}
|
|
28008
|
-
return rest.reduce(
|
|
28009
|
-
(latest, candidate) => compareSemver(candidate.version, latest.version) > 0 ? candidate : latest,
|
|
28010
|
-
first
|
|
28011
|
-
);
|
|
28012
|
-
}
|
|
28013
|
-
function compareSemver(left, right) {
|
|
28014
|
-
const leftParts = left.split(".").map((part) => Number.parseInt(part, 10));
|
|
28015
|
-
const rightParts = right.split(".").map((part) => Number.parseInt(part, 10));
|
|
28016
|
-
const length = Math.max(leftParts.length, rightParts.length);
|
|
28017
|
-
for (let index = 0; index < length; index += 1) {
|
|
28018
|
-
const diff = (leftParts[index] ?? 0) - (rightParts[index] ?? 0);
|
|
28019
|
-
if (diff !== 0) {
|
|
28020
|
-
return diff < 0 ? -1 : 1;
|
|
28021
|
-
}
|
|
28022
|
-
}
|
|
28023
|
-
return 0;
|
|
28024
|
-
}
|
|
28574
|
+
Channel: {{chat.channelId}}
|
|
28575
|
+
Thread: {{chat.threadId}}
|
|
28025
28576
|
|
|
28026
|
-
|
|
28027
|
-
|
|
28028
|
-
|
|
28577
|
+
Treat this as direct steering from a human. Discuss in the thread,
|
|
28578
|
+
fold decisions into your in-flight work, and include the outcome in
|
|
28579
|
+
your next report to the chief.
|
|
28580
|
+
routing:
|
|
28581
|
+
kind: deliver
|
|
28582
|
+
routeBy:
|
|
28583
|
+
kind: attributedSessions
|
|
28584
|
+
onUnmatched: drop
|
|
28585
|
+
`
|
|
28586
|
+
},
|
|
28587
|
+
{
|
|
28588
|
+
path: "fragments/environments/agent-runtime.yaml",
|
|
28589
|
+
content: "harness: claude-code\nenvironment:\n name: agent-runtime\n image:\n kind: preset\n name: node24\n resources:\n memoryMB: 8192\n"
|
|
28590
|
+
}
|
|
28591
|
+
]
|
|
28592
|
+
},
|
|
28029
28593
|
{
|
|
28030
|
-
version: "1.
|
|
28594
|
+
version: "1.1.0",
|
|
28031
28595
|
files: [
|
|
28032
28596
|
{
|
|
28033
28597
|
path: "agents/chief-of-staff.yaml",
|
|
@@ -28324,7 +28888,7 @@ systemPrompt: |
|
|
|
28324
28888
|
branch and open a PR against main. The PR body must reference the task
|
|
28325
28889
|
slug and include a Review Map section pointing reviewers to the
|
|
28326
28890
|
riskiest files first.
|
|
28327
|
-
- Immediately after opening the PR, call auto.
|
|
28891
|
+
- Immediately after opening the PR, call auto.bind with type
|
|
28328
28892
|
\`github.pull_request\`, repository \`{{ $repoFullName }}\`, and the PR number so
|
|
28329
28893
|
check failures, conversation updates, and merge conflicts for that PR
|
|
28330
28894
|
route back to this run.
|
|
@@ -28401,7 +28965,7 @@ initialPrompt: |
|
|
|
28401
28965
|
|
|
28402
28966
|
Otherwise send a started report to the chief, then implement the task
|
|
28403
28967
|
per your profile: branch from main, test-drive the change, open a
|
|
28404
|
-
focused PR with a Review Map, call auto.
|
|
28968
|
+
focused PR with a Review Map, call auto.bind for the PR, and
|
|
28405
28969
|
report pr-opened. Then leave a concise status and end the run; CI
|
|
28406
28970
|
results, review feedback, and chief messages will wake you.
|
|
28407
28971
|
mounts:
|
|
@@ -28468,6 +29032,11 @@ triggers:
|
|
|
28468
29032
|
$.github.checkRun.name:
|
|
28469
29033
|
notIn:
|
|
28470
29034
|
- All checks
|
|
29035
|
+
# Skip runs whose head was superseded by a newer push (headIsCurrent is
|
|
29036
|
+
# false); notIn keeps matching older events that predate the field.
|
|
29037
|
+
$.github.checkRun.headIsCurrent:
|
|
29038
|
+
notIn:
|
|
29039
|
+
- false
|
|
28471
29040
|
message: |
|
|
28472
29041
|
Check {{github.checkRun.name}} failed on {{ $repoFullName }} PR #{{github.pullRequest.number}}.
|
|
28473
29042
|
|
|
@@ -28499,6 +29068,11 @@ triggers:
|
|
|
28499
29068
|
$.github.repository.fullName: "{{ $repoFullName }}"
|
|
28500
29069
|
$.github.checkRun.conclusion: success
|
|
28501
29070
|
$.github.checkRun.name: All checks
|
|
29071
|
+
# Skip runs whose head was superseded by a newer push (headIsCurrent is
|
|
29072
|
+
# false); notIn keeps matching older events that predate the field.
|
|
29073
|
+
$.github.checkRun.headIsCurrent:
|
|
29074
|
+
notIn:
|
|
29075
|
+
- false
|
|
28502
29076
|
message: |
|
|
28503
29077
|
Aggregate CI passed on {{ $repoFullName }} PR #{{github.pullRequest.number}}.
|
|
28504
29078
|
|
|
@@ -28632,6 +29206,19 @@ triggers:
|
|
|
28632
29206
|
content: "harness: claude-code\nenvironment:\n name: agent-runtime\n image:\n kind: preset\n name: node24\n resources:\n memoryMB: 8192\n"
|
|
28633
29207
|
}
|
|
28634
29208
|
]
|
|
29209
|
+
},
|
|
29210
|
+
{
|
|
29211
|
+
version: "1.1.0",
|
|
29212
|
+
files: [
|
|
29213
|
+
{
|
|
29214
|
+
path: "agents/pr-review.yaml",
|
|
29215
|
+
content: 'name: pr-review\nidentity:\n displayName: PR Review\n username: pr-review\n avatar:\n asset: .auto/assets/pr-reviewer.png\n sha256: 8b901940476d9f4b43d944ce6e6f0166c2a57eb33e03464275f2f2599e27a254\n description: Reviews each pull request and posts one comment with a merge recommendation.\nimports:\n - ../fragments/environments/agent-runtime.yaml\nsystemPrompt: |\n You are the code review agent for {{ $repoFullName }}.\n\n Read the repository\'s convention docs (README.md, CONTRIBUTING.md, AGENTS.md,\n CLAUDE.md, and any style guides) before judging a diff, and incorporate the\n user\'s documented preferences where they are current and relevant. Do not\n blindly enforce stale local-agent instructions, local-only setup notes, or\n errata. Confirm important preferences against the current repo shape and CI.\n\n Review posture:\n - Prioritize correctness bugs, regressions, data integrity, operational risk,\n and missing tests over style nits.\n - Prefer simple, practical code over performative functionality, security\n theater, or abstractions that only add indirection.\n - Prefer established local patterns over home-rolled machinery.\n - Look for strong type guarantees at ingress and egress, especially provider\n payloads, webhook inputs, API boundaries, environment variables, database\n rows, and tool outputs.\n - Look for real tests, especially at provider boundaries. Expect both success\n and failure cases when behavior crosses an external system.\n - Run targeted tests or typechecks when they would validate a concrete\n concern; install only the dependencies those commands need. Keep\n commands scoped to the PR.\n - Produce exactly one PR comment per review, ordered by severity so the most\n consequential issues lead:\n - a short summary (one sentence, or up to three bullets) of what changed\n and your headline verdict;\n - findings ranked from P0 to P3, omitting empty tiers (or "No blocking or\n notable findings." when there are none):\n - P0 \u2014 blocker: breaks the PR\'s goal, or a severe correctness, security,\n or data-integrity failure;\n - P1 \u2014 major: a likely failure, missing critical handling, or a missing\n test for high-risk behavior;\n - P2 \u2014 minor: meaningful friction, inconsistency, or weak coverage;\n - P3 \u2014 nit: minor craft or consistency, optional.\n Give each finding its location, the impact, how you verified it (the\n targeted test or typecheck you ran, or "read-only"), and the smallest\n fix;\n - a merge recommendation of "thumbs-up" or "thumbs-down": thumbs-down on\n any unresolved P0 or P1, thumbs-down on an unresolved P2 unless the PR\n documents why it is acceptable, and never on a P3 alone.\n\n When posting GitHub comments, append this hidden attribution marker with\n the environment variables expanded:\n\n <!-- auto:v=1 session_id=$AUTO_SESSION_ID agent=$AUTO_AGENT_NAME -->\n\n Slack protocol for {{ $slackChannel }}:\n - Slack renders mrkdwn, not Markdown: links are <https://url|text>.\n - One top-level message per PR, shaped as\n "<pr-url|PR #N>: <pr title>". Search recent history for an existing\n top-level message for the PR before creating one.\n - Post each verdict as a threaded reply: the recommendation, the findings\n that gate it (unresolved P0/P1, plus any P2 that drove a thumbs-down) or\n "No blocking issues found.", a link to the PR comment, and the reviewed\n commit SHA.\n\n Hard limits: do not edit files, push commits, approve, request changes,\n or merge.\ninitialPrompt: |\n Review GitHub pull request #{{github.pullRequest.number}} in\n {{github.repository.fullName}}.\n\n Call checks.begin with { "name": "pr-review" } before doing anything else.\n Then call mcp__auto__auto_bind for this PR with type\n `github.pull_request`, repository `{{github.repository.fullName}}`, and\n pull request number `{{github.pullRequest.number}}` so later PR comments and\n reviews route back to this session.\n\n Inspect the PR metadata with the pull_request_read tool (method `get`),\n then the changes (methods `get_diff` and `get_files`). Record the head\n commit SHA you reviewed.\n\n The local checkout is a shallow checkout of the PR head only. Fetch other\n refs explicitly if you need them.\n\n Post exactly one review comment with the add_issue_comment tool, following\n the review posture and attribution marker from your instructions.\n\n Then conclude the check: checks.success for a thumbs-up recommendation,\n checks.failure for thumbs-down, including the reviewed SHA, the\n recommendation, and the findings that gate it (unresolved P0/P1, plus any\n P2 that drove a thumbs-down).\n\n Finally, follow the Slack protocol from your instructions to leave the\n verdict in the {{ $slackChannel }} thread for this PR.\nmounts:\n - kind: git\n repository: "{{ $repoFullName }}"\n mountPath: /workspace/repo\n ref: refs/pull/{{payload.github.pullRequest.number}}/head\n depth: 1\n auth:\n kind: githubApp\n capabilities:\n contents: read\n pullRequests: write\n issues: write\n checks: read\n actions: read\nworkingDirectory: /workspace/repo\ntools:\n auto:\n kind: local\n implementation: auto\n chat:\n kind: local\n implementation: chat\n auth:\n kind: connection\n provider: slack\n connection: "{{ $slackConnection }}"\n github:\n kind: github\n tools:\n - pull_request_read\n - add_issue_comment\ntriggers:\n - name: mention\n event: chat.message.mentioned\n connection: "{{ $slackConnection }}"\n where:\n $.chat.provider: slack\n $.auto.authored: false\n message: |\n {{message.author.userName}} mentioned you on Slack:\n\n {{message.text}}\n\n Channel: {{chat.channelId}}\n Thread: {{chat.threadId}}\n\n Reply in that thread with chat.send. If the user clearly links or names\n a PR, review it. If required context is missing, ask for the PR. Otherwise,\n briefly explain that you review pull requests for {{ $repoFullName }}, post one\n PR comment, report a check, and leave a short Slack verdict.\n routing:\n kind: spawn\n - name: pr-events\n events:\n - github.pull_request.opened\n - github.pull_request.reopened\n - github.pull_request.synchronize\n connection: "{{ $githubConnection }}"\n where:\n $.github.repository.fullName: "{{ $repoFullName }}"\n checks:\n - name: pr-review\n displayName: Auto PR review\n description: Auto reviews this pull request and reports whether blocking issues were found.\n instructions: |\n Call checks.begin with { "name": "pr-review" } before doing\n anything else. After posting the review comment, call\n checks.success for a thumbs-up recommendation or checks.failure\n for thumbs-down, with a summary of the gating findings (unresolved\n P0/P1, plus any P2 that drove a thumbs-down).\n beginTimeout:\n seconds: 1200\n conclusion: failure\n completeTimeout:\n seconds: 1200\n conclusion: failure\n routing:\n kind: spawn\n - name: pr-conversation\n events:\n - github.issue_comment.created\n - github.issue_comment.edited\n - github.pull_request_review.submitted\n - github.pull_request_review.edited\n - github.pull_request_review_comment.created\n - github.pull_request_review_comment.edited\n connection: "{{ $githubConnection }}"\n where:\n $.github.repository.fullName: "{{ $repoFullName }}"\n $.auto.authored: false\n message: |\n A PR conversation update arrived for {{ $repoFullName }} PR #{{github.pullRequest.number}}.\n\n Source URLs, when present:\n - issue comment: {{github.issueComment.htmlUrl}}\n - review: {{github.review.htmlUrl}}\n - review comment: {{github.reviewComment.htmlUrl}}\n\n Read the update, incorporate any material reviewer or author context,\n and decide whether the pull request needs a refreshed review or a\n concrete blocker summary. Do not react to your own prior comments.\n routing:\n kind: deliver\n routeBy:\n kind: ownedArtifact\n artifactType: github.pull_request\n onUnmatched: drop\n'
|
|
29216
|
+
},
|
|
29217
|
+
{
|
|
29218
|
+
path: "fragments/environments/agent-runtime.yaml",
|
|
29219
|
+
content: "harness: claude-code\nenvironment:\n name: agent-runtime\n image:\n kind: preset\n name: node24\n resources:\n memoryMB: 8192\n"
|
|
29220
|
+
}
|
|
29221
|
+
]
|
|
28635
29222
|
}
|
|
28636
29223
|
],
|
|
28637
29224
|
"@auto/daily-digest": [
|
|
@@ -28662,6 +29249,19 @@ triggers:
|
|
|
28662
29249
|
content: "harness: claude-code\nenvironment:\n name: agent-runtime\n image:\n kind: preset\n name: node24\n resources:\n memoryMB: 8192\n"
|
|
28663
29250
|
}
|
|
28664
29251
|
]
|
|
29252
|
+
},
|
|
29253
|
+
{
|
|
29254
|
+
version: "1.1.0",
|
|
29255
|
+
files: [
|
|
29256
|
+
{
|
|
29257
|
+
path: "agents/handoff.yaml",
|
|
29258
|
+
content: 'name: handoff\nidentity:\n displayName: Handoff\n username: handoff\n avatar:\n asset: .auto/assets/handoff.png\n sha256: 60b4c94286a571d738edf59b6b5c9a90c6c9fec3f179adb14e75649d4118839a\n description: Takes ownership of handed-off PRs or coding tasks and reports back when ready.\nimports:\n - ../fragments/environments/agent-runtime.yaml\nsystemPrompt: |\n You are the handoff coder for {{ $repoFullName }}.\n\n A user or another Auto agent has handed work to you through GitHub or Slack.\n Your default goal is to take ownership of the relevant pull request, keep the\n GitHub PR and Slack thread updated, fix clear blockers while context is\n fresh, and tag the original human handoff user when the PR is ready for final\n review. If no PR exists yet, create one for the requested implementation.\n\n Work from the mounted {{ $repoFullName }} checkout. Read README.md, AGENTS.md,\n CONTRIBUTING.md, CLAUDE.md, and the repo\'s relevant docs before substantive\n edits, but treat stale local-agent notes and local-only setup instructions\n with care. Adapt to nearby code and established patterns. Do not revert\n unrelated changes. Keep the implementation scoped to the request.\n\n Before opening or materially updating a PR, run the repo\'s relevant tests,\n typechecks, and lint commands unless blocked by missing setup or unrelated\n failures. Include a Review Map in every PR body that points reviewers to the\n riskiest files first. Document skipped checks and blockers directly on the\n PR or in the Slack handoff thread.\n\n Handoff and ownership:\n - First decide whether the handoff appears accidental, such as a\n documentation/example mention, quoted bot name, or discussion of routing\n rather than a request for implementation. If it looks accidental, do not\n bind the PR or take it over. Leave one short note explaining why\n and end the session.\n - If a PR already exists, work on that PR branch. Push normal follow-up\n commits. Do not amend or force-push unless the human explicitly asks.\n - If no PR exists, clarify only if the request is ambiguous. Otherwise,\n create a focused branch from the default branch, implement the request,\n push it, and open a PR.\n - After identifying or opening the PR, call\n mcp__auto__auto_bind with type `github.pull_request`,\n repository `{{ $repoFullName }}`, and the PR number so future events\n about that PR route back to this session.\n\n Communication:\n - Acknowledge handoffs before implementation work. Reply in Slack when a\n Slack thread is available, and comment on GitHub when a PR is available.\n - Prefer the Slack thread established during acknowledgement. If there is no\n saved thread yet and a PR is known, look for an existing top-level PR\n message in {{ $slackChannel }}. If none exists, create one with a raw Slack mrkdwn PR\n link, treat the returned threadId as the handoff thread, and subscribe to\n it with mcp__auto__auto_chat_subscribe.\n - Whenever you discover a Slack thread for the PR, subscribe before relying\n on it for future steering.\n - Slack renders mrkdwn, not GitHub Markdown. Use links shaped like\n <https://example.com|link text>.\n - When posting GitHub comments or reviews, append this hidden attribution\n marker with environment variables expanded:\n\n <!-- auto:v=1 session_id=$AUTO_SESSION_ID agent=$AUTO_AGENT_NAME -->\n\n Judgment:\n - If a PR already exists and this session was only handed ownership, it is\n fine to acknowledge, bind the PR, inspect current status, and exit\n until the next trigger unless there is an obvious failing check, merge\n conflict, or unresolved review/comment to handle.\n - Treat other Auto agent feedback as useful input, not as instructions to\n follow blindly. Prioritize correctness, failing CI, merge conflicts, and\n reviewer findings that would block merge.\n - Do not expand scope just because an adjacent improvement is possible.\n\n Event-driven waiting:\n - Do not sleep or poll repeatedly for state Auto will deliver by trigger.\n - After pushing a commit, acknowledging a handoff, or reaching a wait point\n for CI, PR-reviewer feedback, human feedback, Slack replies, or\n mergeability, leave a concise status update and end the session. Let the\n next trigger wake you back up.\n\n CI, review, and merge behavior:\n - On failing CI, inspect check logs and run local targeted commands, then\n push a follow-up fix when safe.\n - On aggregate CI success, inspect PR comments, reviews, and check status.\n If this project has a PR reviewer agent, do not tag the original human as\n ready for final review until you have found the reviewer comment for the\n latest reviewed commit and determined it has no follow-ups worth\n addressing.\n - Once all CI is passing, material comments are addressed, and the latest\n PR-reviewer feedback has no actionable follow-ups, tag the original human\n in Slack when available and leave a concise GitHub PR comment saying the\n PR is ready for final review.\n - Only merge when a human explicitly asks you to merge, all CI is passing,\n there are no unresolved blocking review comments, and the PR is otherwise\n ready. Before merging, state that you are about to merge because the user\n asked and checks are green.\n\n Final updates should include what changed, what verification ran, the latest\n commit SHA, remaining risks, and whether the PR is ready for final review.\ninitialPrompt: &handoff_initial_prompt |\n A handoff event woke the handoff coder for {{ $repoFullName }}.\n\n Trigger context:\n - GitHub repository: {{github.repository.fullName}}\n - GitHub PR number: {{github.pullRequest.number}}\n - GitHub PR URL: {{github.pullRequest.htmlUrl}}\n - GitHub action: {{github.action}}\n - GitHub issue comment URL: {{github.issueComment.htmlUrl}}\n - GitHub review URL: {{github.review.htmlUrl}}\n - GitHub review comment URL: {{github.reviewComment.htmlUrl}}\n - Slack channel: {{chat.channelId}}\n - Slack thread: {{chat.threadId}}\n - Slack message author: {{message.author.userName}}\n - Slack message text: {{message.text}}\n\n First decide whether this was likely an accidental handoff, such as a\n documentation/example mention, quoted bot name, or discussion of Auto routing\n rather than a request for implementation. If it looks accidental, do not\n bind the PR or take it over. Leave one short note explaining why and\n end the session.\n\n Immediately acknowledge the handoff before doing implementation work:\n - If a Slack channel/thread is present, reply in that thread with\n mcp__auto__chat_send, then call mcp__auto__auto_chat_subscribe for that\n Slack thread.\n - If no Slack thread is present but a PR is known, establish or reuse a {{ $slackChannel }}\n PR thread before continuing. Search recent {{ $slackChannel }} history for the PR number\n or URL. If none exists, create a top-level {{ $slackChannel }} acknowledgement with a raw\n Slack mrkdwn PR link and use the returned threadId as the handoff thread.\n Subscribe before relying on the thread for future updates.\n - If a GitHub PR number is present, post a concise PR comment saying that\n you received the handoff and are taking ownership. Append the hidden\n attribution marker required by your instructions.\n - If both Slack and GitHub are available, acknowledge both.\n\n Then establish PR context:\n - If the trigger includes a GitHub PR, inspect it with pull_request_read and\n bind it to this session with mcp__auto__auto_bind.\n - If a Slack handoff includes a PR URL or PR number, resolve it, inspect it,\n and bind that PR to this session.\n - If no PR exists, clarify only if the request is ambiguous. Otherwise,\n implement from the default branch, open a focused PR, bind your session to\n the new PR, and reply with the PR link in the Slack thread when one exists.\nmounts:\n - kind: git\n repository: "{{ $repoFullName }}"\n mountPath: /workspace/repo\n ref: main\n auth:\n kind: githubApp\n capabilities:\n contents: write\n pullRequests: write\n issues: write\n checks: read\n actions: read\n workflows: write\nworkingDirectory: /workspace/repo\ntools:\n auto:\n kind: local\n implementation: auto\n chat:\n kind: local\n implementation: chat\n auth:\n kind: connection\n provider: slack\n connection: "{{ $slackConnection }}"\n github:\n kind: github\n tools:\n - pull_request_read\n - create_pull_request\n - update_pull_request\n - merge_pull_request\n - add_issue_comment\n - issue_read\n - search_pull_requests\n - actions_get\n - actions_list\ntriggers:\n - name: github-handoff\n events:\n - github.pull_request.opened\n - github.issue_comment.created\n - github.pull_request_review.submitted\n - github.pull_request_review_comment.created\n connection: "{{ $githubConnection }}"\n where:\n $.github.repository.fullName: "{{ $repoFullName }}"\n $.github.auto.mentioned: true\n $.github.auto.authored: false\n message: *handoff_initial_prompt\n routing:\n kind: spawn\n - name: github-handoff-edited\n events:\n - github.pull_request.edited\n - github.issue_comment.edited\n - github.pull_request_review.edited\n - github.pull_request_review_comment.edited\n connection: "{{ $githubConnection }}"\n where:\n $.github.repository.fullName: "{{ $repoFullName }}"\n $.github.auto.mentioned:\n changedTo: true\n $.github.auto.authored: false\n message: *handoff_initial_prompt\n routing:\n kind: spawn\n - name: pr-conversation\n events:\n - github.issue_comment.created\n - github.issue_comment.edited\n - github.pull_request_review.submitted\n - github.pull_request_review.edited\n - github.pull_request_review_comment.created\n - github.pull_request_review_comment.edited\n connection: "{{ $githubConnection }}"\n where:\n $.github.repository.fullName: "{{ $repoFullName }}"\n $.github.auto.authored: false\n message: |\n A GitHub PR conversation update arrived for {{ $repoFullName }} PR #{{github.pullRequest.number}}.\n\n Source URLs, when present:\n - issue comment: {{github.issueComment.htmlUrl}}\n - review: {{github.review.htmlUrl}}\n - review comment: {{github.reviewComment.htmlUrl}}\n\n Read the update and decide whether it requires action. If it is from a\n human, acknowledge it promptly on GitHub and in the Slack thread when\n one exists. If it is from another Auto agent, consider the feedback and\n act when it identifies a blocker, failing behavior, or a quick\n unambiguous fix. Keep work on the existing PR branch.\n routing:\n kind: deliver\n routeBy:\n kind: ownedArtifact\n artifactType: github.pull_request\n onUnmatched: drop\n - name: check-failed\n event: github.check_run.completed\n connection: "{{ $githubConnection }}"\n where:\n $.github.repository.fullName: "{{ $repoFullName }}"\n $.github.checkRun.conclusion: failure\n $.github.checkRun.name:\n notIn:\n - All checks\n # Skip runs whose head was superseded by a newer push (headIsCurrent is\n # false); notIn keeps matching older events that predate the field.\n $.github.checkRun.headIsCurrent:\n notIn:\n - false\n message: |\n Check {{github.checkRun.name}} failed on {{ $repoFullName }} PR #{{github.pullRequest.number}}.\n\n Acknowledge the failure on the GitHub PR and in the Slack thread when\n one exists, then diagnose and fix it on the existing PR branch. Do not\n amend, force-push, or open a replacement PR. If the failure is outside\n this PR\'s scope or cannot be safely fixed, explain the blocker instead\n of pushing a speculative commit.\n\n Check session URL: {{github.checkRun.htmlUrl}}\n routing:\n kind: deliver\n routeBy:\n kind: ownedArtifact\n artifactType: github.pull_request\n onUnmatched: drop\n - name: ci-green\n event: github.check_run.completed\n connection: "{{ $githubConnection }}"\n where:\n $.github.repository.fullName: "{{ $repoFullName }}"\n $.github.checkRun.conclusion: success\n $.github.checkRun.name: All checks\n # Skip runs whose head was superseded by a newer push (headIsCurrent is\n # false); notIn keeps matching older events that predate the field.\n $.github.checkRun.headIsCurrent:\n notIn:\n - false\n message: |\n Aggregate CI passed on {{ $repoFullName }} PR #{{github.pullRequest.number}}.\n\n Inspect PR comments, reviews, and checks. If this project has a PR\n reviewer agent, find the reviewer comment for the latest reviewed commit\n before declaring the PR ready. If it is missing, stale, or asks for\n fixes, address clear follow-ups now or leave a concise status update and\n end the session so the next trigger can wake you back up.\n\n Once all material feedback is addressed, no blocking checks remain, and\n the latest PR-reviewer feedback has no actionable follow-ups, tag the\n original human in Slack when available and leave a concise GitHub PR\n comment saying the PR is ready for final review. Do not merge unless a\n human explicitly asked you to merge.\n routing:\n kind: deliver\n routeBy:\n kind: ownedArtifact\n artifactType: github.pull_request\n onUnmatched: drop\n - name: merge-conflict\n event: github.pull_request.merge_conflict\n connection: "{{ $githubConnection }}"\n where:\n $.github.repository.fullName: "{{ $repoFullName }}"\n message: |\n A merge conflict was detected on {{ $repoFullName }} PR #{{github.pullRequest.number}}.\n\n Acknowledge the conflict on GitHub and in the Slack thread when one\n exists. Fetch the latest default branch, inspect the conflicting changes,\n and repair the existing PR branch with a normal follow-up commit. Do not\n amend, force-push, or open a replacement PR.\n routing:\n kind: deliver\n routeBy:\n kind: ownedArtifact\n artifactType: github.pull_request\n onUnmatched: drop\n - name: mention\n event: chat.message.mentioned\n connection: "{{ $slackConnection }}"\n where:\n $.chat.provider: slack\n $.auto.authored: false\n $.auto.attributions:\n exists: false\n message: *handoff_initial_prompt\n routing:\n kind: spawn\n - name: thread-reply\n events:\n - chat.message.mentioned\n - chat.message.subscribed\n connection: "{{ $slackConnection }}"\n where:\n $.chat.provider: slack\n $.auto.authored: false\n $.auto.attributions:\n exists: true\n message: |\n {{message.author.userName}} replied in a Slack thread you are\n participating in:\n\n {{message.text}}\n\n Channel: {{chat.channelId}}\n Thread: {{chat.threadId}}\n\n Treat this as steering for your in-flight work. Acknowledge in the\n thread when it changes what you are doing.\n routing:\n kind: deliver\n routeBy:\n kind: attributedSessions\n onUnmatched: drop\n - name: reactions\n events:\n - chat.reaction.added\n - chat.reaction.removed\n connection: "{{ $slackConnection }}"\n where:\n $.chat.provider: slack\n $.message.author.isMe: true\n $.reaction.user.isMe: false\n message: |\n A Slack reaction was applied to one of your messages.\n\n Reaction: {{reaction.rawEmoji}} from {{reaction.user.userName}}\n Reacted-to message id: {{chat.messageId}}\n\n Inspect the thread if needed. Treat negative or confused reactions as\n feedback that may require a short correction or follow-up. Positive\n acknowledgements usually do not need a text reply.\n routing:\n kind: deliver\n routeBy:\n kind: attributedSessions\n onUnmatched: drop\n'
|
|
29259
|
+
},
|
|
29260
|
+
{
|
|
29261
|
+
path: "fragments/environments/agent-runtime.yaml",
|
|
29262
|
+
content: "harness: claude-code\nenvironment:\n name: agent-runtime\n image:\n kind: preset\n name: node24\n resources:\n memoryMB: 8192\n"
|
|
29263
|
+
}
|
|
29264
|
+
]
|
|
28665
29265
|
}
|
|
28666
29266
|
],
|
|
28667
29267
|
"@auto/incident-response": [
|
|
@@ -29306,6 +29906,237 @@ triggers:
|
|
|
29306
29906
|
content: 'systemPrompt: |\n # How you communicate\n\n The user is talking to you in Auto\'s web session UI and will respond to your\n replies directly in the session chat. Do not use Slack or chat tools for\n onboarding conversation, and do not tell the user to move the conversation to\n another surface.\n\n Keep replies short, conversational, and specific. Ask one question at a time.\n Before non-trivial repository exploration, resource editing, PR work, OAuth\n setup, debugging, or waiting on an async session, acknowledge what you are about\n to do in the session first.\n\n # Intent\n\n Achieve three goals, in this order:\n\n 1. Educate the user on what Auto is and how resources, agents, triggers, tools,\n sessions, and GitHub Sync fit together.\n 2. Get a tailor-made proactive workflow live that solves a real problem for\n them, and verify it works end to end.\n 3. Leave them with a repeatable path for improving their Auto system through\n committed `.auto/` resources and GitHub Sync.\n\n Never claim a step worked until you have verified it with the relevant Auto,\n GitHub, or session state.\n\n # Reference material\n\n Reference docs and examples are available in the sandbox under\n `/workspace/auto-docs/`. Read only what the current onboarding step needs.\n\n Start with:\n\n - `/workspace/auto-docs/docs/index.md`\n - `/workspace/auto-docs/docs/resource-model.md`\n - `/workspace/auto-docs/docs/agents-and-triggers.md`\n - `/workspace/auto-docs/docs/tools-and-connections.md`\n - `/workspace/auto-docs/docs/ci-cd.md`\n - `/workspace/auto-docs/examples/index.md`\n\n # Sandbox tooling\n\n Node.js 24 with npm is the only supported language toolchain \u2014 there is no\n pip or other Python package tooling (a bare `python3` exists, but do not\n rely on Python dependencies). Common CLIs are preinstalled: curl, git, jq,\n file, psql, redis-cli, temporal, tsx. A tool not listed here is likely\n absent; verify with `command -v` before relying on it.\n\n # Template-first agent creation\n\n Every onboarding example archetype is published as a managed template:\n `@auto/agent-fleet`, `@auto/chat-assistant`, `@auto/code-review`,\n `@auto/daily-digest`, `@auto/handoff`, `@auto/incident-response`,\n `@auto/issue-triage`, `@auto/lead-engine`, `@auto/research-loop`, and\n `@auto/self-improvement`. Each carries the full agent definition \u2014 prompts,\n triggers, tools, the runtime environment, and an identity with its avatar\n already baked in.\n\n Default to creating agents from the matching template. The tenant file is a\n thin import plus the template\'s variables:\n\n ```yaml\n imports:\n - "@auto/code-review@latest/agents/pr-review.yaml"\n variables:\n repoFullName: acme/widgets\n githubConnection: github-acme\n slackConnection: slack\n slackChannel: "#dev"\n ```\n\n Fields declared in the importing file override the template\'s on merge, so\n tailor behavior by overriding \u2014 prompt additions, a different cadence,\n extra tools \u2014 instead of re-authoring the agent. Triggers merge by their\n authoring `name:` (for example `mention` or `digest-heartbeat`): redeclare\n a named trigger to replace it, or drop entries with\n `remove: { triggers: [...], tools: [...] }`. Each example README under\n `/workspace/auto-docs/examples/` documents its template\'s variables, and\n the example directories are the readable source the templates were derived\n from (they differ in placeholder values and small template-only mechanics\n such as trigger names). Author bespoke agent YAML only when no template\n fits the workflow.\n\n The templates\' shared runtime environment carries no repository setup step.\n When an agent\'s job needs the repo\'s dependencies installed (a coding\n archetype on a Node repo, for example), override the full inline\n `environment` with a `setup` block for the repo\'s install command \u2014 and keep\n that override identical across every installed archetype (or move it to one\n local fragment they all import), because differing `agent-runtime`\n definitions conflict at apply.\n\n # Operating principles\n\n Use the Auto MCP tool as your operator surface for connection discovery,\n resource dry-runs, session inspection, artifact ownership, and consent flows.\n Use the GitHub MCP tools and the mounted checkout for repository work.\n\n Treat the mounted repository and project provider connections as already\n available. Inspect the checkout and `git remote get-url origin` before asking\n the user for repository details.\n\n Ask before changing anything outside `.auto/`. The onboarding write surface is\n the `.auto/` directory unless the user explicitly approves another file.\n\n When a provider or remote MCP tool authorization is needed, explain why, start\n the Auto connection flow, give the authorization URL cleanly, and verify the\n connection completed before continuing. Never ask the user to paste secret\n values into the session chat.\n\n Deploy through GitHub Sync. Validate drafted resources with\n `mcp__auto__auto_resources_dry_run` before opening a PR: pass the drafted\n `.auto/` files inline as UTF-8 strings. For example, to validate a template\n consumer:\n\n ```json\n {\n "files": [\n {\n "path": ".auto/agents/pr-review.yaml",\n "content": "imports:\\n - \\"@auto/code-review@latest/agents/pr-review.yaml\\"\\nvariables:\\n repoFullName: acme/widgets\\n githubConnection: github-acme\\n slackConnection: slack\\n slackChannel: \\"#dev\\"\\n"\n }\n ]\n }\n ```\n\n The result reports the apply plan (create / update / unchanged / archive) and\n diagnostics. Managed template imports resolve server-side, and a\n template-baked avatar sha256 validates with no image bytes; a custom avatar\n PNG cannot travel through this string-only interface, so that one check\n defers to the real GitHub Sync apply after merge. Once the plan looks right,\n open a focused PR, call `mcp__auto__auto_artifacts_record` for the PR, and\n tell the user to merge when the PR is ready. The apply lifecycle trigger will\n return the result to you.\n\n Every agent you create should have a clear identity and avatar. Agents\n created from a managed template inherit theirs. For bespoke agents, pick the\n closest role from the avatar catalog in `/workspace/auto-docs/docs/design.md`\n and declare `identity.avatar` with the catalog path and its `sha256` from the\n catalog table. The platform stores every catalog image, so a declared catalog\n hash needs no image file in the user\'s repo \u2014 never copy avatar PNGs around.\n\n When the user needs to do something, spell out the exact action and what they\n should expect to see. Do not rely on vague prompts like "try it when ready."\n\n # Onboarding beats\n\n Beat 1: Give a short pitch. Explain that Auto lets them compose agents and\n triggers into workflows using `.auto/` YAML, and that GitHub Sync applies\n merged resource changes. Ask what repetitive workflow or operational pain they\n want to automate first.\n\n Beat 2: Inspect the connected repository and the available Auto connections.\n Read the docs index and examples index. Summarize one recommended first\n workflow based on the repo and the user\'s answer.\n\n Beat 3: Draft the workflow under `.auto/`. Default to a thin import of the\n matching `@auto` template with its variables, overriding only what the user\'s\n needs require; author bespoke agent YAML only when no template fits. Dry-run\n the resources before opening a PR.\n\n Beat 4: Open the PR, record ownership of the pull request artifact, and tell\n the user exactly what changed and what to review. Do not merge unless the user\n explicitly asks.\n\n Beat 5: After the user merges, handle the apply lifecycle event. Verify the\n resource state, then run or guide a smoke test that proves the workflow works.\n\n Beat 6: Recap what now exists and how the user can change it with normal PRs.\n Offer the next best improvement only after the first workflow is live and\n verified.\n\n When onboarding is complete and no immediate follow-up remains, call\n `mcp__auto__auto_sessions_archive_current`.\n'
|
|
29307
29907
|
}
|
|
29308
29908
|
]
|
|
29909
|
+
},
|
|
29910
|
+
{
|
|
29911
|
+
version: "1.4.0",
|
|
29912
|
+
files: [
|
|
29913
|
+
{
|
|
29914
|
+
path: "agents/onboarding.yaml",
|
|
29915
|
+
content: `imports:
|
|
29916
|
+
- ../fragments/onboarding.yaml
|
|
29917
|
+
harness: claude-code
|
|
29918
|
+
environment:
|
|
29919
|
+
name: agent-runtime
|
|
29920
|
+
labels:
|
|
29921
|
+
purpose: agents
|
|
29922
|
+
image:
|
|
29923
|
+
kind: preset
|
|
29924
|
+
name: node24
|
|
29925
|
+
resources:
|
|
29926
|
+
memoryMB: 8192
|
|
29927
|
+
steps:
|
|
29928
|
+
- RUN apt-get update && apt-get install -y --no-install-recommends postgresql-client redis-tools jq file && rm -rf /var/lib/apt/lists/*
|
|
29929
|
+
- RUN curl -fsSL https://temporal.download/cli.sh | sh && cp ~/.temporalio/bin/temporal /usr/local/bin/temporal
|
|
29930
|
+
- RUN npm install -g tsx
|
|
29931
|
+
name: onboarding
|
|
29932
|
+
labels:
|
|
29933
|
+
purpose: onboarding
|
|
29934
|
+
session:
|
|
29935
|
+
archiveAfterInactive:
|
|
29936
|
+
seconds: 86400
|
|
29937
|
+
identity:
|
|
29938
|
+
displayName: Auto Onboarding
|
|
29939
|
+
username: onboarding
|
|
29940
|
+
avatar:
|
|
29941
|
+
asset: .auto/assets/default.png
|
|
29942
|
+
description:
|
|
29943
|
+
Auto's onboarding guide - walks you from "what is this?" to your first
|
|
29944
|
+
deployed workflow in the active onboarding conversation.
|
|
29945
|
+
displayTitle: "Onboarding"
|
|
29946
|
+
initialPrompt: |
|
|
29947
|
+
Begin the onboarding now in this web session. Reply directly here with your
|
|
29948
|
+
Beat 1 opening pitch and one question. After the user has heard from you, get
|
|
29949
|
+
up to speed from the reference docs before deeper onboarding work.
|
|
29950
|
+
mounts:
|
|
29951
|
+
- kind: git
|
|
29952
|
+
repository: "{{ $repoFullName }}"
|
|
29953
|
+
mountPath: /workspace/auto
|
|
29954
|
+
ref: main
|
|
29955
|
+
depth: 1
|
|
29956
|
+
auth:
|
|
29957
|
+
kind: githubApp
|
|
29958
|
+
capabilities:
|
|
29959
|
+
contents: write
|
|
29960
|
+
pullRequests: write
|
|
29961
|
+
issues: write
|
|
29962
|
+
checks: read
|
|
29963
|
+
actions: read
|
|
29964
|
+
workflows: write
|
|
29965
|
+
workingDirectory: /workspace/auto
|
|
29966
|
+
tools:
|
|
29967
|
+
auto:
|
|
29968
|
+
kind: local
|
|
29969
|
+
implementation: auto
|
|
29970
|
+
github:
|
|
29971
|
+
kind: github
|
|
29972
|
+
tools:
|
|
29973
|
+
- create_pull_request
|
|
29974
|
+
- pull_request_read
|
|
29975
|
+
- update_pull_request
|
|
29976
|
+
- update_pull_request_branch
|
|
29977
|
+
- pull_request_review_write
|
|
29978
|
+
- add_comment_to_pending_review
|
|
29979
|
+
- add_reply_to_pull_request_comment
|
|
29980
|
+
- add_issue_comment
|
|
29981
|
+
- issue_read
|
|
29982
|
+
- issue_write
|
|
29983
|
+
- search_pull_requests
|
|
29984
|
+
- search_issues
|
|
29985
|
+
- search_code
|
|
29986
|
+
- get_file_contents
|
|
29987
|
+
- list_commits
|
|
29988
|
+
- create_branch
|
|
29989
|
+
- create_or_update_file
|
|
29990
|
+
- push_files
|
|
29991
|
+
- actions_get
|
|
29992
|
+
- actions_list
|
|
29993
|
+
- get_job_logs
|
|
29994
|
+
triggers:
|
|
29995
|
+
- events:
|
|
29996
|
+
- github.issue_comment.created
|
|
29997
|
+
- github.issue_comment.edited
|
|
29998
|
+
- github.pull_request_review.submitted
|
|
29999
|
+
- github.pull_request_review.edited
|
|
30000
|
+
- github.pull_request_review_comment.created
|
|
30001
|
+
- github.pull_request_review_comment.edited
|
|
30002
|
+
connection: "{{ $githubConnection }}"
|
|
30003
|
+
where:
|
|
30004
|
+
$.github.repository.fullName: "{{ $repoFullName }}"
|
|
30005
|
+
message: |
|
|
30006
|
+
A GitHub PR conversation update arrived for {{ $repoFullName }} PR #{{github.pullRequest.number}}.
|
|
30007
|
+
|
|
30008
|
+
Source URLs, when present:
|
|
30009
|
+
- issue comment: {{github.issueComment.htmlUrl}}
|
|
30010
|
+
- review: {{github.review.htmlUrl}}
|
|
30011
|
+
- review comment: {{github.reviewComment.htmlUrl}}
|
|
30012
|
+
|
|
30013
|
+
Read the update and decide whether it requires onboarding follow-up.
|
|
30014
|
+
Keep work on the existing PR branch and communicate in this web session.
|
|
30015
|
+
routing:
|
|
30016
|
+
kind: deliver
|
|
30017
|
+
routeBy:
|
|
30018
|
+
kind: ownedArtifact
|
|
30019
|
+
artifactType: github.pull_request
|
|
30020
|
+
onUnmatched: drop
|
|
30021
|
+
- event: github.check_run.completed
|
|
30022
|
+
connection: "{{ $githubConnection }}"
|
|
30023
|
+
where:
|
|
30024
|
+
$.github.repository.fullName: "{{ $repoFullName }}"
|
|
30025
|
+
$.github.checkRun.conclusion: failure
|
|
30026
|
+
$.github.checkRun.name:
|
|
30027
|
+
notIn:
|
|
30028
|
+
- All checks
|
|
30029
|
+
# Skip runs whose head was superseded by a newer push (headIsCurrent is
|
|
30030
|
+
# false); notIn keeps matching older events that predate the field.
|
|
30031
|
+
$.github.checkRun.headIsCurrent:
|
|
30032
|
+
notIn:
|
|
30033
|
+
- false
|
|
30034
|
+
message: |
|
|
30035
|
+
Check {{github.checkRun.name}} failed on {{ $repoFullName }} PR #{{github.pullRequest.number}}.
|
|
30036
|
+
|
|
30037
|
+
Diagnose the failure, fix it on the existing PR branch when it is in
|
|
30038
|
+
scope, and update this web session.
|
|
30039
|
+
|
|
30040
|
+
Check session URL: {{github.checkRun.htmlUrl}}
|
|
30041
|
+
routing:
|
|
30042
|
+
kind: deliver
|
|
30043
|
+
routeBy:
|
|
30044
|
+
kind: ownedArtifact
|
|
30045
|
+
artifactType: github.pull_request
|
|
30046
|
+
onUnmatched: drop
|
|
30047
|
+
- event: github.check_run.completed
|
|
30048
|
+
connection: "{{ $githubConnection }}"
|
|
30049
|
+
where:
|
|
30050
|
+
$.github.repository.fullName: "{{ $repoFullName }}"
|
|
30051
|
+
$.github.checkRun.conclusion: success
|
|
30052
|
+
$.github.checkRun.name: All checks
|
|
30053
|
+
# Skip runs whose head was superseded by a newer push (headIsCurrent is
|
|
30054
|
+
# false); notIn keeps matching older events that predate the field.
|
|
30055
|
+
$.github.checkRun.headIsCurrent:
|
|
30056
|
+
notIn:
|
|
30057
|
+
- false
|
|
30058
|
+
message: |
|
|
30059
|
+
Aggregate CI passed on {{ $repoFullName }} PR #{{github.pullRequest.number}}.
|
|
30060
|
+
|
|
30061
|
+
Inspect PR comments, reviews, and checks. If the PR is ready for the
|
|
30062
|
+
user to merge, say so in this web session; do not merge unless the user
|
|
30063
|
+
explicitly asks.
|
|
30064
|
+
routing:
|
|
30065
|
+
kind: deliver
|
|
30066
|
+
routeBy:
|
|
30067
|
+
kind: ownedArtifact
|
|
30068
|
+
artifactType: github.pull_request
|
|
30069
|
+
onUnmatched: drop
|
|
30070
|
+
- event: github.pull_request.merge_conflict
|
|
30071
|
+
connection: "{{ $githubConnection }}"
|
|
30072
|
+
where:
|
|
30073
|
+
$.github.repository.fullName: "{{ $repoFullName }}"
|
|
30074
|
+
message: |
|
|
30075
|
+
A merge conflict was detected on {{ $repoFullName }} PR #{{github.pullRequest.number}}.
|
|
30076
|
+
|
|
30077
|
+
Repair the existing PR branch with a normal follow-up commit if it is
|
|
30078
|
+
safe and scoped. Do not force-push or open a replacement PR.
|
|
30079
|
+
routing:
|
|
30080
|
+
kind: deliver
|
|
30081
|
+
routeBy:
|
|
30082
|
+
kind: ownedArtifact
|
|
30083
|
+
artifactType: github.pull_request
|
|
30084
|
+
onUnmatched: drop
|
|
30085
|
+
- event: auto.project_resource_apply.completed
|
|
30086
|
+
where:
|
|
30087
|
+
$.apply.auditAction: github_sync.apply
|
|
30088
|
+
message: |
|
|
30089
|
+
GitHub Sync applied project resources for an onboarding PR you own.
|
|
30090
|
+
|
|
30091
|
+
Apply operation: {{apply.operationId}}
|
|
30092
|
+
Created: {{apply.plan.counts.create}}
|
|
30093
|
+
Updated: {{apply.plan.counts.update}}
|
|
30094
|
+
Archived: {{apply.plan.counts.archive}}
|
|
30095
|
+
Unchanged: {{apply.plan.counts.unchanged}}
|
|
30096
|
+
Diagnostics: {{apply.plan.counts.diagnostics}}
|
|
30097
|
+
|
|
30098
|
+
Continue the onboarding flow in the web session. Inspect the deployed
|
|
30099
|
+
resource state with Auto MCP tools. If apply.plan.changedResources
|
|
30100
|
+
contains a newly created agent, spawn that agent to introduce itself in
|
|
30101
|
+
the session context or perform the next smoke-test step. Do not wait for
|
|
30102
|
+
the user to say they merged the PR or that the apply finished.
|
|
30103
|
+
routing:
|
|
30104
|
+
kind: deliver
|
|
30105
|
+
routeBy:
|
|
30106
|
+
kind: ownedArtifact
|
|
30107
|
+
artifactType: github.pull_request
|
|
30108
|
+
onUnmatched: drop
|
|
30109
|
+
- event: auto.project_resource_apply.failed
|
|
30110
|
+
where:
|
|
30111
|
+
$.apply.auditAction: github_sync.apply
|
|
30112
|
+
message: |
|
|
30113
|
+
GitHub Sync failed while applying project resources for an onboarding PR
|
|
30114
|
+
you own.
|
|
30115
|
+
|
|
30116
|
+
Apply operation: {{apply.operationId}}
|
|
30117
|
+
Error type: {{apply.error.name}}
|
|
30118
|
+
Error: {{apply.error.message}}
|
|
30119
|
+
Requested resources: {{apply.request.resources}}
|
|
30120
|
+
Requested deletes: {{apply.request.delete}}
|
|
30121
|
+
|
|
30122
|
+
Tell the user in the web session that Auto tried to apply the change and
|
|
30123
|
+
hit the error above. Then diagnose the failure, propose the concrete
|
|
30124
|
+
solution, repair the existing PR branch with a normal follow-up commit if
|
|
30125
|
+
the fix is in scope, and update the session with what changed. Do not ask
|
|
30126
|
+
the user to debug the apply locally.
|
|
30127
|
+
routing:
|
|
30128
|
+
kind: deliver
|
|
30129
|
+
routeBy:
|
|
30130
|
+
kind: ownedArtifact
|
|
30131
|
+
artifactType: github.pull_request
|
|
30132
|
+
onUnmatched: drop
|
|
30133
|
+
`
|
|
30134
|
+
},
|
|
30135
|
+
{
|
|
30136
|
+
path: "fragments/onboarding.yaml",
|
|
30137
|
+
content: 'systemPrompt: |\n # How you communicate\n\n The user is talking to you in Auto\'s web session UI and will respond to your\n replies directly in the session chat. Do not use Slack or chat tools for\n onboarding conversation, and do not tell the user to move the conversation to\n another surface.\n\n Keep replies short, conversational, and specific. Ask one question at a time.\n Before non-trivial repository exploration, resource editing, PR work, OAuth\n setup, debugging, or waiting on an async session, acknowledge what you are about\n to do in the session first.\n\n # Intent\n\n Achieve three goals, in this order:\n\n 1. Educate the user on what Auto is and how resources, agents, triggers, tools,\n sessions, and GitHub Sync fit together.\n 2. Get a tailor-made proactive workflow live that solves a real problem for\n them, and verify it works end to end.\n 3. Leave them with a repeatable path for improving their Auto system through\n committed `.auto/` resources and GitHub Sync.\n\n Never claim a step worked until you have verified it with the relevant Auto,\n GitHub, or session state.\n\n # Reference material\n\n Reference docs and examples are available in the sandbox under\n `/workspace/auto-docs/`. Read only what the current onboarding step needs.\n\n Start with:\n\n - `/workspace/auto-docs/docs/index.md`\n - `/workspace/auto-docs/docs/resource-model.md`\n - `/workspace/auto-docs/docs/agents-and-triggers.md`\n - `/workspace/auto-docs/docs/tools-and-connections.md`\n - `/workspace/auto-docs/docs/ci-cd.md`\n - `/workspace/auto-docs/examples/index.md`\n\n # Sandbox tooling\n\n Node.js 24 with npm is the only supported language toolchain \u2014 there is no\n pip or other Python package tooling (a bare `python3` exists, but do not\n rely on Python dependencies). Common CLIs are preinstalled: curl, git, jq,\n file, psql, redis-cli, temporal, tsx. A tool not listed here is likely\n absent; verify with `command -v` before relying on it.\n\n # Template-first agent creation\n\n Every onboarding example archetype is published as a managed template:\n `@auto/agent-fleet`, `@auto/chat-assistant`, `@auto/code-review`,\n `@auto/daily-digest`, `@auto/handoff`, `@auto/incident-response`,\n `@auto/issue-triage`, `@auto/lead-engine`, `@auto/research-loop`, and\n `@auto/self-improvement`. Each carries the full agent definition \u2014 prompts,\n triggers, tools, the runtime environment, and an identity with its avatar\n already baked in.\n\n Default to creating agents from the matching template. The tenant file is a\n thin import plus the template\'s variables:\n\n ```yaml\n imports:\n - "@auto/code-review@latest/agents/pr-review.yaml"\n variables:\n repoFullName: acme/widgets\n githubConnection: github-acme\n slackConnection: slack\n slackChannel: "#dev"\n ```\n\n Fields declared in the importing file override the template\'s on merge, so\n tailor behavior by overriding \u2014 prompt additions, a different cadence,\n extra tools \u2014 instead of re-authoring the agent. Triggers merge by their\n authoring `name:` (for example `mention` or `digest-heartbeat`): redeclare\n a named trigger to replace it, or drop entries with\n `remove: { triggers: [...], tools: [...] }`. Each example README under\n `/workspace/auto-docs/examples/` documents its template\'s variables, and\n the example directories are the readable source the templates were derived\n from (they differ in placeholder values and small template-only mechanics\n such as trigger names). Author bespoke agent YAML only when no template\n fits the workflow.\n\n The templates\' shared runtime environment carries no repository setup step.\n When an agent\'s job needs the repo\'s dependencies installed (a coding\n archetype on a Node repo, for example), override the full inline\n `environment` with a `setup` block for the repo\'s install command \u2014 and keep\n that override identical across every installed archetype (or move it to one\n local fragment they all import), because differing `agent-runtime`\n definitions conflict at apply.\n\n # Operating principles\n\n Use the Auto MCP tool as your operator surface for connection discovery,\n resource dry-runs, session inspection, session bindings, and consent flows.\n Use the GitHub MCP tools and the mounted checkout for repository work.\n\n Treat the mounted repository and project provider connections as already\n available. Inspect the checkout and `git remote get-url origin` before asking\n the user for repository details.\n\n Ask before changing anything outside `.auto/`. The onboarding write surface is\n the `.auto/` directory unless the user explicitly approves another file.\n\n When a provider or remote MCP tool authorization is needed, explain why, start\n the Auto connection flow, give the authorization URL cleanly, and verify the\n connection completed before continuing. Never ask the user to paste secret\n values into the session chat.\n\n Deploy through GitHub Sync. Validate drafted resources with\n `mcp__auto__auto_resources_dry_run` before opening a PR: pass the drafted\n `.auto/` files inline as UTF-8 strings. For example, to validate a template\n consumer:\n\n ```json\n {\n "files": [\n {\n "path": ".auto/agents/pr-review.yaml",\n "content": "imports:\\n - \\"@auto/code-review@latest/agents/pr-review.yaml\\"\\nvariables:\\n repoFullName: acme/widgets\\n githubConnection: github-acme\\n slackConnection: slack\\n slackChannel: \\"#dev\\"\\n"\n }\n ]\n }\n ```\n\n The result reports the apply plan (create / update / unchanged / archive) and\n diagnostics. Managed template imports resolve server-side, and a\n template-baked avatar sha256 validates with no image bytes; a custom avatar\n PNG cannot travel through this string-only interface, so that one check\n defers to the real GitHub Sync apply after merge. Once the plan looks right,\n open a focused PR, call `mcp__auto__auto_bind` for the PR, and\n tell the user to merge when the PR is ready. The apply lifecycle trigger will\n return the result to you.\n\n Every agent you create should have a clear identity and avatar. Agents\n created from a managed template inherit theirs. For bespoke agents, pick the\n closest role from the avatar catalog in `/workspace/auto-docs/docs/design.md`\n and declare `identity.avatar` with the catalog path and its `sha256` from the\n catalog table. The platform stores every catalog image, so a declared catalog\n hash needs no image file in the user\'s repo \u2014 never copy avatar PNGs around.\n\n When the user needs to do something, spell out the exact action and what they\n should expect to see. Do not rely on vague prompts like "try it when ready."\n\n # Onboarding beats\n\n Beat 1: Give a short pitch. Explain that Auto lets them compose agents and\n triggers into workflows using `.auto/` YAML, and that GitHub Sync applies\n merged resource changes. Ask what repetitive workflow or operational pain they\n want to automate first.\n\n Beat 2: Inspect the connected repository and the available Auto connections.\n Read the docs index and examples index. Summarize one recommended first\n workflow based on the repo and the user\'s answer.\n\n Beat 3: Draft the workflow under `.auto/`. Default to a thin import of the\n matching `@auto` template with its variables, overriding only what the user\'s\n needs require; author bespoke agent YAML only when no template fits. Dry-run\n the resources before opening a PR.\n\n Beat 4: Open the PR, bind the pull request to your session, and tell\n the user exactly what changed and what to review. Do not merge unless the user\n explicitly asks.\n\n Beat 5: After the user merges, handle the apply lifecycle event. Verify the\n resource state, then run or guide a smoke test that proves the workflow works.\n\n Beat 6: Recap what now exists and how the user can change it with normal PRs.\n Offer the next best improvement only after the first workflow is live and\n verified.\n\n When onboarding is complete and no immediate follow-up remains, call\n `mcp__auto__auto_sessions_archive_current`.\n'
|
|
30138
|
+
}
|
|
30139
|
+
]
|
|
29309
30140
|
}
|
|
29310
30141
|
],
|
|
29311
30142
|
"@auto/pr-review": [
|
|
@@ -38920,6 +39751,9 @@ function questionPart(data) {
|
|
|
38920
39751
|
function legacyToolEntry(chunk) {
|
|
38921
39752
|
switch (chunk.type) {
|
|
38922
39753
|
case "tool-input-available":
|
|
39754
|
+
if (chunk.toolName === ASK_USER_QUESTION_TOOL_NAME) {
|
|
39755
|
+
return null;
|
|
39756
|
+
}
|
|
38923
39757
|
return {
|
|
38924
39758
|
role: "assistant",
|
|
38925
39759
|
kind: "tool_call",
|
|
@@ -39466,6 +40300,16 @@ function conversationProjectionToUiChunks(projection) {
|
|
|
39466
40300
|
if (projection.kind === "question") {
|
|
39467
40301
|
return projection.content.parts.flatMap(
|
|
39468
40302
|
(part) => part.type === "question" ? [
|
|
40303
|
+
{
|
|
40304
|
+
type: "ui_message_chunk",
|
|
40305
|
+
chunk: {
|
|
40306
|
+
type: "tool-input-available",
|
|
40307
|
+
toolCallId: part.toolCallId ?? UNKNOWN_MESSAGE_ID,
|
|
40308
|
+
toolName: ASK_USER_QUESTION_TOOL_NAME,
|
|
40309
|
+
input: { questions: part.questions }
|
|
40310
|
+
},
|
|
40311
|
+
turnStatus: "waiting_for_input"
|
|
40312
|
+
},
|
|
39469
40313
|
{
|
|
39470
40314
|
type: "ui_message_chunk",
|
|
39471
40315
|
chunk: {
|
|
@@ -39488,10 +40332,13 @@ function conversationProjectionToUiChunks(projection) {
|
|
|
39488
40332
|
];
|
|
39489
40333
|
}
|
|
39490
40334
|
function projectAssistantSnapshot(projections) {
|
|
39491
|
-
|
|
39492
|
-
|
|
39493
|
-
|
|
39494
|
-
|
|
40335
|
+
const messageChunks = assistantSnapshotMessageChunks(projections);
|
|
40336
|
+
const rest = projections.filter((projection) => !isAssistantMessageOrToolCall(projection)).flatMap((projection) => conversationProjectionToUiChunks(projection));
|
|
40337
|
+
const last = messageChunks.at(-1);
|
|
40338
|
+
if (last?.type === "ui_message_chunk" && last.chunk.type === "finish" && rest.length > 0) {
|
|
40339
|
+
return [...messageChunks.slice(0, -1), ...rest, last];
|
|
40340
|
+
}
|
|
40341
|
+
return [...messageChunks, ...rest];
|
|
39495
40342
|
}
|
|
39496
40343
|
function assistantSnapshotMessageChunks(projections) {
|
|
39497
40344
|
const messageProjection = projections.find(
|