mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-24 11:01:54 +00:00
Add installation_id to panic events
Co-Authored-By: Julia <30666851+ForLoveOfCats@users.noreply.github.com>
This commit is contained in:
parent
af8671cf7f
commit
7d065fa14e
2 changed files with 30 additions and 37 deletions
|
@ -1,5 +1,4 @@
|
||||||
use crate::{TelemetrySettings, ZED_SECRET_CLIENT_TOKEN, ZED_SERVER_URL};
|
use crate::{TelemetrySettings, ZED_SECRET_CLIENT_TOKEN, ZED_SERVER_URL};
|
||||||
use db::kvp::KEY_VALUE_STORE;
|
|
||||||
use gpui::{executor::Background, serde_json, AppContext, Task};
|
use gpui::{executor::Background, serde_json, AppContext, Task};
|
||||||
use lazy_static::lazy_static;
|
use lazy_static::lazy_static;
|
||||||
use parking_lot::Mutex;
|
use parking_lot::Mutex;
|
||||||
|
@ -8,7 +7,6 @@ use std::{env, io::Write, mem, path::PathBuf, sync::Arc, time::Duration};
|
||||||
use tempfile::NamedTempFile;
|
use tempfile::NamedTempFile;
|
||||||
use util::http::HttpClient;
|
use util::http::HttpClient;
|
||||||
use util::{channel::ReleaseChannel, TryFutureExt};
|
use util::{channel::ReleaseChannel, TryFutureExt};
|
||||||
use uuid::Uuid;
|
|
||||||
|
|
||||||
pub struct Telemetry {
|
pub struct Telemetry {
|
||||||
http_client: Arc<dyn HttpClient>,
|
http_client: Arc<dyn HttpClient>,
|
||||||
|
@ -120,39 +118,15 @@ impl Telemetry {
|
||||||
Some(self.state.lock().log_file.as_ref()?.path().to_path_buf())
|
Some(self.state.lock().log_file.as_ref()?.path().to_path_buf())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn start(self: &Arc<Self>) {
|
pub fn start(self: &Arc<Self>, installation_id: Option<String>) {
|
||||||
let this = self.clone();
|
let mut state = self.state.lock();
|
||||||
self.executor
|
state.installation_id = installation_id.map(|id| id.into());
|
||||||
.spawn(
|
let has_clickhouse_events = !state.clickhouse_events_queue.is_empty();
|
||||||
async move {
|
drop(state);
|
||||||
let installation_id =
|
|
||||||
if let Ok(Some(installation_id)) = KEY_VALUE_STORE.read_kvp("device_id") {
|
|
||||||
installation_id
|
|
||||||
} else {
|
|
||||||
let installation_id = Uuid::new_v4().to_string();
|
|
||||||
KEY_VALUE_STORE
|
|
||||||
.write_kvp("device_id".to_string(), installation_id.clone())
|
|
||||||
.await?;
|
|
||||||
installation_id
|
|
||||||
};
|
|
||||||
|
|
||||||
let installation_id: Arc<str> = installation_id.into();
|
if has_clickhouse_events {
|
||||||
let mut state = this.state.lock();
|
self.flush_clickhouse_events();
|
||||||
state.installation_id = Some(installation_id.clone());
|
}
|
||||||
|
|
||||||
let has_clickhouse_events = !state.clickhouse_events_queue.is_empty();
|
|
||||||
|
|
||||||
drop(state);
|
|
||||||
|
|
||||||
if has_clickhouse_events {
|
|
||||||
this.flush_clickhouse_events();
|
|
||||||
}
|
|
||||||
|
|
||||||
anyhow::Ok(())
|
|
||||||
}
|
|
||||||
.log_err(),
|
|
||||||
)
|
|
||||||
.detach();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// This method takes the entire TelemetrySettings struct in order to force client code
|
/// This method takes the entire TelemetrySettings struct in order to force client code
|
||||||
|
|
|
@ -48,6 +48,7 @@ use util::{
|
||||||
http::{self, HttpClient},
|
http::{self, HttpClient},
|
||||||
paths::PathLikeWithPosition,
|
paths::PathLikeWithPosition,
|
||||||
};
|
};
|
||||||
|
use uuid::Uuid;
|
||||||
use welcome::{show_welcome_experience, FIRST_OPEN};
|
use welcome::{show_welcome_experience, FIRST_OPEN};
|
||||||
|
|
||||||
use fs::RealFs;
|
use fs::RealFs;
|
||||||
|
@ -68,7 +69,8 @@ fn main() {
|
||||||
log::info!("========== starting zed ==========");
|
log::info!("========== starting zed ==========");
|
||||||
let mut app = gpui::App::new(Assets).unwrap();
|
let mut app = gpui::App::new(Assets).unwrap();
|
||||||
|
|
||||||
init_panic_hook(&app);
|
let installation_id = app.background().block(installation_id()).ok();
|
||||||
|
init_panic_hook(&app, installation_id.clone());
|
||||||
|
|
||||||
app.background();
|
app.background();
|
||||||
|
|
||||||
|
@ -169,7 +171,7 @@ fn main() {
|
||||||
})
|
})
|
||||||
.detach();
|
.detach();
|
||||||
|
|
||||||
client.telemetry().start();
|
client.telemetry().start(installation_id);
|
||||||
|
|
||||||
let app_state = Arc::new(AppState {
|
let app_state = Arc::new(AppState {
|
||||||
languages,
|
languages,
|
||||||
|
@ -269,6 +271,20 @@ fn main() {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async fn installation_id() -> Result<String> {
|
||||||
|
if let Ok(Some(installation_id)) = KEY_VALUE_STORE.read_kvp("device_id") {
|
||||||
|
Ok(installation_id)
|
||||||
|
} else {
|
||||||
|
let installation_id = Uuid::new_v4().to_string();
|
||||||
|
|
||||||
|
KEY_VALUE_STORE
|
||||||
|
.write_kvp("device_id".to_string(), installation_id.clone())
|
||||||
|
.await?;
|
||||||
|
|
||||||
|
Ok(installation_id)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
fn open_urls(
|
fn open_urls(
|
||||||
urls: Vec<String>,
|
urls: Vec<String>,
|
||||||
cli_connections_tx: &mpsc::UnboundedSender<(
|
cli_connections_tx: &mpsc::UnboundedSender<(
|
||||||
|
@ -372,6 +388,8 @@ struct Panic {
|
||||||
os_version: Option<String>,
|
os_version: Option<String>,
|
||||||
architecture: String,
|
architecture: String,
|
||||||
panicked_on: u128,
|
panicked_on: u128,
|
||||||
|
#[serde(skip_serializing_if = "Option::is_none")]
|
||||||
|
installation_id: Option<String>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Serialize)]
|
#[derive(Serialize)]
|
||||||
|
@ -380,7 +398,7 @@ struct PanicRequest {
|
||||||
token: String,
|
token: String,
|
||||||
}
|
}
|
||||||
|
|
||||||
fn init_panic_hook(app: &App) {
|
fn init_panic_hook(app: &App, installation_id: Option<String>) {
|
||||||
let is_pty = stdout_is_a_pty();
|
let is_pty = stdout_is_a_pty();
|
||||||
let platform = app.platform();
|
let platform = app.platform();
|
||||||
|
|
||||||
|
@ -433,6 +451,7 @@ fn init_panic_hook(app: &App) {
|
||||||
.unwrap()
|
.unwrap()
|
||||||
.as_millis(),
|
.as_millis(),
|
||||||
backtrace,
|
backtrace,
|
||||||
|
installation_id: installation_id.clone(),
|
||||||
};
|
};
|
||||||
|
|
||||||
if is_pty {
|
if is_pty {
|
||||||
|
|
Loading…
Reference in a new issue