- Should install to `./local/opt/<package>-<version>`
- Should not need `sudo` (except perhaps for a one-time `setcap`, etc)
- Follow the example of
- <https://github.com/webinstall/packages/tree/master/node>
+ <https://github.com/webinstall/packages/tree/master/ripgrep>,
+ <https://github.com/webinstall/packages/tree/master/node>, or
+ <https://github.com/webinstall/packages/tree/master/golang>
- - Note: the version handling is nasty, we'd like to move this to an API
+## Creating an Installer
+
+An install consists of 4 parts:
+
+1. Generate a list of releases by OS and ARCH
+ - For a Github releases example, see `ripgrep/releases.js` and
+ `_common/github.js`
+2. A bash version check (to skip downloading if already installed)
+ - typically just 1 unique line of bash
+3. A bash install (move files from the archive (zip, tar) to \$HOME/.local)
+ - also typically just 1 unique line of bash
+4. Update PATH
+ - the `webi_path_add` bash function will work for bash, zsh, and fish
+
+The `webinstall.dev` server uses the list of releases returned by
+`<your-package>/releases.js` to generate a bash script with most necessary
+variables and functions pre-defined.
+
+You just fill in the blanks.
+
+## Script API
+
+See `webi/template.bash`
+
+These variables will be set by the server:
+
+```
+WEBI_PKG=example@v1
+WEBI_NAME=example
+WEBI_HOST=https://webinstall.dev
+WEBI_RELEASES=https://webinstall.dev/api/releases/example@v1?os=macos&arch=amd64&pretty=true
+WEBI_CSV=v1.0.2,
+WEBI_VERSION=1.0.2
+WEBI_MAJOR=1
+WEBI_MINOR=0
+WEBI_PATCH=2
+WEBI_LTS=
+WEBI_CHANNEL=stable
+WEBI_EXT=tar
+WEBI_PKG_URL=https://cdn.example.com/example-macos-amd64.tar.gz
+WEBI_PKG_FILE=example-macos-amd64.tar.gz
+```
+
+```bash
+WEBI_TMP=${WEBI_TMP:-"$(mktemp -d -t webinstall-foobar.XXXXXXXX)"}
+```
+
+```bash
+webi_download # Downloads the selected release to $HOME/Downloads/<package-name>.tar.gz
+webi_extract # Extracts the download to /tmp/<package-name>-<random>/
+webi_path_add /new/path # Adds /new/path to PATH for bash, zsh, and fish
+```
# Roadmap
- Wrap release APIs to unify and expose
- - [ ] Golang <https://golang.org/dl/?mode=json>
- - [ ] Node <https://nodejs.org/dist/index.tab>
- - [ ] Flutter
+ - [x] Golang <https://golang.org/dl/?mode=json>
+ - [x] Node <https://nodejs.org/dist/index.tab>
+ - [x] Flutter
<https://storage.googleapis.com/flutter_infra/releases/releases_linux.json> -
Started at
<https://github.com/webinstall/packages/blob/master/flutter/versions.js>
- [ ] git
- Note: do all platforms expose tar/zip releases with the same URLs?
- [ ] npm
- - [ ] github (NOT until `git` is supported)
+ - [x] github (see ripgrep)
+ - [x] gitea (see serviceman)
- [ ] Support git urls (i.e. `@github.com/node/node`)
- (maybe `ghi node/node` for github specifically)