Manage your ServerPilot servers, system users, apps, and databases with command line!
Set the following variables to your credentials. If these variables are not set when the script is loaded, it will look for them in the "serverpilot_config" file which can either be located in the same directory as the script or in your home directory.
export serverpilot_client_id="CLIENT ID"
export serverpilot_api_key="API KEY"
Replace CLIENT ID
and API KEY
, then run the following two commands:
$ curl -sSL https://raw.githubusercontent.com/kodie/serverpilot-shell/master/lib/serverpilot.sh > /usr/local/bin/serverpilot && chmod a+x /usr/local/bin/serverpilot
$ a="CLIENT ID"; b="API KEY"; printf '\nexport serverpilot_client_id="'$a'"\nexport serverpilot_api_key="'$b'"' >> ~/.bash_profile && source ~/.bash_profile
The first command will download serverpilot.sh
to /usr/local/bin/serverpilot
and make it executable.
The second command will set the serverpilot_client_id
and serverpilot_api_key
variables in your ~/.bash_profile
file.
To test for a successful installation, just run serverpilot servers
.
To update to the latest version at any time, just run the first command again.
Options can be used with commands to do different things.
Option | Name | Description |
---|---|---|
-f |
Force | Skips "Are you sure?" prompts. Used on all delete functions. |
-r |
Raw | Returns raw JSON response instead of user friendly text. Used on all functions that return a response. |
-s |
Silent | Returns nothing. Used on all functions that return a response. Takes priorty over "raw" option and enables "force" option. |
-w |
Wait | Waits for action to complete before finishing. Used on all functions that return an action id. |
This would delete the system user without prompt and would wait for the action to complete before finishing:
$ serverpilot -f -w sysusers delete PPkfc1NECzvwiEBI
This would return a JSON object containing all server info:
$ serverpilot -r servers
An added feature of this API wrapper is the find
function.
Name | Type | Description |
---|---|---|
find |
string |
A comma separated list of fields and values to search for. i.e: name=www2 or id=UXOSIYrdtL4cSGp3,firewall=true |
fields |
string |
A comma separated list of fields to return. i.e: id,name |
This would list all apps on the "www2" server:
$ serverpilot find apps serverid=$(serverpilot find servers name=www2 id)
Servers
System Users
- List All System Users
- Create a System User
- Retrieve an Existing System User
- Delete a System User
- Update a System User
Apps
- List All Apps
- Create an App
- Get Details of an App
- Delete an App
- Update an App
- Add a Custom SSL Cert
- Enable AutoSSL
- Delete a Custom SSL Cert or Disable AutoSSL
- Enable or Disable ForceSSL
Databases
- List All Databases
- Create a Database
- Retrieve an Existing Database
- Delete a Database
- Update a Database User Password
Actions
$ serverpilot 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. |
$ serverpilot servers create www2
$ serverpilot servers UXOSIYrdtL4cSGp3
$ serverpilot servers delete 4zGDDO2xg30yEeum
Name | Type | Description |
---|---|---|
firewall |
bool |
Describes the "enabled" state of the Server 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. |
$ serverpilot servers update UXOSIYrdtL4cSGp3 firewall false
$ serverpilot 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 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. |
$ serverpilot sysusers create FqHWrrcUfRI18F0l derek hlZkUk
$ serverpilot sysusers PPkfc1NECzvwiEBI
Warning: Deleting a System User will delete all Apps (and Databases) associated.
$ serverpilot sysusers delete PPkfc1NECzvwiEBI
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. |
$ serverpilot sysusers update RvnwAIfuENyjUVnl password mRak7S
$ serverpilot 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 an App. Choose from php5.4 , php5.5 , php5.6 , php7.0 , or php7.1 . |
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:
$ serverpilot apps create gallery RvnwAIfuENyjUVnl php7.0 '["example.com","www.example.com"]'
Creating an App with WordPress:
$ serverpilot apps create wordpress RvnwAIfuENyjUVnl php7.0 '["example.com","www.example.com"]' '{"site_title":"My WordPress Site","admin_user":"admin","admin_password":"mypassword","admin_email":"example@example.com"}'
$ serverpilot apps nlcN0TwdZAyNEgdp
$ serverpilot apps delete B1w7yc1tfUPQLIKS
Name | Type | Description |
---|---|---|
runtime |
string |
The PHP runtime for an App. Choose from php5.4 , php5.5 , php5.6 , php7.0 , or php7.1 . |
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. |
$ serverpilot apps update nlcN0TwdZAyNEgdp runtime php5.6
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. |
$ serverpilot apps ssl add nlcN0TwdZAyNEgdp \
'-----BEGIN PRIVATE KEY-----\
...the rest of the key file contents here...\
-----END PRIVATE KEY-----' \
'-----BEGIN CERTIFICATE-----\
...the rest of the key file contents here...\
-----END PRIVATE KEY-----' \
null
Name | Type | Description |
---|---|---|
auto |
bool |
Value must be true . |
$ serverpilot apps ssl update nlcN0TwdZAyNEgdp auto true
$ serverpilot apps ssl delete nlcN0TwdZAyNEgdp
Name | Type | Description |
---|---|---|
force |
bool |
Whether forced redirection from HTTP to HTTPS is enabled. |
$ serverpilot apps ssl update nlcN0TwdZAyNEgdp force true
$ serverpilot 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 |
string |
Required. The name of the Database User. Length must be at most 16 characters. |
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. |
$ serverpilot dbs create nlcN0TwdZAyNEgdp gallerydb arturo 8apNPT
$ serverpilot dbs 8PV1OIAlAW3jbGmM
$ serverpilot dbs delete 8PV1OIAlAW3jbGmM
Name | Type | Description |
---|---|---|
userid |
string |
Required. The id of the Database User. |
userpassword |
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. |
$ serverpilot dbs update 8PV1OIAlAW3jbGmM k2HWtU33mpUsfOdA 8aTWa7
$ serverpilot actions g3kiiYzxPgAjbwcY
MIT. See the License file for more info.