Skip to content

ServerPilot API v1

Notifications You must be signed in to change notification settings

ServerPilot/API

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

70 Commits
 
 
 
 

Repository files navigation

ServerPilot API v1.0

The ServerPilot API is RESTful and allows you to manage ServerPilot resources using HTTP requests. All responses return JSON objects, including errors.

Authentication

The ServerPilot API supports authentication through Basic Auth. You must provide your client_id and API key. All requests require authentication.

You can manage your API credentials from your account.

Only one API key is active at a time. Take care to keep your API key secret!

Base URL

To ensure data privacy, all API requests must be made over HTTPS. Unencrypted requests made over plain HTTP are not supported.

https://api.serverpilot.io/v1

HTTP Status Code Summary

200 OK - Everything worked as expected.

400 Bad Request - We couldn't understand your request. Typically missing a parameter or header.

401 Unauthorized - Either no authentication credentials were provided or they are invalid.

402 Payment Required - Account does not have a valid credit card on file.

403 Forbidden - Typically when trying to alter or delete protected resources.

404 Not Found - You requested a resource that does not exist.

409 Conflict - Typically when trying creating a resource that already exists.

500 Server Error - Something unexpected happened on ServerPilot's end.

Errors

When you a receive a response with a status code in the 4xx or 5xx range, you'll receive a JSON object in the body with details. The object will have a error and message key, like so:

{
    "error": {
        "message": "Password must be at least 8 characters."
    }
}

Limits

There is no limit to the number of servers on an account.

Each account can have at most 1000 SSH keys.

Each server can have at most 1000 system users.

Each system user can have at most 1000 apps and 100 SSH keys.

Each app can have at most 300 domains and 1000 databases.

Resources & Methods

Servers

SSH Keys

System Users

Apps

Databases

Actions

Servers

Servers are 64-bit Ubuntu LTS systems, such Ubuntu 14.04, that are managed by ServerPilot.

Every App, Database, and System User is related to a Server. By default, all Servers will have a serverpilot System User.

List All Servers

GET /servers

$ curl https://api.serverpilot.io/v1/servers \
   -u $CLIENTID:$APIKEY
{
  "data": [
  {
    "id": "FqHWrrcUfRI18F0l",
    "name": "www1",
    "plan": "economy",
    "autoupdates": true,
    "firewall": true,
    "deny_unknown_domains": true,
    "available_runtimes": ["php5.6", "php7.0", "php7.1", "php7.2"],
    "lastaddress": "1.2.3.4",
    "lastconn": 1403130552,
    "datecreated": 1403130551
  }, {
    "id": "4zGDDO2xg30yEeum",
    "name": "www3",
    "plan": "business",
    "autoupdates": true,
    "firewall": true,
    "deny_unknown_domains": true,
    "available_runtimes": ["php5.6", "php7.0", "php7.1", "php7.2"],
    "lastaddress": "1.2.3.4",
    "lastconn": 1403130554,
    "datecreated": 1403130553
  }]
}

Connect a New Server

Use this method to tell ServerPilot that you plan to connect a new server.

Once you have the id and apikey, you'll need to:

  • download the serverpilot-installer script, and
  • run the script with the values specific to your server.

If you were to manually log in to your server and do this, it would look like:

$ export SERVERID=JvFFIQn2WV8VHDsP
$ export SERVERAPIKEY=4lW87naDckYJq1carYffSAwBISa0wfVp5TYh3m3fQSA
$ sudo apt-get update && sudo apt-get -y install wget ca-certificates && \
  sudo wget -nv -O serverpilot-installer https://download.serverpilot.io/serverpilot-installer && \
  sudo sh serverpilot-installer \
    --server-id=$SERVERID \
    --server-apikey=$SERVERAPIKEY

ServerPilot will install Nginx, Apache, PHP, and MySQL. You can just sit back and relax.

POST /servers

Name Type Description
name string Required. The nickname of the Server. Length must be between 1 and 255 characters. Characters can be of lowercase ascii letters, digits, a period, or a dash ('abcdefghijklmnopqrstuvwxyz0123456789-'), but must start with a lowercase ascii letter and end with either a lowercase ascii letter or digit. www.store2 is a valid name, while .org.company nor www.blog- are.
plan string The plan the server is on. Must be either economy, business, or first_class. If not specified, defaults to economy.
enable_ssh_password_auth bool If true, password authentication for SSH/SFTP logins is enabled when the server is being initially configured by ServerPilot. If false, has no effect (does not disable passwored authentication). Defaults to false.
$ curl https://api.serverpilot.io/v1/servers \
   -u $CLIENTID:$APIKEY \
   -H "Content-Type: application/json" \
   -d '{"name": "www2"}'
{
  "actionid": "tW2fu4hjHnsix6Rn",
  "data":
  {
    "id": "UXOSIYrdtL4cSGp3",
    "name": "www2",
    "plan": "economy",
    "autoupdates": true,
    "firewall": true,
    "deny_unknown_domains": true,
    "available_runtimes": ["php5.6", "php7.0", "php7.1", "php7.2"],
    "lastaddress": null,
    "lastconn": null,
    "datecreated": 1403130553,
    "apikey": "nqXUevYSkpW09YKy7CY7PdnL14Q1HIlAfniJZwzjqNQ"
  }
}

Retrieve an Existing Server

GET /servers/:id

$ curl https://api.serverpilot.io/v1/servers/UXOSIYrdtL4cSGp3 \
   -u $CLIENTID:$APIKEY \
{
  "data":
  {
    "id": "UXOSIYrdtL4cSGp3",
    "name": "www2",
    "plan": "economy",
    "autoupdates": true,
    "firewall": true,
    "deny_unknown_domains": true,
    "available_runtimes": ["php5.6", "php7.0", "php7.1", "php7.2"],
    "lastaddress": "1.2.3.4",
    "lastconn": 1403130554,
    "datecreated": 1403130553
  }
}

Delete a Server

DELETE /servers/:id

$ curl https://api.serverpilot.io/v1/servers/4zGDDO2xg30yEeum \
   -u $CLIENTID:$APIKEY \
   -X DELETE
{
  "data": {}
}

Update a Server

POST /servers/:id

Name Type Description
plan string The plan the server is on. Must be either economy, business, or first_class.
firewall bool Describes the "enabled" state of the server's firewall. false means the firewall is not enabled.
autoupdates bool Describes the "enabled" state of automatic system updates. false means automatic system updates are not enabled.
deny_unknown_domains bool Whether requests for domains not associated with any app are denied (true) or are sent to the default app (false).
$ curl https://api.serverpilot.io/v1/servers/UXOSIYrdtL4cSGp3 \
   -u $CLIENTID:$APIKEY \
   -H "Content-Type: application/json" \
   -d '{"firewall": false}'
{
  "actionid": "g3kiiYzxPgAjbwcY",
  "data":
  {
    "id": "UXOSIYrdtL4cSGp3",
    "name": "www2",
    "plan": "economy",
    "autoupdates": true,
    "firewall": false,
    "deny_unknown_domains": true,
    "lastaddress": "1.2.3.4",
    "available_runtimes": ["php5.6", "php7.0", "php7.1", "php7.2"],
    "lastconn": 1403130554,
    "datecreated": 1403130553
  }
}

SSH Keys

SSH Keys are managed account-wide. Once an SSH Key is added to your account, it can be assigned to one or more System Users.

List SSH Keys

GET /sshkeys

$ curl https://api.serverpilot.io/v1/sshkeys \
   -u $CLIENT_ID:$API_KEY
{
  "data": [
    {
      "id": "aUAG0Z3p0F3xmc6R",
      "name": "joe's key",
      "sha256_fingerprint": "SHA256:...",
      "public_key": "ssh-rsa ...",
      "datecreated": 1403139066
    },
    {
      "id": "QecKhpb14kk2a6H3",
      "name": "jenny's key",
      "sha256_fingerprint": "SHA256:...",
      "public_key": "ssh-rsa ...",
      "datecreated": 1403139067
    }
  ]
}

Add an SSH Key

POST /sshkeys

The public key must be a string in the format:

KEY_TYPE PEM_ENCODED_KEY OPTIONAL_COMMENT

This is the same format as the contents of a .pub file created with the ssh-keygen command.

The KEY_TYPE must be either ssh-rsa or ssh-ed25519.

Name Type Description
name string Required. The name of the SSH Key. Length must be between 1 and 50 characters. Characters can be any printable character other than <, >, and ".
public_key string Required. The public key to add.
$ curl https://api.serverpilot.io/v1/sshkeys \
   -u $CLIENT_ID:$API_KEY \
   -H "Content-Type: application/json" \
   -d '{"name": "joe's key", "public_key": "ssh-rsa ..."}'
{
  "data":
  {
    "id": "aUAG0Z3p0F3xmc6R",
    "name": "joe's key",
    "sha256_fingerprint": "SHA256:...",
    "public_key": "ssh-rsa ...",
    "datecreated": 1403139066
  }
}

Retrieve an Existing SSH Key

GET /sshkeys/:id

Returns the SSH Key's details in addition to a list of System Users using this SSH Key.

$ curl https://api.serverpilot.io/v1/sshkeys/aUAG0Z3p0F3xmc6R \
   -u $CLIENT_ID:$API_KEY
{
  "data":
  {
    "id": "aUAG0Z3p0F3xmc6R",
    "name": "joe's key",
    "sha256_fingerprint": "SHA256:...",
    "public_key": "ssh-rsa ...",
    "datecreated": 1403139066,
    "sysusers": [
      {
        "id": "PdmHhsb3fnaZ2r5f",
        "name": "serverpilot",
        "serverid": "FqHWrrcUfRI18F0l",
        "datecreated": 1403084618
      },
      {
        "id": "RvnwAIfuENyjUVnl",
        "name": "serverpilot",
        "serverid": "FqHWrrcUfRI18F0l",
        "datecreated": 1402875948
      }
    ]
  }
}

Rename an SSH Key

POST /sshkeys/:id

Name Type Description
name string Required. The new name of the SSH Key. Length must be between 1 and 50 characters. Characters can be any printable character other than <, >, and ".
$ curl https://api.serverpilot.io/v1/sshkeys/RvnwAIfuENyjUVnl \
   -u $CLIENT_ID:$API_KEY \
   -H "Content-Type: application/json" \
   -d '{"name": "new name for joe's key"}'
{
  "data":
  {
    "id": "aUAG0Z3p0F3xmc6R",
    "name": "new name for joe's key",
    "sha256_fingerprint": "SHA256:...",
    "public_key": "ssh-rsa ...",
    "datecreated": 1403139066
  }
}

Delete an SSH Key

DELETE /sshkeys/:id

Delete an SSH Key so that it will no longer be available for assignment to System Users.

An SSH Key can't be deleted if it is currently in use by any System Users.

$ curl https://api.serverpilot.io/v1/sshkeys/aUAG0Z3p0F3xmc6R \
   -u $CLIENT_ID:$API_KEY \
   -X DELETE
{
  "data": {}
}

System Users

System Users are Linux user accounts that ServerPilot creates on your Server. Every App belongs to and runs as one of these System Users. You can log in to your Server as a System User via SSH to deploy an App or view an App's log files.

By default, ServerPilot creates the serverpilot System User.

The home directory of each System User created by ServerPilot is

/srv/users/USERNAME

Under the System User's home directory are additional directories:

  • apps — each app has its own directory under here.
  • log — each app has its log files here.

List All System Users

GET /sysusers

$ curl https://api.serverpilot.io/v1/sysusers \
   -u $CLIENTID:$APIKEY
{
  "data": [
  {
    "id": "PdmHhsb3fnaZ2r5f",
    "name": "serverpilot",
    "serverid": "FqHWrrcUfRI18F0l"
  },
  {
    "id": "RvnwAIfuENyjUVnl",
    "name": "serverpilot",
    "serverid": "4zGDDO2xg30yEeum"
  }]
}

Create a System User

POST /sysusers

Name Type Description
serverid string Required. The id of the Server.
name string Required. The name of the System User. Length must be between 3 and 32 characters. Characters can be of lowercase ascii letters, digits, or a dash ('abcdefghijklmnopqrstuvwxyz0123456789-'), but must start with a lowercase ascii letter. user-32 is a valid name, while 3po is not.
password string The password of the System User. If user has no password, they will not be able to SSH/SFTP in with a password. No leading or trailing whitespace is allowed and the password must be at least 8 and no more than 200 characters long.
sshkey_id string The id of an SSH Key to add to the System User. If the user does not have an SSH Key, they will not be able to SSH/SFTP in using public key authentication.
$ curl https://api.serverpilot.io/v1/sysusers \
   -u $CLIENTID:$APIKEY \
   -H "Content-Type: application/json" \
   -d '{"serverid": "FqHWrrcUfRI18F0l", "name": "derek", "password": "hlZkUk"}'
{
  "actionid": "nnpgQoNzSK11fuTe",
  "data":
  {
    "id": "PPkfc1NECzvwiEBI",
    "name": "derek",
    "serverid": "FqHWrrcUfRI18F0l"
  }
}

Change the Password of a System User

POST /sysusers/:id

Name Type Description
password string Required. The new password of the System User. If user has no password, they will not be able to log in with a password. No leading or trailing whitespace is allowed and the password must be at least 8 and no more than 200 characters long.
$ curl https://api.serverpilot.io/v1/sysusers/RvnwAIfuENyjUVnl \
   -u $CLIENT_ID:$API_KEY \
   -H "Content-Type: application/json" \
   -d '{"password": "2short"}'
{
  "actionid": "OF42xCWkKcaX3qG2",
  "data":
  {
    "id": "RvnwAIfuENyjUVnl",
    "name": "serverpilot",
    "serverid": "4zGDDO2xg30yEeum"
  }
}

Retrieve an Existing System User

GET /sysusers/:id

$ curl https://api.serverpilot.io/v1/sysusers/PPkfc1NECzvwiEBI \
   -u $CLIENTID:$APIKEY
{
  "data":
  {
    "id": "PPkfc1NECzvwiEBI",
    "name": "derek",
    "serverid": "FqHWrrcUfRI18F0l"
  }
}

Delete a System User

DELETE /sysusers/:id

Warning: Deleting a System User will delete all Apps (and Databases) associated.

$ curl https://api.serverpilot.io/v1/sysusers/PPkfc1NECzvwiEBI \
   -u $CLIENTID:$APIKEY \
   -X DELETE
{
  "actionid": "9tvygrrXZulYuizz",
  "data": {}
}

Update a System User

POST /sysusers/:id

Name Type Description
password string Required. The new password of the System User. If user has no password, they will not be able to log in with a password. No leading or trailing whitespace is allowed and the password must be at least 8 and no more than 200 characters long.
$ curl https://api.serverpilot.io/v1/sysusers/RvnwAIfuENyjUVnl \
   -u $CLIENTID:$APIKEY \
   -H "Content-Type: application/json" \
   -d '{"password": "mRak7S"}'
{
  "actionid": "OF42xCWkKcaX3qG2",
  "data":
  {
    "id": "RvnwAIfuENyjUVnl",
    "name": "serverpilot",
    "serverid": "4zGDDO2xg30yEeum"
  }
}

Add an SSH Key to a System User

POST /sysusers/:id/sshkeys

Name Type Description
sshkey_id string Required. The id of the SSH Key to add to this System User.
$ curl https://api.serverpilot.io/v1/sysusers/RvnwAIfuENyjUVnl/sshkeys \
   -u $CLIENT_ID:$API_KEY \
   -H "Content-Type: application/json" \
   -d '{"sshkey_id": "aUAG0Z3p0F3xmc6R"}'
{
  "actionid": "OF42xCWkKcaX3qG2",
  "data": {}
}

Remove an SSH Key from a System User

DELETE /sysusers/:sysuser_id/sshkeys/:sshkey_id

$ curl https://api.serverpilot.io/v1/sysusers/RvnwAIfuENyjUVnl/sshkeys/aUAG0Z3p0F3xmc6R \
   -u $CLIENT_ID:$API_KEY \
   -X DELETE
{
  "actionid": "OF42xCWkKcaX3qG2",
  "data": {}
}

List SSH Keys of a System User

GET /sysusers/:id/sshkeys

$ curl https://api.serverpilot.io/v1/sysusers/RvnwAIfuENyjUVnl/sshkeys \
   -u $CLIENT_ID:$API_KEY
{
  "data": [
    {
      "id": "aUAG0Z3p0F3xmc6R",
      "name": "joe's key",
      "sha256_fingerprint": "SHA256:...",
      "public_key": "ssh-rsa ...",
      "datecreated": 1403139066
    },
    {
      "id": "QecKhpb14kk2a6H3",
      "name": "jenny's key",
      "sha256_fingerprint": "SHA256:...",
      "public_key": "ssh-rsa ...",
      "datecreated": 1403139067
    }
  ]
}

Apps

Apps are your web applications. Sometimes people call apps "websites".

ServerPilot currently supports PHP 5.4, 5.5, 5.6, 7.0, 7.1, and 7.2 apps.

ServerPilot configures your servers with Nginx as the public-facing webserver. All requests are proxied to Apache 2.4 so your apps can use .htaccess files. PHP is configured to run via FPM. Each app can have multiple MySQL databases.

The web root directory for each app is:

/srv/users/serverpilot/apps/{APPNAME}/public

ServerPilot does not manage DNS for you. In order for you to access your apps by their domain name, you must make the appropriate changes in your domain's DNS zone so that your domain name resolves to your server's IP address. You can do this where you currently manage DNS for your domain.

List All Apps

GET /apps

$ curl https://api.serverpilot.io/v1/apps \
   -u $CLIENTID:$APIKEY
{
  "data": [
  {
    "id": "c77JD4gZooGjrF8K",
    "datecreated": 1403139066,
    "name": "blog",
    "sysuserid": "RvnwAIfuENyjUVnl",
    "domains": ["www.myblog.com", "blog.com"],
    "ssl": null,
    "serverid": "4zGDDO2xg30yEeum",
    "runtime": "php7.0"
  },
  {
    "id": "B1w7yc1tfUPQLIKS",
    "datecreated": 1403143012,
    "name": "store",
    "sysuserid": "RvnwAIfuENyjUVnl",
    "domains": ["www.mystore.com", "mystore.com"],
    "ssl": {
      "key": "-----BEGIN PRIVATE KEY----- ...",
      "cert": "-----BEGIN CERTIFICATE----- ...",
      "cacerts": "-----BEGIN CERTIFICATE----- ...",
      "auto": false,
      "force": false
    },
    "serverid": "4zGDDO2xg30yEeum",
    "runtime": "php7.0"
  }]
}

Create an App

POST /apps

Name Type Description
name string Required. The nickname of the App. Length must be between 3 and 30 characters. Characters can be of lowercase ascii letters and digits.
sysuserid string Required. The System User that will "own" this App. Since every System User is specific to a Server, this implicitly determines on which Server the App will be created.
runtime string Required. The PHP runtime for this App. Must be a runtime listed in the server's available_runtimes.
domains array An array of domains that will be used in the webserver's configuration. If you set your app's domain name to example.com, Nginx and Apache will be configured to listen for both example.com and www.example.com. Note: The complete list of domains must be included in every update to this field.
wordpress object If present, installs WordPress on the App. Value is a JSON object containing keys site_title, admin_user, admin_password, and admin_email, each with values that are strings. The admin_password value must be at least 8 and no more than 200 characters long.

Creating an App without WordPress:

$ curl https://api.serverpilot.io/v1/apps \
   -u $CLIENTID:$APIKEY \
   -H "Content-Type: application/json" \
   -d '{"name": "gallery", "sysuserid": "RvnwAIfuENyjUVnl", "runtime": "php7.0", "domains": ["example.com", "www.example.com"]}'

Creating an App with WordPress:

$ curl https://api.serverpilot.io/v1/apps \
   -u $CLIENTID:$APIKEY \
   -H "Content-Type: application/json" \
   -d '{"name": "wordpress", "sysuserid": "RvnwAIfuENyjUVnl", "runtime": "php7.0", "domains": ["example.com", "www.example.com"], "wordpress": {"site_title": "My WordPress Site", "admin_user": "admin", "admin_password": "mypassword", "admin_email": "[email protected]"}}'
{
  "actionid": "dIrCNoWunW92lPjw",
  "data":
  {
    "id": "nlcN0TwdZAyNEgdp",
    "datecreated": 1403143012,
    "name": "gallery",
    "sysuserid": "RvnwAIfuENyjUVnl",
    "domains": ["www.example.com", "example.com"],
    "ssl": null,
    "serverid": "4zGDDO2xg30yEeum",
    "runtime": "php7.0"
  }
}

Get Details of an App

GET /apps/:id

$ curl https://api.serverpilot.io/v1/apps/nlcN0TwdZAyNEgdp \
   -u $CLIENTID:$APIKEY
{
  "data":
  {
    "id": "nlcN0TwdZAyNEgdp",
    "datecreated": 1403143012,
    "name": "gallery",
    "sysuserid": "RvnwAIfuENyjUVnl",
    "domains": ["www.example.com", "example.com", "foo.com"],
    "ssl": {
      "key": "-----BEGIN PRIVATE KEY----- ... -----END PRIVATE KEY-----",
      "cert": "-----BEGIN CERTIFICATE----- ... -----END CERTIFICATE-----",
      "cacerts": "-----BEGIN CERTIFICATE----- ... -----END CERTIFICATE-----",
      "auto": false,
      "force": false
    },
    "autossl": {
      "available": true,
      "domains": ["www.example.com", "example.com"]
    },
    "serverid": "4zGDDO2xg30yEeum",
    "runtime": "php7.0"
  }
}

The value of auto in the ssl object indicates whether AutoSSL is currently enabled for the app. In the example above, since auto is false and there is an SSL certificate, the SSL certificate is a custom certificate rather than an AutoSSL certificate.

To know whether AutoSSL is available for an app, use the autossl key. If the value of available is true, there will also be a domains key with a list of the domains in the currently available AutoSSL certificate. Note that the autossl key is only available through this app details API, not through the apps list API that lists all apps of the account.

Delete an App

DELETE /apps/:id

$ curl https://api.serverpilot.io/v1/apps/B1w7yc1tfUPQLIKS \
   -u $CLIENTID:$APIKEY \
   -X DELETE
{
  "actionid": "88Ypexhx28Y63eyA",
  "data": {}
}

Update an App

POST /apps/:id

Name Type Description
runtime string The PHP runtime for this App. Must be a runtime listed in the server's available_runtimes.
domains array An array of domains that will be used in the webserver's configuration. If you set your app's domain name to example.com, Nginx and Apache will be configured to listen for both example.com and www.example.com. Note: The complete list of domains must be included in every update to this field.
$ curl https://api.serverpilot.io/v1/apps/nlcN0TwdZAyNEgdp \
   -u $CLIENTID:$APIKEY \
   -H "Content-Type: application/json" \
   -d '{"runtime": "php5.6"}'
{
  "actionid": "KlsNzLikw3BRvShc",
  "data":
  {
    "id": "nlcN0TwdZAyNEgdp",
    "datecreated": 1403143012,
    "name": "gallery",
    "sysuserid": "RvnwAIfuENyjUVnl",
    "domains": ["www.example.com", "example.com"],
    "ssl": null,
    "serverid": "4zGDDO2xg30yEeum",
    "runtime": "php5.6"
  }
}

Add a Custom SSL Cert

POST /apps/:id/ssl

A custom SSL cert cannot be added to an app that is using AutoSSL. To replace AutoSSL with a custom SSL certificate, you must first disable AutoSSL on the app before adding the custom SSL certificate.

Name Type Description
key string Required. The contents of the private key.
cert string Required. The contents of the certificate.
cacerts string Required. The contents of the CA certificate(s). If none, null is acceptable.
<?php
$clientid = "YOUR_CLIENTID";
$apikey = "YOUR_APIKEY";

$appid = "YOUR_APPID";

$sslkey = "-----BEGIN PRIVATE KEY-----
...the rest of the key file contents here...
-----END PRIVATE KEY-----";

$sslcert = "-----BEGIN CERTIFICATE-----
...the rest of the certificate file contents here...
-----END CERTIFICATE-----";

$data = array(
    "key" => $sslkey,
    "cert" => $sslcert,
    "cacerts" => null
);
$data_string = json_encode($data);

$ch = curl_init("https://api.serverpilot.io/v1/apps/$appid/ssl");
curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
curl_setopt($ch, CURLOPT_USERPWD, "$clientid:$apikey");
curl_setopt($ch, CURLOPT_CUSTOMREQUEST, "POST");
curl_setopt($ch, CURLOPT_POSTFIELDS, $data_string);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, array(
    'Content-Type: application/json',
    'Content-Length: ' . strlen($data_string))
);
// Uncomment the following line for debugging.
//curl_setopt($ch, CURLOPT_VERBOSE, true);

$result = curl_exec($ch);
curl_close($ch);

echo json_encode(json_decode($result), JSON_PRETTY_PRINT);
{
  "actionid": "BzcMNZ9sdBY62vTd",
  "data":
  {
    "key": "-----BEGIN PRIVATE KEY----- ... -----END PRIVATE KEY-----",
    "cert": "-----BEGIN CERTIFICATE----- ... -----END CERTIFICATE-----",
    "cacerts": "-----BEGIN CERTIFICATE----- ... -----END CERTIFICATE-----"
  }
}

Enable AutoSSL

POST /apps/:id/ssl

AutoSSL can only be enabled when an AutoSSL certificate is available for an app. To determine if an AutoSSL certificate is available for an app, use the app details API call.

Additionally, AutoSSL cannot be enabled when an app currently has a custom SSL certificate. To enable AutoSSL when an app is already using a custom SSL, first delete the app's custom SSL certificate.

Note that disabling AutoSSL is not done through this API call but instead is done by deleting SSL from the app.

Name Type Description
auto bool Value must be true.
$ curl https://api.serverpilot.io/v1/apps/nlcN0TwdZAyNEgdp/ssl \
   -u $CLIENTID:$APIKEY \
   -H "Content-Type: application/json" \
   -d '{"auto": true}'
{
  "actionid": "pneQJGaAwIyIojW8",
  "data":
  {
    "key": "-----BEGIN PRIVATE KEY----- ... -----END PRIVATE KEY-----",
    "cert": "-----BEGIN CERTIFICATE----- ... -----END CERTIFICATE-----",
    "cacerts": "-----BEGIN CERTIFICATE----- ... -----END CERTIFICATE-----",
    "auto": true,
    "force": false
  }
}

Delete a Custom SSL Cert or Disable AutoSSL

DELETE /apps/:id/ssl

$ curl https://api.serverpilot.io/v1/apps/nlcN0TwdZAyNEgdp/ssl \
   -u $CLIENTID:$APIKEY \
   -X DELETE
{
  "actionid": "I1nUHIUR0yzBLESI",
  "data": {}
}

Enable or Disable ForceSSL

POST /apps/:id/ssl

ForceSSL can only be enabled when an app already has SSL enabled.

You cannot enable ForceSSL at the same time as adding a custom SSL certificate or enabling AutoSSL. You must make a separate API call to enable or disable ForceSSL.

ForceSSL will be automatically disabled if SSL is deleted from an app.

Name Type Description
force bool Whether forced redirection from HTTP to HTTPS is enabled.
$ curl https://api.serverpilot.io/v1/apps/nlcN0TwdZAyNEgdp/ssl \
   -u $CLIENTID:$APIKEY \
   -H "Content-Type: application/json" \
   -d '{"force": true}'
{
  "actionid": "S8zEaeSMrD5gSt9A",
  "data":
  {
    "key": "-----BEGIN PRIVATE KEY----- ... -----END PRIVATE KEY-----",
    "cert": "-----BEGIN CERTIFICATE----- ... -----END CERTIFICATE-----",
    "cacerts": "-----BEGIN CERTIFICATE----- ... -----END CERTIFICATE-----",
    "auto": false,
    "force": true
  }
}

Databases

Databases are MySQL databases. Each Database is associated with an App.

There is only one Database User for each Database.

List All Databases

GET /dbs

$ curl https://api.serverpilot.io/v1/dbs \
   -u $CLIENTID:$APIKEY
{
  "data": [
  {
    "id": "hdXkAZchuj27Hm1L",
    "name": "wordpress",
    "appid": "c77JD4gZooGjrF8K",
    "serverid": "4zGDDO2xg30yEeum",
    "user": {
      "id": "vt08Qz9kjOC3RVLr",
      "name": "robert"
    }
  }]
}

Create a Database

POST /dbs

Name Type Description
appid string Required. The id of the App.
name string Required. The name of the database. Length must be between 3 and 64 characters. Characters can be of lowercase ascii letters, digits, or a dash ('abcdefghijklmnopqrstuvwxyz0123456789-').
user object Required. A JSON object containing name and password name/value pairs.
user[name] string Required. The name of the Database User. Length must be at most 16 characters.
user[password] string Required. The password of the Database User. No leading or trailing whitespace is allowed and the password must be at least 8 and no more than 200 characters long.
$ curl https://api.serverpilot.io/v1/dbs \
   -u $CLIENTID:$APIKEY \
   -H "Content-Type: application/json" \
   -d '{"appid": "nlcN0TwdZAyNEgdp", "name": "gallerydb", "user": {"name": "arturo", "password": "8apNPT"}}'
{
  "actionid": "gPFiWP9hFNUxvT70",
  "data":
  {
    "id": "8PV1OIAlAW3jbGmM",
    "name": "gallerydb",
    "appid": "nlcN0TwdZAyNEgdp",
    "serverid": "4zGDDO2xg30yEeum",
    "user": {
      "id": "k2HWtU33mpUsfOdA",
      "name": "arturo"
    }
  }
}

Retrieve an Existing Database

GET /dbs/:id

$ curl https://api.serverpilot.io/v1/dbs/8PV1OIAlAW3jbGmM \
   -u $CLIENTID:$APIKEY
{
  "data":
  {
    "id": "8PV1OIAlAW3jbGmM",
    "name": "gallerydb",
    "appid": "nlcN0TwdZAyNEgdp",
    "serverid": "4zGDDO2xg30yEeum",
    "user": {
      "id": "k2HWtU33mpUsfOdA",
      "name": "arturo"
    }
  }
}

Delete a Database

DELETE /dbs/:id

$ curl https://api.serverpilot.io/v1/dbs/8PV1OIAlAW3jbGmM \
   -u $CLIENTID:$APIKEY \
   -X DELETE
{
  "actionid": "AtzNxxz4fZv3zJ9D",
  "data": {}
}

Update the Database User Password

POST /dbs/:id

Name Type Description
user object Required. A JSON object containing id and password name/value pairs.
user[id] string Required. The id of the Database User.
user[password] string Required. The new password of the Database User. No leading or trailing whitespace is allowed and the password must be at least 8 and no more than 200 characters long.
$ curl https://api.serverpilot.io/v1/dbs/8PV1OIAlAW3jbGmM \
   -u $CLIENTID:$APIKEY \
   -d '{"user": {"id": "k2HWtU33mpUsfOdA", "password": "8aTWa7"}}'
{
  "actionid": "VfH12ukDJFv0RZAO",
  "data":
  {
    "id": "8PV1OIAlAW3jbGmM",
    "name": "gallerydb",
    "appid": "nlcN0TwdZAyNEgdp",
    "serverid": "4zGDDO2xg30yEeum",
    "user": {
      "id": "k2HWtU33mpUsfOdA",
      "name": "arturo"
    }
  }
}

Actions

Actions are a record of work done on ServerPilot resources. These can be things like the creation of an App, deploying SSL, deleting an old Database, etc.

All methods that modify a resource will have an actionid top-level key in the JSON response if any server configuration was required. The actionid can be used to track the status of the Action.

Possible values of Action status

Status Description
success Action was completed successfully.
open Action has not completed yet.
error Action has completed but there were errors.

Check the Status of an Action

GET /actions/:id

$ curl https://api.serverpilot.io/v1/actions/g3kiiYzxPgAjbwcY \
   -u $CLIENTID:$APIKEY
{
  "data":
  {
    "id": "g3kiiYzxPgAjbwcY",
    "serverid": "4zGDDO2xg30yEeum",
    "status": "success",
    "datecreated": 1403138066
  }
}

Releases

No releases published

Packages

No packages published

Contributors 4

  •  
  •  
  •  
  •