#tauri-plugin #licensing #sh #update #real-time #validation #key-gen

tauri-plugin-keygen-rs

Tauri plugin for Keygen.sh licensing, based on keygen-rs

5 releases

0.2.3 Dec 3, 2024
0.2.2 Sep 2, 2024
0.2.0 Sep 1, 2024
0.1.1 Aug 30, 2024
0.1.0 Aug 27, 2024

#980 in GUI

MIT license

115KB
2.5K SLoC

Tauri Plugin keygen-rs

Tauri plugin for Keygen.sh licensing, based on the keygen-rs SDK.

For Tauri v2 support, please use tauri-plugin-keygen-rs2.

Features

  • License validation and management
  • Machine-specific license activation and deactivation
  • Real-time license state updates
  • Rust and TypeScript APIs for seamless integration
  • Customizable Keygen.sh API endpoint

Installation

Add the following to your Cargo.toml:

[dependencies]
tauri-plugin-keygen-rs = "0.2.2"

Usage

  1. In your Tauri app's main.rs, import and use the plugin:
use tauri_plugin_keygen_rs::Builder;

fn main() {
tauri::Builder::default()
    .plugin(
        Builder::new(account, product, public_key)
        .api_url(api_url)
        .build()
    )
    // ... other configurations
    .run(tauri::generate_context!())
    .expect("error while running tauri application");
}
  1. You can use the plugin's API in your frontend code:
import {
    getLicense,
    validateKey,
    deactivate,
    checkoutLicense,
    checkoutMachine,
} from 'tauri-plugin-keygen-rs-api';

const license = await validateKey('YOUR_LICENSE_KEY');
  1. Access the plugin state in Rust code:
tauri::Builder::default()
    // ... other configurations
    .setup(|app| {
        let app_handle = app.handle();

        tauri::async_runtime::block_on(async move {
            let license_state = app_handle.get_license_state();
            let license_state = license_state.lock().await;
            println!("License: {:?}", license_state.license);

            let machine_state = app_handle.get_machine_state();
            let machine_state = machine_state.lock().await;
            println!("Machine: {:?}", machine_state);

            tauri_plugin_keygen_rs::add_license_listener(|state| {
                println!("License state change: {:?}", state);
            }).await;
        });
        Ok(())
    })
    .run(tauri::generate_context!())
    .expect("error while running tauri application");

For more detailed examples, refer to the examples directory.

Error Handling

The plugin uses a KeygenError class for error handling. Catch and handle these errors in your application as needed.

Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

License

This project is licensed under the MIT License.

Dependencies

~27–69MB
~1M SLoC