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

推荐订阅源

让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
人人都是产品经理
人人都是产品经理
Cisco Talos Blog
Cisco Talos Blog
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
V
V2EX
博客园 - 三生石上(FineUI控件)
Martin Fowler
Martin Fowler
WordPress大学
WordPress大学
D
Docker
S
SegmentFault 最新的问题
博客园 - 聂微东
美团技术团队
Apple Machine Learning Research
Apple Machine Learning Research
月光博客
月光博客
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
Last Week in AI
Last Week in AI
M
MIT News - Artificial intelligence
F
Fortinet All Blogs
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
The GitHub Blog
The GitHub Blog
GbyAI
GbyAI
L
LangChain Blog
Vercel News
Vercel News
博客园 - 叶小钗
MongoDB | Blog
MongoDB | Blog
Stack Overflow Blog
Stack Overflow Blog
H
Help Net Security
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
The Cloudflare Blog
Engineering at Meta
Engineering at Meta
T
Threat Research - Cisco Blogs
T
Threatpost
Scott Helme
Scott Helme
T
Tailwind CSS Blog
Latest news
Latest news
Stack Overflow Blog
Stack Overflow Blog
Blog — PlanetScale
Blog — PlanetScale
The Register - Security
The Register - Security
罗磊的独立博客
P
Proofpoint News Feed
腾讯CDC
S
Schneier on Security
雷峰网
雷峰网
A
About on SuperTechFans
T
Tenable Blog
F
Full Disclosure
Cyberwarzone
Cyberwarzone
博客园_首页
有赞技术团队
有赞技术团队
K
Kaspersky official blog

Recent Commits to openclaw:main

fix(memory): bound qmd embed backoff · openclaw/openclaw@caac973 fix(discord): bound timeout member expiry · openclaw/openclaw@6399b6a fix(qqbot): skip token cache on invalid clock · openclaw/openclaw@472606d fix(infra): bound device bootstrap expiry · openclaw/openclaw@1774965 fix(cron): bound relative at timestamps · openclaw/openclaw@e0248fc fix(crestodian): bound rescue approval expiry · openclaw/openclaw@6a753ad fix(gateway): forward stop sequences across providers feat: expand workboard orchestration metadata (#88408) fix(discord): bound rest rate-limit deadlines · openclaw/openclaw@abc26b0 fix(agents): show exec target node in tool display · openclaw/openclaw@64533ba fix(telegram): bound transport cooldown expiry · openclaw/openclaw@7d4bf8f test(release): harden live release checks · openclaw/openclaw@bdb0fde fix(anthropic): bound setup token expiry fix(bedrock): bound mantle runtime token expiry · openclaw/openclaw@70b6fdd fix(agents): bound sqlite cache expiry fix(agents): bound google prompt cache expiry · openclaw/openclaw@1ee751d fix(agents): bound auth profile block expiry · openclaw/openclaw@30e3ca0 fix(telegram): bound error cooldown expiry · openclaw/openclaw@1f6c1ea fix(discord): bound component registry expiry fix(discord): carry reply typing feedback through queue · openclaw/openclaw@6f20f29 fix(discord): omit undefined component registry fields fix(gateway): bound node pending work expiry fix(gateway): explain ignored restart signal · openclaw/openclaw@bc77f7a fix(media): dedupe duplicate inbound media path urls fix(gateway): bound plugin node capability expiry fix(install): show npm install progress without gum · openclaw/openclaw@1c9851e fix(commitments): bound terminal failure cooldown expiry · openclaw/openclaw@a4f6240 test(tasks): cover task domain view mappers (#86755) · openclaw/openclaw@8d3fe21 fix(imessage): bound private api negative cache expiry refactor(matrix): move ephemeral state to plugin sqlite (#88387) fix(imessage): bound approval reaction poll expiry fix(agents): bound exec followup handoff expiry · openclaw/openclaw@cbad1b6 fix(sandbox): bound novnc observer token expiry · openclaw/openclaw@f4cd5e4 test(release): wait for live probe cleanup · openclaw/openclaw@0e7773d fix(agents): bound exec approval request expiry · openclaw/openclaw@d8e7734 fix(google): bound realtime browser session expiry · openclaw/openclaw@da7fb64 fix(msteams): bound delegated token expiry · openclaw/openclaw@3fffb34 fix(workboard): bound claim expiry checks · openclaw/openclaw@0dd67e2 fix(browser): bound armed dialog expiry · openclaw/openclaw@4df27b9 fix(commands): bound private approval route expiry · openclaw/openclaw@e708a87 fix(agents): hide sessions_send alias normalization · openclaw/openclaw@2dacc6d fix(plugin-state): bound ttl expiry writes · openclaw/openclaw@9660e42 fix(skills): bound upload expiry checks · openclaw/openclaw@522da25 fix(exec): bound approval pending expiry · openclaw/openclaw@d44621b test(release): skip unavailable anthropic live models fix(matrix): bound allowlist store cache expiry · openclaw/openclaw@283238f fix(discord): bound unbound webhook echo expiry · openclaw/openclaw@5568ecc fix(zalouser): bound group context cache expiry · openclaw/openclaw@743d537 fix(tui): distinguish /new and /reset descriptions · openclaw/openclaw@63a3676 fix(voice-call): bound realtime stream token expiry feat(ui): add collapsible recent sessions section · openclaw/openclaw@a2fc4ca refactor: route model catalog imports to core package · openclaw/openclaw@8eeaa45 fix(sessions): repair prompt blobs on fast updates · openclaw/openclaw@4d13055 fix(qqbot): bound upload cache expiry · openclaw/openclaw@bfceffa fix(gateway): bound exec approval expiry · openclaw/openclaw@031583e fix(scripts): prebuild gateway cpu private qa artifacts · openclaw/openclaw@2ccbc67 fix(agents): bound code mode snapshot expiry · openclaw/openclaw@11b5728 [Fix] Deliver restart recovery replies (#86089) fix(feishu): bound card action token expiry · openclaw/openclaw@ac0fb97 fix(ci): repair current test type fixtures · openclaw/openclaw@1de9f99 fix(nvidia): bound featured model cache expiry fix(bedrock): bound discovery cache expiry · openclaw/openclaw@e52b4bc fix(plugins): ignore helper files in extension roots fix(bedrock): bound mantle iam token expiry · openclaw/openclaw@5ba3505 perf(gateway): reuse stable turn metadata · openclaw/openclaw@18e7d28 fix(outbound): bound current conversation expiry · openclaw/openclaw@02ca283 fix(plugin-sdk): bound live catalog cache expiry · openclaw/openclaw@4f0e3cb fix(outbound): pack newline-mode paragraphs up to limit fix(gateway): bound run session miss cache expiry · openclaw/openclaw@b1911a7 fix(agents): bound native permission approval expiry · openclaw/openclaw@450642a fix(discord): avoid private test session intersection fix(agents): bound native hook relay expiry fix(gateway): bound transcription relay session expiry fix(codex): refresh stale managed runtime plugin · openclaw/openclaw@3c91928 fix(gateway): bound realtime relay session expiry · openclaw/openclaw@6ac7564 fix(feishu): bound sender name cache expiry · openclaw/openclaw@23e1aac fix(discord): bound realtime wake followup expiry · openclaw/openclaw@c65af78 fix(scripts): make kitchen sink rpc help inert · openclaw/openclaw@4155ac1 fix(qqbot): honor legacy c2c stream progress fix(discord): bound speaker context cache expiry fix(gateway): bound config schema cache expiry Add per-agent SQLite cache store (#88349) · openclaw/openclaw@fc50f94 fix(qqbot): deliver partial tool progress fix(tailscale): bound whois cache expiry · openclaw/openclaw@f491d42 fix(google): bound gemini oauth token expiry fix(google): bound vertex adc token cache expiry · openclaw/openclaw@697bafa fix(msteams): bound parent thread cache expiry fix(msteams): bound team id cache expiry fix(whatsapp): bound group metadata cache expiry · openclaw/openclaw@5eb7192 fix(scripts): parse forwarded package script options fix(feishu): bound approval card expiry fix(feishu): bound quick action launcher expiry · openclaw/openclaw@0563470 fix(gateway): guard traced channel handoff stops · openclaw/openclaw@536c009 fix(feishu): bound card action chat cache clocks · openclaw/openclaw@c94c43d feat(ios): refresh app store metadata (#88235) · openclaw/openclaw@8a99c0d refactor: extract model catalog core package · openclaw/openclaw@30e1556 fix(feishu): bound group name cache clocks · openclaw/openclaw@ec15f90 fix(feishu): bound probe cache expiry clocks fix(zalo): bound hosted media expiry clocks · openclaw/openclaw@f91ddef fix(deps): remove photon root runtime · openclaw/openclaw@8438589
fix(agents): bound codex cli fallback expiry · openclaw/openclaw@53812bd
steipete · 2026-05-31 · via Recent Commits to openclaw:main

@@ -385,6 +385,30 @@ describe("cli credentials", () => {

385385

});

386386

});

387387388+

it("rejects Codex keychain fallback expiry when the process clock is invalid", () => {

389+

const tempHome = fs.mkdtempSync(path.join(os.tmpdir(), "openclaw-codex-"));

390+

process.env.CODEX_HOME = tempHome;

391+

const accountHash = "cli|";

392+

const dateNowSpy = vi.spyOn(Date, "now").mockReturnValue(Number.NaN);

393+

try {

394+

execSyncMock.mockImplementation((command: unknown) => {

395+

const cmd = String(command);

396+

expect(cmd).toContain("Codex Auth");

397+

expect(cmd).toContain(accountHash);

398+

return JSON.stringify({

399+

tokens: {

400+

access_token: createJwtWithExp(8_700_000_000_000),

401+

refresh_token: "keychain-refresh",

402+

},

403+

});

404+

});

405+406+

expect(readCodexCliCredentials({ platform: "darwin", execSync: execSyncMock })).toBeNull();

407+

} finally {

408+

dateNowSpy.mockRestore();

409+

}

410+

});

411+388412

it("falls back to Codex auth.json when keychain is unavailable", () => {

389413

const tempHome = fs.mkdtempSync(path.join(os.tmpdir(), "openclaw-codex-"));

390414

process.env.CODEX_HOME = tempHome;

@@ -418,6 +442,69 @@ describe("cli credentials", () => {

418442

});

419443

});

420444445+

it("rejects Codex auth.json fallback expiry when stat and process clock are invalid", () => {

446+

const tempHome = fs.mkdtempSync(path.join(os.tmpdir(), "openclaw-codex-invalid-clock-"));

447+

process.env.CODEX_HOME = tempHome;

448+

const authPath = path.join(tempHome, "auth.json");

449+

fs.mkdirSync(tempHome, { recursive: true, mode: 0o700 });

450+

fs.writeFileSync(

451+

authPath,

452+

JSON.stringify({

453+

tokens: {

454+

access_token: createJwtWithExp(8_700_000_000_000),

455+

refresh_token: "file-refresh",

456+

},

457+

}),

458+

"utf8",

459+

);

460+

execSyncMock.mockImplementation(() => {

461+

throw new Error("not found");

462+

});

463+

const statSyncSpy = vi.spyOn(fs, "statSync").mockImplementation(() => {

464+

throw new Error("stat unavailable");

465+

});

466+

const dateNowSpy = vi.spyOn(Date, "now").mockReturnValue(Number.NaN);

467+

try {

468+

expect(readCodexCliCredentials({ platform: "linux", execSync: execSyncMock })).toBeNull();

469+

} finally {

470+

dateNowSpy.mockRestore();

471+

statSyncSpy.mockRestore();

472+

}

473+

});

474+475+

it("uses Codex auth.json fallback expiry when file mtime has fractional milliseconds", () => {

476+

const tempHome = fs.mkdtempSync(path.join(os.tmpdir(), "openclaw-codex-fractional-mtime-"));

477+

process.env.CODEX_HOME = tempHome;

478+

const authPath = path.join(tempHome, "auth.json");

479+

fs.mkdirSync(tempHome, { recursive: true, mode: 0o700 });

480+

fs.writeFileSync(

481+

authPath,

482+

JSON.stringify({

483+

tokens: {

484+

access_token: createJwtWithExp(8_700_000_000_000),

485+

refresh_token: "file-refresh",

486+

},

487+

}),

488+

"utf8",

489+

);

490+

execSyncMock.mockImplementation(() => {

491+

throw new Error("not found");

492+

});

493+

const mtimeMs = Date.parse("2026-03-24T10:00:00Z") + 0.75;

494+

const statSyncSpy = vi.spyOn(fs, "statSync").mockReturnValue({ mtimeMs } as fs.Stats);

495+

try {

496+

const creds = readCodexCliCredentials({ platform: "linux", execSync: execSyncMock });

497+498+

expectFields(creds, {

499+

refresh: "file-refresh",

500+

provider: "openai-codex",

501+

expires: Math.floor(mtimeMs) + 60 * 60 * 1000,

502+

});

503+

} finally {

504+

statSyncSpy.mockRestore();

505+

}

506+

});

507+421508

it("does not read Codex keychain when keychain prompts are disabled", () => {

422509

const tempHome = fs.mkdtempSync(path.join(os.tmpdir(), "openclaw-codex-no-prompt-"));

423510

process.env.CODEX_HOME = tempHome;