Saltearse al contenido
Tauri

Actualizar desde Tauri 1.0

Esta guía te guiará a través de la actualización de tu aplicación Tauri 1.0 a Tauri 2.0.

Preparación para móvil

La interfaz móvil de Tauri requiere que tu proyecto produzca una biblioteca compartida. Si estás apuntando a móviles para tu aplicación existente, debes cambiar tu crate para producir ese tipo de artefacto junto con el ejecutable de escritorio.

  1. Modifica el manifiesto Cargo para producir la biblioteca. Añade el siguiente bloque:
src-tauri/Cargo.toml
[lib]
name = "app_lib"
crate-type = ["staticlib", "cdylib", "rlib"]
  1. Cambia el nombre de src-tauri/src/main.rs a src-tauri/src/lib.rs. Este archivo será compartido tanto por los targets de escritorio como por los móviles.

  2. Cambia el nombre de la cabecera de la función main en lib.rs por el siguiente:

src-tauri/src/lib.rs
#[cfg_attr(mobile, tauri::mobile_entry_point)]
pub fn run() {
// tu código aquí
}

El macro tauri::mobile_entry_point prepara tu función para ser ejecutada en el móvil.

  1. Vuelve a crear el archivo main.rs llamando a la función de ejecución compartida:
src-tauri/src/main.rs
#![cfg_attr(not(debug_assertions), windows_subsystem = "windows")]
fn main() {
app_lib::run();
}

Migración Automatizada

La CLI de Tauri v2 incluye un comando migrate que automatiza la mayor parte del proceso y te ayuda a finalizar la migración:

npm install @tauri-apps/cli@latest
npm run tauri migrate

Para saber más sobre el comando migrate, consulta la Referencia de la interfaz de línea de comandos

Resumen de los cambios

A continuación se resumen los cambios de Tauri 1.0 a Tauri 2.0:

Configuración de Tauri

  • Los campos package > productName y package > version se han trasladado al campo de nivel superior.
  • el nombre del binario ya no se renombra automáticamente para coincidir con productName, por lo que debes agregar una string mainBinaryName en el objeto de nivel superior que coincida con productName.
  • package eliminado.
  • La clave tauri ha pasado a ser app.
  • tauri > allowlist eliminado. Véase Migrar permisos.
  • tauri > allowlist > protocol > assetScope movido a app > security > assetProtocol > scope.
  • tauri > cli movido a plugins > cli.
  • tauri > windows > fileDropEnabled renombrado a app > windows > dragDropEnabled.
  • tauri > updater > active eliminado.
  • tauri > updater > dialog eliminado.
  • tauri > updater movido a plugins > updater.
  • Se ha agragado bundle > createUpdaterArtifacts, debe ser configurado al usar el actualizador de la aplicación.
    • configúralo a v1Compatible cuando actualices desde aplicaciones de la V1 que ya habían sido distribuidas. Consulta la guía del actualizador para más información.
  • tauri > systemTray renombrado a app > trayIcon.
  • tauri > pattern movido a app > security > pattern.
  • tauri > bundle movido a nivel superior.
  • tauri > bundle > identifier movido a objeto del nivel superior.
  • tauri > bundle > dmg movido a bundle > macOS > dmg
  • tauri > bundle > deb movido a bundle > linux > deb
  • tauri > bundle > appimage movido a bundle > linux > appimage
  • tauri > bundle > macOS > license eliminado, utiliza bundle > licenseFile en su lugar.
  • tauri > bundle > windows > wix > license eliminado, utiliza bundle > licenseFile en su lugar.
  • tauri > bundle > windows > nsis > license eliminado, utiliza bundle > licenseFile en su lugar.
  • tauri > bundle > windows > webviewFixedRuntimePath eliminado, utiliza bundle > windows > webviewInstallMode en su lugar.
  • build > withGlobalTauri movido a app > withGlobalTauri.
  • build > distDir renombrado a frontendDist.
  • build > devPath renombrado a devUrl.

Referencia de la API de configuración de Tauri 2.0

Nuevas características de Cargo

  • linux-protocol-body: Habilita el análisis personalizado del cuerpo de solicitud del protocolo, permitiendo que el IPC lo utilice. Requiere webkit2gtk 2.40.

Características de Cargo eliminadas

  • reqwest-client: reqwest es ahora el único cliente soportado.
  • reqwest-native-tls-vendored: utiliza native-tls-vendored en su lugar.
  • process-command-api: utiliza el plugin shell en su lugar. (véanse las instrucciones en la sección siguiente).
  • shell-open-api: utiliza el plugin shell en su lugar. (véanse las instrucciones en la sección siguiente).
  • windows7-compat: movido al plugin notification.
  • updater: Updater es ahora un plugin.
  • linux-protocol-headers: Ahora habilitado por defecto desde que actualizamos nuestra versión mínima de webkit2gtk.
  • system-tray: renombrado a tray-icon.

Cambios en el Crate de Rust

  • El módulo api ha sido eliminado. Cada módulo de API se puede encontrar en un plugin de Tauri.
  • El módulo api::dialog ha sido eliminado. Utiliza tauri-plugin-dialog en su lugar. Migración
  • El módulo api::file ha sido eliminado. Utiliza std::fs de Rust en su lugar.
  • El módulo api::http ha sido eliminado. Utiliza tauri-plugin-http en su lugar. Migración
  • El módulo api::ip ha sido reescrito y movido a tauri::ipc. Revisa las nuevas APIs, especialmente tauri::ipc::Channel.
  • Las funciones del módulo api::path y tauri::PathResolved se han movido a tauri::Manager::path. Migración
  • Las APIs api::process::Command, tauri::api::shell y tauri::Manager::shell_scope han sido eliminadas. Utiliza tauri-plugin-shell en su lugar. Migración
  • Las funciones api::process::current_binary y tauri::api::process::restart se han movido a tauri::process.
  • El módulo api::version ha sido eliminado. Utiliza el crate semver en su lugar.
  • Los métodos App::clipboard_manager y AppHandle::clipboard_manager han sido eliminados. Utiliza tauri-plugin-clipboard en su lugar. Migración
  • El método App::get_cli_matches ha sido eliminado. Utiliza tauri-plugin-cli en su lugar. Migración
  • Los métodos App::global_shortcut_manager y AppHandle::global_shortcut_manager han sido eliminados. Utiliza tauri-plugin-global-shortcut en su lugar. Migración
  • El método Manager::fs_scope ha sido eliminado. El alcance del sistema de archivos puede ser accedido a través de tauri_plugin_fs::FsExt.
  • Ahora, Plugin::PluginApi recibe una configuración de plugin como segundo argumento.
  • El método Plugin::setup_with_config ha sido eliminado. Utiliza el actualizado tauri::Plugin::PluginApi en su lugar.
  • Los métodos scope::ipc::RemoteDomainAccessScope::enable_tauri_api y scope::ipc::RemoteDomainAccessScope::enables_tauri_api han sido eliminados. Habilita cada plugin del núcleo individualmente mediante scope::ipc::RemoteDomainAccessScope::add_plugin en su lugar.
  • El módulo scope::IpcScope ha sido eliminado, utiliza scope::ipc::Scope en su lugar.
  • Los módulos scope::FsScope, scope::GlobPattern y scope::FsScopeEvent han sido eliminados, utiliza scope::fs::Scope, scope::fs::Pattern y scope::fs::Event respectivamente.
  • El módulo updater ha sido eliminado. Utiliza tauri-plugin-updater en su lugar. Migración
  • El campo Env.args ha sido eliminado, utiliza el campo Env.args_os en su lugar.
  • Las APIs Menu, MenuEvent, CustomMenuItem, Submenu, WindowMenuEvent, MenuItem y Builder::on_menu_event han sido eliminadas. Migración
  • Las APIs SystemTray, SystemTrayHandle, SystemTrayMenu, SystemTrayMenuItemHandle, SystemTraySubmenu, MenuEntry y SystemTrayMenuItem han sido eliminadas. Migración

Cambios en la API de JavaScript

El paquete @tauri-apps/api ya no proporciona módulos no centrales. Sólo se exportan los anteriores módulos tauri (ahora core), path, event y window. Todos los demás se han trasladado a plugins.

  • El módulo @tauri-apps/api/tauri ha sido renombrado a @tauri-apps/api/core. Migración
  • El módulo @tauri-apps/api/cli ha sido eliminado. Utiliza @tauri-apps/plugin-cli en su lugar. Migración
  • El módulo @tauri-apps/api/clipboard ha sido eliminado. Utiliza @tauri-apps/plugin-clipboard en su lugar. Migración
  • El módulo @tauri-apps/api/dialog ha sido eliminado. Utiliza @tauri-apps/plugin-dialog en su lugar. Migración
  • El módulo @tauri-apps/api/fs ha sido eliminado. Utiliza @tauri-apps/plugin-fs en su lugar. Migración
  • El módulo @tauri-apps/api/global-shortcut ha sido eliminado. Utiliza @tauri-apps/plugin-global-shortcut en su lugar. Migración
  • El módulo @tauri-apps/api/http ha sido eliminado. Utiliza @tauri-apps/plugin-http en su lugar. Migración
  • El módulo @tauri-apps/api/os ha sido eliminado. Utiliza @tauri-apps/plugin-os en su lugar. Migración
  • El módulo @tauri-apps/api/notification ha sido eliminado. Utiliza @tauri-apps/plugin-notification en su lugar. Migración
  • El módulo @tauri-apps/api/process ha sido eliminado. Utiliza @tauri-apps/plugin-process en su lugar. Migración
  • El módulo @tauri-apps/api/shell ha sido eliminado. Utiliza @tauri-apps/plugin-shell en su lugar. Migración
  • El módulo @tauri-apps/api/updater ha sido eliminado. Utiliza @tauri-apps/plugin-updater en su lugar. Migración
  • El módulo @tauri-apps/api/window ha sido renombrado a @tauri-apps/api/webviewWindow. Migración

Los plugins the la V1 ahora están publicados como @tauri-apps/plugin-<plugin-name>. Anteriormente, estaban disponibles desde git como tauri-plugin-<plugin-name>-api.

Cambios en las variables de entorno

La mayoría de las variables de entorno leídas y escritas por el CLI de Tauri fueron renombradas por consistencia y prevención de errores:

  • TAURI_PRIVATE_KEY -> TAURI_SIGNING_PRIVATE_KEY
  • TAURI_KEY_PASSWORD -> TAURI_SIGNING_PRIVATE_KEY_PASSWORD
  • TAURI_SKIP_DEVSERVER_CHECK -> TAURI_CLI_NO_DEV_SERVER_WAIT
  • TAURI_DEV_SERVER_PORT -> TAURI_CLI_PORT
  • TAURI_PATH_DEPTH -> TAURI_CLI_CONFIG_DEPTH
  • TAURI_FIPS_COMPLIANT -> TAURI_BUNDLER_WIX_FIPS_COMPLIANT
  • TAURI_DEV_WATCHER_IGNORE_FILE -> TAURI_CLI_WATCHER_IGNORE_FILENAME
  • TAURI_TRAY -> TAURI_LINUX_AYATANA_APPINDICATOR
  • TAURI_APPLE_DEVELOPMENT_TEAM -> APPLE_DEVELOPMENT_TEAM
  • TAURI_PLATFORM -> TAURI_ENV_PLATFORM
  • TAURI_ARCH -> TAURI_ENV_ARCH
  • TAURI_FAMILY -> TAURI_ENV_FAMILY
  • TAURI_PLATFORM_VERSION -> TAURI_ENV_PLATFORM_VERSION
  • TAURI_PLATFORM_TYPE -> TAURI_ENV_PLATFORM_TYPE
  • TAURI_DEBUG -> TAURI_ENV_DEBUG

Sistema de eventos

El sistema de eventos fue rediseñado para ser más fácil de usar. En lugar de depender de la fuente del evento, ahora tiene una implementación más simple que se basa en los objetivos del evento.

  • La función emit ahora emite el evento a todos los escuchadores de eventos.
  • Se agregó una nueva función emit_to para desencadenar un evento a un objetivo específico.
  • emit_filter ahora filtra en función de EventTarget en lugar de una ventana.
  • Se renombró listen_global a listen_any. Ahora escucha todos los eventos independientemente de sus filtros y objetivos.

Soporte Multiwebview

Tauri v2 introduce soporte multiwebview actualmente detrás de una bandera de característica unstable. Para admitirlo, renombramos el tipo de ventana Rust Window a WebviewWindow y la función get_window del Manager a get_webview_window.

El tipo de API JS WebviewWindow ahora se reexporta desde @tauri-apps/api/webviewWindow en lugar de @tauri-apps/api/window.

Nueva URL de origen en Windows

On Windows the frontend files in production apps are now hosted on http://tauri.localhost instead of https://tauri.localhost. Because of this IndexedDB, LocalStorage and Cookies will be reset unless dangerousUseHttpScheme was used in v1. To prevent this you can set app > windows > useHttpsScheme to true or use WebviewWindowBuilder::use_https_scheme to keep using the https scheme.

Pasos Detallados de Migración

Escenarios comunes que puedes encontrar al migrar tu aplicación de Tauri 1.0 a Tauri 2.0.

Migrar al Módulo Core

El módulo @tauri-apps/api/tauri fue renombrado a @tauri-apps/api/core. Simplemente renombra la importación del módulo:

import { invoke } from "@tauri-apps/api/tauri"
import { invoke } from "@tauri-apps/api/core"

Migrar al plugin CLI

Las APIs de Rust App::get_cli_matches y JavaScript @tauri-apps/api/cli han sido eliminadas. Utiliza en su lugar el plugin @tauri-apps/plugin-cli:

  1. Agrega a las dependencias de Cargo:
Cargo.toml
[dependencies]
tauri-plugin-cli = "2"
  1. Úsalo en un proyecto con JavaScript o Rust:
fn main() {
tauri::Builder::default()
.plugin(tauri_plugin_cli::init())
}
package.json
{
"dependencies": {
"@tauri-apps/plugin-cli": "^2.0.0"
}
}
import { getMatches } from '@tauri-apps/plugin-cli';
const matches = await getMatches();

Migrar al Plugin de Portapapeles

Las APIs de Rust App::clipboard_manager,AppHandle::clipboard_manager y la API JavaScript @tauri-apps/api/clipboard han sido eliminadas. En su lugar, utiliza el plugin @tauri-apps/plugin-clipboard-manager:

[dependencies]
tauri-plugin-clipboard-manager = "2"
fn main() {
tauri::Builder::default()
.plugin(tauri_plugin_clipboard_manager::init())
}
package.json
{
"dependencies": {
"@tauri-apps/plugin-clipboard-manager": "^2.0.0"
}
}
import { writeText, readText } from '@tauri-apps/plugin-clipboard-manager';
await writeText('Tauri is awesome!');
assert(await readText(), 'Tauri is awesome!');

Las APIs de Rust tauri::api::dialog y JavaScript @tauri-apps/api/dialog han sido eliminadas. Utiliza en su lugar el plugin @tauri-apps/plugin-dialog:

  1. Agrega a las dependencias de Cargo:
Cargo.toml
[dependencies]
tauri-plugin-dialog = "2"
  1. Úsalo en un proyecto con JavaScript o Rust:
fn main() {
tauri::Builder::default()
.plugin(tauri_plugin_dialog::init())
}
package.json
{
"dependencies": {
"@tauri-apps/plugin-dialog": "^2.0.0"
}
}
import { save } from '@tauri-apps/plugin-dialog';
const filePath = await save({
filters: [
{
name: 'Image',
extensions: ['png', 'jpeg'],
},
],
});

Migrar al Plugin del Sistema de Archivos

Las APIs de Rust App::get_cli_matches y JavaScript @tauri-apps/api/fs han sido eliminadas. En su lugar, utiliza std::fs para Rust y el plugin @tauri-apps/plugin-fs para JavaScript:

  1. Agrega a las dependencias de Cargo:
Cargo.toml
[dependencies]
tauri-plugin-fs = "2"
  1. Úsalo en un proyecto con JavaScript o Rust:
fn main() {
tauri::Builder::default()
.plugin(tauri_plugin_fs::init())
}
package.json
{
"dependencies": {
"@tauri-apps/plugin-fs": "^2.0.0"
}
}
import { mkdir, BaseDirectory } from '@tauri-apps/plugin-fs';
await mkdir('db', { baseDir: BaseDirectory.AppLocalData });

Algunas funciones y tipos han sido renombrados o eliminados:

  • Se eliminó el alias Dir para el enum, utiliza BaseDirectory.
  • Las interfaces y alias de tipo FileEntry, FsBinaryFileOption, FsDirOptions, FsOptions, FsTextFileOption y BinaryFileContents han sido eliminados y reemplazados con nuevas interfaces adecuadas para cada función.
  • createDir fue renombrado a mkdir.
  • readBinaryFile fue renombrado a readFile.
  • removeDir fue eliminado y reemplazado con remove.
  • removeFile fue eliminado y reemplazado con remove.
  • renameFile fue eliminado y reemplazado con rename.
  • writeBinaryFile fue renombrado a writeFile.

Migrar al Plugin de Atajos Globales

Las APIs de Rust App::global_shortcut_manager y AppHandle::global_shortcut_manager, y JavaScript @tauri-apps/api/global-shortcut han sido eliminadas. Utiliza en su lugar el plugin @tauri-apps/plugin-global-shortcut:

  1. Agrega a las dependencias de Cargo:
Cargo.toml
[dependencies]
[target."cfg(not(any(target_os = \"android\", target_os = \"ios\")))".dependencies]
tauri-plugin-global-shortcut = "2"
  1. Úsalo en un proyecto con JavaScript o Rust:
fn main() {
tauri::Builder::default()
.plugin(tauri_plugin_global_shortcut::Builder::default().build())
}
package.json
{
"dependencies": {
"@tauri-apps/plugin-global-shortcut": "^2.0.0"
}
}
import { register } from '@tauri-apps/plugin-global-shortcut';
await register('CommandOrControl+Shift+C', () => {
console.log('Shortcut triggered');
});

Migrar al Plugin HTTP

Las APIs de Rust tauri::api::http y JavaScript @tauri-apps/api/http han sido eliminadas. Utiliza el plugin @tauri-apps/plugin-http en su lugar:

  1. Agrega las dependencias a Cargo:
Cargo.toml
[dependencies]
tauri-plugin-http = "2"
  1. Úsalo en un proyecto con JavaScript o Rust:
fn main() {
tauri::Builder::default()
.plugin(tauri_plugin_http::init())
}
package.json
{
"dependencies": {
"@tauri-apps/plugin-http": "^2.0.0"
}
}
import { fetch } from '@tauri-apps/plugin-http';
const response = await fetch(
'https://raw.githubusercontent.com/tauri-apps/tauri/dev/package.json'
);

Migrar al Plugin de Notificaciones

Las APIs de Rust tauri::api::notification y JavaScript @tauri-apps/api/notification han sido eliminadas. Utiliza el plugin @tauri-apps/plugin-notification en su lugar:

  1. Agrega a las dependencias de Cargo:
Cargo.toml
[dependencies]
tauri-plugin-notification = "2"
  1. Úsalo en proyectos con JavaScript o Rust:
fn main() {
tauri::Builder::default()
.plugin(tauri_plugin_notification::init())
}
package.json
{
"dependencies": {
"@tauri-apps/plugin-notification": "^2.0.0"
}
}
import { sendNotification } from '@tauri-apps/plugin-notification';
sendNotification('Tauri is awesome!');

Migrar al Módulo de Menú

Las APIs de Rust Menu fueron movidas al módulo tauri::menu y refactorizadas para utilizar el muda crate.

Usa tauri::menu::MenuBuilder

Utiliza tauri::menu::MenuBuilder en lugar de tauri::Menu. Ten en cuenta que su constructor toma una instancia de Manager (uno de App, AppHandle o WebviewWindow) como argumento:

use tauri::menu::MenuBuilder;
tauri::Builder::default()
.setup(|app| {
let menu = MenuBuilder::new(app)
.copy()
.paste()
.separator()
.undo()
.redo()
.text("open-url", "Open URL")
.check("toggle", "Toggle")
.icon("show-app", "Show App", app.default_window_icon().cloned().unwrap())
.build()?;
Ok(())
})

Usa tauri::menu::PredefinedMenuItem

Utiliza tauri::menu::PredefinedMenuItem en lugar de tauri::MenuItem:

use tauri::menu::{MenuBuilder, PredefinedMenuItem};
tauri::Builder::default()
.setup(|app| {
let menu = MenuBuilder::new(app).item(&PredefinedMenuItem::copy(app)?).build()?;
Ok(())
})

Utiliza tauri::menu::MenuItemBuilder

Utiliza tauri::menu::MenuItemBuilder en lugar de tauri::CustomMenuItem:

use tauri::menu::MenuItemBuilder;
tauri::Builder::default()
.setup(|app| {
let toggle = MenuItemBuilder::new("Toggle").accelerator("Ctrl+Shift+T").build(app)?;
Ok(())
})

Utiliza tauri::menu::SubmenuBuilder

Utiliza tauri::menu::SubmenuBuilder en lugar de tauri::Submenu:

use tauri::menu::{MenuBuilder, SubmenuBuilder};
tauri::Builder::default()
.setup(|app| {
let submenu = SubmenuBuilder::new(app, "Sub")
.text("Tauri")
.separator()
.check("Is Awesome")
.build()?;
let menu = MenuBuilder::new(app).item(&submenu).build()?;
Ok(())
})

tauri::Builder::menu ahora toma un cierre porque el menú necesita una instancia de Manager para ser construido. Consulta la documentación para obtener más información.

Eventos de Menú

La API tauri::Builder::on_menu_event de Rust fue eliminada. En su lugar, usa tauri::App::on_menu_event o tauri::AppHandle::on_menu_event.

use tauri::menu::{CheckMenuItemBuilder, MenuBuilder, MenuItemBuilder};
tauri::Builder::default()
.setup(|app| {
let toggle = MenuItemBuilder::with_id("toggle", "Toggle").build(app)?;
let check = CheckMenuItemBuilder::new("Mark").build(app)?;
let menu = MenuBuilder::new(app).items(&[&toggle, &check]).build()?;
app.set_menu(menu)?;
app.on_menu_event(move |app, event| {
if event.id() == check.id() {
println!("`check` triggered, do something! is checked? {}", check.is_checked().unwrap());
} else if event.id() == "toggle" {
println!("toggle triggered!");
}
});
Ok(())
})

Ten en cuenta que hay dos formas de verificar qué elemento del menú fue seleccionado: mover el elemento al cierre del controlador de eventos y comparar los identificadores, o definir un identificador personalizado para el elemento a través del constructor with_id y usar esa cadena de identificación para comparar.

Migrar al Plugin OS

Las APIs tauri::api::os de Rust y @tauri-apps/api/os de JavaScript han sido eliminadas. Utiliza en su lugar el plugin @tauri-apps/plugin-os:

  1. Agrega a las dependencias de Cargo:
Cargo.toml
[dependencies]
tauri-plugin-os = "2"
  1. Usa en el proyecto JavaScript o Rust:
fn main() {
tauri::Builder::default()
.plugin(tauri_plugin_os::init())
}
package.json
{
"dependencies": {
"@tauri-apps/plugin-os": "^2.0.0"
}
}
import { arch } from '@tauri-apps/plugin-os';
const architecture = await arch();

Migrar al Plugin Process

Las APIs tauri::api::process de Rust y @tauri-apps/api/process de JavaScript han sido eliminadas. Utiliza en su lugar el plugin @tauri-apps/plugin-process:

  1. Agrega a las dependencias de Cargo:
Cargo.toml
[dependencies]
tauri-plugin-process = "2"
  1. Úsalo en proyectos con JavaScript o Rust:
fn main() {
tauri::Builder::default()
.plugin(tauri_plugin_process::init())
}
package.json
{
"dependencies": {
"@tauri-apps/plugin-process": "^2.0.0"
}
}
import { exit, relaunch } from '@tauri-apps/plugin-process';
await exit(0);
await relaunch();

Migrar al Plugin Shell

Las APIs tauri::api::shell de Rust y @tauri-apps/api/shell de JavaScript han sido eliminadas. Utiliza en su lugar el plugin @tauri-apps/plugin-shell:

  1. Agrega a las dependencias de Cargo:
Cargo.toml
[dependencies]
tauri-plugin-shell = "2"
  1. Úsalo en un proyecto con JavaScript o Rust:
fn main() {
tauri::Builder::default()
.plugin(tauri_plugin_shell::init())
}
package.json
{
"dependencies": {
"@tauri-apps/plugin-shell": "^2.0.0"
}
}
import { Command, open } from '@tauri-apps/plugin-shell';
const output = await Command.create('echo', 'message').execute();
await open('https://github.com/tauri-apps/tauri');

Migrar al Módulo de Tray Icon

Las APIs SystemTray de Rust fueron renombradas a TrayIcon para mayor consistencia. Las nuevas APIs pueden encontrarse en el módulo tray de Rust.

Usa tauri::tray::TrayIconBuilder

Utiliza tauri::tray::TrayIconBuilder en lugar de tauri::SystemTray:

let tray = tauri::tray::TrayIconBuilder::with_id("mi-bandeja").build(app)?;

Consulta TrayIconBuilder para más información.

Migrar a Menú

Utiliza tauri::menu::Menu en lugar de tauri::SystemTrayMenu, tauri::menu::Submenu en lugar de tauri::SystemTraySubmenu, y tauri::menu::PredefinedMenuItem en lugar de tauri::SystemTrayMenuItem.

Eventos de Bandeja

tauri::SystemTray::on_event ha sido dividido en tauri::tray::TrayIconBuilder::on_menu_event y tauri::tray::TrayIconBuilder::on_tray_icon_event:

use tauri::{
menu::{MenuBuilder, MenuItemBuilder},
tray::{MouseButton, MouseButtonState, TrayIconBuilder, TrayIconEvent},
};
tauri::Builder::default()
.setup(|app| {
let toggle = MenuItemBuilder::with_id("toggle", "Toggle").build(app)?;
let menu = MenuBuilder::new(app).items(&[&toggle]).build()?;
let tray = TrayIconBuilder::new()
.menu(&menu)
.on_menu_event(move |app, event| match event.id().as_ref() {
"toggle" => {
println!("toggle clicked");
}
_ => (),
})
.on_tray_icon_event(|tray, event| {
if let TrayIconEvent::Click {
button: MouseButton::Left,
button_state: MouseButtonState::Up,
..
} = event
{
let app = tray.app_handle();
if let Some(webview_window) = app.get_webview_window("main") {
let _ = webview_window.show();
let _ = webview_window.set_focus();
}
}
})
.build(app)?;
Ok(())
})

Migrar al Plugin de Actualizaciones

El diálogo incorporado con una verificación de actualización automática ha sido eliminado. En su lugar, utiliza las APIs de Rust y JS para verificar e instalar actualizaciones.

Las APIs tauri::updater de Rust y @tauri-apps/api-updater de JavaScript han sido eliminadas. Para establecer un objetivo de actualización personalizado con @tauri-apps/plugin-updater:

  1. Agrega a las dependencias de Cargo:
[dependencies]
tauri-plugin-updater = "2"
  1. Úsalo en un proyecto con JavaScript o Rust:
fn main() {
tauri::Builder::default()
.plugin(tauri_plugin_updater::Builder::new().build())
}
package.json
{
"dependencies": {
"@tauri-apps/plugin-updater": "^2.0.0"
}
}
import { check } from '@tauri-apps/plugin-updater';
import { relaunch } from '@tauri-apps/plugin-process';
const update = await check();
if (update?.available) {
console.log(
`¡Actualización a ${update.version} disponible! Fecha: ${update.date}`
);
console.log(`Notas del parche: ${update.body}`);
await update.downloadAndInstall();
// requiere el plugin `process`
await relaunch();
}

Migrar de Path a Tauri Manager

Las funciones del módulo tauri::api::path de Rust y tauri::PathResolver se han trasladado a tauri::Manager::path:

use tauri::{path::BaseDirectory, Manager};
tauri::Builder::default()
.setup(|app| {
let home_dir_path = app.path().home_dir().expect("no se pudo obtener el directorio home");
let path = app.path().resolve("path/haz/algo", BaseDirectory::Config)?;
Ok(())
})

Migrar a la nueva API de Ventanas

En el lado de Rust, Window fue renombrado a WebviewWindow, su constructor WindowBuilder ahora se llama WebviewWindowBuilder y WindowUrl ahora se llama WebviewUrl.

Además, la función Manager::get_window fue renombrada a get_webview_window y la API parent_window de la ventana fue renombrada a parent_raw para admitir una API de ventana principal de alto nivel.

En el lado de JavaScript, la clase WebviewWindow ahora se exporta en la ruta @tauri-apps/api/webviewWindow.

La función onMenuClicked fue eliminada, ahora puedes interceptar eventos de menú al crear un menú en JavaScript en su lugar.

Migrar Archivos Adicionales Incrustados (Recursos)

En el lado de JavaScript, asegúrate de Migrar al Plugin del Sistema de Archivos. Además, ten en cuenta que los cambios hechos en la lista blanca de la v1 en Migrar Permisos.

En el lado de Rust, asegúrate de Migrar de Path a Tauri Manager.

Migrar de Binarios Externos Incrustados (Sidecar)

En Tauri v1, los binarios externos y sus argumentos se definían en la lista blanca. En la v2, utiliza el nuevo sistema de permisos. Lee Migración de Permisos para más información.

En el lado de JavaScript, asegúrate de Migrar al Plugin Shell.

En el lado de Rust, la API tauri::api::process ha sido eliminada. Usa tauri_plugin_shell::ShellExt y las APIs tauri_plugin_shell::process::CommandEvent en su lugar. Lee la guía de Incrustar Binarios Externos para ver cómo.

El indicador de características “process-command-api” ha sido eliminado en la v2. Por lo tanto, ejecutar los binarios externos ya no requiere que esta característica esté definida en la configuración de Tauri.

Migrar Permisos

La lista blanca v1 ha sido reescrita a un sistema completamente nuevo para permisos que funciona para plugins individuales y es mucho más configurable para soportar múltiples ventanas y URL remotas. Este nuevo sistema funciona como una lista de control de acceso (ACL) donde puedes permitir o denegar comandos, asignar permisos a un conjunto específico de ventanas y dominios, y definir alcances de acceso.

Para habilitar permisos para tu aplicación, debes crear archivos de capacidades dentro de la carpeta src-tauri/capabilities, y Tauri configurará automáticamente todo lo demás para ti.

El comando migrate de la CLI analiza automáticamente tu lista blanca v1 y genera el archivo de capacidad asociado.

Para obtener más información sobre permisos y capacidades, consulta la documentación de seguridad.


© 2025 Tauri Contributors. CC-BY / MIT