惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

T
True Tiger Recordings
Cyberwarzone
Cyberwarzone
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
C
Cybersecurity and Infrastructure Security Agency CISA
Spread Privacy
Spread Privacy
T
Threat Research - Cisco Blogs
T
Tenable Blog
Latest news
Latest news
H
Hackread – Cybersecurity News, Data Breaches, AI and More
S
Securelist
F
Future of Privacy Forum
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
aimingoo的专栏
aimingoo的专栏
量子位
小众软件
小众软件
罗磊的独立博客
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
酷 壳 – CoolShell
酷 壳 – CoolShell
V
V2EX - 技术
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
云风的 BLOG
云风的 BLOG
P
Palo Alto Networks Blog
C
CERT Recently Published Vulnerability Notes
博客园 - Franky
C
Cyber Attacks, Cyber Crime and Cyber Security
T
Threatpost
J
Java Code Geeks
Apple Machine Learning Research
Apple Machine Learning Research
T
Tailwind CSS Blog
P
Privacy International News Feed
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
博客园 - 聂微东
H
Help Net Security
A
Arctic Wolf
L
LINUX DO - 热门话题
D
DataBreaches.Net
K
Kaspersky official blog
N
News | PayPal Newsroom
C
Check Point Blog
Project Zero
Project Zero
D
Darknet – Hacking Tools, Hacker News & Cyber Security
SecWiki News
SecWiki News
Jina AI
Jina AI
L
LINUX DO - 最新话题
Recent Commits to openclaw:main
Recent Commits to openclaw:main
The GitHub Blog
The GitHub Blog
Google DeepMind News
Google DeepMind News
美团技术团队
F
Full Disclosure
Schneier on Security
Schneier on Security

Recent Commits to openclaw:main

test(docker): expect prod store seed command fix(agents): bound embedded compaction write locks · openclaw/openclaw@46de078 fix(update): repair managed npm plugin peers fix(update): repair managed npm plugin peers (#83794) (thanks @fuller… · openclaw/openclaw@de8a82a fix(telegram): honor table mode in outbound chunks (#85455) fix(docker): precreate owned named volume targets (#85454) fix(ui): strip ANSI from displayed gateway logs (#85453) fix(skills): accept macos os requirement on darwin (#85451) fix(gateway): preserve message-tool replies in chat history test: track Docker prod store seed command · openclaw/openclaw@9a816f4 fix: satisfy prod store package list lint · openclaw/openclaw@d5247d0 test(plugins): clear lookup metadata memo fix(docker): seed prod store before offline prune · openclaw/openclaw@6788aa1 fix(memory): expand home paths in extra memory paths (#85449) · openclaw/openclaw@48bf037 docs: add security FAQ guidance chore(deps): refresh npm shrinkwraps docs: clarify OpenAI HTTP client guidance docs: remove stale showcase intro videos · openclaw/openclaw@00d3dca fix(gateway): point model override error to config docs docs: document secrets provider plan fields docs: clarify media directive formatting · openclaw/openclaw@c876fec docs: align memory search cache default refactor(ios): centralize setup auth parsing test(release): wait for config reload log proof refactor(ios): consolidate manual auth override inputs · openclaw/openclaw@d93c597 fix(ui): hide thinking options for non-reasoning models (#85406) · openclaw/openclaw@bb4d88e fix(ui): attach pasted data image text (#85392) · openclaw/openclaw@a03a8d9 fix(gateway): preserve OpenAI usage aliases in chat history (#85383) · openclaw/openclaw@d9c6c5f feat(ios): add realtime talk relay mode · openclaw/openclaw@e730e9b fix(browser): hint WSL portproxy CDP empty replies (#85379) · openclaw/openclaw@933f01c fix(installer): persist portable Git on Windows · openclaw/openclaw@5b90a48 fix(opencode-go): strip Kimi reasoning replay fields (#85377) · openclaw/openclaw@d22bcfc fix(build): normalize cache paths on Windows (#85437) · openclaw/openclaw@81d22c8 fix(update): detect nested macOS gateway ancestry (#85391) · openclaw/openclaw@adc6adc fix(docker): seed offline prune store in runtime stage · openclaw/openclaw@faf2a6c fix(ci): stabilize npm shrinkwrap metadata · openclaw/openclaw@21bedd3 fix(codex): route node exec through OpenClaw tools · openclaw/openclaw@5cc0dbc test(installer): track portable node root helper · openclaw/openclaw@9364b21 fix(ui): sync talk transcript translations fix(ui): localize talk transcript labels · openclaw/openclaw@8fc48af fix(release): stabilize config restart QA · openclaw/openclaw@cc91ff0 fix(installer): extract portable Node directly test(qa-lab): report scenario pack coverage · openclaw/openclaw@dcd98bf fix(plugins): drop stale tlon tool contract · openclaw/openclaw@d70dc4b fix(installer): prefer tar for portable Node extraction · openclaw/openclaw@a54a881 fix(codex): deliver native subagent completions feat: add context-engine host capability requirements (#84994) · openclaw/openclaw@cff5244 fix(release): keep shrinkwrap pinned to pnpm lock · openclaw/openclaw@9d24fde fix: surface plan updates as status notices · openclaw/openclaw@dc04503 test(google): narrow web search fake timers · openclaw/openclaw@fe7d13c fix(installer): extract portable Node with ZipFile · openclaw/openclaw@ffa6cd8 fix(gateway): defer provider auth prewarm after startup (#85369) · openclaw/openclaw@69255f8 fix(talk): stabilize realtime voice consults · openclaw/openclaw@683ad75 test(qa): tolerate slow gateway rpc startup · openclaw/openclaw@29118a0 chore(diagnostics): refresh plugin sdk baseline · openclaw/openclaw@ab684f5 fix(diagnostics): surface async queue drops fix(diagnostics): bound diagnostic buffers · openclaw/openclaw@bdcaac0 fix(installer): copy portable Node into place · openclaw/openclaw@c21ca88 fix(cli): recover replaced device approvals (#85342) · openclaw/openclaw@6ea907c test(release): align prerelease validation · openclaw/openclaw@0def3e2 fix(installer): install portable Node directory atomically · openclaw/openclaw@2890b1a fix(runtime-llm): avoid duplicate provider prefix in allowlist diagno… · openclaw/openclaw@937a756 fix(gateway): include openclaw bin in service PATH (#84475) · openclaw/openclaw@66d1d13 fix(gateway): handle concurrent launchd bootstrap restart race (#84722) · openclaw/openclaw@ba86716 feat: support pi and opencode autoreview engines · openclaw/openclaw@31a189d ci(package): gate acceptance on package integrity · openclaw/openclaw@5275929 ci(release): bypass pnpm for tsdown package build · openclaw/openclaw@fea89cd test(release): align prerelease validation baselines · openclaw/openclaw@04ebdc6 ci(release): harden docker package build · openclaw/openclaw@7b1fbe1 fix(codex): skip native web search transcript mirroring (#85346) · openclaw/openclaw@c3531fc fix(gateway): harden launchd reload handoff race recovery (#84641) · openclaw/openclaw@fc7a531 fix: honor per-model provider transport overrides (#80488) fix(skills): type watcher mock calls in dedupe regression tests · openclaw/openclaw@bb73f0a fix(skills): dedupe shared-directory watchers across agent workspaces… · openclaw/openclaw@3e94290 fix(skills): document watcher edge cases, add teardown/rebuild tests,… · openclaw/openclaw@19ff77e fix(infra): allow macos browser open over ssh env (#85340) · openclaw/openclaw@47d66fe fix(update): preserve package service state during cutover (#83026) · openclaw/openclaw@a15797a fix(gateway): broadcast agent-run error payloads (#85355) · openclaw/openclaw@07e61fc test(e2e): avoid synthetic channel config in plugin smoke fix(cli): suppress systemd hints for live gateway (#85336) · openclaw/openclaw@a00c583 fix(cli): honor agent for model auth logout (#85326) · openclaw/openclaw@fc47c1f fix(gateway): eager-load lifecycle runtime to survive in-place upgrad… · openclaw/openclaw@4a91385 fix(doctor): point codex asset warning at migrate plan (#85324) fix(update): harden managed handoff cwd (#83875) · openclaw/openclaw@1bafc23 docs(release): prepare 2026.5.21 notes ci(crabbox): harden docker hydration refactor(crabbox): parse provider list from binary help instead of ha… test(plugins): keep rpc source walk on source call gateway test(plugins): add kitchen sink rpc docker lane · openclaw/openclaw@6f6da5f test(plugins): run kitchen sink rpc lane without tsx test(qa-lab): add bus tool trace scenario · openclaw/openclaw@2b39613 fix(cron): classify network retry errors (#85344) fix(installer): bootstrap portable Windows Node · openclaw/openclaw@3551e98 fix(ui): move chat session search into picker (#85303) · openclaw/openclaw@1fdc73a fix: opt codex out of bundled runtime deps · openclaw/openclaw@fcecbd8 test: update shrinkwrap packaging expectations · openclaw/openclaw@a1b05aa fix: publish explicit plugin bundled dependencies · openclaw/openclaw@976da39 chore: refresh shrinkwrap metadata chore: harden npm shrinkwrap release path fix: keep bundled plugin peers nested · openclaw/openclaw@86faf65
fix(update): roll back failed git updates · openclaw/openclaw@769fd0b
vincentkoc · 2026-05-23 · via Recent Commits to openclaw:main

@@ -161,7 +161,7 @@ export type UpdateInstallSurface =

161161162162

function mapManagerResolutionFailure(

163163

reason: UpdatePackageManagerFailureReason,

164-

): UpdateRunResult["reason"] {

164+

): NonNullable<UpdateRunResult["reason"]> {

165165

return reason;

166166

}

167167

@@ -766,7 +766,7 @@ export async function runGatewayUpdate(opts: UpdateRunnerOptions = {}): Promise<

766766

const beforeVersion = await readPackageVersion(gitRoot);

767767

const channel: UpdateChannel = opts.channel ?? "dev";

768768

const devTargetRef = channel === "dev" ? normalizeDevTargetRef(opts.devTargetRef) : null;

769-

const branch = channel === "dev" ? await readBranchName(runCommand, gitRoot, timeoutMs) : null;

769+

const branch = await readBranchName(runCommand, gitRoot, timeoutMs);

770770

const needsCheckoutMain = channel === "dev" && !devTargetRef && branch !== DEV_BRANCH;

771771

gitTotalSteps = channel === "dev" ? (needsCheckoutMain ? 11 : 10) : 9;

772772

const buildGitErrorResult = (reason: string): UpdateRunResult => ({

@@ -786,6 +786,60 @@ export async function runGatewayUpdate(opts: UpdateRunnerOptions = {}): Promise<

786786

}

787787

return null;

788788

};

789+

const appendRecoveryStep = async (name: string, argv: string[]) => {

790+

const started = Date.now();

791+

const result = await runCommand(argv, { cwd: gitRoot, timeoutMs });

792+

const recoveryStep: UpdateStepResult = {

793+

name,

794+

command: argv.join(" "),

795+

cwd: gitRoot,

796+

durationMs: Date.now() - started,

797+

exitCode: result.code,

798+

stdoutTail: trimLogTail(result.stdout, MAX_LOG_CHARS),

799+

stderrTail: trimLogTail(result.stderr, MAX_LOG_CHARS),

800+

};

801+

steps.push(recoveryStep);

802+

return recoveryStep.exitCode === 0;

803+

};

804+

const rollbackGitCheckout = async () => {

805+

if (!beforeSha) {

806+

return;

807+

}

808+

await appendRecoveryStep("git rollback clean", ["git", "-C", gitRoot, "reset", "--hard"]);

809+

if (branch && branch !== "HEAD") {

810+

const checkedOutBranch = await appendRecoveryStep("git rollback checkout", [

811+

"git",

812+

"-C",

813+

gitRoot,

814+

"checkout",

815+

"--force",

816+

branch,

817+

]);

818+

if (checkedOutBranch) {

819+

await appendRecoveryStep("git rollback reset", [

820+

"git",

821+

"-C",

822+

gitRoot,

823+

"reset",

824+

"--hard",

825+

beforeSha,

826+

]);

827+

}

828+

return;

829+

}

830+

await appendRecoveryStep("git rollback checkout", [

831+

"git",

832+

"-C",

833+

gitRoot,

834+

"checkout",

835+

"--detach",

836+

beforeSha,

837+

]);

838+

};

839+

const buildGitErrorResultWithRollback = async (reason: string): Promise<UpdateRunResult> => {

840+

await rollbackGitCheckout();

841+

return buildGitErrorResult(reason);

842+

};

789843790844

const statusCheck = await runStep(

791845

step(

@@ -1212,15 +1266,7 @@ export async function runGatewayUpdate(opts: UpdateRunnerOptions = {}): Promise<

12121266

"require-preferred",

12131267

);

12141268

if (manager.kind === "missing-required") {

1215-

return {

1216-

status: "error",

1217-

mode: "git",

1218-

root: gitRoot,

1219-

reason: mapManagerResolutionFailure(manager.reason),

1220-

before: { sha: beforeSha, version: beforeVersion },

1221-

steps,

1222-

durationMs: Date.now() - startedAt,

1223-

};

1269+

return await buildGitErrorResultWithRollback(mapManagerResolutionFailure(manager.reason));

12241270

}

12251271

try {

12261272

const installEnv = resolveInstallEnv(manager.manager, manager.env);

@@ -1247,15 +1293,7 @@ export async function runGatewayUpdate(opts: UpdateRunnerOptions = {}): Promise<

12471293

}

12481294

}

12491295

if (finalDepsStep.exitCode !== 0) {

1250-

return {

1251-

status: "error",

1252-

mode: "git",

1253-

root: gitRoot,

1254-

reason: "deps-install-failed",

1255-

before: { sha: beforeSha, version: beforeVersion },

1256-

steps,

1257-

durationMs: Date.now() - startedAt,

1258-

};

1296+

return await buildGitErrorResultWithRollback("deps-install-failed");

12591297

}

1260129812611299

const buildStep = await runStep(

@@ -1268,31 +1306,15 @@ export async function runGatewayUpdate(opts: UpdateRunnerOptions = {}): Promise<

12681306

);

12691307

steps.push(buildStep);

12701308

if (buildStep.exitCode !== 0) {

1271-

return {

1272-

status: "error",

1273-

mode: "git",

1274-

root: gitRoot,

1275-

reason: "build-failed",

1276-

before: { sha: beforeSha, version: beforeVersion },

1277-

steps,

1278-

durationMs: Date.now() - startedAt,

1279-

};

1309+

return await buildGitErrorResultWithRollback("build-failed");

12801310

}

1281131112821312

const uiBuildStep = await runStep(

12831313

step("ui:build", managerScriptArgs(manager.manager, "ui:build"), gitRoot, manager.env),

12841314

);

12851315

steps.push(uiBuildStep);

12861316

if (uiBuildStep.exitCode !== 0) {

1287-

return {

1288-

status: "error",

1289-

mode: "git",

1290-

root: gitRoot,

1291-

reason: "ui-build-failed",

1292-

before: { sha: beforeSha, version: beforeVersion },

1293-

steps,

1294-

durationMs: Date.now() - startedAt,

1295-

};

1317+

return await buildGitErrorResultWithRollback("ui-build-failed");

12961318

}

1297131912981320

const doctorEntry = path.join(gitRoot, "openclaw.mjs");

@@ -1309,15 +1331,7 @@ export async function runGatewayUpdate(opts: UpdateRunnerOptions = {}): Promise<

13091331

exitCode: 1,

13101332

stderrTail: `missing ${doctorEntry}`,

13111333

});

1312-

return {

1313-

status: "error",

1314-

mode: "git",

1315-

root: gitRoot,

1316-

reason: "doctor-entry-missing",

1317-

before: { sha: beforeSha, version: beforeVersion },

1318-

steps,

1319-

durationMs: Date.now() - startedAt,

1320-

};

1334+

return await buildGitErrorResultWithRollback("doctor-entry-missing");

13211335

}

1322133613231337

// Use --fix so that doctor auto-strips unknown config keys introduced by

@@ -1335,15 +1349,7 @@ export async function runGatewayUpdate(opts: UpdateRunnerOptions = {}): Promise<

13351349

);

13361350

steps.push(doctorStep);

13371351

if (doctorStep.exitCode !== 0) {

1338-

return {

1339-

status: "error",

1340-

mode: "git",

1341-

root: gitRoot,

1342-

reason: "doctor-failed",

1343-

before: { sha: beforeSha, version: beforeVersion },

1344-

steps,

1345-

durationMs: Date.now() - startedAt,

1346-

};

1352+

return await buildGitErrorResultWithRollback("doctor-failed");

13471353

}

1348135413491355

const uiIndexHealth = await resolveControlUiDistIndexHealth({ root: gitRoot });

@@ -1367,15 +1373,7 @@ export async function runGatewayUpdate(opts: UpdateRunnerOptions = {}): Promise<

13671373

steps.push(repairStep);

1368137413691375

if (repairResult.code !== 0) {

1370-

return {

1371-

status: "error",

1372-

mode: "git",

1373-

root: gitRoot,

1374-

reason: "ui-build-failed",

1375-

before: { sha: beforeSha, version: beforeVersion },

1376-

steps,

1377-

durationMs: Date.now() - startedAt,

1378-

};

1376+

return await buildGitErrorResultWithRollback("ui-build-failed");

13791377

}

1380137813811379

const repairedUiIndexHealth = await resolveControlUiDistIndexHealth({ root: gitRoot });

@@ -1390,15 +1388,7 @@ export async function runGatewayUpdate(opts: UpdateRunnerOptions = {}): Promise<

13901388

exitCode: 1,

13911389

stderrTail: `missing ${uiIndexPath}`,

13921390

});

1393-

return {

1394-

status: "error",

1395-

mode: "git",

1396-

root: gitRoot,

1397-

reason: "ui-assets-missing",

1398-

before: { sha: beforeSha, version: beforeVersion },

1399-

steps,

1400-

durationMs: Date.now() - startedAt,

1401-

};

1391+

return await buildGitErrorResultWithRollback("ui-assets-missing");

14021392

}

14031393

}

14041394