# Pleroma: A lightweight social networking server # Copyright © 2017-2021 Pleroma Authors <https://pleroma.social/> # SPDX-License-Identifier: AGPL-3.0-only defmodule Pleroma.Web.ApiSpec.Schemas.Account do alias OpenApiSpex.Schema alias Pleroma.Web.ApiSpec.Schemas.AccountField alias Pleroma.Web.ApiSpec.Schemas.AccountRelationship alias Pleroma.Web.ApiSpec.Schemas.ActorType alias Pleroma.Web.ApiSpec.Schemas.Emoji alias Pleroma.Web.ApiSpec.Schemas.FlakeID alias Pleroma.Web.ApiSpec.Schemas.VisibilityScope require OpenApiSpex OpenApiSpex.schema(%{ title: "Account", description: "Response schema for an account", type: :object, properties: %{ acct: %Schema{type: :string}, avatar_static: %Schema{type: :string, format: :uri}, avatar: %Schema{type: :string, format: :uri}, bot: %Schema{type: :boolean}, created_at: %Schema{type: :string, format: "date-time"}, display_name: %Schema{type: :string}, emojis: %Schema{type: :array, items: Emoji}, fields: %Schema{type: :array, items: AccountField}, follow_requests_count: %Schema{type: :integer}, followers_count: %Schema{type: :integer}, following_count: %Schema{type: :integer}, header_static: %Schema{type: :string, format: :uri}, header: %Schema{type: :string, format: :uri}, id: FlakeID, locked: %Schema{type: :boolean}, note: %Schema{type: :string, format: :html}, statuses_count: %Schema{type: :integer}, url: %Schema{type: :string, format: :uri}, username: %Schema{type: :string}, pleroma: %Schema{ type: :object, properties: %{ ap_id: %Schema{type: :string}, also_known_as: %Schema{type: :array, items: %Schema{type: :string}}, allow_following_move: %Schema{ type: :boolean, description: "whether the user allows automatically follow moved following accounts" }, background_image: %Schema{type: :string, nullable: true, format: :uri}, is_confirmed: %Schema{ type: :boolean, description: "whether the user account is waiting on email confirmation to be activated" }, hide_favorites: %Schema{type: :boolean}, hide_followers_count: %Schema{ type: :boolean, description: "whether the user has follower stat hiding enabled" }, hide_followers: %Schema{ type: :boolean, description: "whether the user has follower hiding enabled" }, hide_follows_count: %Schema{ type: :boolean, description: "whether the user has follow stat hiding enabled" }, hide_follows: %Schema{ type: :boolean, description: "whether the user has follow hiding enabled" }, is_admin: %Schema{ type: :boolean, description: "whether the user is an admin of the local instance" }, is_moderator: %Schema{ type: :boolean, description: "whether the user is a moderator of the local instance" }, skip_thread_containment: %Schema{type: :boolean}, tags: %Schema{ type: :array, items: %Schema{type: :string}, description: "List of tags being used for things like extra roles or moderation(ie. marking all media as nsfw all)." }, unread_conversation_count: %Schema{ type: :integer, description: "The count of unread conversations. Only returned to the account owner." }, notification_settings: %Schema{ type: :object, properties: %{ block_from_strangers: %Schema{type: :boolean}, hide_notification_contents: %Schema{type: :boolean} } }, relationship: %Schema{allOf: [AccountRelationship], nullable: true}, settings_store: %Schema{ type: :object, description: "A generic map of settings for frontends. Opaque to the backend. Only returned in `verify_credentials` and `update_credentials`" }, favicon: %Schema{ type: :string, format: :uri, nullable: true, description: "Favicon image of the user's instance" } } }, akkoma: %Schema{ type: :object, properties: %{ note_ttl_days: %Schema{type: :integer} } }, source: %Schema{ type: :object, properties: %{ fields: %Schema{type: :array, items: AccountField}, note: %Schema{ type: :string, description: "Plaintext version of the bio without formatting applied by the backend, used for editing the bio." }, privacy: VisibilityScope, sensitive: %Schema{type: :boolean}, pleroma: %Schema{ type: :object, properties: %{ actor_type: ActorType, discoverable: %Schema{ type: :boolean, description: "whether the user allows indexing / listing of the account by external services (search engines etc.)." }, no_rich_text: %Schema{ type: :boolean, description: "whether the HTML tags for rich-text formatting are stripped from all statuses requested from the API." }, show_role: %Schema{ type: :boolean, description: "whether the user wants their role (e.g admin, moderator) to be shown" } } } } } }, example: %{ "acct" => "foobar", "avatar" => "https://mypleroma.com/images/avi.png", "avatar_static" => "https://mypleroma.com/images/avi.png", "bot" => false, "created_at" => "2020-03-24T13:05:58.000Z", "display_name" => "foobar", "emojis" => [], "fields" => [], "follow_requests_count" => 0, "followers_count" => 0, "following_count" => 1, "header" => "https://mypleroma.com/images/banner.png", "header_static" => "https://mypleroma.com/images/banner.png", "id" => "9tKi3esbG7OQgZ2920", "locked" => false, "note" => "cofe", "pleroma" => %{ "allow_following_move" => true, "background_image" => nil, "is_confirmed" => false, "hide_favorites" => true, "hide_followers" => false, "hide_followers_count" => false, "hide_follows" => false, "hide_follows_count" => false, "is_admin" => false, "is_moderator" => false, "skip_thread_containment" => false, "unread_conversation_count" => 0, "tags" => [], "notification_settings" => %{ "block_from_strangers" => false, "hide_notification_contents" => false }, "relationship" => %{ "blocked_by" => false, "blocking" => false, "domain_blocking" => false, "endorsed" => false, "followed_by" => false, "following" => false, "id" => "9tKi3esbG7OQgZ2920", "muting" => false, "muting_notifications" => false, "note" => "", "requested" => false, "showing_reblogs" => true, "subscribing" => false, "notifying" => false }, "settings_store" => %{ "pleroma-fe" => %{} } }, "source" => %{ "fields" => [], "note" => "foobar", "pleroma" => %{ "actor_type" => "Person", "discoverable" => false, "no_rich_text" => false, "show_role" => true }, "privacy" => "public", "sensitive" => false }, "statuses_count" => 0, "url" => "https://mypleroma.com/users/foobar", "username" => "foobar" } }) end