306 lines
		
	
	
	
		
			9.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			306 lines
		
	
	
	
		
			9.3 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # Pleroma API
 | ||
| 
 | ||
| Requests that require it can be authenticated with [an OAuth token](https://tools.ietf.org/html/rfc6749), the `_pleroma_key` cookie, or [HTTP Basic Authentication](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Authorization).
 | ||
| 
 | ||
| Request parameters can be passed via [query strings](https://en.wikipedia.org/wiki/Query_string) or as [form data](https://www.w3.org/TR/html401/interact/forms.html). Files must be uploaded as `multipart/form-data`.
 | ||
| 
 | ||
| ## `/api/pleroma/emoji`
 | ||
| ### Lists the custom emoji on that server.
 | ||
| * Method: `GET`
 | ||
| * Authentication: not required
 | ||
| * Params: none
 | ||
| * Response: JSON
 | ||
| * Example response:
 | ||
| ```json
 | ||
| {
 | ||
|   "girlpower": {
 | ||
|     "tags": [
 | ||
|       "Finmoji"
 | ||
|     ],
 | ||
|     "image_url": "/finmoji/128px/girlpower-128.png"
 | ||
|   },
 | ||
|   "education": {
 | ||
|     "tags": [
 | ||
|       "Finmoji"
 | ||
|     ],
 | ||
|     "image_url": "/finmoji/128px/education-128.png"
 | ||
|   },
 | ||
|   "finnishlove": {
 | ||
|     "tags": [
 | ||
|       "Finmoji"
 | ||
|     ],
 | ||
|     "image_url": "/finmoji/128px/finnishlove-128.png"
 | ||
|   }
 | ||
| }
 | ||
| ```
 | ||
| * Note: Same data as Mastodon API’s `/api/v1/custom_emojis` but in a different format
 | ||
| 
 | ||
| ## `/api/pleroma/follow_import`
 | ||
| ### Imports your follows, for example from a Mastodon CSV file.
 | ||
| * Method: `POST`
 | ||
| * Authentication: required
 | ||
| * Params:
 | ||
|     * `list`: STRING or FILE containing a whitespace-separated list of accounts to follow
 | ||
| * Response: HTTP 200 on success, 500 on error
 | ||
| * Note: Users that can't be followed are silently skipped.
 | ||
| 
 | ||
| ## `/api/pleroma/captcha`
 | ||
| ### Get a new captcha
 | ||
| * Method: `GET`
 | ||
| * Authentication: not required
 | ||
| * Params: none
 | ||
| * Response: Provider specific JSON, the only guaranteed parameter is `type`
 | ||
| * Example response: `{"type": "kocaptcha", "token": "whatever", "url": "https://captcha.kotobank.ch/endpoint"}`
 | ||
| 
 | ||
| ## `/api/pleroma/delete_account`
 | ||
| ### Delete an account
 | ||
| * Method `POST`
 | ||
| * Authentication: required
 | ||
| * Params:
 | ||
|     * `password`: user's password
 | ||
| * Response: JSON. Returns `{"status": "success"}` if the deletion was successful, `{"error": "[error message]"}` otherwise
 | ||
| * Example response: `{"error": "Invalid password."}`
 | ||
| 
 | ||
| ## `/api/pleroma/disable_account`
 | ||
| ### Disable an account
 | ||
| * Method `POST`
 | ||
| * Authentication: required
 | ||
| * Params:
 | ||
|     * `password`: user's password
 | ||
| * Response: JSON. Returns `{"status": "success"}` if the account was successfully disabled, `{"error": "[error message]"}` otherwise
 | ||
| * Example response: `{"error": "Invalid password."}`
 | ||
| 
 | ||
| ## `/api/account/register`
 | ||
| ### Register a new user
 | ||
| * Method `POST`
 | ||
| * Authentication: not required
 | ||
| * Params:
 | ||
|     * `nickname`
 | ||
|     * `fullname`
 | ||
|     * `bio`
 | ||
|     * `email`
 | ||
|     * `password`
 | ||
|     * `confirm`
 | ||
|     * `captcha_solution`: optional, contains provider-specific captcha solution,
 | ||
|     * `captcha_token`: optional, contains provider-specific captcha token
 | ||
|     * `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",
 | ||
| 	"created_at": "Tue Dec 18 16:55:56 +0000 2018",
 | ||
| 	"default_scope": "public",
 | ||
| 	"description": "blushy-crushy fediverse idol + pleroma dev\nlet's be friends \nぷれろまの生徒会長。謎の外人。日本語OK. \n公主病.",
 | ||
| 	"description_html": "blushy-crushy fediverse idol + pleroma dev.<br />let's be friends <br />ぷれろまの生徒会長。謎の外人。日本語OK. <br />公主病.",
 | ||
| 	"favourites_count": 0,
 | ||
| 	"fields": [],
 | ||
| 	"followers_count": 0,
 | ||
| 	"following": false,
 | ||
| 	"follows_you": false,
 | ||
| 	"friends_count": 0,
 | ||
| 	"id": 6,
 | ||
| 	"is_local": true,
 | ||
| 	"locked": false,
 | ||
| 	"name": "lain",
 | ||
| 	"name_html": "lain",
 | ||
| 	"no_rich_text": false,
 | ||
| 	"pleroma": {
 | ||
| 		"tags": []
 | ||
| 	},
 | ||
| 	"profile_image_url": "https://pleroma.soykaf.com/images/avi.png",
 | ||
| 	"profile_image_url_https": "https://pleroma.soykaf.com/images/avi.png",
 | ||
| 	"profile_image_url_original": "https://pleroma.soykaf.com/images/avi.png",
 | ||
| 	"profile_image_url_profile_size": "https://pleroma.soykaf.com/images/avi.png",
 | ||
| 	"rights": {
 | ||
| 		"delete_others_notice": false
 | ||
| 	},
 | ||
| 	"screen_name": "lain",
 | ||
| 	"statuses_count": 0,
 | ||
| 	"statusnet_blocking": false,
 | ||
| 	"statusnet_profile_url": "https://pleroma.soykaf.com/users/lain"
 | ||
| }
 | ||
| ```
 | ||
| 
 | ||
| ## `/api/pleroma/admin/`…
 | ||
| See [Admin-API](Admin-API.md)
 | ||
| 
 | ||
| ## `/api/pleroma/notifications/read`
 | ||
| ### Mark a single notification as read
 | ||
| * Method `POST`
 | ||
| * Authentication: required
 | ||
| * Params:
 | ||
|     * `id`: notification's id
 | ||
| * Response: JSON. Returns `{"status": "success"}` if the reading was successful, otherwise returns `{"error": "error_msg"}`
 | ||
| 
 | ||
| ## `/api/v1/pleroma/accounts/:id/subscribe`
 | ||
| ### Subscribe to receive notifications for all statuses posted by a user
 | ||
| * Method `POST`
 | ||
| * Authentication: required
 | ||
| * Params:
 | ||
|     * `id`: account id to subscribe to
 | ||
| * Response: JSON, returns a mastodon relationship object on success, otherwise returns `{"error": "error_msg"}`
 | ||
| * Example response:
 | ||
| ```json
 | ||
| {
 | ||
|   "id": "abcdefg",
 | ||
|   "following": true,
 | ||
|   "followed_by": false,
 | ||
|   "blocking": false,
 | ||
|   "muting": false,
 | ||
|   "muting_notifications": false,
 | ||
|   "subscribing": true,
 | ||
|   "requested": false,
 | ||
|   "domain_blocking": false,
 | ||
|   "showing_reblogs": true,
 | ||
|   "endorsed": false
 | ||
| }
 | ||
| ```
 | ||
| 
 | ||
| ## `/api/v1/pleroma/accounts/:id/unsubscribe`
 | ||
| ### Unsubscribe to stop receiving notifications from user statuses
 | ||
| * Method `POST`
 | ||
| * Authentication: required
 | ||
| * Params:
 | ||
|     * `id`: account id to unsubscribe from
 | ||
| * Response: JSON, returns a mastodon relationship object on success, otherwise returns `{"error": "error_msg"}`
 | ||
| * Example response:
 | ||
| ```json
 | ||
| {
 | ||
|   "id": "abcdefg",
 | ||
|   "following": true,
 | ||
|   "followed_by": false,
 | ||
|   "blocking": false,
 | ||
|   "muting": false,
 | ||
|   "muting_notifications": false,
 | ||
|   "subscribing": false,
 | ||
|   "requested": false,
 | ||
|   "domain_blocking": false,
 | ||
|   "showing_reblogs": true,
 | ||
|   "endorsed": false
 | ||
| }
 | ||
| ```
 | ||
| 
 | ||
| ## `/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/v1/pleroma/mascot`
 | ||
| ### Gets user mascot image
 | ||
| * Method `GET`
 | ||
| * Authentication: required
 | ||
| 
 | ||
| * Response: JSON. Returns a mastodon media attachment entity.
 | ||
| * Example response:
 | ||
| ```json
 | ||
| {
 | ||
|     "id": "abcdefg",
 | ||
|     "url": "https://pleroma.example.org/media/abcdefg.png",
 | ||
|     "type": "image",
 | ||
|     "pleroma": {
 | ||
|         "mime_type": "image/png"
 | ||
|     }
 | ||
| }
 | ||
| ```
 | ||
| 
 | ||
| ### Updates user mascot image
 | ||
| * Method `PUT`
 | ||
| * Authentication: required
 | ||
| * Params:
 | ||
|     * `image`: Multipart image
 | ||
| * Response: JSON. Returns a mastodon media attachment entity
 | ||
|   when successful, otherwise returns HTTP 415 `{"error": "error_msg"}`
 | ||
| * Example response:
 | ||
| ```json
 | ||
| {
 | ||
|     "id": "abcdefg",
 | ||
|     "url": "https://pleroma.example.org/media/abcdefg.png",
 | ||
|     "type": "image",
 | ||
|     "pleroma": {
 | ||
|         "mime_type": "image/png"
 | ||
|     }
 | ||
| }
 | ||
| ```
 | ||
| * Note: Behaves exactly the same as `POST /api/v1/upload`.
 | ||
|   Can only accept images - any attempt to upload non-image files will be met with `HTTP 415 Unsupported Media Type`.
 | ||
| 
 | ||
| ## `/api/pleroma/notification_settings`
 | ||
| ### Updates user notification settings
 | ||
| * Method `PUT`
 | ||
| * Authentication: required
 | ||
| * Params:
 | ||
|     * `followers`: BOOLEAN field, receives notifications from followers
 | ||
|     * `follows`: BOOLEAN field, receives notifications from people the user follows
 | ||
|     * `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
 | ||
| }
 | ||
| ```
 | 
