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

推荐订阅源

Google DeepMind News
Google DeepMind News
F
Fortinet All Blogs
阮一峰的网络日志
阮一峰的网络日志
Apple Machine Learning Research
Apple Machine Learning Research
爱范儿
爱范儿
WordPress大学
WordPress大学
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
J
Java Code Geeks
罗磊的独立博客
S
SegmentFault 最新的问题
V
V2EX
V
Visual Studio Blog
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
美团技术团队
博客园 - 三生石上(FineUI控件)
Stack Overflow Blog
Stack Overflow Blog
Y
Y Combinator Blog
MyScale Blog
MyScale Blog
D
Docker
Google DeepMind News
Google DeepMind News
Blog — PlanetScale
Blog — PlanetScale
M
Microsoft Research Blog - Microsoft Research
Martin Fowler
Martin Fowler
S
Secure Thoughts
B
Blog
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
www.infosecurity-magazine.com
www.infosecurity-magazine.com
Recent Announcements
Recent Announcements
MongoDB | Blog
MongoDB | Blog
C
Cisco Blogs
C
CERT Recently Published Vulnerability Notes
T
True Tiger Recordings
GbyAI
GbyAI
P
Proofpoint News Feed
P
Privacy International News Feed
Jina AI
Jina AI
The Cloudflare Blog
I
Intezer
AWS News Blog
AWS News Blog
Hacker News - Newest:
Hacker News - Newest: "LLM"
S
Security Archives - TechRepublic
NISL@THU
NISL@THU
The Register - Security
The Register - Security
Recent Commits to openclaw:main
Recent Commits to openclaw:main
P
Palo Alto Networks Blog
S
Schneier on Security
L
LINUX DO - 热门话题
C
CXSECURITY Database RSS Feed - CXSecurity.com
Security Latest
Security Latest
C
Cybersecurity and Infrastructure Security Agency CISA

Recent Commits to openclaw:main

暂无文章

fix(qqbot): wrap malformed token json · openclaw/openclaw@d9c6036
vincentkoc · 2026-05-14 · via Recent Commits to openclaw:main

File tree

  • extensions/qqbot/src/engine/api

Original file line numberDiff line numberDiff line change

@@ -61,6 +61,7 @@ Docs: https://docs.openclaw.ai

6161

- Google provider: report malformed SSE stream JSON with provider-owned errors instead of leaking raw parser failures.

6262

- Node host: report malformed built-in invoke `paramsJSON` with stable invalid-request errors instead of leaking raw parser failures.

6363

- Amazon Bedrock embeddings: report malformed provider response JSON with provider-owned errors instead of leaking raw parser failures.

64+

- QQBot: report malformed access-token JSON with provider-owned errors instead of leaking raw parser failures.

6465

- Models config/auth: stop inferring provider env-var markers from broad `^[A-Z_][A-Z0-9_]*$` strings, and resolve config-backed provider `apiKey` values only through structured env SecretRefs (`secrets.providers[id]` / `secrets.defaults`), so unrelated env vars cannot accidentally become provider credentials. Thanks @sallyom.

6566

- Media fetch: skip allocating and buffering the response body for bodyless media responses (HEAD probes and 204-style empty bodies), avoiding wasted heap on streams that carry no payload. Thanks @shakkernerd.

6667

- CLI/onboarding: forward provider-specific auth flags (e.g. `--openai-api-key`) through the onboarding wizard so they reach provider auth methods via `ctx.opts`, letting `--openai-api-key "$OPENAI_API_KEY"` skip the redundant "use existing env var?" prompt in non-interactive harnesses. (#81669) Thanks @sjf.

Original file line numberDiff line numberDiff line change

@@ -0,0 +1,24 @@

1+

import { afterEach, describe, expect, it, vi } from "vitest";

2+

import { TokenManager } from "./token.js";

3+
4+

describe("QQBot token manager", () => {

5+

afterEach(() => {

6+

vi.unstubAllGlobals();

7+

});

8+
9+

it("wraps malformed access token JSON", async () => {

10+

vi.stubGlobal(

11+

"fetch",

12+

vi.fn().mockResolvedValue(

13+

new Response("{not json", {

14+

status: 200,

15+

headers: { "content-type": "application/json" },

16+

}),

17+

),

18+

);

19+
20+

await expect(new TokenManager().getAccessToken("app-id", "secret")).rejects.toThrow(

21+

"QQBot access_token response was malformed JSON",

22+

);

23+

});

24+

});

Original file line numberDiff line numberDiff line change

@@ -228,17 +228,23 @@ export class TokenManager {

228228

`[qqbot:token:${appId}] <<< ${response.status}${traceId ? ` | TraceId: ${traceId}` : ""}`,

229229

);

230230
231-

let data: { access_token?: string; expires_in?: number };

231+

let rawBody: string;

232232

try {

233-

const rawBody = await response.text();

234-

const logBody = rawBody.replace(/"access_token"\s*:\s*"[^"]+"/g, '"access_token": "***"');

235-

this.logger?.debug?.(`[qqbot:token:${appId}] <<< Body: ${logBody}`);

236-

data = JSON.parse(rawBody);

233+

rawBody = await response.text();

237234

} catch (err) {

238-

throw new Error(`Failed to parse access_token response: ${formatErrorMessage(err)}`, {

235+

throw new Error(`Failed to read access_token response: ${formatErrorMessage(err)}`, {

239236

cause: err,

240237

});

241238

}

239+

const logBody = rawBody.replace(/"access_token"\s*:\s*"[^"]+"/g, '"access_token": "***"');

240+

this.logger?.debug?.(`[qqbot:token:${appId}] <<< Body: ${logBody}`);

241+
242+

let data: { access_token?: string; expires_in?: number };

243+

try {

244+

data = JSON.parse(rawBody);

245+

} catch {

246+

throw new Error("QQBot access_token response was malformed JSON");

247+

}

242248
243249

if (!data.access_token) {

244250

throw new Error(`Failed to get access_token: ${JSON.stringify(data)}`);