Add initial docs page, improve adding domains

Signed-off-by: Marcin Mikołajczak <git@mkljczk.pl>
This commit is contained in:
Marcin Mikołajczak 2023-11-10 00:53:17 +01:00
parent c2c7c23aab
commit 182e0b58da
7 changed files with 56 additions and 10 deletions

View file

@ -1061,6 +1061,18 @@
suggestions: [ suggestions: [
"en" "en"
] ]
},
%{
key: :multitenancy,
type: :map,
description: "Multitenancy support",
children: [
%{
key: :enabled,
type: :boolean,
description: "Enables allowing multiple Webfinger domains"
},
]
} }
] ]
}, },
@ -3466,5 +3478,5 @@
] ]
} }
] ]
} },
] ]

View file

@ -0,0 +1,30 @@
# How to serve multiple domains for Pleroma user identifiers
It is possible to use multiple domains for WebFinger identifiers. If configured, users can select from the available domains during registration. Domains can be set by instance administrator and can be marked as either public (everyone can choose it) or private (only available when admin creates a user)
## Configuring
### Configuring Pleroma
To enable using multiple domains, append the following to your `prod.secret.exs` or `dev.secret.exs`:
```elixir
config :pleroma, :instance, :multitenancy, enabled: true
```
Creating, updating and deleting domains is available from the admin API.
### Configuring WebFinger domains
If you recall how webfinger queries work, the first step is to query `https://example.org/.well-known/host-meta`, which will contain an URL template.
Therefore, the easiest way to configure the additional domains is to redirect `/.well-known/host-meta` to the domain used by Pleroma.
With nginx, it would be as simple as adding:
```nginx
location = /.well-known/host-meta {
return 301 https://pleroma.example.org$request_uri;
}
```
in the additional domain's server block.

View file

@ -19,11 +19,13 @@ def changeset(%__MODULE__{} = domain, params \\ %{}) do
domain domain
|> cast(params, [:domain, :public]) |> cast(params, [:domain, :public])
|> validate_required([:domain]) |> validate_required([:domain])
|> update_change(:domain, &String.downcase/1)
|> unique_constraint(:domain)
end end
def update_changeset(%__MODULE__{} = domain, params \\ %{}) do def update_changeset(%__MODULE__{} = domain, params \\ %{}) do
domain domain
|> cast(params, [:domain]) |> cast(params, [:public])
end end
def get(id), do: Repo.get(__MODULE__, id) def get(id), do: Repo.get(__MODULE__, id)

View file

@ -37,11 +37,13 @@ def index(conn, _) do
end end
def create(%{body_params: params} = conn, _) do def create(%{body_params: params} = conn, _) do
domain = with {:domain_not_used, true} <-
params {:domain_not_used, params[:domain] !== Pleroma.Web.WebFinger.domain()},
|> Domain.create() {:domain, domain} <- Domain.create(params) do
render(conn, "show.json", domain: domain)
render(conn, "show.json", domain: domain) else
{:domain_not_used, false} -> {:error, :invalid_domain}
end
end end
def update(%{body_params: params} = conn, %{id: id}) do def update(%{body_params: params} = conn, %{id: id}) do

View file

@ -147,7 +147,7 @@ def fields_limits do
end end
defp multitenancy do defp multitenancy do
enabled = Config.get([:multitenancy, :enabled]) enabled = Config.get([:instance, :multitenancy, :enabled])
if enabled do if enabled do
domains = domains =

View file

@ -102,7 +102,7 @@ defp get_subject(%User{nickname: nickname}) do
end end
end end
defp domain do def domain do
Pleroma.Config.get([__MODULE__, :domain]) || Pleroma.Web.Endpoint.host() Pleroma.Config.get([__MODULE__, :domain]) || Pleroma.Web.Endpoint.host()
end end

View file

@ -3,7 +3,7 @@ defmodule Pleroma.Repo.Migrations.CreateDomains do
def change do def change do
create_if_not_exists table(:domains) do create_if_not_exists table(:domains) do
add(:domain, :string) add(:domain, :citext)
add(:public, :boolean) add(:public, :boolean)
timestamps() timestamps()