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

推荐订阅源

N
News and Events Feed by Topic
Malwarebytes
Malwarebytes
Threat Intelligence Blog | Flashpoint
Threat Intelligence Blog | Flashpoint
C
Cybersecurity and Infrastructure Security Agency CISA
F
Future of Privacy Forum
C
Cisco Blogs
T
The Exploit Database - CXSecurity.com
A
Arctic Wolf
S
Securelist
K
Kaspersky official blog
S
Schneier on Security
T
ThreatConnect
T
Tenable Blog
Spread Privacy
Spread Privacy
T
True Tiger Recordings
AWS News Blog
AWS News Blog
F
Fox-IT International blog
量子位
T
Threatpost
V
Vulnerabilities – Threatpost
C
CERT Recently Published Vulnerability Notes
Cisco Talos Blog
Cisco Talos Blog
GbyAI
GbyAI
宝玉的分享
宝玉的分享
腾讯CDC
G
Google Developers Blog
aimingoo的专栏
aimingoo的专栏
Cyberwarzone
Cyberwarzone
有赞技术团队
有赞技术团队
S
SegmentFault 最新的问题
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
V
Visual Studio Blog
U
Unit 42
雷峰网
雷峰网
cs.CV updates on arXiv.org
cs.CV updates on arXiv.org
Simon Willison's Weblog
Simon Willison's Weblog
O
OpenAI News
freeCodeCamp Programming Tutorials: Python, JavaScript, Git & More
The GitHub Blog
The GitHub Blog
The Register - Security
The Register - Security
MyScale Blog
MyScale Blog
小众软件
小众软件
A
About on SuperTechFans
Last Week in AI
Last Week in AI
Y
Y Combinator Blog
博客园 - 三生石上(FineUI控件)
美团技术团队
Google Online Security Blog
Google Online Security Blog
P
Proofpoint News Feed
MongoDB | Blog
MongoDB | Blog

Recent Commits to openclaw:main

test(agents): keep runtime-plan provider mock current fix(scripts): launch env package scripts on Windows · openclaw/openclaw@4d4ce9e fix(agents): cache fallback provider resolution · openclaw/openclaw@3c8d101 fix(test): make import timing scripts Windows-safe · openclaw/openclaw@8ae9977 fix(telegram): transient Telegram pairing prompts (#85555) · openclaw/openclaw@8209426 fix(test): make max Vitest scripts Windows-safe · openclaw/openclaw@b681d5d fix(doctor): migrate Feishu account bot names (#86081) · openclaw/openclaw@9e8cc7e fix(scripts): prefilter conflict marker scans docs: add ClawSweeper review policy to AGENTS (#86197) · openclaw/openclaw@242e876 fix(installer): avoid before with npm release-age configs (#85491) · openclaw/openclaw@4742db6 fix(e2e): retry Windows kitchen sink probes · openclaw/openclaw@3e275a5 fix(installer): install node with apk on alpine fix(installer): detect musl linux shells · openclaw/openclaw@acfed37 perf(plugins,gateway): thread metadata snapshot + discovery through h… · openclaw/openclaw@8ccb11c fix(ui): split control ui runtime chunks · openclaw/openclaw@8bf4f7d refactor(config): extract GoogleChat schema into zod-schema.providers… · openclaw/openclaw@fe34141 fix(update): suppress internal handoff version warnings · openclaw/openclaw@6cc8244 test(e2e): select installable bundled plugins · openclaw/openclaw@0acc3e3 fix(scripts): harden Windows native opus install · openclaw/openclaw@43252c8 fix(agents): match runtime policy entries when session provider is em… fix(scripts): harden Windows generated formatting · openclaw/openclaw@0a98559 fix(mcp): bound tools/list during catalog discovery (#85063) · openclaw/openclaw@07f500a fix(test): focus plugin binding Docker smoke · openclaw/openclaw@dfa1a51 test(e2e): fail release memory indexing errors test(daemon): fail launchd integration bootstrap errors · openclaw/openclaw@af07769 feat(imessage): support thumb approval reactions (#85952) · openclaw/openclaw@5c7980f fix(crabbox): default macos aws runs on demand fix(scripts): preserve test passthrough args · openclaw/openclaw@e4332f7 fix(e2e): harden Windows plugin assertions fix(test): mount upgrade survivor helper · openclaw/openclaw@5f03154 fix(android): prevent stale chat during session switches fix(android): keep permission setup action visible · openclaw/openclaw@94bc18a style(android): sharpen voice mode surfaces · openclaw/openclaw@c452510 fix(android): hide internal chat content blocks · openclaw/openclaw@d86ed21 style(android): refine list surface spacing · openclaw/openclaw@955909c feat(android): add pair new gateway action · openclaw/openclaw@cc5eb97 Advance iMessage catchup cursor after live handling (#85475) · openclaw/openclaw@102555c fix(scripts): ignore forwarded arg separator · openclaw/openclaw@79ee70c fix(test): fail empty gateway startup samples · openclaw/openclaw@5a8ce6a fix(e2e): harden Windows kitchen sink assertions · openclaw/openclaw@87a2eba fix(e2e): harden Telegram credential paths on Windows · openclaw/openclaw@c643370 fix(android): align setup pairing scopes fix(android): complete qr setup operator handoff · openclaw/openclaw@be9bb77 fix(test): copy cleanup smoke prepare hook · openclaw/openclaw@dbc08f6 fix(secrets): allow hash in exec SecretRef ids (#86072) · openclaw/openclaw@675158c fix(media): use static image compression metadata · openclaw/openclaw@694d45e fix(release): verify large plugin npm packs fix(test): require kitchen sink diagnostic canaries · openclaw/openclaw@7e51f83 fix(scripts): harden Windows upgrade survivor recipe · openclaw/openclaw@483d7be fix(installer): count verify progress stage fix: Refine PR template for review state (#86054) fix(test): repair split agent shard runs · openclaw/openclaw@125d82c fix(codex): harden Windows protocol formatting · openclaw/openclaw@ce48e4c fix(openrouter): use endpoint context limits (#86041) · openclaw/openclaw@dd01a2e test(qa): remove brittle capability flip setup turn fix(telegram): migrate legacy cache sidecars · openclaw/openclaw@eb9b882 fix(telegram): migrate account topic cache sidecars · openclaw/openclaw@5cfb12f fix(scripts): harden Windows ZAI fallback repro · openclaw/openclaw@5be62e7 style(android): sharpen v2 screen rhythm · openclaw/openclaw@400d90a test(qa): extend capability flip setup budget · openclaw/openclaw@c91c3c6 fix(android): simplify gateway status copy fix(android): route offline voice to gateway setup fix(scripts): harden Windows control UI i18n commands · openclaw/openclaw@581c8a6 fix(android): stop operator chat subscription · openclaw/openclaw@5c15859 fix(test): fail missing kitchen sink rss samples test(qa): widen capability flip restart budget · openclaw/openclaw@c7d4e9e fix(android): smooth gateway pairing recovery · openclaw/openclaw@60e6ccd fix(test): suppress rolldown timing noise · openclaw/openclaw@6d9b388 style(android): fix talk mode ktlint formatting · openclaw/openclaw@01b284c fix(telegram): store topic cache in plugin state fix(telegram): store bot info cache in plugin state · openclaw/openclaw@2ed5296 fix(test): sync sparse AWS Crabbox runs from full checkout · openclaw/openclaw@0f82c81 fix(release): harden Windows cross-os command shims · openclaw/openclaw@7154767 fix(test): harden Docker resource ceilings test(telegram): keep startup limiter coverage focused test(telegram): isolate startup probe limiter timing · openclaw/openclaw@04d86e0 test(release): harden plugin prerelease checks · openclaw/openclaw@578e73f fix(telegram): serialize topic dispatch replies (#85709) · openclaw/openclaw@62b51a6 test(release): stabilize plugin prerelease checks · openclaw/openclaw@3679151 fix(test): fail live gateway false greens · openclaw/openclaw@295339d fix(test): build startup artifacts for smoke scripts · openclaw/openclaw@3838e45 test(telegram): wait for startup probe slots · openclaw/openclaw@0a8af67 test(codex): match sandbox exec-server yolo policy · openclaw/openclaw@783290f fix(test): fail missing explicit test targets · openclaw/openclaw@9ff4d36 test(codex): avoid full sandbox exec-server turn run · openclaw/openclaw@558c1bc fix(ci): keep Crabbox pnpm hydration shims writable · openclaw/openclaw@bca1ac0 fix(release): harden Windows release-check npm probes · openclaw/openclaw@75ac11a fix(docker): parse peer-suffixed lockfile packages · openclaw/openclaw@cf46f2e fix(docker): seed lockfile packages before prune · openclaw/openclaw@f799da0 fix(docker): seed lockfile snapshot tarballs before prune · openclaw/openclaw@2cd93f1 test(codex): type thread start mock params · openclaw/openclaw@a4ef3a2 test(codex): avoid full sandbox run in thread-start test · openclaw/openclaw@11bf642 fix(plugins): harden Windows npm package staging · openclaw/openclaw@abdd8a4 test(codex): complete sandbox turn inline · openclaw/openclaw@c14a0c6 fix(release): harden Windows npm shim verification · openclaw/openclaw@a56f452 test(release): type metadata snapshot mock params · openclaw/openclaw@f878959 test(release): finish plugin metadata prerelease sync fix(update): avoid broad tag fetches for dev updates (#84737) · openclaw/openclaw@501f2cb Fix iMessage slash command acknowledgements (#82642) · openclaw/openclaw@4d15020 test(release): align prerelease contracts · openclaw/openclaw@02f53e6
fix(installer): support alpine cli installs · openclaw/openclaw@f68ed72
vincentkoc · 2026-05-25 · via Recent Commits to openclaw:main

@@ -53,6 +53,12 @@ OPENCLAW_EFFECTIVE_HOME="$(resolve_openclaw_effective_home)"

5353

PREFIX="${OPENCLAW_PREFIX:-${HOME}/.openclaw}"

5454

OPENCLAW_VERSION="${OPENCLAW_VERSION:-latest}"

5555

NODE_VERSION="${OPENCLAW_NODE_VERSION:-22.22.0}"

56+

NODE_VERSION_REQUESTED=0

57+

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

58+

NODE_VERSION_REQUESTED=1

59+

fi

60+

MIN_NODE_VERSION="22.19.0"

61+

APK_NODE_BIN_DIR="/usr/bin"

5662

SHARP_IGNORE_GLOBAL_LIBVIPS="${SHARP_IGNORE_GLOBAL_LIBVIPS:-1}"

5763

NPM_LOGLEVEL="${OPENCLAW_NPM_LOGLEVEL:-error}"

5864

INSTALL_METHOD="${OPENCLAW_INSTALL_METHOD:-npm}"

@@ -215,6 +221,14 @@ ensure_git() {

215221

else

216222

fail "Git missing and sudo unavailable. Install git and retry."

217223

fi

224+

elif command -v apk >/dev/null 2>&1; then

225+

if is_root; then

226+

apk add --no-cache git

227+

elif has_sudo; then

228+

sudo apk add --no-cache git

229+

else

230+

fail "Git missing and sudo unavailable. Install git and retry."

231+

fi

218232

else

219233

fail "Git missing and package manager not found. Install git and retry."

220234

fi

@@ -252,6 +266,7 @@ parse_args() {

252266

;;

253267

--node-version)

254268

NODE_VERSION="$2"

269+

NODE_VERSION_REQUESTED=1

255270

shift 2

256271

;;

257272

--install-method|--method)

@@ -329,6 +344,177 @@ npm_bin() {

329344

echo "$(node_dir)/bin/npm"

330345

}

331346347+

command_path_without_node_prefix() {

348+

local name="$1"

349+

local path_entry

350+

local prefix_bin

351+

local filtered_path=""

352+

local separator=""

353+

local -a path_entries=()

354+355+

prefix_bin="$(node_dir)/bin"

356+

IFS=: read -r -a path_entries <<<"$PATH"

357+

for path_entry in "${path_entries[@]}"; do

358+

if [[ "$path_entry" == "$prefix_bin" ]]; then

359+

continue

360+

fi

361+

filtered_path="${filtered_path}${separator}${path_entry}"

362+

separator=":"

363+

done

364+365+

PATH="$filtered_path" command -v "$name" 2>/dev/null

366+

}

367+368+

is_musl_linux() {

369+

if [[ "$(os_detect)" != "linux" ]]; then

370+

return 1

371+

fi

372+

if [[ -f /etc/alpine-release ]]; then

373+

return 0

374+

fi

375+

ldd --version 2>&1 | grep -qi musl

376+

}

377+378+

link_node_runtime_paths() {

379+

local node_path="$1"

380+

local npm_path="$2"

381+

local dir

382+

local runtime_bin

383+

local resolved

384+

dir="$(node_dir)"

385+

runtime_bin="${node_path%/*}"

386+387+

mkdir -p "${dir}/bin" "${PREFIX}/tools"

388+

ln -sfn "$node_path" "${dir}/bin/node"

389+

ln -sfn "$npm_path" "${dir}/bin/npm"

390+

for name in npx corepack; do

391+

if [[ -x "${runtime_bin}/${name}" ]]; then

392+

ln -sfn "${runtime_bin}/${name}" "${dir}/bin/${name}"

393+

continue

394+

fi

395+

resolved="$(command_path_without_node_prefix "$name" || true)"

396+

if [[ -n "$resolved" && "$resolved" != "${dir}/bin/${name}" ]]; then

397+

ln -sfn "$resolved" "${dir}/bin/${name}"

398+

fi

399+

done

400+

ln -sfn "$dir" "${PREFIX}/tools/node"

401+

}

402+403+

linked_node_is_usable() {

404+

local current_version

405+

local required_version

406+407+

if [[ ! -x "$(node_bin)" || ! -x "$(npm_bin)" ]]; then

408+

return 1

409+

fi

410+411+

current_version="$("$(node_bin)" -v 2>/dev/null || echo "")"

412+

required_version="$(required_node_version)"

413+

if ! semver_at_least "$current_version" "$required_version"; then

414+

return 1

415+

fi

416+417+

"$(node_bin)" -e "require('node:sqlite')" >/dev/null 2>&1

418+

}

419+420+

semver_at_least() {

421+

local version="${1#v}"

422+

local required="${2#v}"

423+

local version_major version_minor version_patch

424+

local required_major required_minor required_patch

425+426+

IFS=. read -r version_major version_minor version_patch <<<"$version"

427+

IFS=. read -r required_major required_minor required_patch <<<"$required"

428+

version_minor="${version_minor:-0}"

429+

version_patch="${version_patch:-0}"

430+

required_minor="${required_minor:-0}"

431+

required_patch="${required_patch:-0}"

432+433+

for part in "$version_major" "$version_minor" "$version_patch" "$required_major" "$required_minor" "$required_patch"; do

434+

if [[ ! "$part" =~ ^[0-9]+$ ]]; then

435+

return 1

436+

fi

437+

done

438+439+

if ((version_major != required_major)); then

440+

((version_major > required_major))

441+

return

442+

fi

443+

if ((version_minor != required_minor)); then

444+

((version_minor > required_minor))

445+

return

446+

fi

447+

((version_patch >= required_patch))

448+

}

449+450+

required_node_version() {

451+

if [[ "$NODE_VERSION_REQUESTED" == "1" ]] && semver_at_least "$NODE_VERSION" "$MIN_NODE_VERSION"; then

452+

printf '%s\n' "$NODE_VERSION"

453+

return

454+

fi

455+

printf '%s\n' "$MIN_NODE_VERSION"

456+

}

457+458+

try_link_usable_node_runtime_from_path() {

459+

local path_entry

460+

local prefix_bin

461+

local -a path_entries=()

462+463+

prefix_bin="$(node_dir)/bin"

464+

IFS=: read -r -a path_entries <<<"$PATH"

465+

for path_entry in "${path_entries[@]}"; do

466+

if [[ -z "$path_entry" ]]; then

467+

path_entry="."

468+

fi

469+

if [[ "$path_entry" == "$prefix_bin" ]]; then

470+

continue

471+

fi

472+

if [[ -x "${path_entry}/node" && -x "${path_entry}/npm" ]]; then

473+

link_node_runtime_paths "${path_entry}/node" "${path_entry}/npm"

474+

if linked_node_is_usable; then

475+

return 0

476+

fi

477+

fi

478+

done

479+

return 1

480+

}

481+482+

install_alpine_node() {

483+

local installed_version

484+

local required_version

485+486+

emit_json "{\"event\":\"step\",\"name\":\"node\",\"status\":\"start\",\"method\":\"apk\"}"

487+

if try_link_usable_node_runtime_from_path; then

488+

installed_version="$("$(node_bin)" -v 2>/dev/null || echo unknown)"

489+

emit_json "{\"event\":\"step\",\"name\":\"node\",\"status\":\"ok\",\"method\":\"system\",\"version\":\"${installed_version}\"}"

490+

return

491+

fi

492+493+

log "Installing Node via apk (Alpine Linux detected)..."

494+

if is_root; then

495+

apk add --no-cache nodejs npm

496+

elif has_sudo; then

497+

sudo apk add --no-cache nodejs npm

498+

else

499+

fail "Alpine Linux detected, but Node musl tarballs are unavailable and sudo is unavailable. Install nodejs and npm with apk, then retry."

500+

fi

501+502+

if [[ -x "${APK_NODE_BIN_DIR}/node" && -x "${APK_NODE_BIN_DIR}/npm" ]]; then

503+

link_node_runtime_paths "${APK_NODE_BIN_DIR}/node" "${APK_NODE_BIN_DIR}/npm"

504+

elif ! try_link_usable_node_runtime_from_path; then

505+

fail "apk Node install failed. Install nodejs and npm manually, then retry."

506+

fi

507+508+

if ! linked_node_is_usable; then

509+

installed_version="$("$(node_bin)" -v 2>/dev/null || echo unknown)"

510+

required_version="$(required_node_version)"

511+

fail "Alpine Node package must provide Node >= ${required_version} with node:sqlite; found ${installed_version}."

512+

fi

513+514+

installed_version="$("$(node_bin)" -v 2>/dev/null || echo unknown)"

515+

emit_json "{\"event\":\"step\",\"name\":\"node\",\"status\":\"ok\",\"method\":\"apk\",\"version\":\"${installed_version}\"}"

516+

}

517+332518

set_pnpm_cmd() {

333519

PNPM_CMD=("$@")

334520

}

@@ -560,6 +746,11 @@ install_node() {

560746

arch="$(arch_detect)"

561747

dir="$(node_dir)"

562748749+

if [[ "$os" == "linux" ]] && command -v apk >/dev/null 2>&1 && is_musl_linux; then

750+

install_alpine_node

751+

return

752+

fi

753+563754

if [[ -x "$(node_bin)" ]]; then

564755

current_major="$("$(node_bin)" -v 2>/dev/null | tr -d 'v' | cut -d'.' -f1 || echo "")"

565756

if [[ -n "$current_major" && "$current_major" -ge 22 ]]; then