diff options
Diffstat (limited to 'docs')
| -rw-r--r-- | docs/api/differences_in_mastoapi_responses.md | 26 | ||||
| -rw-r--r-- | docs/api/pleroma_api.md | 75 | ||||
| -rw-r--r-- | docs/config.md | 8 | ||||
| -rw-r--r-- | docs/config/custom_emoji.md | 25 | 
4 files changed, 125 insertions, 9 deletions
| diff --git a/docs/api/differences_in_mastoapi_responses.md b/docs/api/differences_in_mastoapi_responses.md index ed3fd9b67..1350ace43 100644 --- a/docs/api/differences_in_mastoapi_responses.md +++ b/docs/api/differences_in_mastoapi_responses.md @@ -20,6 +20,7 @@ Has these additional fields under the `pleroma` object:  - `local`: true if the post was made on the local instance.  - `conversation_id`: the ID of the conversation the status is associated with (if any) +- `in_reply_to_account_acct`: the `acct` property of User entity for replied user (if any)  - `content`: a map consisting of alternate representations of the `content` property with the key being it's mimetype. Currently the only alternate representation supported is `text/plain`  - `spoiler_text`: a map consisting of alternate representations of the `spoiler_text` property with the key being it's mimetype. Currently the only alternate representation supported is `text/plain` @@ -37,9 +38,18 @@ Has these additional fields under the `pleroma` object:  - `tags`: Lists an array of tags for the user  - `relationship{}`: Includes fields as documented for Mastodon API https://docs.joinmastodon.org/api/entities/#relationship -- `is_moderator`: boolean, true if user is a moderator -- `is_admin`: boolean, true if user is an admin +- `is_moderator`: boolean, nullable,  true if user is a moderator +- `is_admin`: boolean, nullable, true if user is an admin  - `confirmation_pending`: boolean, true if a new user account is waiting on email confirmation to be activated +- `hide_followers`: boolean, true when the user has follower hiding enabled +- `hide_follows`: boolean, true when the user has follow hiding enabled + +### Source + +Has these additional fields under the `pleroma` object: + +- `show_role`: boolean, nullable, true when the user wants his role (e.g admin, moderator) to be shown +- `no_rich_text` - boolean, nullable, true when html tags are stripped from all statuses requested from the API  ## Account Search @@ -58,3 +68,15 @@ Has these additional fields under the `pleroma` object:  Additional parameters can be added to the JSON body/Form data:  - `preview`: boolean, if set to `true` the post won't be actually posted, but the status entitiy would still be rendered back. This could be useful for previewing rich text/custom emoji, for example. +- `content_type`: string, contain the MIME type of the status, it is transformed into HTML by the backend. You can get the list of the supported MIME types with the nodeinfo endpoint. + +## PATCH `/api/v1/update_credentials` + +Additional parameters can be added to the JSON body/Form data: + +- `no_rich_text` - if true, html tags are stripped from all statuses requested from the API +- `hide_followers` - if true, user's followers will be hidden +- `hide_follows` - if true, user's follows will be hidden +- `hide_favorites` - if true, user's favorites timeline will be hidden +- `show_role` - if true, user's role (e.g admin, moderator) will be exposed to anyone in the API +- `default_scope` - the scope returned under `privacy` key in Source subentity diff --git a/docs/api/pleroma_api.md b/docs/api/pleroma_api.md index dbe250300..190846de9 100644 --- a/docs/api/pleroma_api.md +++ b/docs/api/pleroma_api.md @@ -77,7 +77,7 @@ Request parameters can be passed via [query strings](https://en.wikipedia.org/wi      * `token`: invite token required when the registrations aren't public.  * Response: JSON. Returns a user object on success, otherwise returns `{"error": "error_msg"}`  * Example response: -``` +```json  {  	"background_image": null,  	"cover_photo": "https://pleroma.soykaf.com/images/banner.png", @@ -187,6 +187,62 @@ See [Admin-API](Admin-API.md)  }  ``` +## `/api/v1/pleroma/accounts/:id/favourites` +### Returns favorites timeline of any user +* Method `GET` +* Authentication: not required +* Params: +    * `id`: the id of the account for whom to return results +    * `limit`: optional, the number of records to retrieve +    * `since_id`: optional, returns results that are more recent than the specified id +    * `max_id`: optional, returns results that are older than the specified id +* Response: JSON, returns a list of Mastodon Status entities on success, otherwise returns `{"error": "error_msg"}` +* Example response: +```json +[ +  { +    "account": { +      "id": "9hptFmUF3ztxYh3Svg", +      "url": "https://pleroma.example.org/users/nick2", +      "username": "nick2", +      ... +    }, +    "application": {"name": "Web", "website": null}, +    "bookmarked": false, +    "card": null, +    "content": "This is :moominmamma: note 0", +    "created_at": "2019-04-15T15:42:15.000Z", +    "emojis": [], +    "favourited": false, +    "favourites_count": 1, +    "id": "9hptFmVJ02khbzYJaS", +    "in_reply_to_account_id": null, +    "in_reply_to_id": null, +    "language": null, +    "media_attachments": [], +    "mentions": [], +    "muted": false, +    "pinned": false, +    "pleroma": { +      "content": {"text/plain": "This is :moominmamma: note 0"}, +      "conversation_id": 13679, +      "local": true, +      "spoiler_text": {"text/plain": "2hu"} +    }, +    "reblog": null, +    "reblogged": false, +    "reblogs_count": 0, +    "replies_count": 0, +    "sensitive": false, +    "spoiler_text": "2hu", +    "tags": [{"name": "2hu", "url": "/tag/2hu"}], +    "uri": "https://pleroma.example.org/objects/198ed2a1-7912-4482-b559-244a0369e984", +    "url": "https://pleroma.example.org/notice/9hptFmVJ02khbzYJaS", +    "visibility": "public" +  } +] +``` +  ## `/api/pleroma/notification_settings`  ### Updates user notification settings  * Method `PUT` @@ -197,3 +253,20 @@ See [Admin-API](Admin-API.md)      * `remote`: BOOLEAN field, receives notifications from people on remote instances      * `local`: BOOLEAN field, receives notifications from people on the local instance  * Response: JSON. Returns `{"status": "success"}` if the update was successful, otherwise returns `{"error": "error_msg"}` + +## `/api/pleroma/healthcheck` +### Healthcheck endpoint with additional system data. +* Method `GET` +* Authentication: not required +* Params: none +* Response: JSON, statuses (200 - healthy, 503 unhealthy). +* Example response: +```json +{ +  "pool_size": 0, # database connection pool +  "active": 0, # active processes +  "idle": 0, # idle processes +  "memory_used": 0.00, # Memory used +  "healthy": true # Instance state +} +``` diff --git a/docs/config.md b/docs/config.md index 69d389382..cd0e145df 100644 --- a/docs/config.md +++ b/docs/config.md @@ -87,7 +87,6 @@ config :pleroma, Pleroma.Emails.Mailer,  * `quarantined_instances`: List of ActivityPub instances where private(DMs, followers-only) activities will not be send.  * `managed_config`: Whenether the config for pleroma-fe is configured in this config or in ``static/config.json``  * `allowed_post_formats`: MIME-type list of formats allowed to be posted (transformed into HTML) -* `finmoji_enabled`: Whenether to enable the finmojis in the custom emojis.  * `mrf_transparency`: Make the content of your Message Rewrite Facility settings public (via nodeinfo).  * `scope_copy`: Copy the scope (private/unlisted/public) in replies to posts by default.  * `subject_line_behavior`: Allows changing the default behaviour of subject lines in replies. Valid values: @@ -104,6 +103,7 @@ config :pleroma, Pleroma.Emails.Mailer,  * `welcome_user_nickname`: The nickname of the local user that sends the welcome message.  * `max_report_comment_size`: The maximum size of the report comment (Default: `1000`)  * `safe_dm_mentions`: If set to true, only mentions at the beginning of a post will be used to address people in direct messages. This is to prevent accidental mentioning of people when talking about them (e.g. "@friend hey i really don't like @enemy"). (Default: `false`) +* `healthcheck`: if set to true, system data will be shown on ``/api/pleroma/healthcheck``.  ## :logger  * `backends`: `:console` is used to send logs to stdout, `{ExSyslogger, :ex_syslogger}` to log to syslog, and `Quack.Logger` to log to Slack @@ -205,6 +205,7 @@ This section is used to configure Pleroma-FE, unless ``:managed_config`` in ``:i  * `enabled`: Enables proxying of remote media to the instance’s proxy  * `base_url`: The base URL to access a user-uploaded file. Useful when you want to proxy the media files via another host/CDN fronts.  * `proxy_opts`: All options defined in `Pleroma.ReverseProxy` documentation, defaults to `[max_body_length: (25*1_048_576)]`. +* `whitelist`: List of domains to bypass the mediaproxy  ## :gopher  * `enabled`: Enables the gopher interface @@ -499,3 +500,8 @@ config :ueberauth, Ueberauth,      microsoft: {Ueberauth.Strategy.Microsoft, [callback_params: []]}    ]  ``` + +## :emoji +* `shortcode_globs`: Location of custom emoji files. `*` can be used as a wildcard. Example `["/emoji/custom/**/*.png"]` +* `groups`: Emojis are ordered in groups (tags). This is an array of key-value pairs where the key is the groupname and the value the location or array of locations. `*` can be used as a wildcard. Example `[Custom: ["/emoji/*.png", "/emoji/custom/*.png"]]` +* `default_manifest`: Location of the JSON-manifest. This manifest contains information about the emoji-packs you can download. Currently only one manifest can be added (no arrays). diff --git a/docs/config/custom_emoji.md b/docs/config/custom_emoji.md index 5ce9865a2..f72c0edbc 100644 --- a/docs/config/custom_emoji.md +++ b/docs/config/custom_emoji.md @@ -1,15 +1,25 @@  # Custom Emoji +Before you add your own custom emoji, check if they are available in an existing pack. +See `Mix.Tasks.Pleroma.Emoji` for information about emoji packs. +  To add custom emoji: -* Add the image file(s) to `priv/static/emoji/custom` -* In case of conflicts: add the desired shortcode with the path to `config/custom_emoji.txt`, comma-separated and one per line -* Force recompilation (``mix clean && mix compile``) +* Create the `STATIC-DIR/emoji/` directory if it doesn't exist +  (`STATIC-DIR` is configurable, `instance/static/` by default) +* Create a directory with whatever name you want (custom is a good name to show the purpose of it). +  This will create a local emoji pack. +* Put your `.png` emoji files in that directory. In case of conflicts, you can create an `emoji.txt` +  file in that directory and specify a custom shortcode using the following format: +  `shortcode, file-path, tag1, tag2, etc`. One emoji per line. Note that if you do so, +  you'll have to list all other emojis in the pack too. +* Either restart pleroma or connect to the iex session pleroma's running and +  run `Pleroma.Emoji.reload/0` in it.  Example: -image files (in `/priv/static/emoji/custom`): `happy.png` and `sad.png` +image files (in `instance/static/emoji/custom`): `happy.png` and `sad.png` -content of `config/custom_emoji.txt`: +content of `emoji.txt`:  ```  happy, /emoji/custom/happy.png, Tag1,Tag2  sad, /emoji/custom/sad.png, Tag1 @@ -18,6 +28,11 @@ foo, /emoji/custom/foo.png  The files should be PNG (APNG is okay with `.png` for `image/png` Content-type) and under 50kb for compatibility with mastodon. +Default file extentions and locations for emojis are set in `config.exs`. To use different locations or file-extentions, add the `shortcode_globs` to your secrets file (`prod.secret.exs` or `dev.secret.exs`) and edit it. Note that not all fediverse-software will show emojis with other file extentions: +```elixir +config :pleroma, :emoji, shortcode_globs: ["/emoji/custom/**/*.png", "/emoji/custom/**/*.gif"] +``` +  ## Emoji tags (groups)  Default tags are set in `config.exs`. To set your own tags, copy the structure to your secrets file (`prod.secret.exs` or `dev.secret.exs`) and edit it. | 
