ed718704ee
- Add prepare job: computes version (4.12.{run_number}), creates/updates
the Gitea release once — eliminates the race condition where build-windows
and build-linux both tried to create the same release simultaneously.
- Auto-increment version: both build jobs patch tauri.conf.json with
4.12.{run_number} before building, so every CI run produces a strictly
increasing semver and the Tauri updater fires correctly.
- Fix double -- in Windows build command: was 'build -- --bundles nsis'
which passed --bundles as cargo args (silently ignored), causing all
bundle targets to build. Now 'build --bundles nsis' (single --).
- Add setup-node to Windows build: pins Node.js to .node-version like
the Linux job already does.
- update-manifest: uses version/release_id from prepare outputs instead
of re-fetching and parsing the release name.
- Fix window title: was "Cinny", now "Lotus Chat".
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
80 lines
3.2 KiB
Rust
80 lines
3.2 KiB
Rust
#![cfg_attr(
|
|
all(not(debug_assertions), target_os = "windows"),
|
|
windows_subsystem = "windows"
|
|
)]
|
|
|
|
use tauri::{webview::{NewWindowResponse, WebviewWindowBuilder}, WebviewUrl};
|
|
use tauri_plugin_opener::OpenerExt;
|
|
|
|
pub fn run() {
|
|
let port: u16 = 44548;
|
|
let context = tauri::generate_context!();
|
|
let builder = tauri::Builder::default();
|
|
|
|
builder
|
|
.plugin(tauri_plugin_localhost::Builder::new(port).build())
|
|
.plugin(tauri_plugin_window_state::Builder::default().build())
|
|
.plugin(tauri_plugin_opener::init())
|
|
.setup(move |app| {
|
|
#[cfg(debug_assertions)]
|
|
let window_url = WebviewUrl::App(Default::default());
|
|
|
|
#[cfg(not(debug_assertions))]
|
|
let window_url = {
|
|
let url = format!("http://localhost:{}", port).parse().unwrap();
|
|
WebviewUrl::External(url)
|
|
};
|
|
|
|
let app_handle = app.handle().clone();
|
|
let window = WebviewWindowBuilder::new(app, "main".to_string(), window_url)
|
|
.title("Lotus Chat")
|
|
.disable_drag_drop_handler()
|
|
.on_new_window(move |url, _features| {
|
|
let _ = app_handle.opener().open_url(url.as_str(), None::<&str>);
|
|
NewWindowResponse::Deny
|
|
})
|
|
.build()?;
|
|
|
|
// Grant camera and microphone to WebView2 automatically.
|
|
// Windows requires an explicit PermissionRequested COM event handler.
|
|
#[cfg(target_os = "windows")]
|
|
window.with_webview(|webview| {
|
|
use webview2_com::{
|
|
Microsoft::Web::WebView2::Win32::{
|
|
COREWEBVIEW2_PERMISSION_KIND,
|
|
COREWEBVIEW2_PERMISSION_KIND_CAMERA,
|
|
COREWEBVIEW2_PERMISSION_KIND_MICROPHONE,
|
|
COREWEBVIEW2_PERMISSION_STATE_ALLOW,
|
|
},
|
|
PermissionRequestedEventHandler,
|
|
};
|
|
|
|
let controller = webview.controller();
|
|
if let Ok(core) = unsafe { controller.CoreWebView2() } {
|
|
let handler = PermissionRequestedEventHandler::create(Box::new(
|
|
|_sender, args| {
|
|
if let Some(args) = args {
|
|
let mut kind = COREWEBVIEW2_PERMISSION_KIND(0);
|
|
unsafe { args.PermissionKind(&mut kind) }?;
|
|
if kind == COREWEBVIEW2_PERMISSION_KIND_MICROPHONE
|
|
|| kind == COREWEBVIEW2_PERMISSION_KIND_CAMERA
|
|
{
|
|
unsafe {
|
|
args.SetState(COREWEBVIEW2_PERMISSION_STATE_ALLOW)
|
|
}?;
|
|
}
|
|
}
|
|
Ok(())
|
|
},
|
|
));
|
|
let mut token = Default::default();
|
|
let _ = unsafe { core.add_PermissionRequested(&handler, &mut token) };
|
|
}
|
|
})?;
|
|
|
|
Ok(())
|
|
})
|
|
.run(context)
|
|
.expect("error while building tauri application");
|
|
}
|