df2f3d340f
* fix popularity contest * more info in the Debug for Web3Rpc * add frontend_requests and cache_misses to the Balance query * add more to balance and stats flushing and improved test coverage * it compiles * deserializer for Ulid to Uuid I think a wrapper type on Ulid that implements sea_orm::Value is probably better * rename variable to match struct name * add deserializer for Address -> Vec<u8> * sql sum returns a Decimal. need to convert to u64 * assert more * one log and assert more * log more * use a helper to get the user's rpc provider * this should be 2 now that we have a public and authed call * this should be zero. the public has the cache miss * instrument cu calcs * trace the value we took, not the default that replaced it * move usd_per_chain into config * remove some extra logging * use Arc::into_inner to maybe avoid a race * off by 1 * pass paid credits used instead of returning it this lets us use it to write to our user balance cache first. importantly, this keeps us from holding a write lock while writing to mysql * no cache misses expected in this test * actually check the admin * put the balance checks back now that the rest of the test works * archive request is being set incorrectly * wow howd we manage flipping the greater than sign on archive depth * move latest_balance and premium_credits_used to before any stats are emitted * lint * and build undoes the linting. fun i didnt even want to lint them in the first place, so this is fine * missed incrementing total_spent when not incrementing total_spent_paid_credits * use the credits on self * use the credits on self (pt 2) * fix type for 10 cu query * convert the requestmetadata on the other side of the channel * logs * viewing stats is allowed even without a balance * move paid_credits_used to AuthorizationChecks * wip * test_sum_credits_used finally passes * UserBalanceCache::get_or_insert * re-enable rpc_secret_key_cache * move invalidate to a helper function and always call it **after** the db is commited * fix PartialEq and Eq on RpcSecretKey * cargo upgrade
66 lines
1.4 KiB
Rust
66 lines
1.4 KiB
Rust
use axum::headers::authorization::Bearer;
|
|
use migration::sea_orm::prelude::Uuid;
|
|
use serde::{Deserialize, Serialize};
|
|
use std::fmt;
|
|
use std::str::FromStr;
|
|
use ulid::Ulid;
|
|
|
|
/// Key used for caching the user's login
|
|
#[derive(Copy, Clone, Debug, Deserialize, Hash, PartialEq, Eq, Serialize)]
|
|
#[serde(transparent)]
|
|
pub struct UserBearerToken(pub Ulid);
|
|
|
|
impl UserBearerToken {
|
|
pub fn redis_key(&self) -> String {
|
|
format!("bearer:{}", self.0)
|
|
}
|
|
|
|
pub fn uuid(&self) -> Uuid {
|
|
Uuid::from_u128(self.0.into())
|
|
}
|
|
}
|
|
|
|
impl Default for UserBearerToken {
|
|
fn default() -> Self {
|
|
Self(Ulid::new())
|
|
}
|
|
}
|
|
|
|
impl FromStr for UserBearerToken {
|
|
type Err = ulid::DecodeError;
|
|
|
|
fn from_str(s: &str) -> Result<Self, Self::Err> {
|
|
let ulid = Ulid::from_str(s)?;
|
|
|
|
Ok(Self(ulid))
|
|
}
|
|
}
|
|
|
|
impl From<Ulid> for UserBearerToken {
|
|
fn from(x: Ulid) -> Self {
|
|
Self(x)
|
|
}
|
|
}
|
|
|
|
impl From<UserBearerToken> for Uuid {
|
|
fn from(x: UserBearerToken) -> Self {
|
|
x.uuid()
|
|
}
|
|
}
|
|
|
|
impl fmt::Display for UserBearerToken {
|
|
fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
|
|
self.0.fmt(f)
|
|
}
|
|
}
|
|
|
|
impl TryFrom<Bearer> for UserBearerToken {
|
|
type Error = ulid::DecodeError;
|
|
|
|
fn try_from(b: Bearer) -> Result<Self, ulid::DecodeError> {
|
|
let u = Ulid::from_string(b.token())?;
|
|
|
|
Ok(UserBearerToken(u))
|
|
}
|
|
}
|