Organize WordPress Backups in Slack With Kinsta API

by | Dec 18, 2023 | Etcetera | 0 comments

Backups offer web site householders a confidence-boosting coverage internet in case of mishaps. Shoppers of Kinsta’s Controlled WordPress Internet hosting provider get pleasure from six varieties of backups: automatic daily, now not mandatory hourly, information, system-generated, downloadable, and external backups sent automatically to your Amazon S3 or Google Cloud Storage.

Managing the ones backups is a breeze inside the MyKinsta dashboard. And now the Kinsta API opens the door on your method to operating with WordPress web pages and their backups. From companies with their dashboards to control lots of installations to teams taking a look to leverage productivity apparatus like Slack, the Kinsta API can be in agreement connect it all.

This data explores the various backup endpoints available right through the API, their conceivable, and the way in which you’ll have the ability to use them to control backups in a Slack atmosphere.

Figuring out the Kinsta API

The Kinsta API is a powerful instrument that lets you engage with Kinsta services like hosted WordPress web pages programmatically. It’ll in all probability be in agreement automate various tasks related to WordPress keep watch over, at the side of internet web page advent, retrieving internet web page wisdom, getting the standing of a web site, browsing and restoring backups, and additional.

To use Kinsta’s API, you’ll have to have an account with at least one WordPress internet web page, software, or database in MyKinsta. You moreover need to generate an API key to authenticate and get right to use your account.

To generate an API key:

  1. Transfer to your MyKinsta dashboard.
  2. Navigate to the API Keys internet web page (Your identify > Company settings > API Keys).
  3. Click on on Create API Key.
  4. Select an expiration or set a custom designed get began date and selection of hours for the vital factor to expire.
  5. Give the vital factor a unique identify.
  6. Click on on Generate.

After growing an API key, copy it and store it somewhere safe (the usage of a password supervisor is actually helpful), as that’s the highest time it’s revealed within MyKinsta. You’ll have the ability to generate a few API keys, which could be listed on the API Keys internet web page. If you wish to revoke an API key, click on at the Revoke button next to its identify and expiry date.

Managing WordPress Internet web page Backups With Kinsta API

The Kinsta API has endpoints for the ones backup-related operations:

To interact with the ones endpoints, you’ll need the API key you generated earlier. Let’s uncover the ones endpoints and later mix them proper right into a Slackbot so that you’ll have the ability to use Slack’s Slash instructions to interact with the Kinsta API.

How To Get Information, Scheduled, and System-Generated Backups With Kinsta API

Whilst you navigate to a selected WordPress internet web page within your MyKinsta dashboard and click on at the Backups tab, you’ll find a tick list of backups, at the side of daily, hourly (if activated), information, and system-generated backups.

See also  Download a FREE 404 Page Template for Divi’s Podcaster Layout Pack

Now, for individuals who purpose to get right to use this data or execute actions from an external instrument or platform, our API simplifies the process.

You’ll have the ability to retrieve backup details akin to ID, identify, kind, and advent time programmatically. By way of the usage of the API on your private apparatus, you’ll have the ability to do away with the need for dashboard get right to use on each instance this information is wanted

To get right to use this endpoint, obtain your internet web page’s atmosphere ID programmatically right through the get web site surroundings endpoint, which returns details about your internet web page’s atmosphere, at the side of its ID:

{
  "internet web page": {
    "environments": [
      {
        "id": "54fb80af-576c-4fdc-ba4f-b596c83f15a1",
        "name": "first-site",
        "display_name": "First site",
        "is_blocked": false,
        "id_edge_cache": "54fb80af-576c-4fdc-ba4f-b596c83f15a1",
        "cdn_cache_id": "54fb80af-576c-4fdc-ba4f-b596c83f15a1",
        "is_premium": false,
        "domains": [
          {
            "id": "54fb80af-576c-4fdc-ba4f-b596c83f15a1",
            "name": "example.com",
            "type": "live"
          }
        ],
        "primaryDomain": {
          "id": "54fb80af-576c-4fdc-ba4f-b596c83f15a1",
          "identify": "example.com",
          "kind": "live"
        },
        "ssh_connection": {
          "ssh_port": "808080",
          "ssh_ip": {
            "external_ip": "1xx.1xx.1xx.1xx"
          }
        },
        "container_info": {
          "id": "54fb80af-576c-4fdc-ba4f-b596c83f15a1",
          "php_engine_version": "php8.0"
        }
      }
    ]
  }
}

Whilst you know your internet web page’s atmosphere ID, you’ll have the ability to then send a GET request to https://api.kinsta.com/v2/websites/environments/${envId}/backups to retrieve an array of your entire internet web page’s backups:

curl -i -X GET 
  'https://api.kinsta.com/v2/web pages/environments/{env_id}/backups' 
  -H 'Authorization: Bearer '

This will likely increasingly more return an Object with an array of backups, which you’ll have the ability to loop into your client and also manipulate its wisdom:

{
  "atmosphere": {
    "display_name": "MyEnvironment",
    "backups": [
      {
        "id": 123456789,
        "name": "mySiteName-1234567890-backupType",
        "note": "Daily Auto Backup",
        "type": "manual",
        "created_at": 1665382600770
      }
    ]
  }
}

How To Restore a Scheduled, Information or System-Generated Backup With Kinsta API

With the Kinsta API, you’ll have the ability to moreover restore a selected backup from the generated tick list to an environment the usage of a POST request.

All you wish to have is the backup ID, purpose atmosphere ID, and the environment identify of the backup. This movement moreover gets rid of the need to revisit the MyKinsta dashboard for restoration tasks.

curl -i -X POST 
  'https://api.kinsta.com/v2/web pages/environments/{target_env_id}/backups/restore' 
  -H 'Authorization: Bearer ' 
  -H 'Content material material-Type: instrument/json' 
  -d '{
    "backup_id": 123456789,
    "env_display_name_of_backup": "my-env"
  }'

The response to this request accommodates an operation status and an operation ID, enabling you to programmatically practice the expansion of the restoration with our operation standing endpoint:

{
  "operation_id": "backups:restore-54fb80af-576c-4fdc-ba4f-b596c83f15a1",
  "message": "Restoring a backup to atmosphere in expansion",
  "status": 202
}

How To Get Downloadable Backups With Kinsta API

While there’s in recent years no endpoint to create downloadable backups, you’ll have the ability to get right to use provide downloadable backups and their download links programmatically.

This will also be finished via sending a GET request to https://api.kinsta.com/v2/websites/environments/{env_id}/downloadable-backups to retrieve an array of your entire internet web page’s downloadable backups:

curl -i -X GET 
  'https://api.kinsta.com/v2/web pages/environments/{env_id}/downloadable-backups' 
  -H 'Authorization: Bearer '

Each and every downloadable backup inside the array accommodates an ID, advent timestamp, download link, expiration timestamp, and a status indicating whether or not or now not the era process is ongoing:

{
  "atmosphere": {
    "display_name": "MyEnvironment",
    "downloadable_backups": [
      {
        "id": "1915fa3a-7ef4-4766-806d-71104be7deb0",
        "created_at": 1665382600770,
        "download_link": "https://example.com",
        "expires_at": 1665382600770,
        "is_generation_in_progress": true
      }
    ]
  }
}

Clicking on the download link turns on the download of the backup zip file, allowing you to embed the link on your instrument for at hand get right to use and acquire via your consumers.

Implementing Slack Slash Directions for Managing Backups With Kinsta API

In a modern knowledge, the process of crafting a Slackbot using Node.js and the Kinsta API for internet web page keep watch over was once as soon as detailed. The ideas outlined creating a Slackbot and setting up interaction with the Kinsta API by way of a Node.js instrument hosted on our Utility Internet hosting platform.

Proper right here, you focusing on growing new Slack Slash directions for the three backup endpoints. To watch along proper right here, first assessment the earlier knowledge to understand the Node.js instrument and the way you’ll be able to configure your customized Slackbot.

See also  What Is Cloud Garage?

Once completed, you’ll have the ability to proceed to clone our starter problem with Git:

  1. Navigate to your preferred checklist for storing your code and execute the following command on your terminal:
    git clone -b tutorial-1 --single-branch https://github.com/olawanlejoel/SlackBot-KinstaAPI.git
  2. Switch into the problem folder and arrange the entire required dependencies:
    cd SlackBot-KinstaAPI
    npm arrange

Rising Slash Directions on Slack for Coping with Backups

Inside the previous article, 5 slash directions have been created to deal with the following:

  • /site_id [site name]: Used to retrieve internet web page ID.
  • /environment_id [site name]: Used to retrieve atmosphere ID.
  • /clear_site_cache [environment id]: Used to clear internet web page cache.
  • /restart_php_engine [environment id]: Used to a internet web page’s restart PHP engine.
  • /operation_status [operation id]: Used to check an operation’s status.

For this data, you add 3 new directions. To create Slash directions on Slack, navigate to your Slack software, click on at the Slash Directions menu risk on the left sidebar, and click on at the Create New Command button. Create 3 directions with the ideas below:

Command Temporary Description Usage Hint
/get_backups Retrieve your entire internet web page’s backups with their connected wisdom [Environment ID]
/get_downloadable_backups Retrieve your entire internet web page’s downloadable backups with their connected wisdom and link [Environment ID]
/restore_backup Restore a scheduled or information or components generated backup to an environment [Target environment ID] [Backup ID] [Environment name]

After getting created the ones directions, you’ll have the ability to take a look at your Slack atmosphere via typing /. You’ll perceive the ones directions have been added.

The next move is to enforce interaction with the Kinsta API so that the information passed from Slack will also be received and used to query the proper API endpoint.

Implementing Node.js Fetch Requests for Backup Operations

Whilst you’ve created the vital slash directions, you’ll have the ability to now regulate your Node.js app to respond to them. Let’s get started via growing asynchronous purposes to interact with each endpoint.

Inside the app.js file, let’s define 3 functions:

  • getBackups(environmentId): Fetches information about backups for a selected atmosphere.
  • getDownloadableBackups(environmentId): Retrieves downloadable backups for a given atmosphere.
  • restoreBackup(targetEnvironmentId, backupId, environmentName): Initiates a restoration process for a decided on backup proper right into a specified atmosphere.

Right here’s the Fetch request for each function:

async function getBackups(environmentId) {
    const resp = wait for fetch(
        `${KinstaAPIUrl}/web pages/environments/${environmentId}/backups`,
        {
            means: 'GET',
            headers: getHeaders,
        }
    );
    const wisdom = wait for resp.json();
    return wisdom;
}

async function getDownloadableBackups(environmentId) {
    const resp = wait for fetch(
        `${KinstaAPIUrl}/web pages/environments/${environmentId}/downloadable-backups`,
        {
            means: 'GET',
            headers: getHeaders,
        }
    );
    const wisdom = wait for resp.json();
    return wisdom;
}

async function restoreBackup(targetEnvironmentId, backupId, environmentName) {
    const resp = wait for fetch(
        `${KinstaAPIUrl}/web pages/environments/${targetEnvironmentId}/backups/restore`,
        {
            means: 'POST',
            headers: postHeaders,
            body: JSON.stringify({
                backup_id: backupId,
                env_display_name_of_backup: environmentName,
            }),
        }
    );
    const wisdom = wait for resp.json();
    return wisdom;
}

Each and every function is constructed to keep in touch with the Kinsta API via the usage of JavaScript’s Fetch API. Parameters for atmosphere IDs, backup IDs, and atmosphere names are expected inputs, which are meant to be received from Slack directions and then passed on to these functions for execution.

To streamline the code and prevent repetition, you’ll perceive using 3 variables used to store a very powerful portions: the ground API URL and headers for GET and POST requests.

const KinstaAPIUrl = 'https://api.kinsta.com/v2';

const getHeaders = {
    Authorization: `Bearer ${process.env.KINSTA_API_KEY}`,
};

const postHeaders = {
    'Content material material-Type': 'instrument/json',
    Authorization: `Bearer ${process.env.KINSTA_API_KEY}`,
};

Moreover, refined keys and tokens, such since the Slack signing secret, bot token, app token, company ID, and API key, are stored securely throughout the .env file.

SLACK_SIGNING_SECRET="YOUR_SIGNING_SECRET"
SLACK_BOT_TOKEN="xoxb-YOUR_BOT_TOKEN"
APP_TOKEN="xapp-YOUR_APP_TOKEN"
REACT_APP_KINSTA_COMPANY_ID = 'YOUR_COMPANY_ID' 
REACT_APP_KINSTA_API_KEY = 'YOUR_API_KEY'

With the ones functions and keys in place, the next move involves configuring the Slack directions. This configuration comprises receiving input values from Slack, invoking the connected methods in step with this input, and sending a selected response once more to Slack.

See also  Why You Want To Be The use of A WordPress Website Supervisor (And How)

Configuring Slash Directions With Node.js for Managing Backups

To configure a Slash command, you employ the app.command() function, which functions similarly to event listeners in JavaScript. You specify the command you wish to have to pay attention for and then create an asynchronous callback function to stipulate the desired movement. This function takes 3 parameters:

  • command: Contains the details of the slash command sent throughout the client.
  • ack: Acknowledges the receipt of the slash command.
  • say: Sends a message once more to the Slack channel.

Right here’s the configuration for the three directions:

app.command('/get_backups', async ({ command, ack, say }) => {
    wait for ack();

    let environmentId = command.text;
    let response = wait for getBackups(environmentId);
    let backups = response.atmosphere.backups;

    let backupDetails = backups
        .map((backup) => {
            return `Backup ID: ${backup.id}nName: ${backup.identify}nNote: ${
                backup.practice
            }nType: ${backup.kind}nCreated At: ${new Date(backup.created_at)}nn`;
        })
        .join('');

    if (backupDetails) {
        say(
            `Just right day 👋, listed below are the backup details for atmosphere ID ${environmentId}:nn${backupDetails}`
        );
    } else {
        say(`No backups found out for atmosphere ID ${environmentId}`);
    }
});

app.command('/get_downloadable_backups', async ({ command, ack, say }) => {
    wait for ack();

    let environmentId = command.text;
    let response = wait for getDownloadableBackups(environmentId);
    let backups = response.atmosphere.downloadable_backups;

    let downloadable_backupDetails = backups
        .map((backup) => {
            return `Backup ID: ${backup.id}nDownload Link: ${
                backup.download_link
            }nCreated At: ${new Date(backup.created_at)}nExpires At: ${new Date(
                backup.expires_at
            )}nIs Era in Building: ${backup.is_generation_in_progress}nn`;
        })
        .join('');

    if (downloadable_backupDetails) {
        say(
            `Just right day 👋, listed below are the downloadable backup details for atmosphere ${environmentId}:nn${downloadable_backupDetails}`
        );
    } else {
        say(`No downloadable backups found out for atmosphere ${environmentId}`);
    }
});

app.command('/restore_backup', async ({ command, ack, say }) => {
    wait for ack();

    const [targetEnvironmentId, backupId, environmentName] =
        command.text.get a divorce(' ');

    let response = wait for restoreBackup(
        targetEnvironmentId,
        backupId,
        environmentName
    );

    if (response) {
        say(
            `Just right day 👋, nn${response.message}. You are able to use the /operation_status slack commmand to check the status of this Operation Identity ${response.operation_id}`
        );
    }
});

The Slash directions above organize various backup-related tasks: /get_backups retrieves environment-specific backup details, /get_downloadable_backups fetches downloadable backup wisdom, and /restore_backup initiates restoration in step with equipped parameters.

Each and every command acknowledges receipt, processes input, triggers respective functions (getBackups(), getDownloadableBackups(), restoreBackup()), formats responses, and communicates results once more to Slack, offering a whole interface for backup operations.

Now, when you deploy your instrument, you’ll have the ability to visit Slack to test the various directions.

Interacting with Kinsta API's backup endpoints via Slack Slash commands
Interacting with Kinsta API’s backup endpoints by way of Slack Slash directions.

You’ll have the ability to get right to use the complete code for this problem on our GitHub repository.

Summary

In this knowledge, you learned how you’ll be able to effectively take advantage of the latest backup endpoints integrated into the Kinsta API. The ones endpoints empower you to seamlessly incorporate backup operations into your frontend programs, determine pipelines, and undertake various tasks that simplify the keep watch over of your web pages via programmatic approach.

The Kinsta API offers many purposes previous this, so that you’re impressed to find additional endpoints and brainstorm forefront ways to leverage them on your duties.

How do you right now leverage the Kinsta API? Are there any specific choices you’d love to see presented or made available in the market one day?

The put up Organize WordPress Backups in Slack With Kinsta API seemed first on Kinsta®.

WP Hosting

[ continue ]

WordPress Maintenance Plans | WordPress Hosting

read more

0 Comments

Submit a Comment

DON'T LET YOUR WEBSITE GET DESTROYED BY HACKERS!

Get your FREE copy of our Cyber Security for WordPress® whitepaper.

You'll also get exclusive access to discounts that are only found at the bottom of our WP CyberSec whitepaper.

You have Successfully Subscribed!