forked from mirrors/akkoma
9fcff7851f
Too many changes in OpenAPI spec to describe each one, but basically it is tag fixes, bringing consitency to operation summaries and fixing some incorrect information.
85 lines
2.6 KiB
Elixir
85 lines
2.6 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.DomainBlockOperation do
|
|
alias OpenApiSpex.Operation
|
|
alias OpenApiSpex.Schema
|
|
import Pleroma.Web.ApiSpec.Helpers
|
|
|
|
def open_api_operation(action) do
|
|
operation = String.to_existing_atom("#{action}_operation")
|
|
apply(__MODULE__, operation, [])
|
|
end
|
|
|
|
def index_operation do
|
|
%Operation{
|
|
tags: ["Domain blocks"],
|
|
summary: "Retrieve a list of blocked domains",
|
|
security: [%{"oAuth" => ["follow", "read:blocks"]}],
|
|
operationId: "DomainBlockController.index",
|
|
responses: %{
|
|
200 =>
|
|
Operation.response("Domain blocks", "application/json", %Schema{
|
|
description: "Response schema for domain blocks",
|
|
type: :array,
|
|
items: %Schema{type: :string},
|
|
example: ["google.com", "facebook.com"]
|
|
})
|
|
}
|
|
}
|
|
end
|
|
|
|
# Supporting domain query parameter is deprecated in Mastodon API
|
|
def create_operation do
|
|
%Operation{
|
|
tags: ["Domain blocks"],
|
|
summary: "Block a domain",
|
|
description: """
|
|
Block a domain to:
|
|
|
|
- hide all public posts from it
|
|
- hide all notifications from it
|
|
- remove all followers from it
|
|
- prevent following new users from it (but does not remove existing follows)
|
|
""",
|
|
operationId: "DomainBlockController.create",
|
|
requestBody: domain_block_request(),
|
|
parameters: [Operation.parameter(:domain, :query, %Schema{type: :string}, "Domain name")],
|
|
security: [%{"oAuth" => ["follow", "write:blocks"]}],
|
|
responses: %{200 => empty_object_response()}
|
|
}
|
|
end
|
|
|
|
# Supporting domain query parameter is deprecated in Mastodon API
|
|
def delete_operation do
|
|
%Operation{
|
|
tags: ["Domain blocks"],
|
|
summary: "Unblock a domain",
|
|
description: "Remove a domain block, if it exists in the user's array of blocked domains.",
|
|
operationId: "DomainBlockController.delete",
|
|
requestBody: domain_block_request(),
|
|
parameters: [Operation.parameter(:domain, :query, %Schema{type: :string}, "Domain name")],
|
|
security: [%{"oAuth" => ["follow", "write:blocks"]}],
|
|
responses: %{
|
|
200 => Operation.response("Empty object", "application/json", %Schema{type: :object})
|
|
}
|
|
}
|
|
end
|
|
|
|
defp domain_block_request do
|
|
request_body(
|
|
"Parameters",
|
|
%Schema{
|
|
type: :object,
|
|
properties: %{
|
|
domain: %Schema{type: :string}
|
|
}
|
|
},
|
|
required: false,
|
|
example: %{
|
|
"domain" => "facebook.com"
|
|
}
|
|
)
|
|
end
|
|
end
|