diff options
| author | rinpatch <rinpatch@sdf.org> | 2019-05-21 09:13:10 +0300 | 
|---|---|---|
| committer | rinpatch <rinpatch@sdf.org> | 2019-05-21 09:13:10 +0300 | 
| commit | 76a7429befb2e9a819b653ff8328cc42a565c29d (patch) | |
| tree | 3b85648df8c7a240453bdb4d3f8917f08b3d8bfc | |
| parent | 6430cb1bf78e7949cc023a30df7a8d1547c36524 (diff) | |
| download | pleroma-76a7429befb2e9a819b653ff8328cc42a565c29d.tar.gz pleroma-76a7429befb2e9a819b653ff8328cc42a565c29d.zip | |
Add poll limits to /api/v1/instance and initial state
| -rw-r--r-- | config/config.exs | 6 | ||||
| -rw-r--r-- | docs/config.md | 5 | ||||
| -rw-r--r-- | lib/pleroma/web/mastodon_api/mastodon_api_controller.ex | 4 | ||||
| -rw-r--r-- | test/web/mastodon_api/mastodon_api_controller_test.exs | 3 | 
4 files changed, 16 insertions, 2 deletions
| diff --git a/config/config.exs b/config/config.exs index 9a10b0ff7..47d8dfb42 100644 --- a/config/config.exs +++ b/config/config.exs @@ -211,6 +211,12 @@ config :pleroma, :instance,    avatar_upload_limit: 2_000_000,    background_upload_limit: 4_000_000,    banner_upload_limit: 4_000_000, +  poll_limits: %{ +    max_options: 20, +    max_option_chars: 200, +    min_expiration: 0, +    max_expiration: 365 * 24 * 60 * 60 +  },    registrations_open: true,    federating: true,    federation_reachability_timeout_days: 7, diff --git a/docs/config.md b/docs/config.md index 450d73fda..f9903332c 100644 --- a/docs/config.md +++ b/docs/config.md @@ -71,6 +71,11 @@ config :pleroma, Pleroma.Emails.Mailer,  * `avatar_upload_limit`: File size limit of user’s profile avatars  * `background_upload_limit`: File size limit of user’s profile backgrounds  * `banner_upload_limit`: File size limit of user’s profile banners +* `poll_limits`: A map with poll limits for **local** polls +  * `max_options`: Maximum number of options +  * `max_option_chars`: Maximum number of characters per option +  * `min_expiration`: Minimum expiration time (in seconds) +  * `max_expiration`: Maximum expiration time (in seconds)  * `registrations_open`: Enable registrations for anyone, invitations can be enabled when false.  * `invites_enabled`: Enable user invitations for admins (depends on `registrations_open: false`).  * `account_activation_required`: Require users to confirm their emails before signing in. diff --git a/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex b/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex index 1051861ff..81cc5a972 100644 --- a/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex +++ b/lib/pleroma/web/mastodon_api/mastodon_api_controller.ex @@ -197,7 +197,8 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIController do        languages: ["en"],        registrations: Pleroma.Config.get([:instance, :registrations_open]),        # Extra (not present in Mastodon): -      max_toot_chars: Keyword.get(instance, :limit) +      max_toot_chars: Keyword.get(instance, :limit), +      poll_limits: Keyword.get(instance, :poll_limits)      }      json(conn, response) @@ -1331,6 +1332,7 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIController do              max_toot_chars: limit,              mascot: "/images/pleroma-fox-tan-smol.png"            }, +          poll_limits: Config.get([:instance, :poll_limits]),            rights: %{              delete_others_notice: present?(user.info.is_moderator),              admin: present?(user.info.is_admin) diff --git a/test/web/mastodon_api/mastodon_api_controller_test.exs b/test/web/mastodon_api/mastodon_api_controller_test.exs index 68fe9c1b4..48268d4f7 100644 --- a/test/web/mastodon_api/mastodon_api_controller_test.exs +++ b/test/web/mastodon_api/mastodon_api_controller_test.exs @@ -2494,7 +2494,8 @@ defmodule Pleroma.Web.MastodonAPI.MastodonAPIControllerTest do               "stats" => _,               "thumbnail" => _,               "languages" => _, -             "registrations" => _ +             "registrations" => _, +             "poll_limits" => _             } = result      assert email == from_config_email | 
