gallery.accords-library.com/API.md

9.9 KiB

szurubooru uses REST API for all operations.

Table of contents

  1. General rules

  2. API reference

  3. Resources

  4. Search

General rules

Authentication

Authentication is achieved by means of basic HTTP auth. For this reason, it is recommended to connect through HTTPS. There are no sessions, so every privileged request must be authenticated. Available privileges depend on the user's rank. The way how rank translates to privileges is defined in the server's configuration.

It is recommended to add ?bump-login GET parameter to the first request in a client "session" (where the definition of a session is up to the client), so that the user's last login time is kept up to date.

Basic requests

Every request must use Content-Type: application/json and Accept: application/json. An exception to this rule are requests that upload files.

File uploads

Requests that upload files must use multipart/form-data encoding. JSON metadata must then be included as field of name metadata, whereas files must be included as separate fields with names specific to each request type.

Error handling

All errors (except for unhandled fatal server errors) send relevant HTTP status code together with JSON of following structure:

{
    "title": "Generic title of error message, e.g. 'Not found'",
    "description": "Detailed description of what went wrong, e.g. 'User `rr-` not found."
}

API reference

Depending on the deployment, the URLs might be relative to some base path such as /api/. Values denoted with diamond braces (<like this>) signify variable data.

Listing users

  • Request

    GET /users/?page=<page>&pageSize=<page-size>&query=<query>

  • Output

    {
        "query": "rr-",
        "users": [
            <user>,
            <user>,
            <user>,
            <user>,
            <user>
        ],
        "page": 1,
        "pageSize": 5,
        "total": 7
    }
    

    ...where <user> is an user resource and query contains standard search query.

  • Errors

    • privileges are too low
  • Description

    Searches for users.

    Anonymous tokens

    Same as name token.

    Named tokens

    <value> Description
    name having given name (accepts wildcards)
    creation-date registered at given date
    creation-time alias of creation-date
    last-login-date whose most recent login date matches given date
    last-login-time alias of last-login-date
    login-date alias of last-login-date
    login-time alias of last-login-date

    Order tokens

    <value> Description
    random as random as it can get
    name A to Z
    creation-date newest to oldest
    creation-time alias of creation-date
    last-login-date recently active first
    last-login-time alias of last-login-date
    login-date alias of last-login-date
    login-time alias of last-login-date

    Special tokens

    None.

Creating user

  • Request

    POST /users

  • Input

    {
        "name": <user-name>,
        "password": <user-password>,
        "email": <email>
    }
    
  • Output

    {
        "user": <user>
    }
    

    ...where <user> is an user resource.

  • Errors

    • such user already exists (names are case insensitive)
    • either user name, password or email are invalid
    • privileges are too low
  • Description

    Creates a new user using specified parameters. Names and passwords must match user_name_regex and password_regex from server's configuration, respectively. Email address is optional. If the user happens to be the first user ever created, they're granted highest available rank, becoming an administrator. Subsequent users will be given the rank indicated by default_rank in the server's configuration.

Updating user

  • Request

    PUT /user/<name>

  • Input

    {
        "name": <user-name>,
        "password": <user-password>,
        "email": <email>,
        "rank": <rank>,
        "avatarStyle": <avatar-style>
    }
    
  • Files

    • avatar - the content of the new avatar.
  • Output

    {
        "user": <user>
    }
    

    ...where <user> is an user resource.

  • Errors

    • the user does not exist
    • the user with new name already exists (names are case insensitive)
    • either user name, password, email or rank are invalid
    • the user is trying to update their or someone else's rank to higher than their own
    • privileges are too low
    • avatar is missing for manual avatar style
  • Description

    Updates an existing user using specified parameters. Names and passwords must match user_name_regex and password_regex from server's configuration, respectively. All fields are optional - update concerns only provided fields. To update last login time, see authentication. Avatar style can be either gravatar or manual. manual avatar style requires client to pass also avatar file - see file uploads for details.

Getting user

  • Request

    GET /user/<name>

  • Output

    {
        "user": <user>
    }
    

    ...where <user> is an user resource.

  • Errors

    • the user does not exist
    • privileges are too low
  • Description

    Retrieves information about an existing user.

Removing user

  • Request

    DELETE /user/<name>

  • Output

    {}
    
  • Errors

    • the user does not exist
    • privileges are too low
  • Description

    Deletes existing user.

Password reset - step 1: mail request

  • Request

    GET /password-reset/<email-or-name>

  • Output

    {}
    
  • Errors

    • the user does not exist
    • the user hasn't provided an email address
  • Description

    Sends a confirmation email to given user. The email contains link containing a token. The token cannot be guessed, thus using such link proves that the person who requested to reset the password also owns the mailbox, which is a strong indication they are the rightful owner of the account.

Password reset - step 2: confirmation

  • Request

    POST /password-reset/<email-or-name>

  • Input

    {
        "token": <token-from-email>
    }
    
  • Output

    {
        "password": <new-password>
    }
    
  • Errors

    • the token is missing
    • the token is invalid
    • the user does not exist
  • Description

    Generates a new password for given user. Password is sent as plain-text, so it is recommended to connect through HTTPS.

Resources

User

{
    "id":            2,
    "name":          "rr-",
    "email":         "rr-@sakuya.pl",    // available only if the request is authenticated by the same user
    "rank":          "admin",            // controlled by server's configuration
    "rankName":      "Administrator",    // controlled by server's configuration
    "lastLoginTime": "2016-04-08T20:20:16.570517",
    "creationTime":  "2016-03-28T13:37:01.755461",
    "avatarStyle":   "gravatar",        // "gravatar" or "manual"
    "avatarUrl":     "http://gravatar.com/(...)"
}

Search

Search queries are built of tokens that are separated by spaces. Each token can be of following form:

Syntax Token type Description
<value> anonymous tokens basic filters
<key>:<value> named tokens advanced filters
order:<style> order tokens sort results
special:<value> special tokens filters usually tied to the logged in user

Most of anonymous and named tokens support ranged and composite values that take following form:

<value> Description
a,b,c will show things that satisfy either a, b or c.
1.. will show things that are equal to or greater than 1.
..4 will show things that are equal to at most 4.
1..4 will show things that are equal to 1, 2, 3 or 4.

Date/time values can be of following form:

  • today
  • yesterday
  • <year>
  • <year>-<month>
  • <year>-<month>-<day>

Some fields, such as user names, can take wildcards (*).

Example

Searching for posts with following query:

sea -fav-count:8.. type:swf uploader:Pirate

will show flash files tagged as sea, that were liked by seven people at most, uploaded by user Pirate.