more Sparkle tests
This commit is contained in:
@@ -59,7 +59,8 @@ GITEA_REPO="iKeyMon"
|
|||||||
# optional: GITEA_PRERELEASE="false" # defaults to true until preferences are done
|
# optional: GITEA_PRERELEASE="false" # defaults to true until preferences are done
|
||||||
# optional Sparkle feed helpers:
|
# optional Sparkle feed helpers:
|
||||||
# SPARKLE_EDDSA_KEY_FILE="$HOME/.config/Sparkle/iKeyMon.key"
|
# SPARKLE_EDDSA_KEY_FILE="$HOME/.config/Sparkle/iKeyMon.key"
|
||||||
# SPARKLE_DOWNLOAD_BASE_TEMPLATE="https://git.24unix.net/tracer/iKeyMon/releases/download/v{{VERSION}}"
|
# SPARKLE_DOWNLOAD_BASE_URL="https://git.24unix.net/tracer/iKeyMon/releases/download"
|
||||||
|
# SPARKLE_DOWNLOAD_VERSION_PREFIX="v" # optional
|
||||||
# SPARKLE_APPCAST_OUTPUT="$ROOT_DIR/Sparkle/appcast.xml" # default
|
# SPARKLE_APPCAST_OUTPUT="$ROOT_DIR/Sparkle/appcast.xml" # default
|
||||||
```
|
```
|
||||||
|
|
||||||
@@ -72,12 +73,12 @@ If you re-run the release script for the same version, it removes any existing a
|
|||||||
iKeyMon uses [Sparkle](https://sparkle-project.org/) for macOS-safe updates.
|
iKeyMon uses [Sparkle](https://sparkle-project.org/) for macOS-safe updates.
|
||||||
|
|
||||||
1. Generate an EdDSA key pair once (`./Packages/Sparkle/bin/generate_keys`). Store the private key on-disk (for example `~/.config/Sparkle/iKeyMon.key`, which the build script expects) and copy the public key into the `SUPublicEDKey` entry (see Info.plist notes below).
|
1. Generate an EdDSA key pair once (`./Packages/Sparkle/bin/generate_keys`). Store the private key on-disk (for example `~/.config/Sparkle/iKeyMon.key`, which the build script expects) and copy the public key into the `SUPublicEDKey` entry (see Info.plist notes below).
|
||||||
2. `./scripts/build_release.sh` signs the ZIP with Sparkle’s `sign_update` tool and invokes `generate_appcast` automatically when the Sparkle variables are present. The generated feed is written to `Sparkle/appcast.xml`, so commit that file after every release. Point `SPARKLE_DOWNLOAD_BASE_TEMPLATE` at your release-download prefix (e.g. `https://git.24unix.net/tracer/iKeyMon/releases/download/v{{VERSION}}`) so the generated URLs match where Gitea serves assets. The feed stays inside the repo (it is not uploaded as a release asset).
|
2. `./scripts/build_release.sh` signs the ZIP with Sparkle’s `sign_update` tool and invokes `generate_appcast` automatically when the Sparkle variables are present. The generated feed is written to `Sparkle/appcast.xml`, so commit that file after every release. Set `SPARKLE_DOWNLOAD_BASE_URL` to your release-download root (e.g. `https://git.24unix.net/tracer/iKeyMon/releases/download`) and, if your host groups assets under versioned folders, set `SPARKLE_DOWNLOAD_VERSION_PREFIX` (defaults to `v`, producing URLs like `/download/v26.0.20/...`). The feed stays inside the repo (it is not uploaded as a release asset).
|
||||||
3. Set `SUFeedURL` in Info.plist (or the corresponding build setting) to the raw URL of `Sparkle/appcast.xml` inside this repo (e.g. `https://git.24unix.net/tracer/iKeyMon/raw/branch/master/Sparkle/appcast.xml`).
|
3. Set `SUFeedURL` in Info.plist (or the corresponding build setting) to the raw URL of `Sparkle/appcast.xml` inside this repo (e.g. `https://git.24unix.net/tracer/iKeyMon/raw/branch/master/Sparkle/appcast.xml`).
|
||||||
|
|
||||||
Preferences expose Sparkle’s built-in toggles for “Automatically check” and “Automatically download”, and the toolbar button simply calls Sparkle’s “Check for Updates…” sheet.
|
Preferences expose Sparkle’s built-in toggles for “Automatically check” and “Automatically download”, and the toolbar button simply calls Sparkle’s “Check for Updates…” sheet.
|
||||||
|
|
||||||
> `./scripts/build_release.sh` will call `generate_appcast` for you when `SPARKLE_EDDSA_KEY_FILE` and either `SPARKLE_DOWNLOAD_BASE_TEMPLATE` (with `{{VERSION}}` placeholder) or `SPARKLE_DOWNLOAD_BASE_URL` are set. It tries to locate Sparkle’s CLI in DerivedData automatically, but you can override the path via `SPARKLE_GENERATE_APPCAST`. The resulting feed is written to `SPARKLE_APPCAST_OUTPUT` (defaults to `Sparkle/appcast.xml`).
|
> `./scripts/build_release.sh` will call `generate_appcast` for you when `SPARKLE_EDDSA_KEY_FILE` and either `SPARKLE_DOWNLOAD_BASE_URL` (optionally with `SPARKLE_DOWNLOAD_VERSION_PREFIX`) or `SPARKLE_DOWNLOAD_BASE_TEMPLATE` are set. It tries to locate Sparkle’s CLI in DerivedData automatically, but you can override the path via `SPARKLE_GENERATE_APPCAST`. The resulting feed is written to `SPARKLE_APPCAST_OUTPUT` (defaults to `Sparkle/appcast.xml`).
|
||||||
|
|
||||||
> Build settings include `INFOPLIST_KEY_SUFeedURL` and `INFOPLIST_KEY_SUPublicEDKey`. Make sure to fill both before shipping a build so Sparkle knows where to fetch updates and how to verify them.
|
> Build settings include `INFOPLIST_KEY_SUFeedURL` and `INFOPLIST_KEY_SUPublicEDKey`. Make sure to fill both before shipping a build so Sparkle knows where to fetch updates and how to verify them.
|
||||||
|
|
||||||
|
|||||||
@@ -29,12 +29,8 @@ find_generate_appcast() {
|
|||||||
generate_appcast() {
|
generate_appcast() {
|
||||||
local generator
|
local generator
|
||||||
generator="$(find_generate_appcast)"
|
generator="$(find_generate_appcast)"
|
||||||
local download_prefix=""
|
local download_prefix="${SPARKLE_DOWNLOAD_BASE_URL:-}"
|
||||||
if [[ -n "${SPARKLE_DOWNLOAD_BASE_TEMPLATE:-}" ]]; then
|
local version_prefix="${SPARKLE_DOWNLOAD_VERSION_PREFIX:-}"
|
||||||
download_prefix="${SPARKLE_DOWNLOAD_BASE_TEMPLATE//\{\{VERSION\}\}/$VERSION}"
|
|
||||||
else
|
|
||||||
download_prefix="${SPARKLE_DOWNLOAD_BASE_URL:-}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [[ -z "$generator" || -z "${SPARKLE_EDDSA_KEY_FILE:-}" || -z "$download_prefix" ]]; then
|
if [[ -z "$generator" || -z "${SPARKLE_EDDSA_KEY_FILE:-}" || -z "$download_prefix" ]]; then
|
||||||
echo "ℹ️ Skipping Sparkle appcast generation (generator/key/download prefix not configured)."
|
echo "ℹ️ Skipping Sparkle appcast generation (generator/key/download prefix not configured)."
|
||||||
@@ -61,6 +57,7 @@ generate_appcast() {
|
|||||||
"$staging_dir"; then
|
"$staging_dir"; then
|
||||||
echo "⚠️ Sparkle appcast generation failed."
|
echo "⚠️ Sparkle appcast generation failed."
|
||||||
fi
|
fi
|
||||||
|
rewrite_appcast_urls "$output" "$version_prefix"
|
||||||
rm -rf "$staging_dir"
|
rm -rf "$staging_dir"
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -77,6 +74,49 @@ sign_update_artifacts() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
|
rewrite_appcast_urls() {
|
||||||
|
local appcast="$1"
|
||||||
|
local version_prefix="$2"
|
||||||
|
local marker="${SPARKLE_DOWNLOAD_VERSION_MARKER:-/releases/download/}"
|
||||||
|
if [[ -z "$version_prefix" || -z "$marker" ]]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
python3 - "$appcast" "$marker" "$version_prefix" <<'PY'
|
||||||
|
import sys
|
||||||
|
import xml.etree.ElementTree as ET
|
||||||
|
|
||||||
|
path, marker, prefix = sys.argv[1:]
|
||||||
|
tree = ET.parse(path)
|
||||||
|
root = tree.getroot()
|
||||||
|
ns = {'sparkle': 'http://www.andymatuschak.org/xml-namespaces/sparkle'}
|
||||||
|
changed = False
|
||||||
|
|
||||||
|
for item in root.findall('.//item'):
|
||||||
|
short = item.find('sparkle:shortVersionString', ns)
|
||||||
|
enclosure = item.find('enclosure')
|
||||||
|
if short is None or enclosure is None:
|
||||||
|
continue
|
||||||
|
version = (short.text or '').strip()
|
||||||
|
url = enclosure.get('url')
|
||||||
|
if not version or not url or marker not in url:
|
||||||
|
continue
|
||||||
|
desired = f"{marker}{prefix}{version}/"
|
||||||
|
if desired in url:
|
||||||
|
continue
|
||||||
|
base, rest = url.split(marker, 1)
|
||||||
|
if rest.startswith(f"{prefix}{version}/"):
|
||||||
|
continue
|
||||||
|
new_rest = f"{prefix}{version}/{rest.lstrip('/')}"
|
||||||
|
enclosure.set('url', f"{base}{marker}{new_rest}")
|
||||||
|
changed = True
|
||||||
|
|
||||||
|
if changed:
|
||||||
|
ET.indent(tree, space=" ", level=0)
|
||||||
|
tree.write(path, encoding='utf-8', xml_declaration=True)
|
||||||
|
PY
|
||||||
|
}
|
||||||
|
|
||||||
submit_for_notarization() {
|
submit_for_notarization() {
|
||||||
local target="$1"
|
local target="$1"
|
||||||
local label="$2"
|
local label="$2"
|
||||||
|
|||||||
@@ -11,6 +11,7 @@ GITEA_REPO="iKeyMon"
|
|||||||
|
|
||||||
# Sparkle appcast generation (optional)
|
# Sparkle appcast generation (optional)
|
||||||
# SPARKLE_EDDSA_KEY_FILE="$HOME/.config/Sparkle/iKeyMon.key"
|
# SPARKLE_EDDSA_KEY_FILE="$HOME/.config/Sparkle/iKeyMon.key"
|
||||||
# SPARKLE_DOWNLOAD_BASE_TEMPLATE="https://git.24unix.net/tracer/iKeyMon/releases/download/v{{VERSION}}"
|
# SPARKLE_DOWNLOAD_BASE_URL="https://git.24unix.net/tracer/iKeyMon/releases/download"
|
||||||
|
# SPARKLE_DOWNLOAD_VERSION_PREFIX="v" # prepended before each short version in URLs
|
||||||
# SPARKLE_APPCAST_OUTPUT="$ROOT_DIR/Sparkle/appcast.xml" # defaults to this path
|
# SPARKLE_APPCAST_OUTPUT="$ROOT_DIR/Sparkle/appcast.xml" # defaults to this path
|
||||||
# SPARKLE_GENERATE_APPCAST="/path/to/generate_appcast" # auto-detected if unset
|
# SPARKLE_GENERATE_APPCAST="/path/to/generate_appcast" # auto-detected if unset
|
||||||
|
|||||||
Reference in New Issue
Block a user