mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-27 12:54:42 +00:00
Allow rpc client to connect to an in-memory stream
Co-Authored-By: Nathan Sobo <nathan@zed.dev>
This commit is contained in:
parent
8b58c165a7
commit
b2aa961b4f
1 changed files with 37 additions and 40 deletions
|
@ -1,5 +1,6 @@
|
||||||
use crate::{language::LanguageRegistry, worktree::Worktree};
|
use crate::{language::LanguageRegistry, worktree::Worktree};
|
||||||
use anyhow::{anyhow, Context, Result};
|
use anyhow::{anyhow, Context, Result};
|
||||||
|
use async_tungstenite::tungstenite::{Error as WebSocketError, Message as WebSocketMessage};
|
||||||
use gpui::executor::Background;
|
use gpui::executor::Background;
|
||||||
use gpui::{AsyncAppContext, ModelHandle, Task, WeakModelHandle};
|
use gpui::{AsyncAppContext, ModelHandle, Task, WeakModelHandle};
|
||||||
use lazy_static::lazy_static;
|
use lazy_static::lazy_static;
|
||||||
|
@ -85,24 +86,8 @@ impl Client {
|
||||||
}
|
}
|
||||||
|
|
||||||
let (user_id, access_token) = Self::login(cx.platform(), &cx.background()).await?;
|
let (user_id, access_token) = Self::login(cx.platform(), &cx.background()).await?;
|
||||||
self.connect(
|
let user_id = user_id.parse()?;
|
||||||
&ZED_SERVER_URL,
|
if let Some(host) = ZED_SERVER_URL.strip_prefix("https://") {
|
||||||
user_id.parse()?,
|
|
||||||
access_token,
|
|
||||||
&cx.background(),
|
|
||||||
)
|
|
||||||
.await?;
|
|
||||||
Ok(())
|
|
||||||
}
|
|
||||||
|
|
||||||
pub async fn connect(
|
|
||||||
&self,
|
|
||||||
server_url: &str,
|
|
||||||
user_id: i32,
|
|
||||||
access_token: String,
|
|
||||||
executor: &Arc<Background>,
|
|
||||||
) -> surf::Result<()> {
|
|
||||||
let connection_id = if let Some(host) = server_url.strip_prefix("https://") {
|
|
||||||
let stream = smol::net::TcpStream::connect(host).await?;
|
let stream = smol::net::TcpStream::connect(host).await?;
|
||||||
let (stream, _) = async_tungstenite::async_tls::client_async_tls(
|
let (stream, _) = async_tungstenite::async_tls::client_async_tls(
|
||||||
format!("wss://{}/rpc", host),
|
format!("wss://{}/rpc", host),
|
||||||
|
@ -110,34 +95,46 @@ impl Client {
|
||||||
)
|
)
|
||||||
.await
|
.await
|
||||||
.context("websocket handshake")?;
|
.context("websocket handshake")?;
|
||||||
log::info!("connected to rpc address {}", &*ZED_SERVER_URL);
|
log::info!("connected to rpc address {}", *ZED_SERVER_URL);
|
||||||
let (connection_id, handler) = self.peer.add_connection(stream).await;
|
self.add_connection(stream, user_id, access_token, &cx.background())
|
||||||
executor
|
.await?;
|
||||||
.spawn(async move {
|
} else if let Some(host) = ZED_SERVER_URL.strip_prefix("http://") {
|
||||||
if let Err(error) = handler.run().await {
|
|
||||||
log::error!("connection error: {:?}", error);
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.detach();
|
|
||||||
connection_id
|
|
||||||
} else if let Some(host) = server_url.strip_prefix("http://") {
|
|
||||||
let stream = smol::net::TcpStream::connect(host).await?;
|
let stream = smol::net::TcpStream::connect(host).await?;
|
||||||
let (stream, _) =
|
let (stream, _) =
|
||||||
async_tungstenite::client_async(format!("ws://{}/rpc", host), stream).await?;
|
async_tungstenite::client_async(format!("ws://{}/rpc", host), stream).await?;
|
||||||
log::info!("connected to rpc address {}", &*ZED_SERVER_URL);
|
log::info!("connected to rpc address {}", *ZED_SERVER_URL);
|
||||||
let (connection_id, handler) = self.peer.add_connection(stream).await;
|
self.add_connection(stream, user_id, access_token, &cx.background())
|
||||||
executor
|
.await?;
|
||||||
.spawn(async move {
|
|
||||||
if let Err(error) = handler.run().await {
|
|
||||||
log::error!("connection error: {:?}", error);
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.detach();
|
|
||||||
connection_id
|
|
||||||
} else {
|
} else {
|
||||||
return Err(anyhow!("invalid server url: {}", server_url))?;
|
return Err(anyhow!("invalid server url: {}", *ZED_SERVER_URL))?;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
pub async fn add_connection<Conn>(
|
||||||
|
&self,
|
||||||
|
conn: Conn,
|
||||||
|
user_id: i32,
|
||||||
|
access_token: String,
|
||||||
|
executor: &Arc<Background>,
|
||||||
|
) -> surf::Result<()>
|
||||||
|
where
|
||||||
|
Conn: 'static
|
||||||
|
+ futures::Sink<WebSocketMessage, Error = WebSocketError>
|
||||||
|
+ futures::Stream<Item = Result<WebSocketMessage, WebSocketError>>
|
||||||
|
+ Unpin
|
||||||
|
+ Send,
|
||||||
|
{
|
||||||
|
let (connection_id, handler) = self.peer.add_connection(conn).await;
|
||||||
|
executor
|
||||||
|
.spawn(async move {
|
||||||
|
if let Err(error) = handler.run().await {
|
||||||
|
log::error!("connection error: {:?}", error);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.detach();
|
||||||
|
|
||||||
let auth_response = self
|
let auth_response = self
|
||||||
.peer
|
.peer
|
||||||
.request(
|
.request(
|
||||||
|
|
Loading…
Reference in a new issue