mirror of
https://akkoma.dev/AkkomaGang/akkoma.git
synced 2025-01-10 17:40:15 +00:00
249 lines
8.7 KiB
Elixir
249 lines
8.7 KiB
Elixir
# 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: %{
|
|
instance: %Schema{
|
|
type: :object,
|
|
nullable: true,
|
|
properties: %{
|
|
name: %Schema{type: :string},
|
|
favicon: %Schema{type: :string, format: :uri, nullable: true},
|
|
# XXX: proper nodeinfo schema
|
|
nodeinfo: %Schema{type: :object, nullable: true}
|
|
}
|
|
},
|
|
status_ttl_days: %Schema{type: :integer, nullable: true},
|
|
permit_followback: %Schema{type: :boolean}
|
|
}
|
|
},
|
|
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" => %{}
|
|
}
|
|
},
|
|
"akkoma" => %{
|
|
"instance" => %{
|
|
"name" => "ihatebeinga.live",
|
|
"favicon" => "https://ihatebeinga.live/favicon.png",
|
|
"nodeinfo" =>
|
|
%{
|
|
# XXX: nodeinfo schema
|
|
}
|
|
},
|
|
"status_ttl_days" => nil,
|
|
"permit_followback" => true
|
|
},
|
|
"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
|