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

推荐订阅源

Security Latest
Security Latest
U
Unit 42
D
Docker
H
Help Net Security
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
H
Hackread – Cybersecurity News, Data Breaches, AI and More
Microsoft Azure Blog
Microsoft Azure Blog
C
Cisco Blogs
阮一峰的网络日志
阮一峰的网络日志
S
Schneier on Security
Project Zero
Project Zero
F
Future of Privacy Forum
V
Vulnerabilities – Threatpost
Recent Announcements
Recent Announcements
T
Threatpost
T
True Tiger Recordings
量子位
The Hacker News
The Hacker News
Stack Overflow Blog
Stack Overflow Blog
Recorded Future
Recorded Future
T
The Blog of Author Tim Ferriss
S
SegmentFault 最新的问题
A
Arctic Wolf
Martin Fowler
Martin Fowler
I
InfoQ
Malwarebytes
Malwarebytes
T
Tor Project blog
Hugging Face - Blog
Hugging Face - Blog
M
MIT News - Artificial intelligence
S
Securelist
T
Tailwind CSS Blog
Blog — PlanetScale
Blog — PlanetScale
P
Proofpoint News Feed
W
WeLiveSecurity
The Register - Security
The Register - Security
Cisco Talos Blog
Cisco Talos Blog
H
Hacker News: Front Page
The Cloudflare Blog
O
OpenAI News
C
CERT Recently Published Vulnerability Notes
Hacker News: Ask HN
Hacker News: Ask HN
NISL@THU
NISL@THU
E
Exploit-DB.com RSS Feed
Scott Helme
Scott Helme
Jina AI
Jina AI
Spread Privacy
Spread Privacy
T
The Exploit Database - CXSecurity.com
T
Troy Hunt's Blog
N
News | PayPal Newsroom
李成银的技术随笔

Recent Commits to openclaw:main

fix(cron): route topic targets through channel plugins fix(agents): simplify subagent completion handoff ci(release): isolate npm publish concurrency · openclaw/openclaw@9c26b87 ci(release): allow beta publish after npm preflight · openclaw/openclaw@0e37263 fix(release): allow large beta smoke run lists ci(release): poll child workflows through actions api · openclaw/openclaw@e5dab55 fix(bootstrap): guard bootstrap name checks against undefined names (… · openclaw/openclaw@25fa46b fix(cli): waitForever must keep the event loop alive (#85694) · openclaw/openclaw@eca9645 fix(cli-output): ignore cumulative usage from result events in stream… fix(secrets): show irreversible warning after interactive apply confi… fix(agents/harness): pass CLI runtime aliases through to PI in select… docs: add bug-sweep changelog entries fix(release): run npm shims on Windows · openclaw/openclaw@1f32a48 fix(ci): repair crabbox hydrate replay (#85706) · openclaw/openclaw@0d7d99b feat(auth): support named model login profiles fix(gateway): restore WebChat image understanding routing · openclaw/openclaw@55a0c9b fix(anthropic): migrate 1M context to GA handling fix(scripts): resolve Crabbox shims on Windows · openclaw/openclaw@5c535df test(ci): harden installer smoke coverage · openclaw/openclaw@68bcd4e fix(status): bound deep docker audit probes (#85476) · openclaw/openclaw@f7c05dc docs: expand meeting notes docs · openclaw/openclaw@a7e0fa0 fix(cli): validate tasks audit limit (#84901) · openclaw/openclaw@44d470f fix(twitch): preserve newer message handler during cleanup (#85425) · openclaw/openclaw@71ddc01 fix(ci): require live docker credentials by resource · openclaw/openclaw@1e21121 fix(diagnostics): drop snake case otel ids (#72645) · openclaw/openclaw@e0bafc5 fix(ci): clear signal and docs guard blockers (#85693) · openclaw/openclaw@3a1d4dd fix(ci): require factory auth for droid live docker · openclaw/openclaw@cc6c372 fix: honor disabled synthetic auth lookup · openclaw/openclaw@a4a1abb fix(scripts): repair live docker auth shellcheck · openclaw/openclaw@4e34ac4 fix(docker): avoid printing gateway token · openclaw/openclaw@5db773f fix(cli): keep logs follow on live gateway state · openclaw/openclaw@6e3b318 fix(e2e): prefer x64 MinGit on Windows · openclaw/openclaw@15d9134 feat: add meeting notes plugin docs: update changelog for memory artifacts (#85060) (thanks @brokema… · openclaw/openclaw@9e55383 fix(memory-lancedb): expose public memory artifacts · openclaw/openclaw@aac1abe fix(memory): preserve sidecar capability hooks · openclaw/openclaw@e6288ca fix(e2e): scrub Windows update config on PowerShell 5.1 · openclaw/openclaw@6657b49 docs: absorb documentation PR sweep · openclaw/openclaw@2c536a8 fix(agents): stabilize Linux fallback tests · openclaw/openclaw@6b04170 fix(codex): preserve native web search action metadata (#85378) · openclaw/openclaw@bcf756c test: refresh Codex prompt snapshots · openclaw/openclaw@492d656 docs: absorb hook and subagent guidance PRs fix(agents): audit tool policy blocks (#85673) · openclaw/openclaw@09dd051 ci: fix plugin npm bundled dependency install · openclaw/openclaw@d485464 feat(diagnostics): classify skill and tool usage (#80370) docs(skills): clarify control ui recording proof (#85568) · openclaw/openclaw@0b476b9 test(agents): repair main failure fixtures · openclaw/openclaw@c29967b feat(diagnostics): trace gateway secret preparation (#83019) · openclaw/openclaw@4f0c902 fix(diagnostics): harden observability exports and smokes (#85371) · openclaw/openclaw@7f05be0 fix(stepfun): drop stale auth choice metadata · openclaw/openclaw@0b2ab6c test(e2e): sample kitchen sink RSS on Windows · openclaw/openclaw@73c1e37 test(plugins): fail gauntlet on load diagnostics fix(build): preserve tsdown heap floor · openclaw/openclaw@9ff1a43 fix(tools): honor config apiKey in media tool preflight (#85570) · openclaw/openclaw@31c269f fix(e2e): support macOS script wrappers fix(ci): scope changed shrinkwrap checks · openclaw/openclaw@743fd4c chore(ui): refresh fa control ui locale chore(ui): refresh nl control ui locale · openclaw/openclaw@908464b chore(ui): refresh vi control ui locale · openclaw/openclaw@62b75f4 chore(ui): refresh th control ui locale · openclaw/openclaw@fc4ba31 chore(ui): refresh id control ui locale · openclaw/openclaw@5b1bdd1 chore(ui): refresh pl control ui locale · openclaw/openclaw@534d4b1 chore(ui): refresh uk control ui locale · openclaw/openclaw@055c3bd chore(ui): refresh ar control ui locale · openclaw/openclaw@89c5a68 chore(ui): refresh it control ui locale · openclaw/openclaw@44ca805 chore(ui): refresh tr control ui locale chore(ui): refresh fr control ui locale · openclaw/openclaw@2240b0e chore(ui): refresh ko control ui locale · openclaw/openclaw@5fa250b chore(ui): refresh ja-JP control ui locale · openclaw/openclaw@f4ea401 chore(ui): refresh es control ui locale · openclaw/openclaw@751dde0 chore(ui): refresh de control ui locale · openclaw/openclaw@72a9b5b chore(ui): refresh pt-BR control ui locale · openclaw/openclaw@501b6e0 chore(ui): refresh zh-CN control ui locale chore(ui): refresh zh-TW control ui locale · openclaw/openclaw@88dee79 Add Slack approval QA checkpoints (#85141) fix(agents): mirror internal ui message tool replies (#85564) perf(whatsapp): narrow runtime setter entry (#85589) · openclaw/openclaw@463929d fix: smooth chat focus mode layout · openclaw/openclaw@bb5abef Fix Telegram missing harness spool poison (#85605) · openclaw/openclaw@b745082 fix(session): surface previous-transcript archive failures on /new ro… · openclaw/openclaw@679a46d Policy: add agent workspace conformance checks (#85096) · openclaw/openclaw@a94f344 fix(installer): fail failed Windows git builds · openclaw/openclaw@2edd6e2 fix(codex): honor node exec policy for native surfaces (#85534) · openclaw/openclaw@e0405ec fix(qa-lab): stabilize codex runtime parity fixtures fix(github): preserve sufficient proof against negative relabel (#85567) · openclaw/openclaw@6b52dff docs: add changelog for context pressure preflight · openclaw/openclaw@5ca734f Fix context pressure preflight for tool-heavy sessions (#85541) · openclaw/openclaw@c08400e fix(doctor): classify codex asset notice as info (#85119) · openclaw/openclaw@959b935 fix(ui): keep chat picker search current (#85547) fix: preserve message-tool delivery evidence · openclaw/openclaw@f022b05 fix(codex): add API key paste auth (#85533) fix: satisfy openai video test typecheck · openclaw/openclaw@743caed fix: route openai video edits to edits endpoint · openclaw/openclaw@6c3fcb8 fix(qmd): normalize direct file collection paths (#65212) · openclaw/openclaw@227b4bf fix(testbox): preserve clean sparse checkouts · openclaw/openclaw@58e9628 fix(ui): run ui script through junction paths (#85525) · openclaw/openclaw@ad19dd8 docs: fix troubleshooting logs link (#85545) · openclaw/openclaw@60582b6 Revert chat session picker inline search (#85527) · openclaw/openclaw@d69bcfd fix: preserve guarded video operation cleanup · openclaw/openclaw@ed7d99a fix: retry guarded video downloads · openclaw/openclaw@efbf9f3
ci(release): retry child workflow polling · openclaw/openclaw@c689f71
steipete · 2026-05-23 · via Recent Commits to openclaw:main

@@ -301,12 +301,35 @@ jobs:

301301

echo "Dispatched ${workflow}: https://github.com/${GITHUB_REPOSITORY}/actions/runs/${run_id}"

302302

echo "run_id=${run_id}" >> "$GITHUB_OUTPUT"

303303304+

gh_with_retry() {

305+

local output status attempt

306+

for attempt in 1 2 3 4 5 6; do

307+

set +e

308+

output="$(gh "$@" 2>&1)"

309+

status=$?

310+

set -e

311+

if [[ "$status" -eq 0 ]]; then

312+

printf '%s\n' "$output"

313+

return 0

314+

fi

315+

if [[ "$output" == *"Bad credentials"* || "$output" == *"HTTP 401"* || "$output" == *"secondary rate limit"* || "$output" == *"API rate limit"* ]]; then

316+

echo "::warning::gh $* failed on attempt ${attempt}: ${output}" >&2

317+

sleep $((attempt * 10))

318+

continue

319+

fi

320+

printf '%s\n' "$output" >&2

321+

return "$status"

322+

done

323+

printf '%s\n' "$output" >&2

324+

return "$status"

325+

}

326+304327

fetch_child_run_json() {

305-

gh api "repos/${GITHUB_REPOSITORY}/actions/runs/${run_id}"

328+

gh_with_retry api "repos/${GITHUB_REPOSITORY}/actions/runs/${run_id}"

306329

}

307330308331

fetch_child_jobs() {

309-

gh api --paginate "repos/${GITHUB_REPOSITORY}/actions/runs/${run_id}/jobs?per_page=100" --jq '.jobs[]'

332+

gh_with_retry api --paginate "repos/${GITHUB_REPOSITORY}/actions/runs/${run_id}/jobs?per_page=100" --jq '.jobs[]'

310333

}

311334312335

cancel_child() {

@@ -409,12 +432,35 @@ jobs:

409432

echo "Dispatched ${workflow}: https://github.com/${GITHUB_REPOSITORY}/actions/runs/${run_id}"

410433

echo "run_id=${run_id}" >> "$GITHUB_OUTPUT"

411434435+

gh_with_retry() {

436+

local output status attempt

437+

for attempt in 1 2 3 4 5 6; do

438+

set +e

439+

output="$(gh "$@" 2>&1)"

440+

status=$?

441+

set -e

442+

if [[ "$status" -eq 0 ]]; then

443+

printf '%s\n' "$output"

444+

return 0

445+

fi

446+

if [[ "$output" == *"Bad credentials"* || "$output" == *"HTTP 401"* || "$output" == *"secondary rate limit"* || "$output" == *"API rate limit"* ]]; then

447+

echo "::warning::gh $* failed on attempt ${attempt}: ${output}" >&2

448+

sleep $((attempt * 10))

449+

continue

450+

fi

451+

printf '%s\n' "$output" >&2

452+

return "$status"

453+

done

454+

printf '%s\n' "$output" >&2

455+

return "$status"

456+

}

457+412458

fetch_child_run_json() {

413-

gh api "repos/${GITHUB_REPOSITORY}/actions/runs/${run_id}"

459+

gh_with_retry api "repos/${GITHUB_REPOSITORY}/actions/runs/${run_id}"

414460

}

415461416462

fetch_child_jobs() {

417-

gh api --paginate "repos/${GITHUB_REPOSITORY}/actions/runs/${run_id}/jobs?per_page=100" --jq '.jobs[]'

463+

gh_with_retry api --paginate "repos/${GITHUB_REPOSITORY}/actions/runs/${run_id}/jobs?per_page=100" --jq '.jobs[]'

418464

}

419465420466

cancel_child() {

@@ -527,12 +573,35 @@ jobs:

527573

echo "Dispatched ${workflow}: https://github.com/${GITHUB_REPOSITORY}/actions/runs/${run_id}"

528574

echo "run_id=${run_id}" >> "$GITHUB_OUTPUT"

529575576+

gh_with_retry() {

577+

local output status attempt

578+

for attempt in 1 2 3 4 5 6; do

579+

set +e

580+

output="$(gh "$@" 2>&1)"

581+

status=$?

582+

set -e

583+

if [[ "$status" -eq 0 ]]; then

584+

printf '%s\n' "$output"

585+

return 0

586+

fi

587+

if [[ "$output" == *"Bad credentials"* || "$output" == *"HTTP 401"* || "$output" == *"secondary rate limit"* || "$output" == *"API rate limit"* ]]; then

588+

echo "::warning::gh $* failed on attempt ${attempt}: ${output}" >&2

589+

sleep $((attempt * 10))

590+

continue

591+

fi

592+

printf '%s\n' "$output" >&2

593+

return "$status"

594+

done

595+

printf '%s\n' "$output" >&2

596+

return "$status"

597+

}

598+530599

fetch_child_run_json() {

531-

gh api "repos/${GITHUB_REPOSITORY}/actions/runs/${run_id}"

600+

gh_with_retry api "repos/${GITHUB_REPOSITORY}/actions/runs/${run_id}"

532601

}

533602534603

fetch_child_jobs() {

535-

gh api --paginate "repos/${GITHUB_REPOSITORY}/actions/runs/${run_id}/jobs?per_page=100" --jq '.jobs[]'

604+

gh_with_retry api --paginate "repos/${GITHUB_REPOSITORY}/actions/runs/${run_id}/jobs?per_page=100" --jq '.jobs[]'

536605

}

537606538607

release_check_blocking_job() {

@@ -816,6 +885,29 @@ jobs:

816885

echo "Dispatched npm-telegram-beta-e2e.yml: https://github.com/${GITHUB_REPOSITORY}/actions/runs/${run_id}"

817886

echo "run_id=${run_id}" >> "$GITHUB_OUTPUT"

818887888+

gh_with_retry() {

889+

local output status attempt

890+

for attempt in 1 2 3 4 5 6; do

891+

set +e

892+

output="$(gh "$@" 2>&1)"

893+

status=$?

894+

set -e

895+

if [[ "$status" -eq 0 ]]; then

896+

printf '%s\n' "$output"

897+

return 0

898+

fi

899+

if [[ "$output" == *"Bad credentials"* || "$output" == *"HTTP 401"* || "$output" == *"secondary rate limit"* || "$output" == *"API rate limit"* ]]; then

900+

echo "::warning::gh $* failed on attempt ${attempt}: ${output}" >&2

901+

sleep $((attempt * 10))

902+

continue

903+

fi

904+

printf '%s\n' "$output" >&2

905+

return "$status"

906+

done

907+

printf '%s\n' "$output" >&2

908+

return "$status"

909+

}

910+819911

cancel_child() {

820912

if [[ -n "${run_id:-}" ]]; then

821913

echo "Cancelling child workflow npm-telegram-beta-e2e.yml: ${run_id}" >&2

@@ -826,26 +918,26 @@ jobs:

826918827919

poll_count=0

828920

while true; do

829-

status="$(gh run view "$run_id" --json status --jq '.status')"

921+

status="$(gh_with_retry run view "$run_id" --json status --jq '.status')"

830922

if [[ "$status" == "completed" ]]; then

831923

break

832924

fi

833925

poll_count=$((poll_count + 1))

834926

if (( poll_count % 10 == 0 )); then

835927

echo "Still waiting on npm-telegram-beta-e2e.yml: https://github.com/${GITHUB_REPOSITORY}/actions/runs/${run_id}"

836-

gh run view "$run_id" --json jobs --jq '.jobs[] | select(.status != "completed") | {name, status, url}' || true

928+

gh_with_retry run view "$run_id" --json jobs --jq '.jobs[] | select(.status != "completed") | {name, status, url}' || true

837929

fi

838930

sleep 30

839931

done

840932

trap - EXIT INT TERM

841933842-

conclusion="$(gh run view "$run_id" --json conclusion --jq '.conclusion')"

843-

url="$(gh run view "$run_id" --json url --jq '.url')"

934+

conclusion="$(gh_with_retry run view "$run_id" --json conclusion --jq '.conclusion')"

935+

url="$(gh_with_retry run view "$run_id" --json url --jq '.url')"

844936

echo "npm-telegram-beta-e2e.yml finished with ${conclusion}: ${url}"

845937

echo "url=${url}" >> "$GITHUB_OUTPUT"

846938

echo "conclusion=${conclusion}" >> "$GITHUB_OUTPUT"

847939

if [[ "$conclusion" != "success" ]]; then

848-

gh run view "$run_id" --json jobs --jq '.jobs[] | select(.conclusion != "success" and .conclusion != "skipped") | {name, conclusion, url}' || true

940+

gh_with_retry run view "$run_id" --json jobs --jq '.jobs[] | select(.conclusion != "success" and .conclusion != "skipped") | {name, conclusion, url}' || true

849941

exit 1

850942

fi

851943