Merge pull request #883 from Kingtous/flutter_desktop

opt: add prefix identifier for each session & fix close and a read write error
This commit is contained in:
RustDesk 2022-06-28 23:27:15 +08:00 committed by GitHub
commit 4158a2d50e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 50 additions and 15 deletions

View File

@ -2,9 +2,13 @@ import 'dart:convert';
import 'dart:math'; import 'dart:math';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_hbb/common.dart';
import 'package:flutter_hbb/desktop/pages/remote_page.dart'; import 'package:flutter_hbb/desktop/pages/remote_page.dart';
import 'package:flutter_hbb/desktop/widgets/titlebar_widget.dart'; import 'package:flutter_hbb/desktop/widgets/titlebar_widget.dart';
import 'package:flutter_hbb/utils/multi_window_manager.dart'; import 'package:flutter_hbb/utils/multi_window_manager.dart';
import 'package:get/get.dart';
import '../../models/model.dart';
class ConnectionTabPage extends StatefulWidget { class ConnectionTabPage extends StatefulWidget {
final Map<String, dynamic> params; final Map<String, dynamic> params;
@ -51,6 +55,15 @@ class _ConnectionTabPageState extends State<ConnectionTabPage>
}); });
} }
}); });
} else if (call.method == "onDestroy") {
print("executing onDestroy hook, closing ${connectionIds}");
connectionIds.forEach((id) {
final tag = '${id}';
ffi(tag).close().then((_) {
Get.delete<FFI>(tag: tag);
});
});
Get.back();
} }
}); });
} }

View File

@ -2,8 +2,10 @@ import 'dart:convert';
import 'dart:math'; import 'dart:math';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_hbb/common.dart';
import 'package:flutter_hbb/desktop/pages/file_manager_page.dart'; import 'package:flutter_hbb/desktop/pages/file_manager_page.dart';
import 'package:flutter_hbb/desktop/widgets/titlebar_widget.dart'; import 'package:flutter_hbb/desktop/widgets/titlebar_widget.dart';
import 'package:flutter_hbb/models/model.dart';
import 'package:flutter_hbb/utils/multi_window_manager.dart'; import 'package:flutter_hbb/utils/multi_window_manager.dart';
import 'package:get/get.dart'; import 'package:get/get.dart';
@ -21,7 +23,7 @@ class _FileManagerTabPageState extends State<FileManagerTabPage>
with SingleTickerProviderStateMixin { with SingleTickerProviderStateMixin {
// refactor List<int> when using multi-tab // refactor List<int> when using multi-tab
// this singleton is only for test // this singleton is only for test
List<String> connectionIds = List.empty(growable: true); var connectionIds = List<String>.empty(growable: true).obs;
var initialIndex = 0.obs; var initialIndex = 0.obs;
_FileManagerTabPageState(Map<String, dynamic> params) { _FileManagerTabPageState(Map<String, dynamic> params) {
@ -47,6 +49,15 @@ class _FileManagerTabPageState extends State<FileManagerTabPage>
connectionIds.add(id); connectionIds.add(id);
initialIndex.value = connectionIds.length - 1; initialIndex.value = connectionIds.length - 1;
} }
} else if (call.method == "onDestroy") {
print("executing onDestroy hook, closing ${connectionIds}");
connectionIds.forEach((id) {
final tag = 'ft_${id}';
ffi(tag).close().then((_) {
Get.delete<FFI>(tag: tag);
});
});
Get.back();
} }
}); });
} }

View File

@ -924,6 +924,7 @@ class FFI {
imageModel._id = id; imageModel._id = id;
cursorModel.id = id; cursorModel.id = id;
} }
id = isFileTransfer ? 'ft_${id}' : id;
final stream = bind.sessionConnect(id: id, isFileTransfer: isFileTransfer); final stream = bind.sessionConnect(id: id, isFileTransfer: isFileTransfer);
final cb = ffiModel.startEventListener(id); final cb = ffiModel.startEventListener(id);
() async { () async {
@ -954,10 +955,10 @@ class FFI {
} }
/// Close the remote session. /// Close the remote session.
void close() { Future<void> close() async {
chatModel.close(); chatModel.close();
if (imageModel.image != null && !isWebDesktop) { if (imageModel.image != null && !isWebDesktop) {
savePreference(id, cursorModel.x, cursorModel.y, canvasModel.x, await savePreference(id, cursorModel.x, cursorModel.y, canvasModel.x,
canvasModel.y, canvasModel.scale, ffiModel.pi.currentDisplay); canvasModel.y, canvasModel.scale, ffiModel.pi.currentDisplay);
} }
bind.sessionClose(id: id); bind.sessionClose(id: id);
@ -1085,8 +1086,8 @@ class PeerInfo {
List<Display> displays = []; List<Display> displays = [];
} }
void savePreference(String id, double xCursor, double yCursor, double xCanvas, Future<void> savePreference(String id, double xCursor, double yCursor,
double yCanvas, double scale, int currentDisplay) async { double xCanvas, double yCanvas, double scale, int currentDisplay) async {
SharedPreferences prefs = await SharedPreferences.getInstance(); SharedPreferences prefs = await SharedPreferences.getInstance();
final p = Map<String, dynamic>(); final p = Map<String, dynamic>();
p['xCursor'] = xCursor; p['xCursor'] = xCursor;

View File

@ -62,7 +62,7 @@ dependencies:
desktop_multi_window: desktop_multi_window:
git: git:
url: https://github.com/Kingtous/rustdesk_desktop_multi_window url: https://github.com/Kingtous/rustdesk_desktop_multi_window
ref: c7d97cb6615f2def34f8bad4def01af9e0077beb ref: 7b72918710921f5fe79eae2dbaa411a66f5dfb45
# bitsdojo_window: ^0.1.2 # bitsdojo_window: ^0.1.2
freezed_annotation: ^2.0.3 freezed_annotation: ^2.0.3
tray_manager: 0.1.7 tray_manager: 0.1.7

View File

@ -1,5 +1,5 @@
use crate::common::make_fd_to_json;
use crate::{client::*, flutter_ffi::EventToUI}; use crate::{client::*, flutter_ffi::EventToUI};
use crate::common::{make_fd_to_json};
use flutter_rust_bridge::{StreamSink, ZeroCopyBuffer}; use flutter_rust_bridge::{StreamSink, ZeroCopyBuffer};
use hbb_common::{ use hbb_common::{
allow_err, allow_err,
@ -49,16 +49,17 @@ impl Session {
/// ///
/// # Arguments /// # Arguments
/// ///
/// * `id` - The id of the remote session. /// * `id` - The identifier of the remote session with prefix. Regex: [\w]*[\_]*[\d]+
/// * `is_file_transfer` - If the session is used for file transfer. /// * `is_file_transfer` - If the session is used for file transfer.
pub fn start(id: &str, is_file_transfer: bool, events2ui: StreamSink<EventToUI>) { pub fn start(identifier: &str, is_file_transfer: bool, events2ui: StreamSink<EventToUI>) {
LocalConfig::set_remote_id(&id); LocalConfig::set_remote_id(&identifier);
// TODO check same id // TODO check same id
let session_id = get_session_id(identifier.to_owned());
// TODO close // TODO close
// Self::close(); // Self::close();
let events2ui = Arc::new(RwLock::new(events2ui)); let events2ui = Arc::new(RwLock::new(events2ui));
let mut session = Session { let mut session = Session {
id: id.to_owned(), id: session_id.clone(),
sender: Default::default(), sender: Default::default(),
lc: Default::default(), lc: Default::default(),
events2ui, events2ui,
@ -67,11 +68,11 @@ impl Session {
.lc .lc
.write() .write()
.unwrap() .unwrap()
.initialize(id.to_owned(), false, false); .initialize(session_id.clone(), is_file_transfer, false);
SESSIONS SESSIONS
.write() .write()
.unwrap() .unwrap()
.insert(id.to_owned(), session.clone()); .insert(identifier.to_owned(), session.clone());
std::thread::spawn(move || { std::thread::spawn(move || {
Connection::start(session, is_file_transfer); Connection::start(session, is_file_transfer);
}); });
@ -179,7 +180,6 @@ impl Session {
/// Close the session. /// Close the session.
pub fn close(&self) { pub fn close(&self) {
self.send(Data::Close); self.send(Data::Close);
let _ = SESSIONS.write().unwrap().remove(&self.id);
} }
/// Reconnect to the current session. /// Reconnect to the current session.
@ -1659,3 +1659,12 @@ pub mod connection_manager {
} }
} }
} }
#[inline]
pub fn get_session_id(id: String) -> String {
return if let Some(index) = id.find('_') {
id[index + 1..].to_string()
} else {
id
};
}

View File

@ -1,7 +1,7 @@
use crate::client::file_trait::FileManager; use crate::client::file_trait::FileManager;
use crate::common::make_fd_to_json;
use crate::flutter::connection_manager::{self, get_clients_length, get_clients_state}; use crate::flutter::connection_manager::{self, get_clients_length, get_clients_state};
use crate::flutter::{self, Session, SESSIONS}; use crate::flutter::{self, Session, SESSIONS};
use crate::common::make_fd_to_json;
use crate::start_server; use crate::start_server;
use crate::ui_interface; use crate::ui_interface;
use flutter_rust_bridge::{StreamSink, SyncReturn, ZeroCopyBuffer}; use flutter_rust_bridge::{StreamSink, SyncReturn, ZeroCopyBuffer};
@ -133,6 +133,7 @@ pub fn session_close(id: String) {
if let Some(session) = SESSIONS.read().unwrap().get(&id) { if let Some(session) = SESSIONS.read().unwrap().get(&id) {
session.close(); session.close();
} }
let _ = SESSIONS.write().unwrap().remove(&id);
} }
pub fn session_refresh(id: String) { pub fn session_refresh(id: String) {