Browse Source

Merge branch 'BlackDex-add-avatar-color-feature'

pull/3151/head
Daniel García 2 years ago
parent
commit
174bea8d6e
No known key found for this signature in database GPG Key ID: FC8A7D14C3CD543A
  1. 0
      migrations/mysql/2023-01-11-205851_add_avatar_color/down.sql
  2. 2
      migrations/mysql/2023-01-11-205851_add_avatar_color/up.sql
  3. 0
      migrations/postgresql/2023-01-11-205851_add_avatar_color/down.sql
  4. 2
      migrations/postgresql/2023-01-11-205851_add_avatar_color/up.sql
  5. 0
      migrations/sqlite/2023-01-11-205851_add_avatar_color/down.sql
  6. 2
      migrations/sqlite/2023-01-11-205851_add_avatar_color/up.sql
  7. 27
      src/api/core/accounts.rs
  8. 5
      src/db/models/user.rs
  9. 1
      src/db/schemas/mysql/schema.rs
  10. 1
      src/db/schemas/postgresql/schema.rs
  11. 1
      src/db/schemas/sqlite/schema.rs
  12. 2
      src/main.rs

0
migrations/mysql/2023-01-11-205851_add_avatar_color/down.sql

2
migrations/mysql/2023-01-11-205851_add_avatar_color/up.sql

@ -0,0 +1,2 @@
ALTER TABLE users
ADD COLUMN avatar_color VARCHAR(7);

0
migrations/postgresql/2023-01-11-205851_add_avatar_color/down.sql

2
migrations/postgresql/2023-01-11-205851_add_avatar_color/up.sql

@ -0,0 +1,2 @@
ALTER TABLE users
ADD COLUMN avatar_color TEXT;

0
migrations/sqlite/2023-01-11-205851_add_avatar_color/down.sql

2
migrations/sqlite/2023-01-11-205851_add_avatar_color/up.sql

@ -0,0 +1,2 @@
ALTER TABLE users
ADD COLUMN avatar_color TEXT;

27
src/api/core/accounts.rs

@ -39,6 +39,7 @@ pub fn routes() -> Vec<rocket::Route> {
api_key,
rotate_api_key,
get_known_device,
put_avatar,
]
}
@ -228,6 +229,32 @@ async fn post_profile(data: JsonUpcase<ProfileData>, headers: Headers, mut conn:
Ok(Json(user.to_json(&mut conn).await))
}
#[derive(Deserialize)]
#[allow(non_snake_case)]
struct AvatarData {
AvatarColor: Option<String>,
}
#[put("/accounts/avatar", data = "<data>")]
async fn put_avatar(data: JsonUpcase<AvatarData>, headers: Headers, mut conn: DbConn) -> JsonResult {
let data: AvatarData = data.into_inner().data;
// It looks like it only supports the 6 hex color format.
// If you try to add the short value it will not show that color.
// Check and force 7 chars, including the #.
if let Some(color) = &data.AvatarColor {
if color.len() != 7 {
err!("The field AvatarColor must be a HTML/Hex color code with a length of 7 characters")
}
}
let mut user = headers.user;
user.avatar_color = data.AvatarColor;
user.save(&mut conn).await?;
Ok(Json(user.to_json(&mut conn).await))
}
#[get("/users/<uuid>/public-key")]
async fn get_public_keys(uuid: String, _headers: Headers, mut conn: DbConn) -> JsonResult {
let user = match User::find_by_uuid(&uuid, &mut conn).await {

5
src/db/models/user.rs

@ -46,6 +46,8 @@ db_object! {
pub client_kdf_iter: i32,
pub api_key: Option<String>,
pub avatar_color: Option<String>,
}
#[derive(Identifiable, Queryable, Insertable)]
@ -113,6 +115,8 @@ impl User {
client_kdf_iter: Self::CLIENT_KDF_ITER_DEFAULT,
api_key: None,
avatar_color: None,
}
}
@ -226,6 +230,7 @@ impl User {
"Providers": [],
"ProviderOrganizations": [],
"ForcePasswordReset": false,
"AvatarColor": self.avatar_color,
"Object": "profile",
})
}

1
src/db/schemas/mysql/schema.rs

@ -200,6 +200,7 @@ table! {
client_kdf_type -> Integer,
client_kdf_iter -> Integer,
api_key -> Nullable<Text>,
avatar_color -> Nullable<Text>,
}
}

1
src/db/schemas/postgresql/schema.rs

@ -200,6 +200,7 @@ table! {
client_kdf_type -> Integer,
client_kdf_iter -> Integer,
api_key -> Nullable<Text>,
avatar_color -> Nullable<Text>,
}
}

1
src/db/schemas/sqlite/schema.rs

@ -200,6 +200,7 @@ table! {
client_kdf_type -> Integer,
client_kdf_iter -> Integer,
api_key -> Nullable<Text>,
avatar_color -> Nullable<Text>,
}
}

2
src/main.rs

@ -34,7 +34,7 @@
// The more key/value pairs there are the more recursion occurs.
// We want to keep this as low as possible, but not higher then 128.
// If you go above 128 it will cause rust-analyzer to fail,
#![recursion_limit = "94"]
#![recursion_limit = "97"]
// When enabled use MiMalloc as malloc instead of the default malloc
#[cfg(feature = "enable_mimalloc")]

Loading…
Cancel
Save