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

推荐订阅源

F
Full Disclosure
Recorded Future
Recorded Future
T
Tenable Blog
S
Securelist
C
CERT Recently Published Vulnerability Notes
T
Threatpost
S
Schneier on Security
A
Arctic Wolf
The Hacker News
The Hacker News
C
CXSECURITY Database RSS Feed - CXSecurity.com
Know Your Adversary
Know Your Adversary
P
Privacy International News Feed
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
The Register - Security
The Register - Security
Cisco Talos Blog
Cisco Talos Blog
AWS News Blog
AWS News Blog
K
Kaspersky official blog
T
True Tiger Recordings
T
Threat Research - Cisco Blogs
V
Vulnerabilities – Threatpost
P
Palo Alto Networks Blog
T
The Exploit Database - CXSecurity.com
小众软件
小众软件
B
Blog
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
Microsoft Azure Blog
Microsoft Azure Blog
Cyberwarzone
Cyberwarzone
C
Cybersecurity and Infrastructure Security Agency CISA
T
Tor Project blog
Spread Privacy
Spread Privacy
Malwarebytes
Malwarebytes
P
Proofpoint News Feed
F
Fox-IT International blog
F
Fortinet All Blogs
P
Privacy & Cybersecurity Law Blog
G
GRAHAM CLULEY
量子位
Latest news
Latest news
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
博客园 - 叶小钗
Project Zero
Project Zero
T
Tailwind CSS Blog
N
Netflix TechBlog - Medium
Martin Fowler
Martin Fowler
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
IntelliJ IDEA : IntelliJ IDEA – the Leading IDE for Professional Development in Java and Kotlin | The JetBrains Blog
I
Intezer
博客园_首页
腾讯CDC
H
Hackread – Cybersecurity News, Data Breaches, AI and More
D
Darknet – Hacking Tools, Hacker News & Cyber Security

Recent Commits to openclaw:main

perf(secrets): propagate snapshots and eliminate esm side-effects in … test: stabilize main ci lanes · openclaw/openclaw@f327df8 perf(gateway): keep agent session working store active-only · openclaw/openclaw@54eca3f test(e2e): harden shell helper env assertions · openclaw/openclaw@e6937f9 fix(doctor): warn on unsupported active tool schemas · openclaw/openclaw@4976851 test: fix main ci expectations · openclaw/openclaw@3684696 fix(e2e): bound Telegram credential setup · openclaw/openclaw@9b28603 perf(gateway): borrow agent session lookup safely · openclaw/openclaw@3b9fa16 fix(crabbox): prefer Azure for Windows targets (#87186) · openclaw/openclaw@6afe3e8 test(e2e): isolate shell helper env · openclaw/openclaw@b28f9e0 fix(e2e): bound MCP channel connect · openclaw/openclaw@aa40174 perf(gateway): borrow read-only session metadata · openclaw/openclaw@8c8162f fix(googlechat): suppress thread sends in DMs · openclaw/openclaw@da822dd Fix embedded session file ownership race (#87159) · openclaw/openclaw@3349fe2 ci(ui): refresh raw copy baseline · openclaw/openclaw@ebe09be fix(pi-embedded): route Codex OAuth compaction through OpenAI-Codex · openclaw/openclaw@1710dac fix(commands): enforce /allowlist configWrites origin policy · openclaw/openclaw@ce64d74 fix(plugin-sdk): stop exporting vitest test helpers (#87120) · openclaw/openclaw@780bc79 perf(gateway): borrow session reads on turn hot paths · openclaw/openclaw@9c2a6a8 fix(reply): keep visible turn admission unbounded (#87044) · openclaw/openclaw@455d5e8 fix(e2e): bound Telegram proof Bot API calls · openclaw/openclaw@4b40197 fix(agents): quarantine unsupported tool schemas · openclaw/openclaw@8c644ee test(core): isolate provider and approval tests · openclaw/openclaw@e7214ef fix(agents): preserve sessions fallback errors · openclaw/openclaw@7986917 fix(prompt): route untrusted group prompts outside system prompt [AI]… · openclaw/openclaw@2c88547 feat: expose plugin approval action metadata · openclaw/openclaw@0c867ee docs(changelog): refresh 2026.5.26 notes · openclaw/openclaw@e74a039 fix: bind plugin command llm auth to host agent · openclaw/openclaw@b9f6abf fix(e2e): bound kitchen sink RPC probes · openclaw/openclaw@96bd939 ci: support native Windows Crabbox daemon hydration (#87175) · openclaw/openclaw@95c8fc9 fix: handle sessions_send active fallback failures (#86638) · openclaw/openclaw@81e7e8e fix(gateway): enable default auth rate limiting (#87148) · openclaw/openclaw@ae972fe test(media): isolate generation provider registry mocks (#87173) · openclaw/openclaw@9772cf2 perf(gateway): skip lifecycle session cache clone · openclaw/openclaw@0762aca fix(e2e): backstop Parallels update jobs · openclaw/openclaw@fdf58c1 fix(daemon): keep Windows Scheduled Task running on battery power (#5… · openclaw/openclaw@d92a333 fix(daemon): avoid workgroup schtasks user prompts · openclaw/openclaw@f348284 perf(gateway): avoid cloning live switch store reads · openclaw/openclaw@b75f70b fix(crabbox): use host-visible local work roots · openclaw/openclaw@586a6ce docs(changelog): refresh 2026.5.26 notes · openclaw/openclaw@15c0dfa fix(exec): hide unavailable durable approval actions (#86359) · openclaw/openclaw@42f0822 fix(reply): derive explicit control command turns · openclaw/openclaw@2899560 fix(e2e): check onboarding systemd noise · openclaw/openclaw@44c1cc8 test(agents): cover cold default model alias resolution · openclaw/openclaw@2e3b4b5 fix: keep plugin runtime fallback on startup root · openclaw/openclaw@2b9be22 fix: expand startup argv runtime fallback hints · openclaw/openclaw@e71b6f7 test: cover plugin runtime diagnostic context · openclaw/openclaw@78b2aee Fix runtime fallback startup argv default · openclaw/openclaw@66a8262 fix: prefer trusted argv runtime fallback roots · openclaw/openclaw@5371b96 Fix plugin runtime module resolution diagnostics · openclaw/openclaw@41fa603 fix(ui): show config open failure feedback (#87108) · openclaw/openclaw@8246e91 fix(e2e): bound Telegram RTT bot API calls · openclaw/openclaw@5981822 fix(install): bound finalization probes (#86997) · openclaw/openclaw@bf1a5c3 fix(memory): reject prompt-like memory stores (#87142) · openclaw/openclaw@119d235 fix(e2e): bound release user journey fixture probes · openclaw/openclaw@6b68d05 fix(e2e): bound bundled runtime HTTP probes · openclaw/openclaw@d886816 perf(gateway): skip duplicate turn session touch · openclaw/openclaw@8fa4fad test: avoid repeated module reloads in unit tests · openclaw/openclaw@1c8a112 fix(media): keep explicit workspace roots scoped · openclaw/openclaw@608fa52 fix(e2e): bound bundled runtime smoke commands · openclaw/openclaw@fca77dc test: route more command tests through light suite · openclaw/openclaw@bbfcdea fix(scripts): short-circuit helper help · openclaw/openclaw@4b23b36 test: harden docker smoke portability · openclaw/openclaw@10056c9 fix(agents): recover failed subagent lifecycle completions · openclaw/openclaw@4980c32 fix(e2e): hard kill timed out host commands · openclaw/openclaw@dd44a47 test: move lightweight command tests to light suite · openclaw/openclaw@2831d69 fix(scripts): handle helper cli help · openclaw/openclaw@2cc6871 fix(gateway): bound loopback preflight calls · openclaw/openclaw@6d5c15a fix(hooks): enforce default hook agent allowlist · openclaw/openclaw@e72621e fix(e2e): handle docker helper cli help · openclaw/openclaw@2814ab6 fix(codex): avoid native compaction on budget triggers (#86772) · openclaw/openclaw@eb8f9b4 test: speed up plugin test fixtures · openclaw/openclaw@05ff771 fix(e2e): bound openai chat tools client · openclaw/openclaw@de94217 fix(e2e): bound upgrade survivor probes · openclaw/openclaw@981ae13 fix(doctor): keep hooks model checks read-only (#86101) · openclaw/openclaw@371c4d6 fix(installer): tighten nonroot smoke node preflight · openclaw/openclaw@340f480 fix(e2e): bound HTTP readiness probes · openclaw/openclaw@d58f864 fix(daemon): keep node tasks off gateway listener cleanup · openclaw/openclaw@a4e0b6e perf(gateway): reuse prepared auth stores · openclaw/openclaw@d2711c9 test: speed up codex app server run attempts · openclaw/openclaw@1ce3637 build(codex): update Codex CLI to 0.134.0 · openclaw/openclaw@231a812 docs(skills): omit advisory ids from changelog notes · openclaw/openclaw@989a369 test: speed up test project routing · openclaw/openclaw@140892c Fix stale approval prompts in Control UI (#86270) · openclaw/openclaw@5297eeb fix(installer): reject stale cli node runtimes · openclaw/openclaw@49d605e test: harden e2e harness isolation · openclaw/openclaw@acbb06e fix: keep approval runtime token local-only · openclaw/openclaw@96c5766 perf(gateway): defer skipped-channel sidecars · openclaw/openclaw@145b57c docs(changelog): omit advisory id from release notes · openclaw/openclaw@d606881 docs(changelog): refresh 2026.5.26 notes · openclaw/openclaw@26c0c19 docs(skills): add release changelog update workflow · openclaw/openclaw@c8d20ae fix(e2e): bound upgrade survivor cli checks · openclaw/openclaw@c965b3a test: speed up doctor config flow tests · openclaw/openclaw@5177180 fix(events): sanitize queued system markers (#87094) · openclaw/openclaw@c1151ea fix(gateway): remove redundant unknown union · openclaw/openclaw@f393ebe test: speed up model fallback tests · openclaw/openclaw@e7f644c fix(imessage): stage remote media before understanding · openclaw/openclaw@ae52be9 fix(gateway): drop stale subagent announce history · openclaw/openclaw@982e888 fix: repair local approval resolution (#86771) · openclaw/openclaw@13cfb77 fix(e2e): bound codex media plugin setup · openclaw/openclaw@f89fcdd
fix(gateway): persist model auth profile suffixes · openclaw/openclaw@152f68d
1052326311 · 2026-05-27 · via Recent Commits to openclaw:main

@@ -804,4 +804,107 @@ describe("gateway sessions patch", () => {

804804

expect(entry.providerOverride).toBe("synthetic");

805805

expect(entry.modelOverride).toBe("hf:moonshotai/Kimi-K2.5");

806806

});

807+808+

test("persists trailing @profile suffix as authProfileOverride on model patch", async () => {

809+

const entry = expectPatchOk(

810+

await runPatch({

811+

cfg: createAllowlistedAnthropicModelCfg(),

812+

patch: { key: MAIN_SESSION_KEY, model: "anthropic/claude-sonnet-4-6@myprofile" },

813+

loadGatewayModelCatalog: async () => [

814+

{ provider: "anthropic", id: "claude-sonnet-4-6", name: "claude-sonnet-4-6" },

815+

],

816+

}),

817+

);

818+

expect(entry.providerOverride).toBe("anthropic");

819+

expect(entry.modelOverride).toBe("claude-sonnet-4-6");

820+

expect(entry.authProfileOverride).toBe("myprofile");

821+

expect(entry.authProfileOverrideSource).toBe("user");

822+

expect(entry.liveModelSwitchPending).toBe(true);

823+

});

824+825+

test("marks same-model @profile patches as pending live model switches", async () => {

826+

const store: Record<string, SessionEntry> = {

827+

[MAIN_SESSION_KEY]: {

828+

sessionId: "sess-live-profile-only",

829+

updatedAt: 1,

830+

providerOverride: "anthropic",

831+

modelOverride: "claude-sonnet-4-6",

832+

authProfileOverride: "oldprofile",

833+

authProfileOverrideSource: "user",

834+

} as SessionEntry,

835+

};

836+

const entry = expectPatchOk(

837+

await runPatch({

838+

store,

839+

cfg: createAllowlistedAnthropicModelCfg(),

840+

patch: { key: MAIN_SESSION_KEY, model: "anthropic/claude-sonnet-4-6@newprofile" },

841+

loadGatewayModelCatalog: async () => [

842+

{ provider: "anthropic", id: "claude-sonnet-4-6", name: "claude-sonnet-4-6" },

843+

],

844+

}),

845+

);

846+

expect(entry.providerOverride).toBe("anthropic");

847+

expect(entry.modelOverride).toBe("claude-sonnet-4-6");

848+

expect(entry.authProfileOverride).toBe("newprofile");

849+

expect(entry.liveModelSwitchPending).toBe(true);

850+

});

851+852+

test("does not set authProfileOverride when profile suffix is missing", async () => {

853+

const entry = expectPatchOk(

854+

await runPatch({

855+

cfg: createAllowlistedAnthropicModelCfg(),

856+

patch: { key: MAIN_SESSION_KEY, model: "anthropic/claude-sonnet-4-6" },

857+

loadGatewayModelCatalog: async () => [

858+

{ provider: "anthropic", id: "claude-sonnet-4-6", name: "claude-sonnet-4-6" },

859+

],

860+

}),

861+

);

862+

expect(entry.providerOverride).toBe("anthropic");

863+

expect(entry.modelOverride).toBe("claude-sonnet-4-6");

864+

expect(entry.authProfileOverride).toBeUndefined();

865+

});

866+867+

test("persists full provider:profile authProfileOverride on model patch", async () => {

868+

const entry = expectPatchOk(

869+

await runPatch({

870+

cfg: createAllowlistedAnthropicModelCfg(),

871+

patch: {

872+

key: MAIN_SESSION_KEY,

873+

model: "anthropic/claude-sonnet-4-6@openai-codex:user@example.com",

874+

},

875+

loadGatewayModelCatalog: async () => [

876+

{ provider: "anthropic", id: "claude-sonnet-4-6", name: "claude-sonnet-4-6" },

877+

],

878+

}),

879+

);

880+

expect(entry.providerOverride).toBe("anthropic");

881+

expect(entry.modelOverride).toBe("claude-sonnet-4-6");

882+

expect(entry.authProfileOverride).toBe("openai-codex:user@example.com");

883+

expect(entry.authProfileOverrideSource).toBe("user");

884+

});

885+886+

test("resolves bare allowlisted model ids before persisting @profile suffix", async () => {

887+

const entry = expectPatchOk(

888+

await runPatch({

889+

cfg: {

890+

agents: {

891+

defaults: {

892+

model: { primary: "openai/gpt-5.4" },

893+

models: {

894+

"opencode-go/kimi-k2.6": {},

895+

},

896+

},

897+

},

898+

} as OpenClawConfig,

899+

patch: { key: MAIN_SESSION_KEY, model: "kimi-k2.6@work" },

900+

loadGatewayModelCatalog: async () => [

901+

{ provider: "openai", id: "gpt-5.4", name: "gpt-5.4" },

902+

{ provider: "opencode-go", id: "kimi-k2.6", name: "kimi-k2.6" },

903+

],

904+

}),

905+

);

906+

expect(entry.providerOverride).toBe("opencode-go");

907+

expect(entry.modelOverride).toBe("kimi-k2.6");

908+

expect(entry.authProfileOverride).toBe("work");

909+

});

807910

});