Easily deploy static sites using Wordpress and Netlify
Build Quickly and easily send webhooks to build your Netlify
Status Check the status of your latest build to see if it was successful without even leaving Wordpress
From your WordPress dashboard
- Visit Plugins > Add New
- Search for "Deploy Webhook Button"
- Install plugin
- Activate the plugin
- Click on the new menu item "Deploy Netlify Webhook" and enter your site details/keys
- Enter enter your site_id, webhook POST address, Netlify API Key, and User-Agent
- Read the documentation to get started
- Visit Netlify > Site-Name > Settings > Build & Deploy
- Create A Build Hook (or use an existing hook)
- Copy The Build Hook URL into the
Webhook Build URL
field
- Visit Netlify > Site-Name > Settings
- Copy APP_ID and paste into the
Netlify site_id
field
- Visit Netlify > User Settings > Applications > Personal Access Tokens
- Create A Personal Access Token (or use an existing one)
- Copy The token and paste into the
Netlify API Key
field
- Visit Netlify > Site-Name > Settings
- Copy The Site Name and paste into the
User-Agent Site Value
field - Add The site url in brackets to the
User-Agent Site Value
field - Your field should look similar to this
SiteNameNoSpaces (site-name-url.com)
Is it possible to set daily, weekly, or monthly builds. Using this plugin. Navigate to the 'Schedule Builds' settings page to select build time and date.
WordPress cron jobs are not 100% reliable as they are only fired when the site is visited. A little bit of work may be required to fix this.
- Add the following to your
wp-config.php
file -define('DISABLE_WP_CRON', true);
- Create a system cron
- Log into your systems cpanel.
- Navigate to the Cron Jobs section - Search for "cron"
- Click "Cron Jobs" (If this does not show up you may not have access to this functionality)
- Select "Once per hour" from the common settings
- Add this command to the command input
wget -q -O - https://your-domain.com/wp-cron.php?doing_wp_cron
A solution to not being able to set up cPanel cron jobs is to use a third party scheduler. This ensures that at a certain time every day your WordPress cron events will fire.
- Set up an account with https://cron-job.org
- Login and navigate to "Cronjobs"
- Create a new cron job for
https://your-domain.com/wp-cron.php?doing_wp_cron
firing a minimum of once an hour every hour.
Now the Netlify hook (and all other cron jobs on your site) will run on time.
A deploy button and the status badge of the last build is added to the admin bar. By default this will only be displayed to users that can manage_options
.
You may allow other user roles with these three filters:
add_filter('netlify_status_capability', function() {
return 'edit_pages';
});
add_filter('netlify_deploy_capability', function() {
return 'edit_pages';
});
add_filter('netlify_adjust_settings_capability', function() {
return 'edit_pages';
});
Main Plugin page
- Added Netlify scheduling settings
- Refactored settings names to allow easier scaling
- Bug fix for new permission hooks not working for "Webhook Deploy" menu and "Developer Settings" submenu
- Add Deploy Button and Deploy Status to admin bar
- Add
manage_options
for devs to manage permissions - Nice comments in
php
code - Remove un-needed
add_submenu_items()
params
- Fixed UI
- Seperate Developer Settings and User Build Screen
- Initial Release
View full changelog: here