This plugin provides configurable interfaces for capturing and storing logs.
There are three general methods of installation that we can recommend.
- Pull sources directly from Github using git tags / revision hashes (most secure, good for developement, shown below)
- Git submodule install this repo in your tauri project and then use
file
protocol to ingest the source - Use crates.io and npm (easiest, and requires you to trust that our publishing pipeline worked)
For more details and usage see the example app. Please note, below in the dependencies you can also lock to a revision/tag in both the Cargo.toml
and package.json
src-tauri/Cargo.toml
[dependencies.tauri-plugin-log]
git = "https://github.com/tauri-apps/tauri-plugin-log"
tag = "v0.1.0"
Install from a tagged release
npm install github:tauri-apps/tauri-plugin-log#v0.1.0
# or
yarn add github:tauri-apps/tauri-plugin-log#v0.1.0
package.json
"dependencies": {
"tauri-plugin-log-api": "tauri-apps/tauri-plugin-log#v0.1.0",
Use in src-tauri/src/main.rs
:
use tauri_plugin_log::{LogTarget, LoggerBuilder};
fn main() {
tauri::Builder::default()
.plugin(LoggerBuilder::new([
LogTarget::LogDir,
LogTarget::Stdout,
LogTarget::Webview,
]).build())
.build()
.run();
}
import { trace, info, error, attachConsole } from 'tauri-plugin-log-api'
// with LogTarget::Webview enabled this function will print logs to the browser console
const detach = await attachConsole()
trace("Trace")
info("Info")
error("Error")
// detach the browser console from the log stream
detach()