client: Don't fetch the authenticated user once we have them (#35385)

This PR makes it so we don't keep fetching the authenticated user once
we have them.

Release Notes:

- N/A
This commit is contained in:
Marshall Bowers 2025-07-30 23:37:02 -04:00 committed by GitHub
parent e1e2775b80
commit b90fd4287f
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -23,17 +23,24 @@ impl CloudUserStore {
}; };
if cloud_client.has_credentials() { if cloud_client.has_credentials() {
if let Some(response) = cloud_client let already_fetched_authenticated_user = this
.read_with(cx, |this, _cx| this.authenticated_user().is_some())
.unwrap_or(false);
if already_fetched_authenticated_user {
// We already fetched the authenticated user; nothing to do.
} else {
let authenticated_user_result = cloud_client
.get_authenticated_user() .get_authenticated_user()
.await .await
.context("failed to fetch authenticated user") .context("failed to fetch authenticated user");
.log_err() if let Some(response) = authenticated_user_result.log_err() {
{
this.update(cx, |this, _cx| { this.update(cx, |this, _cx| {
this.authenticated_user = Some(Arc::new(response.user)); this.authenticated_user = Some(Arc::new(response.user));
}) })
.ok(); .ok();
} }
}
} else { } else {
this.update(cx, |this, _cx| { this.update(cx, |this, _cx| {
this.authenticated_user = None; this.authenticated_user = None;