mirror of
https://github.com/tauri-apps/plugins-workspace.git
synced 2026-04-21 11:26:15 +02:00
fix(deep-link): local machine registry handling (#2483)
* fix(deep-link): local machine registry handling * typo * Wrong version bump * return false if registry open fails --------- Co-authored-by: Lucas Fernandes Nogueira <lucas@tauri.app>
This commit is contained in:
@@ -0,0 +1,6 @@
|
||||
---
|
||||
'deep-link': 'patch:bug'
|
||||
'deep-link-js': 'patch:bug'
|
||||
---
|
||||
|
||||
Fix `is_registered` not being able to pickup deep link registered in `HKEY_LOCAL_MACHINE` on Windows
|
||||
@@ -0,0 +1,6 @@
|
||||
---
|
||||
'deep-link': 'patch:bug'
|
||||
'deep-link-js': 'patch:bug'
|
||||
---
|
||||
|
||||
Fix `unregister` not being able to remove deep link registered in `HKEY_LOCAL_MACHINE` on Windows
|
||||
@@ -172,7 +172,7 @@ mod imp {
|
||||
use tauri::Manager;
|
||||
use tauri::{AppHandle, Runtime};
|
||||
#[cfg(windows)]
|
||||
use windows_registry::CURRENT_USER;
|
||||
use windows_registry::{CLASSES_ROOT, CURRENT_USER, LOCAL_MACHINE};
|
||||
|
||||
/// Access to the deep-link APIs.
|
||||
pub struct DeepLink<R: Runtime> {
|
||||
@@ -258,7 +258,8 @@ mod imp {
|
||||
pub fn register<S: AsRef<str>>(&self, _protocol: S) -> crate::Result<()> {
|
||||
#[cfg(windows)]
|
||||
{
|
||||
let key_base = format!("Software\\Classes\\{}", _protocol.as_ref());
|
||||
let protocol = _protocol.as_ref();
|
||||
let key_base = format!("Software\\Classes\\{protocol}");
|
||||
|
||||
let exe = dunce::simplified(&tauri::utils::platform::current_exe()?)
|
||||
.display()
|
||||
@@ -348,13 +349,21 @@ mod imp {
|
||||
///
|
||||
/// ## Platform-specific:
|
||||
///
|
||||
/// - **Windows**: Requires admin rights if the protocol is registered on local machine
|
||||
/// (this can happen when registered from the NSIS installer when the install mode is set to both or per machine)
|
||||
/// - **Linux**: Can only unregister the scheme if it was initially registered with [`register`](`Self::register`). May not work on older distros.
|
||||
/// - **macOS / Android / iOS**: Unsupported, will return [`Error::UnsupportedPlatform`](`crate::Error::UnsupportedPlatform`).
|
||||
pub fn unregister<S: AsRef<str>>(&self, _protocol: S) -> crate::Result<()> {
|
||||
#[cfg(windows)]
|
||||
{
|
||||
CURRENT_USER.remove_tree(format!("Software\\Classes\\{}", _protocol.as_ref()))?;
|
||||
|
||||
let protocol = _protocol.as_ref();
|
||||
let path = format!("Software\\Classes\\{protocol}");
|
||||
if LOCAL_MACHINE.open(&path).is_ok() {
|
||||
LOCAL_MACHINE.remove_tree(&path)?;
|
||||
}
|
||||
if CURRENT_USER.open(&path).is_ok() {
|
||||
CURRENT_USER.remove_tree(&path)?;
|
||||
}
|
||||
Ok(())
|
||||
}
|
||||
|
||||
@@ -398,10 +407,11 @@ mod imp {
|
||||
pub fn is_registered<S: AsRef<str>>(&self, _protocol: S) -> crate::Result<bool> {
|
||||
#[cfg(windows)]
|
||||
{
|
||||
let cmd_reg = CURRENT_USER.open(format!(
|
||||
"Software\\Classes\\{}\\shell\\open\\command",
|
||||
_protocol.as_ref()
|
||||
))?;
|
||||
let protocol = _protocol.as_ref();
|
||||
let Ok(cmd_reg) = CLASSES_ROOT.open(format!("{protocol}\\shell\\open\\command"))
|
||||
else {
|
||||
return Ok(false);
|
||||
};
|
||||
|
||||
let registered_cmd = cmd_reg.get_string("")?;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user