Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/5im-0n/github-app-updater
An updater for your node app
https://github.com/5im-0n/github-app-updater
Last synced: about 1 month ago
JSON representation
An updater for your node app
- Host: GitHub
- URL: https://github.com/5im-0n/github-app-updater
- Owner: 5im-0n
- Created: 2020-06-07T15:38:35.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-06-28T23:50:36.000Z (over 1 year ago)
- Last Synced: 2024-11-13T00:56:41.986Z (about 2 months ago)
- Language: JavaScript
- Size: 24.4 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# GitHub App Updater
A node module that helps you autoupdating your apps if you use GitHub releases.
## Usage
Release your app to GitHub releases using a semver tag name for your version.
This module will go check on GitHub if a new version is available, download it to a temp directory, and start the downloaded executable.`npm i github-app-updater`
```javascript
const gau = require('github-app-updater');gau.checkForUpdate({
currentVersion: require('./package.json').version,
repo: 'https://api.github.com/repos/S2-/gitlit/releases/latest',
assetMatch: /.+setup.+exe/i
});gau.onUpdateAvailable = (version, asset) => {
console.log(`new version ${version} available!`);
gau.downloadNewVersion(asset);
};gau.onNewVersionReadyToInstall = (file) => {
console.log(`ready to install ${file}`);
gau.executeUpdate(file);
};
```### Methods
#### `checkForUpdate(options)`
Starts an update check. This connects to GitHub and looks for new releases.
- `options `
- `currentVersion ` the current version of the running app.
- `repo ` the GitHub api url for the latest version. For example `https://api.github.com/repos/S2-/gitlit/releases/latest`
- `assetMatch ` a regular expression that matches the installer asset. For example to match `gitlit-Setup-2.0.5.exe` it could be `/.+setup.+exe/i`#### `downloadNewVersion(asset)`
Downloads the new release from GitHub to a temp folder.
- `asset ` the asset object received as parameter on the `onUpdateAvailable` event.
#### `executeUpdate(file)`
Executes the downloaded installer for the new version.
- `file ` the `file` path received as parameter on the `onNewVersionReadyToInstall` event.
### Events
#### `onUpdateAvailable(version, asset)`
Callback that is invoked when a new version of the app is available on GitHub.
This event can be used to tell the user that there is a new version available, and ask him if he wants to download it.- `version ` the new remote version that was found.
- `asset ` the GitHub asset object for the release.#### `onNewVersionReadyToInstall(file)`
Callback that is invoked when the new version is downloaded and ready to be installed.
This event can be used to tell the user that the new version is ready to be installed, and ask him if he wants to go ahead with the installation.- `file ` path of the installer that was downloaded.