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

推荐订阅源

L
LINUX DO - 热门话题
T
The Blog of Author Tim Ferriss
WordPress大学
WordPress大学
酷 壳 – CoolShell
酷 壳 – CoolShell
美团技术团队
博客园 - 叶小钗
李成银的技术随笔
V
Visual Studio Blog
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
Apple Machine Learning Research
Apple Machine Learning Research
Hugging Face - Blog
Hugging Face - Blog
V
V2EX
博客园 - 司徒正美
Blog — PlanetScale
Blog — PlanetScale
大猫的无限游戏
大猫的无限游戏
T
Tailwind CSS Blog
Cyber Security Advisories - MS-ISAC
Cyber Security Advisories - MS-ISAC
aimingoo的专栏
aimingoo的专栏
人人都是产品经理
人人都是产品经理
GbyAI
GbyAI
A
About on SuperTechFans
罗磊的独立博客
W
WeLiveSecurity
L
LINUX DO - 最新话题
M
MIT News - Artificial intelligence
Hacker News: Ask HN
Hacker News: Ask HN
Application and Cybersecurity Blog
Application and Cybersecurity Blog
cs.AI updates on arXiv.org
cs.AI updates on arXiv.org
P
Proofpoint News Feed
Microsoft Security Blog
Microsoft Security Blog
奇客Solidot–传递最新科技情报
奇客Solidot–传递最新科技情报
H
Help Net Security
Martin Fowler
Martin Fowler
cs.CL updates on arXiv.org
cs.CL updates on arXiv.org
www.infosecurity-magazine.com
www.infosecurity-magazine.com
The Register - Security
The Register - Security
M
Microsoft Research Blog - Microsoft Research
Hacker News - Newest:
Hacker News - Newest: "LLM"
博客园 - Franky
The Cloudflare Blog
C
Cisco Blogs
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
Google Online Security Blog
Google Online Security Blog
有赞技术团队
有赞技术团队
AWS News Blog
AWS News Blog
C
Cybersecurity and Infrastructure Security Agency CISA
小众软件
小众软件
I
Intezer
N
Netflix TechBlog - Medium
N
News and Events Feed by Topic

Recent Commits to openclaw:main

docs(channels): document ackReactionScope for Slack & Telegram (DM go… · openclaw/openclaw@bbbed26 ci: export Crabbox hydrate pnpm layout · openclaw/openclaw@f6840ac fix(gateway): preserve fresh agent session state · openclaw/openclaw@6f41653 fix(gateway): attribute agent wait timeouts ci: keep Crabbox hydrate runs reusable · openclaw/openclaw@489ea84 Speed up /models browse replies (#84735) · openclaw/openclaw@936dfaa docs: update changelog for plugin binding command escape (#85188) · openclaw/openclaw@9fc5346 Let binding commands escape plugin routes · openclaw/openclaw@af12082 ci: fix Crabbox hydrate pnpm modules dir · openclaw/openclaw@c9b17c5 Restore Control UI gateway token pairing [AI] (#85459) · openclaw/openclaw@10cb0a5 fix(docker): accept single-object pnpm list output · openclaw/openclaw@5e97045 fix: apply docs sweep updates · openclaw/openclaw@59aef2f fix(update): roll back failed git updates · openclaw/openclaw@769fd0b test(docker): expect prod store seed command fix(agents): bound embedded compaction write locks · openclaw/openclaw@46de078 fix(update): repair managed npm plugin peers · openclaw/openclaw@571f364 fix(update): repair managed npm plugin peers (#83794) (thanks @fuller… · openclaw/openclaw@de8a82a fix(telegram): honor table mode in outbound chunks (#85455) · openclaw/openclaw@7fc691a fix(docker): precreate owned named volume targets (#85454) · openclaw/openclaw@d8b9736 fix(ui): strip ANSI from displayed gateway logs (#85453) · openclaw/openclaw@664611c fix(skills): accept macos os requirement on darwin (#85451) fix(gateway): preserve message-tool replies in chat history test: track Docker prod store seed command · openclaw/openclaw@9a816f4 fix: satisfy prod store package list lint · openclaw/openclaw@d5247d0 test(plugins): clear lookup metadata memo fix(docker): seed prod store before offline prune · openclaw/openclaw@6788aa1 fix(memory): expand home paths in extra memory paths (#85449) · openclaw/openclaw@48bf037 docs: add security FAQ guidance chore(deps): refresh npm shrinkwraps docs: clarify OpenAI HTTP client guidance docs: remove stale showcase intro videos · openclaw/openclaw@00d3dca fix(gateway): point model override error to config docs docs: document secrets provider plan fields docs: clarify media directive formatting · openclaw/openclaw@c876fec docs: align memory search cache default refactor(ios): centralize setup auth parsing test(release): wait for config reload log proof refactor(ios): consolidate manual auth override inputs · openclaw/openclaw@d93c597 fix(ui): hide thinking options for non-reasoning models (#85406) · openclaw/openclaw@bb4d88e fix(ui): attach pasted data image text (#85392) · openclaw/openclaw@a03a8d9 fix(gateway): preserve OpenAI usage aliases in chat history (#85383) · openclaw/openclaw@d9c6c5f feat(ios): add realtime talk relay mode · openclaw/openclaw@e730e9b fix(browser): hint WSL portproxy CDP empty replies (#85379) · openclaw/openclaw@933f01c fix(installer): persist portable Git on Windows · openclaw/openclaw@5b90a48 fix(opencode-go): strip Kimi reasoning replay fields (#85377) · openclaw/openclaw@d22bcfc fix(build): normalize cache paths on Windows (#85437) · openclaw/openclaw@81d22c8 fix(update): detect nested macOS gateway ancestry (#85391) · openclaw/openclaw@adc6adc fix(docker): seed offline prune store in runtime stage · openclaw/openclaw@faf2a6c fix(ci): stabilize npm shrinkwrap metadata · openclaw/openclaw@21bedd3 fix(codex): route node exec through OpenClaw tools · openclaw/openclaw@5cc0dbc test(installer): track portable node root helper · openclaw/openclaw@9364b21 fix(ui): sync talk transcript translations fix(ui): localize talk transcript labels · openclaw/openclaw@8fc48af fix(release): stabilize config restart QA · openclaw/openclaw@cc91ff0 fix(installer): extract portable Node directly test(qa-lab): report scenario pack coverage · openclaw/openclaw@dcd98bf fix(plugins): drop stale tlon tool contract · openclaw/openclaw@d70dc4b fix(installer): prefer tar for portable Node extraction · openclaw/openclaw@a54a881 fix(codex): deliver native subagent completions feat: add context-engine host capability requirements (#84994) · openclaw/openclaw@cff5244 fix(release): keep shrinkwrap pinned to pnpm lock · openclaw/openclaw@9d24fde fix: surface plan updates as status notices · openclaw/openclaw@dc04503 test(google): narrow web search fake timers · openclaw/openclaw@fe7d13c fix(installer): extract portable Node with ZipFile · openclaw/openclaw@ffa6cd8 fix(gateway): defer provider auth prewarm after startup (#85369) · openclaw/openclaw@69255f8 fix(talk): stabilize realtime voice consults · openclaw/openclaw@683ad75 test(qa): tolerate slow gateway rpc startup · openclaw/openclaw@29118a0 chore(diagnostics): refresh plugin sdk baseline · openclaw/openclaw@ab684f5 fix(diagnostics): surface async queue drops fix(diagnostics): bound diagnostic buffers · openclaw/openclaw@bdcaac0 fix(installer): copy portable Node into place · openclaw/openclaw@c21ca88 fix(cli): recover replaced device approvals (#85342) · openclaw/openclaw@6ea907c test(release): align prerelease validation · openclaw/openclaw@0def3e2 fix(installer): install portable Node directory atomically · openclaw/openclaw@2890b1a fix(runtime-llm): avoid duplicate provider prefix in allowlist diagno… · openclaw/openclaw@937a756 fix(gateway): include openclaw bin in service PATH (#84475) · openclaw/openclaw@66d1d13 fix(gateway): handle concurrent launchd bootstrap restart race (#84722) · openclaw/openclaw@ba86716 feat: support pi and opencode autoreview engines · openclaw/openclaw@31a189d ci(package): gate acceptance on package integrity · openclaw/openclaw@5275929 ci(release): bypass pnpm for tsdown package build · openclaw/openclaw@fea89cd test(release): align prerelease validation baselines · openclaw/openclaw@04ebdc6 ci(release): harden docker package build · openclaw/openclaw@7b1fbe1 fix(codex): skip native web search transcript mirroring (#85346) · openclaw/openclaw@c3531fc fix(gateway): harden launchd reload handoff race recovery (#84641) · openclaw/openclaw@fc7a531 fix: honor per-model provider transport overrides (#80488) fix(skills): type watcher mock calls in dedupe regression tests · openclaw/openclaw@bb73f0a fix(skills): dedupe shared-directory watchers across agent workspaces… · openclaw/openclaw@3e94290 fix(skills): document watcher edge cases, add teardown/rebuild tests,… · openclaw/openclaw@19ff77e fix(infra): allow macos browser open over ssh env (#85340) · openclaw/openclaw@47d66fe fix(update): preserve package service state during cutover (#83026) · openclaw/openclaw@a15797a fix(gateway): broadcast agent-run error payloads (#85355) · openclaw/openclaw@07e61fc test(e2e): avoid synthetic channel config in plugin smoke fix(cli): suppress systemd hints for live gateway (#85336) · openclaw/openclaw@a00c583 fix(cli): honor agent for model auth logout (#85326) · openclaw/openclaw@fc47c1f fix(gateway): eager-load lifecycle runtime to survive in-place upgrad… · openclaw/openclaw@4a91385 fix(doctor): point codex asset warning at migrate plan (#85324) fix(update): harden managed handoff cwd (#83875) · openclaw/openclaw@1bafc23 docs(release): prepare 2026.5.21 notes ci(crabbox): harden docker hydration refactor(crabbox): parse provider list from binary help instead of ha…
build(pnpm): use packageManager as pnpm source · openclaw/openclaw@a0702e1
steipete · 2026-05-23 · via Recent Commits to openclaw:main

@@ -1,168 +1,53 @@

1-

name: Setup pnpm + store cache

2-

description: Prepare pnpm via corepack and restore pnpm store cache.

1+

name: Setup pnpm

2+

description: Prepare pnpm from the repository packageManager and restore its store cache.

33

inputs:

4-

pnpm-version:

5-

description: pnpm version to activate via corepack.

6-

required: false

7-

default: "11.0.8"

8-

node-version:

9-

description: Expected Node.js version already installed by actions/setup-node.

10-

required: false

11-

default: "24.x"

12-

cache-key-suffix:

13-

description: Suffix appended to the cache key.

4+

package-manager-file:

5+

description: package.json file that owns the packageManager pnpm pin.

146

required: false

15-

default: "node24-pnpm11"

16-

use-restore-keys:

17-

description: Whether to use restore-keys fallback for actions/cache.

7+

default: "package.json"

8+

lockfile-path:

9+

description: pnpm lockfile used to key the store cache.

1810

required: false

19-

default: "true"

11+

default: "pnpm-lock.yaml"

2012

use-actions-cache:

21-

description: Whether to restore pnpm store with actions/cache.

13+

description: Whether pnpm/action-setup should cache the pnpm store.

2214

required: false

2315

default: "true"

2416

outputs:

25-

cache-enabled:

26-

description: Whether actions/cache restore was enabled.

27-

value: ${{ steps.pnpm-cache-config.outputs.enabled }}

28-

cache-hit:

29-

description: Whether the pnpm store cache had an exact key hit.

30-

value: ${{ steps.pnpm-cache-restore.outputs.cache-hit }}

31-

cache-matched-key:

32-

description: Cache key matched by restore, if any.

33-

value: ${{ steps.pnpm-cache-restore.outputs.cache-matched-key }}

34-

primary-key:

35-

description: Primary pnpm store cache key.

36-

value: ${{ steps.pnpm-cache-config.outputs.primary-key }}

37-

store-path:

38-

description: Resolved pnpm store path.

39-

value: ${{ steps.pnpm-store.outputs.path }}

17+

pnpm-version:

18+

description: Resolved pnpm version activated by the setup action.

19+

value: ${{ steps.pnpm-version.outputs.pnpm-version }}

20+

project-dir:

21+

description: Directory containing the packageManager file used for pnpm resolution.

22+

value: ${{ steps.setup-pnpm.outputs.project-dir }}

4023

runs:

4124

using: composite

4225

steps:

43-

- name: Setup pnpm (corepack retry)

26+

- name: Validate pnpm setup inputs

27+

id: setup-pnpm

4428

shell: bash

4529

env:

46-

COREPACK_ENABLE_DOWNLOAD_PROMPT: "0"

47-

PNPM_VERSION: ${{ inputs.pnpm-version }}

48-

REQUESTED_NODE_VERSION: ${{ inputs.node-version }}

30+

PACKAGE_MANAGER_FILE: ${{ inputs.package-manager-file }}

4931

run: |

5032

set -euo pipefail

51-

if [[ ! "$PNPM_VERSION" =~ ^[0-9]+(\.[0-9]+){1,2}([.-][0-9A-Za-z.-]+)?$ ]]; then

52-

echo "::error::Invalid pnpm-version input: '$PNPM_VERSION'"

53-

exit 2

54-

fi

55-56-

requested_node="${REQUESTED_NODE_VERSION:-${NODE_VERSION:-}}"

57-

requested_node="${requested_node#v}"

58-59-

node_version_matches() {

60-

local actual="$1"

61-

local requested="$2"

62-

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

63-

return 0

64-

fi

65-

case "$requested" in

66-

*x)

67-

[[ "${actual%%.*}" == "${requested%%.*}" ]]

68-

;;

69-

*.*.*)

70-

[[ "$actual" == "$requested" ]]

71-

;;

72-

*.*)

73-

[[ "$actual" == "$requested".* ]]

74-

;;

75-

*)

76-

[[ "${actual%%.*}" == "$requested" ]]

77-

;;

78-

esac

79-

}

80-81-

active_node_version="$(node -p 'process.versions.node' 2>/dev/null || true)"

82-

if ! node_version_matches "$active_node_version" "$requested_node"; then

83-

node_roots=()

84-

for root in \

85-

"${RUNNER_TOOL_CACHE:-}" \

86-

"${AGENT_TOOLSDIRECTORY:-}" \

87-

"${ACTIONS_RUNNER_TOOL_CACHE:-}" \

88-

"/opt/hostedtoolcache" \

89-

"/home/runner/_work/_tool" \

90-

"/Users/runner/hostedtoolcache" \

91-

"/c/hostedtoolcache/windows"

92-

do

93-

if [[ -d "$root/node" ]]; then

94-

node_roots+=("$root/node")

95-

elif [[ "$(basename "$root")" == "node" && -d "$root" ]]; then

96-

node_roots+=("$root")

97-

fi

98-

done

99-100-

node_bin=""

101-

for node_root in "${node_roots[@]}"; do

102-

while IFS= read -r candidate; do

103-

candidate_version="$("$candidate" -p 'process.versions.node' 2>/dev/null || true)"

104-

if node_version_matches "$candidate_version" "$requested_node"; then

105-

node_bin="$candidate"

106-

break 2

107-

fi

108-

done < <(find "$node_root" \( -name node -o -name node.exe \) -type f 2>/dev/null | sort -r)

109-

done

110-111-

if [[ -n "$node_bin" ]]; then

112-

echo "Using Node $("$node_bin" -p 'process.versions.node') from $node_bin"

113-

export PATH="$(dirname "$node_bin"):$PATH"

114-

hash -r

115-

fi

116-

fi

117-118-

active_node_version="$(node -p 'process.versions.node' 2>/dev/null || true)"

119-

if ! node_version_matches "$active_node_version" "$requested_node"; then

120-

echo "::error::Expected Node '${requested_node}', but active node is '${active_node_version:-missing}' at $(command -v node || true)"

33+

project_dir="$(dirname "$PACKAGE_MANAGER_FILE")"

34+

if [[ ! -f "$PACKAGE_MANAGER_FILE" ]]; then

35+

echo "::error::package manager file not found: $PACKAGE_MANAGER_FILE"

12136

exit 1

12237

fi

38+

echo "project-dir=$project_dir" >> "$GITHUB_OUTPUT"

12339124-

node -v

125-

command -v node

126-

command -v corepack

127-

corepack enable

128-

for attempt in 1 2 3; do

129-

if corepack prepare "pnpm@$PNPM_VERSION" --activate; then

130-

pnpm -v

131-

exit 0

132-

fi

133-

echo "corepack prepare failed (attempt $attempt/3). Retrying..."

134-

sleep $((attempt * 10))

135-

done

136-

exit 1

137-138-

- name: Resolve pnpm store path

139-

id: pnpm-store

140-

shell: bash

141-

run: echo "path=$(pnpm store path --silent)" >> "$GITHUB_OUTPUT"

40+

- name: Setup pnpm from packageManager

41+

uses: pnpm/action-setup@0e279bb959325dab635dd2c09392533439d90093

42+

with:

43+

package_json_file: ${{ inputs.package-manager-file }}

44+

run_install: false

45+

cache: ${{ inputs.use-actions-cache }}

46+

cache_dependency_path: ${{ inputs.lockfile-path }}

14247143-

- name: Resolve pnpm store cache keys

144-

id: pnpm-cache-config

48+

- name: Record pnpm version

49+

id: pnpm-version

14550

shell: bash

14651

env:

147-

CACHE_KEY_SUFFIX: ${{ inputs.cache-key-suffix }}

148-

LOCKFILE_HASH: ${{ hashFiles('pnpm-lock.yaml') }}

149-

USE_ACTIONS_CACHE: ${{ inputs.use-actions-cache }}

150-

USE_RESTORE_KEYS: ${{ inputs.use-restore-keys }}

151-

run: |

152-

set -euo pipefail

153-

echo "enabled=$USE_ACTIONS_CACHE" >> "$GITHUB_OUTPUT"

154-

echo "primary-key=${RUNNER_OS}-pnpm-store-${CACHE_KEY_SUFFIX}-${LOCKFILE_HASH}" >> "$GITHUB_OUTPUT"

155-

if [ "$USE_RESTORE_KEYS" = "true" ]; then

156-

echo "restore-keys=${RUNNER_OS}-pnpm-store-${CACHE_KEY_SUFFIX}-" >> "$GITHUB_OUTPUT"

157-

else

158-

echo "restore-keys=" >> "$GITHUB_OUTPUT"

159-

fi

160-161-

- name: Restore pnpm store cache

162-

id: pnpm-cache-restore

163-

if: inputs.use-actions-cache == 'true'

164-

uses: actions/cache/restore@v5

165-

with:

166-

path: ${{ steps.pnpm-store.outputs.path }}

167-

key: ${{ steps.pnpm-cache-config.outputs.primary-key }}

168-

restore-keys: ${{ steps.pnpm-cache-config.outputs.restore-keys }}

52+

PROJECT_DIR: ${{ steps.setup-pnpm.outputs.project-dir }}

53+

run: echo "pnpm-version=$(cd "$PROJECT_DIR" && pnpm -v)" >> "$GITHUB_OUTPUT"