|
|
|
//! A module containing everything relating to a account returned from the api.
|
|
|
|
|
|
|
|
use chrono::prelude::*;
|
|
|
|
use serde::de::{self, Deserialize, Deserializer, Unexpected};
|
|
|
|
use status_builder;
|
|
|
|
use std::path::PathBuf;
|
|
|
|
|
|
|
|
/// A struct representing an Account.
|
|
|
|
#[derive(Debug, Clone, Deserialize)]
|
|
|
|
pub struct Account {
|
|
|
|
/// Equals `username` for local users, includes `@domain` for remote ones.
|
|
|
|
pub acct: String,
|
|
|
|
/// URL to the avatar image
|
|
|
|
pub avatar: String,
|
|
|
|
/// URL to the avatar static image (gif)
|
|
|
|
pub avatar_static: String,
|
|
|
|
/// The time the account was created.
|
|
|
|
pub created_at: DateTime<Utc>,
|
|
|
|
/// The account's display name.
|
|
|
|
pub display_name: String,
|
|
|
|
/// The number of followers for the account.
|
|
|
|
pub followers_count: u64,
|
|
|
|
/// The number of accounts the given account is following.
|
|
|
|
pub following_count: u64,
|
|
|
|
/// URL to the header image.
|
|
|
|
pub header: String,
|
|
|
|
/// URL to the header static image (gif).
|
|
|
|
pub header_static: String,
|
|
|
|
/// The ID of the account.
|
|
|
|
pub id: String,
|
|
|
|
/// Boolean for when the account cannot be followed without waiting for
|
|
|
|
/// approval first.
|
|
|
|
pub locked: bool,
|
|
|
|
/// Biography of user.
|
|
|
|
pub note: String,
|
|
|
|
/// The number of statuses the account has made.
|
|
|
|
pub statuses_count: u64,
|
|
|
|
/// URL of the user's profile page (can be remote).
|
|
|
|
pub url: String,
|
|
|
|
/// The username of the account.
|
|
|
|
pub username: String,
|
|
|
|
/// An extra attribute given from `verify_credentials` giving defaults about
|
|
|
|
/// a user
|
|
|
|
pub source: Option<Source>,
|
|
|
|
/// If the owner decided to switch accounts, new account is in
|
|
|
|
/// this attribute
|
|
|
|
pub moved: Option<Box<Account>>,
|
|
|
|
}
|
|
|
|
|
|
|
|
/// An extra object given from `verify_credentials` giving defaults about a user
|
|
|
|
#[derive(Debug, Clone, Deserialize)]
|
|
|
|
pub struct Source {
|
|
|
|
privacy: status_builder::Visibility,
|
|
|
|
#[serde(deserialize_with = "string_or_bool")]
|
|
|
|
sensitive: bool,
|
|
|
|
note: String,
|
|
|
|
}
|
|
|
|
|
|
|
|
fn string_or_bool<'de, D: Deserializer<'de>>(val: D) -> ::std::result::Result<bool, D::Error> {
|
|
|
|
#[derive(Clone, Debug, Deserialize)]
|
|
|
|
#[serde(untagged)]
|
|
|
|
pub enum BoolOrString {
|
|
|
|
Bool(bool),
|
|
|
|
Str(String),
|
|
|
|
}
|
|
|
|
|
|
|
|
Ok(match BoolOrString::deserialize(val)? {
|
|
|
|
BoolOrString::Bool(b) => b,
|
|
|
|
BoolOrString::Str(ref s) => {
|
|
|
|
if s == "true" {
|
|
|
|
true
|
|
|
|
} else if s == "false" {
|
|
|
|
false
|
|
|
|
} else {
|
|
|
|
return Err(de::Error::invalid_value(
|
|
|
|
Unexpected::Str(s),
|
|
|
|
&"true or false",
|
|
|
|
));
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Debug, Default, Clone, Copy, Serialize)]
|
|
|
|
pub(crate) struct UpdateSource {
|
|
|
|
#[serde(skip_serializing_if = "Option::is_none")]
|
|
|
|
pub(crate) privacy: Option<status_builder::Visibility>,
|
|
|
|
#[serde(skip_serializing_if = "Option::is_none")]
|
|
|
|
pub(crate) sensitive: Option<bool>,
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Debug, Default, Serialize)]
|
|
|
|
pub(crate) struct Credentials {
|
|
|
|
#[serde(skip_serializing_if = "Option::is_none")]
|
|
|
|
pub(crate) display_name: Option<String>,
|
|
|
|
#[serde(skip_serializing_if = "Option::is_none")]
|
|
|
|
pub(crate) note: Option<String>,
|
|
|
|
#[serde(skip_serializing_if = "Option::is_none")]
|
|
|
|
pub(crate) avatar: Option<PathBuf>,
|
|
|
|
#[serde(skip_serializing_if = "Option::is_none")]
|
|
|
|
pub(crate) header: Option<PathBuf>,
|
|
|
|
#[serde(skip_serializing_if = "Option::is_none")]
|
|
|
|
pub(crate) source: Option<UpdateSource>,
|
|
|
|
}
|