From 5a29ec78ca4c4af04fe084b74311d33874c44885 Mon Sep 17 00:00:00 2001 From: Peter Steinberger Date: Mon, 12 Jan 2026 10:35:50 +0000 Subject: [PATCH] chore: release 2026.1.11-3 --- CHANGELOG.md | 6 ++++++ apps/android/app/build.gradle.kts | 4 ++-- apps/ios/Sources/Info.plist | 4 ++-- apps/ios/Tests/Info.plist | 4 ++-- .../Sources/Clawdbot/Resources/Info.plist | 4 ++-- docs/platforms/mac/release.md | 14 +++++++------- package.json | 2 +- src/entry.ts | 11 +++++++++-- src/infra/git-commit.ts | 19 +++++++++++++++++++ 9 files changed, 50 insertions(+), 18 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 579c623bb..66eb87e64 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,5 +1,11 @@ # Changelog +## 2026.1.11-3 + +### Fixes +- CLI: avoid top-level await warnings in the entrypoint on fresh installs. +- CLI: show a commit hash in the banner for npm installs (package.json gitHead fallback). + ## 2026.1.11-2 ### Fixes diff --git a/apps/android/app/build.gradle.kts b/apps/android/app/build.gradle.kts index 14e1e563a..49eeb8fc6 100644 --- a/apps/android/app/build.gradle.kts +++ b/apps/android/app/build.gradle.kts @@ -21,8 +21,8 @@ android { applicationId = "com.clawdbot.android" minSdk = 31 targetSdk = 36 - versionCode = 202601112 - versionName = "2026.1.11-2" + versionCode = 202601113 + versionName = "2026.1.11-3" } buildTypes { diff --git a/apps/ios/Sources/Info.plist b/apps/ios/Sources/Info.plist index 33aa35afd..8e3cb7f34 100644 --- a/apps/ios/Sources/Info.plist +++ b/apps/ios/Sources/Info.plist @@ -19,9 +19,9 @@ CFBundlePackageType APPL CFBundleShortVersionString - 2026.1.11-2 + 2026.1.11-3 CFBundleVersion - 202601112 + 202601113 NSAppTransportSecurity NSAllowsArbitraryLoadsInWebContent diff --git a/apps/ios/Tests/Info.plist b/apps/ios/Tests/Info.plist index b6aa2acf4..63aad9d63 100644 --- a/apps/ios/Tests/Info.plist +++ b/apps/ios/Tests/Info.plist @@ -17,8 +17,8 @@ CFBundlePackageType BNDL CFBundleShortVersionString - 2026.1.11-2 + 2026.1.11-3 CFBundleVersion - 202601112 + 202601113 diff --git a/apps/macos/Sources/Clawdbot/Resources/Info.plist b/apps/macos/Sources/Clawdbot/Resources/Info.plist index f1e8ae32c..eab3c550e 100644 --- a/apps/macos/Sources/Clawdbot/Resources/Info.plist +++ b/apps/macos/Sources/Clawdbot/Resources/Info.plist @@ -15,9 +15,9 @@ CFBundlePackageType APPL CFBundleShortVersionString - 2026.1.11-2 + 2026.1.11-3 CFBundleVersion - 202601112 + 202601113 CFBundleIconFile Clawdbot CFBundleURLTypes diff --git a/docs/platforms/mac/release.md b/docs/platforms/mac/release.md index 52d98fd3b..f1dd183d4 100644 --- a/docs/platforms/mac/release.md +++ b/docs/platforms/mac/release.md @@ -29,17 +29,17 @@ Notes: # From repo root; set release IDs so Sparkle feed is enabled. # APP_BUILD must be numeric + monotonic for Sparkle compare. BUNDLE_ID=com.clawdbot.mac \ -APP_VERSION=2026.1.11-2 \ +APP_VERSION=2026.1.11-3 \ APP_BUILD="$(git rev-list --count HEAD)" \ BUILD_CONFIG=release \ SIGN_IDENTITY="Developer ID Application: Peter Steinberger (Y5PE65HELJ)" \ scripts/package-mac-app.sh # Zip for distribution (includes resource forks for Sparkle delta support) -ditto -c -k --sequesterRsrc --keepParent dist/Clawdbot.app dist/Clawdbot-2026.1.11-2.zip +ditto -c -k --sequesterRsrc --keepParent dist/Clawdbot.app dist/Clawdbot-2026.1.11-3.zip # Optional: also build a styled DMG for humans (drag to /Applications) -scripts/create-dmg.sh dist/Clawdbot.app dist/Clawdbot-2026.1.11-2.dmg +scripts/create-dmg.sh dist/Clawdbot.app dist/Clawdbot-2026.1.11-3.dmg # Recommended: build + notarize/staple zip + DMG # First, create a keychain profile once: @@ -47,26 +47,26 @@ scripts/create-dmg.sh dist/Clawdbot.app dist/Clawdbot-2026.1.11-2.dmg # --apple-id "" --team-id "" --password "" NOTARIZE=1 NOTARYTOOL_PROFILE=clawdbot-notary \ BUNDLE_ID=com.clawdbot.mac \ -APP_VERSION=2026.1.11-2 \ +APP_VERSION=2026.1.11-3 \ APP_BUILD="$(git rev-list --count HEAD)" \ BUILD_CONFIG=release \ SIGN_IDENTITY="Developer ID Application: Peter Steinberger (Y5PE65HELJ)" \ scripts/package-mac-dist.sh # Optional: ship dSYM alongside the release -ditto -c -k --keepParent apps/macos/.build/release/Clawdbot.app.dSYM dist/Clawdbot-2026.1.11-2.dSYM.zip +ditto -c -k --keepParent apps/macos/.build/release/Clawdbot.app.dSYM dist/Clawdbot-2026.1.11-3.dSYM.zip ``` ## Appcast entry Use the release note generator so Sparkle renders formatted HTML notes: ```bash -SPARKLE_PRIVATE_KEY_FILE=/Users/steipete/Library/CloudStorage/Dropbox/Backup/Sparkle/ed25519-private-key scripts/make_appcast.sh dist/Clawdbot-2026.1.11-2.zip https://raw.githubusercontent.com/clawdbot/clawdbot/main/appcast.xml +SPARKLE_PRIVATE_KEY_FILE=/Users/steipete/Library/CloudStorage/Dropbox/Backup/Sparkle/ed25519-private-key scripts/make_appcast.sh dist/Clawdbot-2026.1.11-3.zip https://raw.githubusercontent.com/clawdbot/clawdbot/main/appcast.xml ``` Generates HTML release notes from `CHANGELOG.md` (via [`scripts/changelog-to-html.sh`](https://github.com/clawdbot/clawdbot/blob/main/scripts/changelog-to-html.sh)) and embeds them in the appcast entry. Commit the updated `appcast.xml` alongside the release assets (zip + dSYM) when publishing. ## Publish & verify -- Upload `Clawdbot-2026.1.11-2.zip` (and `Clawdbot-2026.1.11-2.dSYM.zip`) to the GitHub release for tag `v2026.1.11-2`. +- Upload `Clawdbot-2026.1.11-3.zip` (and `Clawdbot-2026.1.11-3.dSYM.zip`) to the GitHub release for tag `v2026.1.11-3`. - Ensure the raw appcast URL matches the baked feed: `https://raw.githubusercontent.com/clawdbot/clawdbot/main/appcast.xml`. - Sanity checks: - `curl -I https://raw.githubusercontent.com/clawdbot/clawdbot/main/appcast.xml` returns 200. diff --git a/package.json b/package.json index 3c9fee8d7..6d6638dec 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "clawdbot", - "version": "2026.1.11-2", + "version": "2026.1.11-3", "description": "WhatsApp gateway CLI (Baileys web) with Pi RPC agent", "type": "module", "main": "dist/index.js", diff --git a/src/entry.ts b/src/entry.ts index fd44bd5bd..50953fa18 100644 --- a/src/entry.ts +++ b/src/entry.ts @@ -21,5 +21,12 @@ if (parsed.profile) { process.argv = parsed.argv; } -const { runCli } = await import("./cli/run-main.js"); -await runCli(process.argv); +import("./cli/run-main.js") + .then(({ runCli }) => runCli(process.argv)) + .catch((error) => { + console.error( + "[clawdbot] Failed to start CLI:", + error instanceof Error ? error.stack ?? error.message : error, + ); + process.exitCode = 1; + }); diff --git a/src/infra/git-commit.ts b/src/infra/git-commit.ts index 435c702ed..10032841b 100644 --- a/src/infra/git-commit.ts +++ b/src/infra/git-commit.ts @@ -1,5 +1,6 @@ import fs from "node:fs"; import path from "node:path"; +import { createRequire } from "node:module"; const formatCommit = (value?: string | null) => { if (!value) return null; @@ -37,6 +38,19 @@ const resolveGitHead = (startDir: string) => { let cachedCommit: string | null | undefined; +const readCommitFromPackageJson = () => { + try { + const require = createRequire(import.meta.url); + const pkg = require("../package.json") as { + gitHead?: string; + githead?: string; + }; + return formatCommit(pkg.gitHead ?? pkg.githead ?? null); + } catch { + return null; + } +}; + export const resolveCommitHash = ( options: { cwd?: string; env?: NodeJS.ProcessEnv } = {}, ) => { @@ -48,6 +62,11 @@ export const resolveCommitHash = ( cachedCommit = normalized; return cachedCommit; } + const pkgCommit = readCommitFromPackageJson(); + if (pkgCommit) { + cachedCommit = pkgCommit; + return cachedCommit; + } try { const headPath = resolveGitHead(options.cwd ?? process.cwd()); if (!headPath) {