MainWP

Free, Self-hosted, Open Source WordPress Management Plugin

Integrate the MainWP API with the Python API

Setup the MainWP API trigger to run a workflow which integrates with the Python API. Pipedream's integration platform allows you to integrate MainWP and Python remarkably fast. Free for developers.

Run Python Code with the Python API

Write Python and use any of the 350k+ PyPi packages available. Refer to the Pipedream Python docs to learn more.

 
Try it

Overview of MainWP

MainWP is a WordPress management suite that allows you to control multiple WordPress sites from a single dashboard. With the MainWP API, you can manage updates, backups, security, and more for your child sites programmatically. When integrated with Pipedream, this API enables you to automate various WordPress management tasks, set up custom alerts, or tie in other services to enhance your site management capabilities.

Connect MainWP

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
import { axios } from "@pipedream/platform"
export default defineComponent({
  props: {
    mainwp: {
      type: "app",
      app: "mainwp",
    }
  },
  async run({steps, $}) {
    return await axios($, {
      url: `https://${this.mainwp.$auth.url}/wp-json/mainwp/v1/updates/available-updates`,
      params: {
        consumer_key: `${this.mainwp.$auth.customer_key}`,
        consumer_secret: `${this.mainwp.$auth.customer_secret}`,
      },
    })
  },
})

Overview of Python

Develop, run and deploy your Python code in Pipedream workflows. Integrate seamlessly between no-code steps, with connected accounts, or integrate Data Stores and manipulate files within a workflow.

This includes installing PyPI packages, within your code without having to manage a requirements.txt file or running pip.

Below is an example of using Python to access data from the trigger of the workflow, and sharing it with subsequent workflow steps:

Connect Python

1
2
3
4
5
def handler(pd: "pipedream"):
  # Reference data from previous steps
  print(pd.steps["trigger"]["context"]["id"])
  # Return data for use in future steps
  return {"foo": {"test":True}}