Deep Linking
Set your Tauri application as the default handler for an URL.
Supported Platforms
This plugin requires a Rust version of at least 1.77.2
Platform | Level | Notes |
---|---|---|
windows | ||
linux | ||
macos | | Runtime deep link registration is not supported |
android | | Runtime deep link registration is not supported |
ios | | Runtime deep link registration is not supported |
Setup
Install the deep-link plugin to get started.
Setting up
Android
For app links, you need a server with a
.well-known/assetlinks.json
endpoint that must return a text response in the given format:
Where $APP_BUNDLE_ID
is the value defined on tauri.conf.json > identifier
with -
replaced with _
and
$CERT_FINGERPRINT
is a list of SHA256 fingerprints of your app’s signing certificates,
see verify Android applinks for more information.
iOS
For universal links, you need a server with a .well-known/apple-app-site-association
endpoint that must return a JSON response
in the given format:
Where $DEVELOPMENT_TEAM_ID
is the value defined on tauri.conf.json > tauri > bundle > iOS > developmentTeam
or the
TAURI_APPLE_DEVELOPMENT_TEAM
environment variable and $APP_BUNDLE_ID
is the value defined on tauri.conf.json > identifier
.
To verify if your domain has been properly configured to expose the app associations, you can run the following command,
replacing <host>
with your actual host:
See applinks.details for more information.
Desktop
On Linux and Windows deep links are delivered as a command line argument to a new app process. The deep link plugin has integration with the single instance plugin if you prefer having a unique app instance receiving the events.
- First you must add the
deep-link
feature to the single instance plugin:
- Then configure the single instance plugin which should always be the first plugin you register:
The user could trigger a fake deep link manually by including the URL as argument. Tauri matches the command line argument against the configured schemes to mitigate this, but you should still check if the URL matches the format you expect.
This means Tauri only handles deep links for schemes that were statically configured,
and schemes registered at runtime must be manually checked using Env::args_os
.
Configuration
Under tauri.conf.json > plugins > deep-link
, configure the domains (mobile) and schemes (desktop) you want to associate with your application:
With the above configuration, the something://*
and my-tauri-app://*
URLs are associated with your desktop application,
and on mobile the https://another.site.br/*
and https://your.website.com/open/*
URLs will open your mobile app.
Usage
The deep-link plugin is available in both JavaScript and Rust.
Listening to Deep Links
When a deep link triggers your app to be opened, the onOpenUrl
callback is executed:
When a deep link triggers your app to be opened, the on_open_url
closure is called:
Registering Desktop Deep Links at Runtime
The configuration section describes how to define static deep link schemes for your application.
On Linux and Windows it is possible to also associate schemes with your application at runtime via the register
Rust function.
In the following snippet, we will register the my-app
scheme at runtime. After executing the app for the first time,
the operating system will open my-app://*
URLs with our application:
Testing
There are some caveats to test deep links for your application.
Desktop
Deep links are only triggered for installed applications on desktop.
On Linux and Windows you can circumvent this using the register_all
Rust function,
which registers all configured schemes to trigger the current executable:
Windows
To trigger a deep link on Windows you can either open <scheme>://url
in the browser or run the following command in the terminal:
Linux
To trigger a deep link on Linux you can either open <scheme>://url
in the browser or run xdg-open
in the terminal:
iOS
To trigger an app link on iOS you can open the https://<host>/path
URL in the browser. For simulators you can leverage the simctl
CLI to directly open a link from the terminal:
Android
To trigger an app link on Android you can open the https://<host>/path
URL in the browser. For emulators you can leverage the adb
CLI to directly open a link from the terminal:
Permissions
By default all potentially dangerous plugin commands and scopes are blocked and cannot be accessed. You must modify the permissions in your capabilities
configuration to enable these.
See the Capabilities Overview for more information and the step by step guide to use plugin permissions.
Default Permission
Allows reading the opened deep link via the get_current command
allow-get-current
Permission Table
Identifier | Description |
---|---|
|
Enables the get_current command without any pre-configured scope. |
|
Denies the get_current command without any pre-configured scope. |
|
Enables the is_registered command without any pre-configured scope. |
|
Denies the is_registered command without any pre-configured scope. |
|
Enables the register command without any pre-configured scope. |
|
Denies the register command without any pre-configured scope. |
|
Enables the unregister command without any pre-configured scope. |
|
Denies the unregister command without any pre-configured scope. |
© 2025 Tauri Contributors. CC-BY / MIT