forked from AkkomaGang/akkoma
135 lines
4.3 KiB
Elixir
135 lines
4.3 KiB
Elixir
# Pleroma: A lightweight social networking server
|
|
# Copyright © 2017-2020 Pleroma Authors <https://pleroma.social/>
|
|
# SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
defmodule Pleroma.Web.ApiSpec.PleromaOperation do
|
|
alias OpenApiSpex.Operation
|
|
alias OpenApiSpex.Schema
|
|
alias Pleroma.Web.ApiSpec.NotificationOperation
|
|
alias Pleroma.Web.ApiSpec.Schemas.ApiError
|
|
alias Pleroma.Web.ApiSpec.Schemas.Conversation
|
|
alias Pleroma.Web.ApiSpec.Schemas.FlakeID
|
|
alias Pleroma.Web.ApiSpec.StatusOperation
|
|
|
|
import Pleroma.Web.ApiSpec.Helpers
|
|
|
|
def open_api_operation(action) do
|
|
operation = String.to_existing_atom("#{action}_operation")
|
|
apply(__MODULE__, operation, [])
|
|
end
|
|
|
|
def conversation_operation do
|
|
%Operation{
|
|
tags: ["Conversations"],
|
|
summary: "The conversation with the given ID",
|
|
parameters: [
|
|
Operation.parameter(:id, :path, :string, "Conversation ID",
|
|
example: "123",
|
|
required: true
|
|
)
|
|
],
|
|
security: [%{"oAuth" => ["read:statuses"]}],
|
|
operationId: "PleromaController.conversation",
|
|
responses: %{
|
|
200 => Operation.response("Conversation", "application/json", Conversation)
|
|
}
|
|
}
|
|
end
|
|
|
|
def conversation_statuses_operation do
|
|
%Operation{
|
|
tags: ["Conversations"],
|
|
summary: "Timeline for a given conversation",
|
|
parameters: [
|
|
Operation.parameter(:id, :path, :string, "Conversation ID",
|
|
example: "123",
|
|
required: true
|
|
)
|
|
| pagination_params()
|
|
],
|
|
security: [%{"oAuth" => ["read:statuses"]}],
|
|
operationId: "PleromaController.conversation_statuses",
|
|
responses: %{
|
|
200 =>
|
|
Operation.response(
|
|
"Array of Statuses",
|
|
"application/json",
|
|
StatusOperation.array_of_statuses()
|
|
)
|
|
}
|
|
}
|
|
end
|
|
|
|
def update_conversation_operation do
|
|
%Operation{
|
|
tags: ["Conversations"],
|
|
summary: "Update a conversation. Used to change the set of recipients.",
|
|
parameters: [
|
|
Operation.parameter(:id, :path, :string, "Conversation ID",
|
|
example: "123",
|
|
required: true
|
|
),
|
|
Operation.parameter(
|
|
:recipients,
|
|
:query,
|
|
%Schema{type: :array, items: FlakeID},
|
|
"A list of ids of users that should receive posts to this conversation. This will replace the current list of recipients, so submit the full list. The owner of owner of the conversation will always be part of the set of recipients, though.",
|
|
required: true
|
|
)
|
|
],
|
|
security: [%{"oAuth" => ["write:conversations"]}],
|
|
operationId: "PleromaController.update_conversation",
|
|
responses: %{
|
|
200 => Operation.response("Conversation", "application/json", Conversation)
|
|
}
|
|
}
|
|
end
|
|
|
|
def mark_conversations_as_read_operation do
|
|
%Operation{
|
|
tags: ["Conversations"],
|
|
summary: "Marks all user's conversations as read",
|
|
security: [%{"oAuth" => ["write:conversations"]}],
|
|
operationId: "PleromaController.mark_conversations_as_read",
|
|
responses: %{
|
|
200 =>
|
|
Operation.response(
|
|
"Array of Conversations that were marked as read",
|
|
"application/json",
|
|
%Schema{
|
|
type: :array,
|
|
items: Conversation,
|
|
example: [Conversation.schema().example]
|
|
}
|
|
)
|
|
}
|
|
}
|
|
end
|
|
|
|
def mark_notifications_as_read_operation do
|
|
%Operation{
|
|
tags: ["Notifications"],
|
|
summary: "Mark notifications as read. Query parameters are mutually exclusive.",
|
|
parameters: [
|
|
Operation.parameter(:id, :query, :string, "A single notification ID to read"),
|
|
Operation.parameter(:max_id, :query, :string, "Read all notifications up to this id")
|
|
],
|
|
security: [%{"oAuth" => ["write:notifications"]}],
|
|
operationId: "PleromaController.mark_notifications_as_read",
|
|
responses: %{
|
|
200 =>
|
|
Operation.response(
|
|
"A Notification or array of Motifications",
|
|
"application/json",
|
|
%Schema{
|
|
anyOf: [
|
|
%Schema{type: :array, items: NotificationOperation.notification()},
|
|
NotificationOperation.notification()
|
|
]
|
|
}
|
|
),
|
|
400 => Operation.response("Bad Request", "application/json", ApiError)
|
|
}
|
|
}
|
|
end
|
|
end
|