documentation/content/en/client/intro.md

5.3 KiB

title description menu
Getting started with the API A primer on REST APIs, HTTP requests and responses, and parameters.
docs
weight parent
10 client

An introduction to REST

Mastodon provides access to its data over a REST API. REST stands for REpresentational State Transfer, but for our purposes, just think of it as sending and receiving information about various resources based on the request. The Mastodon REST API uses HTTP for its requests and JSON for its payloads.

Understanding HTTP requests and responses

REST API endpoints can be called with certain HTTP methods, and more than one method can be used on the same endpoint. The Mastodon API will generally use the following HTTP methods:

  • GET: Read or view a resource.
  • POST: Send information to the server.
  • PUT | PATCH: Update a resource.
  • DELETE: Removes a resource.

Your favorite programming language probably has a utility or library to make HTTP requests. For the purposes of this section, the cURL utility will be used for examples, which is a command-line utility included with many operating systems by default (as curl).

With cURL, the default HTTP method is GET, but you can specify the type of request to make by using the --request or -X flag; for example, curl -X POST will send a POST request instead of a GET request. You may also want to use the -i flag to include additional HTTP headers that may be returned as part of the response where relevant.

Providing parameters

HTTP requests can include additional parameters in various different ways, but most notably, the Mastodon API understands query strings, form data, and JSON.

{{< hint style="info" >}} Query strings, form data, and JSON submitted via POST body are equally understood by the API. It is expected that query strings are used for GET requests, and form data or JSON is used for all other requests. {{< /hint >}}

Query strings

Request the URL, but append query strings to the end. Query strings can be appended by first typing ? and then appending them in the form of parameter=value. Multiple query strings can be appended by separating them with &. For example:

curl https://mastodon.example/endpoint?q=test&n=0

Form data

Instead of mutating the URL with query strings, you can send the data separately. With cURL, this is done by passing it with the --data or -d flag. Data may be sent together similar to query strings, or it may be sent separately as key-value pairs with multiple data flags. You may also use the --form or -F flag for key-value pairs, which also allows sending multipart data such as files. For example:

# send raw data as query strings
curl -X POST \
     -d 'q=test&n=0' \
     https://mastodon.example/endpoint
# send raw data separately
curl -X POST \
     -d 'q=test' \
     -d 'n=0' \
     https://mastodon.example/endpoint
# explicit form-encoded; allows for multipart data
curl -X POST \
     -F 'q=test' \
     -F 'n=0' \
     -F 'file=@filename.jpg' \
     https://mastodon.example/endpoint

JSON

JavaScript Object Notation as defined in ECMA-404. Quick one-page overview: https://www.json.org/

Similar to sending form data, but with an additional header to specify that the data is in JSON format. To send a JSON request with cURL, specify the JSON content type with a header, then send the JSON data as form data:

curl -X POST \
     -H 'Content-Type: application/json' \
     -d '{"parameter": "value"}' \
     https://mastodon.example/endpoint

Data types

Multiple values (Array)

An array parameter must encoded using bracket notation, e.g. array[]=foo&array[]=bar would be translated into the following:

array = [
  'foo',
  'bar',
]

As JSON, arrays are formatted like so:

{
  "array": ["foo", "bar"]
}

Nested parameters (Hash)

Some parameters need to be nested. For that, bracket notation must also be used. For example, source[privacy]=public&source[language]=en would be translated into:

source = {
  privacy: 'public',
  language: 'en',
}

As JSON, hashes are formatted like so:

{
  "source": {
    "privacy": "public",
    "language": "en"
  }
}

True-or-false (Booleans)

A boolean value is considered false for the values 0, f, F, false, FALSE, off, OFF, considered to not be provided for empty strings, and considered to be true for all other values. When using JSON data, use the literals true, false, and null instead.

Files

File uploads must be encoded using multipart/form-data.

This can be combined with arrays as well.

How to use API response data

The Mastodon REST API will return JSON as the response text. It also returns HTTP headers which may be useful in handling the response, as well as an HTTP status code which should let you know how the server handled the request. The following HTTP status codes may be expected:

  • 200 = OK. The request was handled successfully.
  • 4xx = Client error. Your request was not correct. Most commonly, you may see 401 Unauthorized, 404 Not Found, 410 Gone, or 422 Unprocessed.
  • 5xx = Server error. Something went wrong while handling the request. Most commonly, you may see 503 Unavailable.