mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2024-08-30 18:12:39 +00:00
chore: clippy
This commit is contained in:
parent
d50194df25
commit
9472361664
1
frontend/rust-lib/Cargo.lock
generated
1
frontend/rust-lib/Cargo.lock
generated
@ -2148,6 +2148,7 @@ dependencies = [
|
|||||||
"anyhow",
|
"anyhow",
|
||||||
"crossbeam-utils",
|
"crossbeam-utils",
|
||||||
"dotenv",
|
"dotenv",
|
||||||
|
"futures",
|
||||||
"lib-infra",
|
"lib-infra",
|
||||||
"log",
|
"log",
|
||||||
"once_cell",
|
"once_cell",
|
||||||
|
@ -278,11 +278,11 @@ impl ChatCloudService for ChatService {
|
|||||||
limit: u64,
|
limit: u64,
|
||||||
) -> FutureResult<RepeatedChatMessage, FlowyError> {
|
) -> FutureResult<RepeatedChatMessage, FlowyError> {
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
RepeatedChatMessage {
|
Ok(RepeatedChatMessage {
|
||||||
messages: vec![],
|
messages: vec![],
|
||||||
has_more: false,
|
has_more: false,
|
||||||
total: 0,
|
total: 0,
|
||||||
}
|
})
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -293,10 +293,10 @@ impl ChatCloudService for ChatService {
|
|||||||
message_id: i64,
|
message_id: i64,
|
||||||
) -> FutureResult<RepeatedRelatedQuestion, FlowyError> {
|
) -> FutureResult<RepeatedRelatedQuestion, FlowyError> {
|
||||||
FutureResult::new(async move {
|
FutureResult::new(async move {
|
||||||
RepeatedRelatedQuestion {
|
Ok(RepeatedRelatedQuestion {
|
||||||
message_id,
|
message_id,
|
||||||
items: vec![],
|
items: vec![],
|
||||||
}
|
})
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,6 +17,7 @@ crossbeam-utils = "0.8.20"
|
|||||||
log = "0.4.21"
|
log = "0.4.21"
|
||||||
parking_lot.workspace = true
|
parking_lot.workspace = true
|
||||||
lib-infra.workspace = true
|
lib-infra.workspace = true
|
||||||
|
futures.workspace = true
|
||||||
|
|
||||||
|
|
||||||
[dev-dependencies]
|
[dev-dependencies]
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
use crate::core::rpc_object::RpcObject;
|
use crate::core::rpc_object::RpcObject;
|
||||||
|
use crate::core::rpc_peer::ResponsePayload;
|
||||||
use crate::error::{ReadError, RemoteError};
|
use crate::error::{ReadError, RemoteError};
|
||||||
use serde_json::{json, Value};
|
use serde_json::{json, Value as JsonValue};
|
||||||
use std::io::BufRead;
|
use std::io::BufRead;
|
||||||
|
|
||||||
#[derive(Debug, Default)]
|
#[derive(Debug, Default)]
|
||||||
@ -30,7 +31,7 @@ impl MessageReader {
|
|||||||
/// This should not be called directly unless you are writing tests.
|
/// This should not be called directly unless you are writing tests.
|
||||||
#[doc(hidden)]
|
#[doc(hidden)]
|
||||||
pub fn parse(&self, s: &str) -> Result<RpcObject, ReadError> {
|
pub fn parse(&self, s: &str) -> Result<RpcObject, ReadError> {
|
||||||
match serde_json::from_str::<Value>(s) {
|
match serde_json::from_str::<JsonValue>(s) {
|
||||||
Ok(val) => {
|
Ok(val) => {
|
||||||
if !val.is_object() {
|
if !val.is_object() {
|
||||||
Err(ReadError::NotObject(s.to_string()))
|
Err(ReadError::NotObject(s.to_string()))
|
||||||
@ -44,10 +45,10 @@ impl MessageReader {
|
|||||||
}
|
}
|
||||||
|
|
||||||
pub type RequestId = u64;
|
pub type RequestId = u64;
|
||||||
#[derive(Debug, Clone, PartialEq)]
|
#[derive(Debug, Clone)]
|
||||||
/// An RPC call, which may be either a notification or a request.
|
/// An RPC call, which may be either a notification or a request.
|
||||||
pub enum Call<R> {
|
pub enum Call<R> {
|
||||||
Message(Value),
|
Message(JsonValue),
|
||||||
/// An id and an RPC Request
|
/// An id and an RPC Request
|
||||||
Request(RequestId, R),
|
Request(RequestId, R),
|
||||||
/// A malformed request: the request contained an id, but could
|
/// A malformed request: the request contained an id, but could
|
||||||
@ -57,17 +58,17 @@ pub enum Call<R> {
|
|||||||
|
|
||||||
pub trait ResponseParser {
|
pub trait ResponseParser {
|
||||||
type ValueType;
|
type ValueType;
|
||||||
fn parse_response(json: serde_json::Value) -> Result<Self::ValueType, RemoteError>;
|
fn parse_response(payload: JsonValue) -> Result<Self::ValueType, RemoteError>;
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct ChatResponseParser;
|
pub struct ChatResponseParser;
|
||||||
impl ResponseParser for ChatResponseParser {
|
impl ResponseParser for ChatResponseParser {
|
||||||
type ValueType = String;
|
type ValueType = String;
|
||||||
|
|
||||||
fn parse_response(json: Value) -> Result<Self::ValueType, RemoteError> {
|
fn parse_response(json: JsonValue) -> Result<Self::ValueType, RemoteError> {
|
||||||
if json.is_object() {
|
if json.is_object() {
|
||||||
if let Some(message) = json.get("data") {
|
if let Some(data) = json.get("data") {
|
||||||
if let Some(message) = message.as_str() {
|
if let Some(message) = data.as_str() {
|
||||||
return Ok(message.to_string());
|
return Ok(message.to_string());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -78,12 +79,12 @@ impl ResponseParser for ChatResponseParser {
|
|||||||
|
|
||||||
pub struct ChatRelatedQuestionsResponseParser;
|
pub struct ChatRelatedQuestionsResponseParser;
|
||||||
impl ResponseParser for ChatRelatedQuestionsResponseParser {
|
impl ResponseParser for ChatRelatedQuestionsResponseParser {
|
||||||
type ValueType = Vec<Value>;
|
type ValueType = Vec<JsonValue>;
|
||||||
|
|
||||||
fn parse_response(json: Value) -> Result<Self::ValueType, RemoteError> {
|
fn parse_response(json: JsonValue) -> Result<Self::ValueType, RemoteError> {
|
||||||
if json.is_object() {
|
if json.is_object() {
|
||||||
if let Some(message) = json.get("data") {
|
if let Some(data) = json.get("data") {
|
||||||
if let Some(values) = message.as_array() {
|
if let Some(values) = data.as_array() {
|
||||||
return Ok(values.clone());
|
return Ok(values.clone());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -96,7 +97,7 @@ pub struct SimilarityResponseParser;
|
|||||||
impl ResponseParser for SimilarityResponseParser {
|
impl ResponseParser for SimilarityResponseParser {
|
||||||
type ValueType = f64;
|
type ValueType = f64;
|
||||||
|
|
||||||
fn parse_response(json: Value) -> Result<Self::ValueType, RemoteError> {
|
fn parse_response(json: JsonValue) -> Result<Self::ValueType, RemoteError> {
|
||||||
if json.is_object() {
|
if json.is_object() {
|
||||||
if let Some(data) = json.get("data") {
|
if let Some(data) = json.get("data") {
|
||||||
if let Some(score) = data.get("score").and_then(|v| v.as_f64()) {
|
if let Some(score) = data.get("score").and_then(|v| v.as_f64()) {
|
||||||
@ -104,6 +105,7 @@ impl ResponseParser for SimilarityResponseParser {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return Err(RemoteError::InvalidResponse(json));
|
return Err(RemoteError::InvalidResponse(json));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,16 +1,15 @@
|
|||||||
use crate::error::Error;
|
use crate::error::Error;
|
||||||
use crate::manager::WeakSidecarState;
|
use crate::manager::WeakSidecarState;
|
||||||
|
|
||||||
use serde::{Deserialize, Serialize};
|
|
||||||
use serde_json::{json, Value};
|
|
||||||
use std::io::BufReader;
|
|
||||||
|
|
||||||
use std::process::{Child, Stdio};
|
|
||||||
use std::sync::Arc;
|
|
||||||
|
|
||||||
use crate::core::parser::ResponseParser;
|
use crate::core::parser::ResponseParser;
|
||||||
use crate::core::rpc_loop::RpcLoop;
|
use crate::core::rpc_loop::RpcLoop;
|
||||||
|
use crate::core::rpc_peer::{Callback, ResponsePayload};
|
||||||
use anyhow::anyhow;
|
use anyhow::anyhow;
|
||||||
|
use serde::{Deserialize, Serialize};
|
||||||
|
use serde_json::{json, Value as JsonValue};
|
||||||
|
use std::io::BufReader;
|
||||||
|
use std::process::{Child, Stdio};
|
||||||
|
use std::sync::Arc;
|
||||||
use std::thread;
|
use std::thread;
|
||||||
use std::time::Instant;
|
use std::time::Instant;
|
||||||
use tracing::{error, info};
|
use tracing::{error, info};
|
||||||
@ -26,16 +25,6 @@ impl From<i64> for PluginId {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub trait Callback: Send {
|
|
||||||
fn call(self: Box<Self>, result: Result<Value, Error>);
|
|
||||||
}
|
|
||||||
|
|
||||||
impl<F: Send + FnOnce(Result<Value, Error>)> Callback for F {
|
|
||||||
fn call(self: Box<F>, result: Result<Value, Error>) {
|
|
||||||
(*self)(result)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/// The `Peer` trait defines the interface for the opposite side of the RPC channel,
|
/// The `Peer` trait defines the interface for the opposite side of the RPC channel,
|
||||||
/// designed to be used behind a pointer or as a trait object.
|
/// designed to be used behind a pointer or as a trait object.
|
||||||
pub trait Peer: Send + Sync + 'static {
|
pub trait Peer: Send + Sync + 'static {
|
||||||
@ -43,14 +32,14 @@ pub trait Peer: Send + Sync + 'static {
|
|||||||
fn box_clone(&self) -> Arc<dyn Peer>;
|
fn box_clone(&self) -> Arc<dyn Peer>;
|
||||||
|
|
||||||
/// Sends an RPC notification to the peer with the specified method and parameters.
|
/// Sends an RPC notification to the peer with the specified method and parameters.
|
||||||
fn send_rpc_notification(&self, method: &str, params: &Value);
|
fn send_rpc_notification(&self, method: &str, params: &JsonValue);
|
||||||
|
|
||||||
/// Sends an asynchronous RPC request to the peer and executes the provided callback upon completion.
|
/// Sends an asynchronous RPC request to the peer and executes the provided callback upon completion.
|
||||||
fn send_rpc_request_async(&self, method: &str, params: &Value, f: Box<dyn Callback>);
|
fn send_rpc_request_async(&self, method: &str, params: &JsonValue, f: Box<dyn Callback>);
|
||||||
|
|
||||||
/// Sends a synchronous RPC request to the peer and waits for the result.
|
/// Sends a synchronous RPC request to the peer and waits for the result.
|
||||||
/// Returns the result of the request or an error.
|
/// Returns the result of the request or an error.
|
||||||
fn send_rpc_request(&self, method: &str, params: &Value) -> Result<Value, Error>;
|
fn send_rpc_request(&self, method: &str, params: &JsonValue) -> Result<JsonValue, Error>;
|
||||||
|
|
||||||
/// Checks if there is an incoming request pending, intended to reduce latency for bulk operations done in the background.
|
/// Checks if there is an incoming request pending, intended to reduce latency for bulk operations done in the background.
|
||||||
fn request_is_pending(&self) -> bool;
|
fn request_is_pending(&self) -> bool;
|
||||||
@ -77,19 +66,19 @@ pub struct Plugin {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl Plugin {
|
impl Plugin {
|
||||||
pub fn initialize(&self, value: Value) -> Result<(), Error> {
|
pub fn initialize(&self, value: JsonValue) -> Result<(), Error> {
|
||||||
self.peer.send_rpc_request("initialize", &value)?;
|
self.peer.send_rpc_request("initialize", &value)?;
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn send_request(&self, method: &str, params: &Value) -> Result<Value, Error> {
|
pub fn send_request(&self, method: &str, params: &JsonValue) -> Result<JsonValue, Error> {
|
||||||
self.peer.send_rpc_request(method, params)
|
self.peer.send_rpc_request(method, params)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn async_send_request<P: ResponseParser>(
|
pub async fn async_send_request<P: ResponseParser>(
|
||||||
&self,
|
&self,
|
||||||
method: &str,
|
method: &str,
|
||||||
params: &Value,
|
params: &JsonValue,
|
||||||
) -> Result<P::ValueType, Error> {
|
) -> Result<P::ValueType, Error> {
|
||||||
let (tx, rx) = tokio::sync::oneshot::channel();
|
let (tx, rx) = tokio::sync::oneshot::channel();
|
||||||
self.peer.send_rpc_request_async(
|
self.peer.send_rpc_request_async(
|
||||||
@ -140,7 +129,7 @@ pub(crate) async fn start_plugin_process(
|
|||||||
let mut looper = RpcLoop::new(child_stdin);
|
let mut looper = RpcLoop::new(child_stdin);
|
||||||
let peer: RpcPeer = Arc::new(looper.get_raw_peer());
|
let peer: RpcPeer = Arc::new(looper.get_raw_peer());
|
||||||
let name = plugin_info.name.clone();
|
let name = plugin_info.name.clone();
|
||||||
peer.send_rpc_notification("ping", &Value::Array(Vec::new()));
|
peer.send_rpc_notification("ping", &JsonValue::Array(Vec::new()));
|
||||||
|
|
||||||
let plugin = Plugin {
|
let plugin = Plugin {
|
||||||
peer,
|
peer,
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
use crate::core::parser::{Call, MessageReader};
|
use crate::core::parser::{Call, MessageReader};
|
||||||
use crate::core::plugin::RpcCtx;
|
use crate::core::plugin::RpcCtx;
|
||||||
use crate::core::rpc_object::RpcObject;
|
use crate::core::rpc_object::RpcObject;
|
||||||
use crate::core::rpc_peer::{RawPeer, RpcState};
|
use crate::core::rpc_peer::{RawPeer, ResponsePayload, RpcState};
|
||||||
use crate::error::{Error, ReadError, RemoteError};
|
use crate::error::{Error, ReadError, RemoteError};
|
||||||
use serde::de::DeserializeOwned;
|
use serde::de::DeserializeOwned;
|
||||||
use serde_json::Value;
|
use serde_json::Value;
|
||||||
@ -15,7 +15,11 @@ const MAX_IDLE_WAIT: Duration = Duration::from_millis(5);
|
|||||||
|
|
||||||
pub trait Handler {
|
pub trait Handler {
|
||||||
type Request: DeserializeOwned;
|
type Request: DeserializeOwned;
|
||||||
fn handle_request(&mut self, ctx: &RpcCtx, rpc: Self::Request) -> Result<Value, RemoteError>;
|
fn handle_request(
|
||||||
|
&mut self,
|
||||||
|
ctx: &RpcCtx,
|
||||||
|
rpc: Self::Request,
|
||||||
|
) -> Result<ResponsePayload, RemoteError>;
|
||||||
#[allow(unused_variables)]
|
#[allow(unused_variables)]
|
||||||
fn idle(&mut self, ctx: &RpcCtx, token: usize) {}
|
fn idle(&mut self, ctx: &RpcCtx, token: usize) {}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
use crate::core::parser::{Call, RequestId};
|
use crate::core::parser::{Call, RequestId};
|
||||||
use crate::core::rpc_peer::Response;
|
use crate::core::rpc_peer::{Response, ResponsePayload};
|
||||||
use serde::de::{DeserializeOwned, Error};
|
use serde::de::{DeserializeOwned, Error};
|
||||||
use serde_json::Value;
|
use serde_json::Value;
|
||||||
|
|
||||||
@ -39,7 +39,7 @@ impl RpcObject {
|
|||||||
}
|
}
|
||||||
let result = self.0.as_object_mut().and_then(|obj| obj.remove("result"));
|
let result = self.0.as_object_mut().and_then(|obj| obj.remove("result"));
|
||||||
match result {
|
match result {
|
||||||
Some(r) => Ok(Ok(r)),
|
Some(r) => Ok(Ok(ResponsePayload::Json(r))),
|
||||||
None => {
|
None => {
|
||||||
let error = self
|
let error = self
|
||||||
.0
|
.0
|
||||||
|
@ -1,11 +1,14 @@
|
|||||||
use crate::core::plugin::{Callback, Peer, PluginId};
|
use crate::core::plugin::{Peer, PluginId};
|
||||||
use crate::core::rpc_object::RpcObject;
|
use crate::core::rpc_object::RpcObject;
|
||||||
use crate::error::{Error, ReadError, RemoteError};
|
use crate::error::{Error, ReadError, RemoteError};
|
||||||
|
use futures::Stream;
|
||||||
use parking_lot::{Condvar, Mutex};
|
use parking_lot::{Condvar, Mutex};
|
||||||
use serde::{de, ser, Deserialize, Deserializer, Serialize, Serializer};
|
use serde::{de, ser, Deserialize, Deserializer, Serialize, Serializer};
|
||||||
use serde_json::{json, Value};
|
use serde_json::{json, Value as JsonValue};
|
||||||
use std::collections::{BTreeMap, BinaryHeap, VecDeque};
|
use std::collections::{BTreeMap, BinaryHeap, VecDeque};
|
||||||
|
use std::fmt::Display;
|
||||||
use std::io::Write;
|
use std::io::Write;
|
||||||
|
use std::pin::Pin;
|
||||||
use std::sync::atomic::{AtomicBool, AtomicUsize, Ordering};
|
use std::sync::atomic::{AtomicBool, AtomicUsize, Ordering};
|
||||||
use std::sync::{mpsc, Arc};
|
use std::sync::{mpsc, Arc};
|
||||||
use std::time::{Duration, Instant};
|
use std::time::{Duration, Instant};
|
||||||
@ -37,7 +40,7 @@ impl<'de, T: Deserialize<'de>> Deserialize<'de> for PluginCommand<T> {
|
|||||||
struct PluginIdHelper {
|
struct PluginIdHelper {
|
||||||
plugin_id: PluginId,
|
plugin_id: PluginId,
|
||||||
}
|
}
|
||||||
let v = Value::deserialize(deserializer)?;
|
let v = JsonValue::deserialize(deserializer)?;
|
||||||
let plugin_id = PluginIdHelper::deserialize(&v)
|
let plugin_id = PluginIdHelper::deserialize(&v)
|
||||||
.map_err(de::Error::custom)?
|
.map_err(de::Error::custom)?
|
||||||
.plugin_id;
|
.plugin_id;
|
||||||
@ -82,7 +85,7 @@ impl<W: Write + Send + 'static> Peer for RawPeer<W> {
|
|||||||
fn box_clone(&self) -> Arc<dyn Peer> {
|
fn box_clone(&self) -> Arc<dyn Peer> {
|
||||||
Arc::new((*self).clone())
|
Arc::new((*self).clone())
|
||||||
}
|
}
|
||||||
fn send_rpc_notification(&self, method: &str, params: &Value) {
|
fn send_rpc_notification(&self, method: &str, params: &JsonValue) {
|
||||||
if let Err(e) = self.send(&json!({
|
if let Err(e) = self.send(&json!({
|
||||||
"method": method,
|
"method": method,
|
||||||
"params": params,
|
"params": params,
|
||||||
@ -94,11 +97,11 @@ impl<W: Write + Send + 'static> Peer for RawPeer<W> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn send_rpc_request_async(&self, method: &str, params: &Value, f: Box<dyn Callback>) {
|
fn send_rpc_request_async(&self, method: &str, params: &JsonValue, f: Box<dyn Callback>) {
|
||||||
self.send_rpc(method, params, ResponseHandler::Callback(f));
|
self.send_rpc(method, params, ResponseHandler::Callback(f));
|
||||||
}
|
}
|
||||||
|
|
||||||
fn send_rpc_request(&self, method: &str, params: &Value) -> Result<Value, Error> {
|
fn send_rpc_request(&self, method: &str, params: &JsonValue) -> Result<JsonValue, Error> {
|
||||||
let (tx, rx) = mpsc::channel();
|
let (tx, rx) = mpsc::channel();
|
||||||
self.0.is_blocking.store(true, Ordering::Release);
|
self.0.is_blocking.store(true, Ordering::Release);
|
||||||
self.send_rpc(method, params, ResponseHandler::Chan(tx));
|
self.send_rpc(method, params, ResponseHandler::Chan(tx));
|
||||||
@ -119,7 +122,7 @@ impl<W: Write + Send + 'static> Peer for RawPeer<W> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl<W: Write> RawPeer<W> {
|
impl<W: Write> RawPeer<W> {
|
||||||
fn send(&self, v: &Value) -> Result<(), io::Error> {
|
fn send(&self, v: &JsonValue) -> Result<(), io::Error> {
|
||||||
let mut s = serde_json::to_string(v).unwrap();
|
let mut s = serde_json::to_string(v).unwrap();
|
||||||
s.push('\n');
|
s.push('\n');
|
||||||
self.0.writer.lock().write_all(s.as_bytes())
|
self.0.writer.lock().write_all(s.as_bytes())
|
||||||
@ -128,7 +131,12 @@ impl<W: Write> RawPeer<W> {
|
|||||||
pub(crate) fn respond(&self, result: Response, id: u64) {
|
pub(crate) fn respond(&self, result: Response, id: u64) {
|
||||||
let mut response = json!({ "id": id });
|
let mut response = json!({ "id": id });
|
||||||
match result {
|
match result {
|
||||||
Ok(result) => response["result"] = result,
|
Ok(result) => match result {
|
||||||
|
ResponsePayload::Json(value) => response["result"] = value,
|
||||||
|
ResponsePayload::Stream(_) => {
|
||||||
|
error!("stream response not supported")
|
||||||
|
},
|
||||||
|
},
|
||||||
Err(error) => response["error"] = json!(error),
|
Err(error) => response["error"] = json!(error),
|
||||||
};
|
};
|
||||||
if let Err(e) = self.send(&response) {
|
if let Err(e) = self.send(&response) {
|
||||||
@ -136,7 +144,7 @@ impl<W: Write> RawPeer<W> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fn send_rpc(&self, method: &str, params: &Value, rh: ResponseHandler) {
|
fn send_rpc(&self, method: &str, params: &JsonValue, rh: ResponseHandler) {
|
||||||
trace!("[RPC] call method: {} params: {:?}", method, params);
|
trace!("[RPC] call method: {} params: {:?}", method, params);
|
||||||
let id = self.0.id.fetch_add(1, Ordering::Relaxed);
|
let id = self.0.id.fetch_add(1, Ordering::Relaxed);
|
||||||
{
|
{
|
||||||
@ -158,16 +166,22 @@ impl<W: Write> RawPeer<W> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) fn handle_response(&self, id: u64, resp: Result<Value, Error>) {
|
pub(crate) fn handle_response(&self, id: u64, resp: Result<ResponsePayload, Error>) {
|
||||||
let id = id as usize;
|
let id = id as usize;
|
||||||
let handler = {
|
let handler = {
|
||||||
let mut pending = self.0.pending.lock();
|
let mut pending = self.0.pending.lock();
|
||||||
pending.remove(&id)
|
pending.remove(&id)
|
||||||
};
|
};
|
||||||
|
let is_stream = resp.as_ref().map(|resp| resp.is_stream()).unwrap_or(false);
|
||||||
match handler {
|
match handler {
|
||||||
Some(response_handler) => {
|
Some(response_handler) => {
|
||||||
//
|
let json = resp.map(|resp| resp.into_json());
|
||||||
response_handler.invoke(resp)
|
response_handler.invoke(json);
|
||||||
|
|
||||||
|
// if is_stream {
|
||||||
|
// let mut pending = self.0.pending.lock();
|
||||||
|
// pending.insert(id, response_handler);
|
||||||
|
// }
|
||||||
},
|
},
|
||||||
None => warn!("[RPC] id {} not found in pending", id),
|
None => warn!("[RPC] id {} not found in pending", id),
|
||||||
}
|
}
|
||||||
@ -250,18 +264,70 @@ impl<W: Write> Clone for RawPeer<W> {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub struct ResponsePayload {
|
#[derive(Clone, Debug)]
|
||||||
value: Value,
|
pub enum ResponsePayload {
|
||||||
|
Json(JsonValue),
|
||||||
|
Stream(JsonValue),
|
||||||
}
|
}
|
||||||
|
|
||||||
pub type Response = Result<Value, RemoteError>;
|
impl ResponsePayload {
|
||||||
|
pub fn empty_json() -> Self {
|
||||||
|
ResponsePayload::Json(json!({}))
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn is_stream(&self) -> bool {
|
||||||
|
match self {
|
||||||
|
ResponsePayload::Json(_) => false,
|
||||||
|
ResponsePayload::Stream(_) => true,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn json(&self) -> &JsonValue {
|
||||||
|
match self {
|
||||||
|
ResponsePayload::Json(v) => v,
|
||||||
|
ResponsePayload::Stream(v) => v,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn into_json(self) -> JsonValue {
|
||||||
|
match self {
|
||||||
|
ResponsePayload::Json(v) => v,
|
||||||
|
ResponsePayload::Stream(v) => v,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Display for ResponsePayload {
|
||||||
|
fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
|
||||||
|
match self {
|
||||||
|
ResponsePayload::Json(v) => write!(f, "{}", v),
|
||||||
|
ResponsePayload::Stream(_) => write!(f, "stream"),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub type Response = Result<ResponsePayload, RemoteError>;
|
||||||
|
|
||||||
|
pub trait ResponseStream: Stream<Item = Result<JsonValue, Error>> + Unpin + Send {}
|
||||||
|
|
||||||
|
impl<T> ResponseStream for T where T: Stream<Item = Result<JsonValue, Error>> + Unpin + Send {}
|
||||||
|
|
||||||
enum ResponseHandler {
|
enum ResponseHandler {
|
||||||
Chan(mpsc::Sender<Result<Value, Error>>),
|
Chan(mpsc::Sender<Result<JsonValue, Error>>),
|
||||||
Callback(Box<dyn Callback>),
|
Callback(Box<dyn Callback>),
|
||||||
}
|
}
|
||||||
|
pub trait Callback: Send {
|
||||||
|
fn call(self: Box<Self>, result: Result<JsonValue, Error>);
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<F: Send + FnOnce(Result<JsonValue, Error>)> Callback for F {
|
||||||
|
fn call(self: Box<F>, result: Result<JsonValue, Error>) {
|
||||||
|
(*self)(result)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl ResponseHandler {
|
impl ResponseHandler {
|
||||||
fn invoke(self, result: Result<Value, Error>) {
|
fn invoke(self, result: Result<JsonValue, Error>) {
|
||||||
match self {
|
match self {
|
||||||
ResponseHandler::Chan(tx) => {
|
ResponseHandler::Chan(tx) => {
|
||||||
let _ = tx.send(result);
|
let _ = tx.send(result);
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
|
use crate::core::rpc_peer::ResponsePayload;
|
||||||
use serde::{Deserialize, Deserializer, Serialize, Serializer};
|
use serde::{Deserialize, Deserializer, Serialize, Serializer};
|
||||||
use serde_json::{json, Value};
|
use serde_json::{json, Value as JsonValue};
|
||||||
use std::{fmt, io};
|
use std::{fmt, io};
|
||||||
|
|
||||||
/// The error type of `tauri-utils`.
|
/// The error type of `tauri-utils`.
|
||||||
@ -36,30 +37,30 @@ pub enum ReadError {
|
|||||||
Disconnect,
|
Disconnect,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, PartialEq, thiserror::Error)]
|
#[derive(Debug, Clone, thiserror::Error)]
|
||||||
pub enum RemoteError {
|
pub enum RemoteError {
|
||||||
/// The JSON was valid, but was not a correctly formed request.
|
/// The JSON was valid, but was not a correctly formed request.
|
||||||
///
|
///
|
||||||
/// This Error is used internally, and should not be returned by
|
/// This Error is used internally, and should not be returned by
|
||||||
/// clients.
|
/// clients.
|
||||||
#[error("Invalid request: {0:?}")]
|
#[error("Invalid request: {0:?}")]
|
||||||
InvalidRequest(Option<Value>),
|
InvalidRequest(Option<JsonValue>),
|
||||||
|
|
||||||
#[error("Invalid response: {0}")]
|
#[error("Invalid response: {0}")]
|
||||||
InvalidResponse(Value),
|
InvalidResponse(JsonValue),
|
||||||
/// A custom error, defined by the client.
|
/// A custom error, defined by the client.
|
||||||
#[error("Custom error: {message}")]
|
#[error("Custom error: {message}")]
|
||||||
Custom {
|
Custom {
|
||||||
code: i64,
|
code: i64,
|
||||||
message: String,
|
message: String,
|
||||||
data: Option<Value>,
|
data: Option<JsonValue>,
|
||||||
},
|
},
|
||||||
/// An error that cannot be represented by an error object.
|
/// An error that cannot be represented by an error object.
|
||||||
///
|
///
|
||||||
/// This error is intended to accommodate clients that return arbitrary
|
/// This error is intended to accommodate clients that return arbitrary
|
||||||
/// error values. It should not be used for new errors.
|
/// error values. It should not be used for new errors.
|
||||||
#[error("Unknown error: {0}")]
|
#[error("Unknown error: {0}")]
|
||||||
Unknown(Value),
|
Unknown(JsonValue),
|
||||||
}
|
}
|
||||||
|
|
||||||
impl ReadError {
|
impl ReadError {
|
||||||
@ -110,7 +111,7 @@ struct ErrorHelper {
|
|||||||
code: i64,
|
code: i64,
|
||||||
message: String,
|
message: String,
|
||||||
#[serde(skip_serializing_if = "Option::is_none")]
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
data: Option<Value>,
|
data: Option<JsonValue>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'de> Deserialize<'de> for RemoteError {
|
impl<'de> Deserialize<'de> for RemoteError {
|
||||||
@ -118,7 +119,7 @@ impl<'de> Deserialize<'de> for RemoteError {
|
|||||||
where
|
where
|
||||||
D: Deserializer<'de>,
|
D: Deserializer<'de>,
|
||||||
{
|
{
|
||||||
let v = Value::deserialize(deserializer)?;
|
let v = JsonValue::deserialize(deserializer)?;
|
||||||
let resp = match ErrorHelper::deserialize(&v) {
|
let resp = match ErrorHelper::deserialize(&v) {
|
||||||
Ok(resp) => resp,
|
Ok(resp) => resp,
|
||||||
Err(_) => return Ok(RemoteError::Unknown(v)),
|
Err(_) => return Ok(RemoteError::Unknown(v)),
|
||||||
@ -150,7 +151,11 @@ impl Serialize for RemoteError {
|
|||||||
RemoteError::Unknown(_) => {
|
RemoteError::Unknown(_) => {
|
||||||
panic!("The 'Unknown' error variant is not intended for client use.")
|
panic!("The 'Unknown' error variant is not intended for client use.")
|
||||||
},
|
},
|
||||||
RemoteError::InvalidResponse(s) => (-1, "Invalid response".to_string(), Some(s.clone())),
|
RemoteError::InvalidResponse(resp) => (
|
||||||
|
-1,
|
||||||
|
"Invalid response".to_string(),
|
||||||
|
Some(json!(resp.to_string())),
|
||||||
|
),
|
||||||
};
|
};
|
||||||
let err = ErrorHelper {
|
let err = ErrorHelper {
|
||||||
code,
|
code,
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
use crate::core::parser::ResponseParser;
|
use crate::core::parser::ResponseParser;
|
||||||
use crate::core::plugin::{start_plugin_process, Plugin, PluginId, PluginInfo, RpcCtx};
|
use crate::core::plugin::{start_plugin_process, Plugin, PluginId, PluginInfo, RpcCtx};
|
||||||
use crate::core::rpc_loop::Handler;
|
use crate::core::rpc_loop::Handler;
|
||||||
use crate::core::rpc_peer::PluginCommand;
|
use crate::core::rpc_peer::{PluginCommand, ResponsePayload};
|
||||||
use crate::error::{Error, ReadError, RemoteError};
|
use crate::error::{Error, ReadError, RemoteError};
|
||||||
use anyhow::anyhow;
|
use anyhow::anyhow;
|
||||||
use lib_infra::util::{get_operating_system, OperatingSystem};
|
use lib_infra::util::{get_operating_system, OperatingSystem};
|
||||||
@ -176,8 +176,12 @@ impl WeakSidecarState {
|
|||||||
impl Handler for WeakSidecarState {
|
impl Handler for WeakSidecarState {
|
||||||
type Request = PluginCommand<String>;
|
type Request = PluginCommand<String>;
|
||||||
|
|
||||||
fn handle_request(&mut self, _ctx: &RpcCtx, rpc: Self::Request) -> Result<Value, RemoteError> {
|
fn handle_request(
|
||||||
|
&mut self,
|
||||||
|
_ctx: &RpcCtx,
|
||||||
|
rpc: Self::Request,
|
||||||
|
) -> Result<ResponsePayload, RemoteError> {
|
||||||
trace!("handling request: {:?}", rpc.cmd);
|
trace!("handling request: {:?}", rpc.cmd);
|
||||||
Ok(json!({}))
|
Ok(ResponsePayload::empty_json())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user