Contribute
This is a stub and is waiting for contributions. Get involved by visiting us on GitHub or joining us on Discord.
Automatically update your Tauri app with an update server or a static JSON.
Install the Tauri updater plugin to get started.
Use your project’s package manager to add the dependency:
npm run tauri add updateryarn run tauri add updaterpnpm tauri add updatercargo tauri add updaterRun cargo add tauri-plugin-updater to add the plugin to the project’s dependencies in Cargo.toml.
Modify lib.rs to initialize the plugin:
#[cfg_attr(mobile, tauri::mobile_entry_point)]fn run() {    tauri::Builder::default()        .plugin(tauri_plugin_updater::Builder::new().build())        .run(tauri::generate_context!())        .expect("error while running tauri application");}You can install the JavaScript Guest bindings using your preferred JavaScript package manager:
npm install @tauri-apps/plugin-updateryarn add @tauri-apps/plugin-updaterpnpm add @tauri-apps/plugin-updaterTauri’s updater needs a signature to verify that the update is from a trusted source. This cannot be disabled.
To sign your updates you need two things:
tauri.config.json to validate the artifacts before the installation. This public key can be uploaded and shared safely as long as your private key is secure.To generate the keys the Tauri CLI provides the signer generate command. On Linux you can run this to create the keys in the home folder:
npm run tauri signer generate -- -w ~/.tauri/myapp.keyyarn tauri signer generate -w ~/.tauri/myapp.keypnpm tauri signer generate -w ~/.tauri/myapp.keybunx tauri signer generate -w ~/.tauri/myapp.keycargo tauri signer generate -w ~/.tauri/myapp.keyIf you are on Windows, you should use $HOME/.tauri/myapp.key or a different path of your choice instead:
npm run tauri signer generate -- -w $HOME/.tauri/myapp.keyyarn tauri signer generate -w $HOME/.tauri/myapp.keypnpm tauri signer generate -w $HOME/.tauri/myapp.keybunx tauri signer generate -w $HOME/.tauri/myapp.keycargo tauri signer generate -w $HOME/.tauri/myapp.keyWhile building your update artifacts, you need to have the private key you generated above in your Environment variables. .env files do not work!
export TAURI_SIGNING_PRIVATE_KEY="Path or content of your private key"# optionally also add a passwordexport TAURI_SIGNING_PRIVATE_KEY_PASSWORD=""Run this in PowerShell:
$env:TAURI_SIGNING_PRIVATE_KEY="Path or content of your private key"<# optionally also add a password #>$env:TAURI_SIGNING_PRIVATE_KEY_PASSWORD=""After that, you can run Tauri build as usual and Tauri will generate the update bundles and their signatures. The generated files depend on the createUpdaterArtifacts  value configured below.
On Linux, Tauri will create the normal AppImage inside the target/release/bundle/appimage/ folder:
myapp.AppImage - The standard app bundle. It will be re-used by the updater.myapp.AppImage.sig - The signature of the updater bundle.On macOS, Tauri will create a .tar.gz archive from the application bundle inside the target/release/bundle/macos/ folder:
myapp.app - The standard app bundle.myapp.app.tar.gz - The updater bundle.myapp.app.tar.gz.sig - The signature of the update bundle.On Windows, Tauri will create the normal MSI and NSIS installers inside the target/release/bundle/msi/ and target/release/bundle/nsis folders:
myapp-setup.exe - The standard app bundle. It will be re-used by the updater.myapp-setup.exe.sig - The signature of the update bundle.myapp.msi - The standard app bundle. It will be re-used by the updater.myapp.msi.sig - Tthe signature of the update bundle.On Linux, Tauri will create a .tar.gz archive from the AppImage inside the target/release/bundle/appimage/ folder:
myapp.AppImage - The standard app bundle.myapp.AppImage.tar.gz - The updater bundle.myapp.AppImage.tar.gz.sig - The signature of the update bundle.On macOS, Tauri will create a .tar.gz archive from the application bundle inside the target/release/bundle/macos/ folder:
myapp.app - The standard app bundle.myapp.app.tar.gz - The updater bundle.myapp.app.tar.gz.sig - The signature of the update bundle.On Windows, Tauri will create .zip archives from the MSI and NSIS installers inside the target/release/bundle/msi/ and target/release/bundle/nsis folders:
myapp-setup.exe - The standard app bundle.myapp-setup.nsis.zip - The updater bundle.myapp-setup.nsis.zip.sig - The signature of the update bundle.myapp.msi - The standard app bundle.myapp.msi.zip - The updater bundle.myapp.msi.zip.sig - The signature of the update bundle.Set up the tauri.config.json in this format for the updater to start working.
| Keys | Description | 
|---|---|
| createUpdaterArtifacts | Setting this to truetells Tauri’s app bundler to create updater artifacts. If you’re migrating your app from an older Tauri version, set it to"v1Compatible"instead. This setting will be removed in v3 so make sure to change it totrueonce all your users are migrated to v2. | 
| pubkey | This has to be the public key generated from the Tauri CLI in the step above. It cannot be a file path! | 
| endpoints | This must be an array of endpoint URLs as strings. TLS is enforced in production mode. Tauri will only continue to the next url if a non-2XX status code is returned! | 
Each updater URL can contain the following dynamic variables, allowing you to determine server-side if an update is available.
{{current_version}}: The version of the app that is requesting the update.{{target}}: The operating system name (one of linux, windows or darwin).{{arch}}: The architecture of the machine (one of x86_64, i686, aarch64 or armv7).{  "bundle": {    "createUpdaterArtifacts": true  },  "plugins": {    "updater": {      "pubkey": "CONTENT FROM PUBLICKEY.PEM",      "endpoints": [        "https://releases.myapp.com/{{target}}/{{arch}}/{{current_version}}",        // or a static github json file        "https://github.com/user/repo/releases/latest/download/latest.json"      ]    }  }}installMode on WindowsOn Windows there is an additional optional "installMode" config to change how the update is installed.
{  "plugins": {    "updater": {      "windows": {        "installMode": "passive"      }    }  }}"passive": There will be a small window with a progress bar. The update will be installed without requiring any user interaction. Generally recommended and the default mode."basicUi": There will be a basic user interface shown which requires user interaction to finish the installation."quiet": There will be no progress feedback to the user. With this mode the installer cannot request admin privileges by itself so it only works in user-wide installations or when your app itself already runs with admin privileges. Generally not recommended.The updater plugin can be used in two ways. Either with a dynamic update server or a static JSON file (to use on services like S3 or GitHub gists).
When using static, you just need to return a JSON containing the required information.
| Keys | Description | 
|---|---|
| version | Must be a valid SemVer, with or without a leading v, meaning that both1.0.0andv1.0.0are valid. | 
| notes | Notes about the update. | 
| pub_date | The date must be formatted according to RFC 3339 if present. | 
| platforms | Each platform key is in the OS-ARCHformat, whereOSis one oflinux,darwinorwindows, andARCHis one ofx86_64,aarch64,i686orarmv7. | 
| signature | The content of the generated .sigfile, which may change with each build. A path or URL does not work! | 
The required keys are "version", "platforms.[target].url" and "platforms.[target].signature"; the others are optional.
{  "version": "",  "notes": "",  "pub_date": "",  "platforms": {    "linux-x86_64": {      "signature": "",      "url": ""    },    "windows-x86_64": {      "signature": "",      "url": ""    },    "darwin-x86_64": {      "signature": "",      "url": ""    }  }}Note that Tauri will validate the whole file before checking the version field, so make sure all existing platform configurations are valid and complete.
When using a dynamic update server, Tauri will follow the server’s instructions. To disable the internal version check you can overwrite the Tauri’s version comparison, this will install the version sent by the server (useful if you need to roll back your app).
Your server can use variables defined in the endpoint URL above to determine if an update is required. If you need more data, you can include additional request headers in Rust to your liking.
Your server should respond with a status code of 204 No Content if there is no update available.
If an update is required, your server should respond with a status code of 200 OK and a JSON response in this format:
| Keys | Description | 
|---|---|
| version | This Must be a valid SemVer, with or without a leading v, meaning that both1.0.0andv1.0.0are valid. | 
| notes | Notes about the update. | 
| pub_date | The date must be formatted according to RFC 3339 if present. | 
| url | This Must be a valid URL to the update bundle. | 
| signature | The content of the generated .sigfile, which may change with each build. A path or URL does not work! | 
The required keys are "url", "version" and "signature"; the others are optional.
{  "version": "",  "pub_date": "",  "url": "",  "signature": "",  "notes": ""}Contribute
This is a stub and is waiting for contributions. Get involved by visiting us on GitHub or joining us on Discord.
© 2024 Tauri Contributors. CC-BY / MIT