Skip to content

WordPress plugin to demonstrate how `GitHubUpdater` can enable WordPress to check for and update a custom plugin that's hosted in either a public or private repository on GitHub.

Notifications You must be signed in to change notification settings

ryansechrest/github-updater-demo

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

67 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

GitHub Updater Demo

WordPress plugin to demonstrate how GitHubUpdater can enable WordPress to check for and update a custom plugin that's hosted in either a public or private repository on GitHub.

Plugin Header Fields

The following plugin header fields are being used by GitHubUpdater.

Version (Required)

Specify your current plugin's version. For example:

Version: 1.0.0

Version is used to compare the installed plugin with the latest one on GitHub to determine if there are updates.

Update URI (Required)

Specify URL to your plugin's repository on GitHub. For example:

Update URI: https://github.com/ryansechrest/github-updater-demo

Repository is used as the source for plugin updates.

Tested up to (Optional)

Specify highest version of WordPress that your plugin was tested on. For example

Tested up to: 6.6

Will show the following compatibility message on Dashboard > Updates when your plugin has an update:

Compatibility with WordPress 6.6: 100% (according to its author)

Getting Started

  1. Copy GitHubUpdater.php into your plugin
  2. Update namespace to match your plugin
  3. Require GitHubUpdater.php in your plugin
  4. Instantiate GitHubUpdater in your plugin

Setup

How to add and configure GitHubUpdater for your plugin.

Instantiate GitHubUpdater (Required)

Instantiate GitHubUpdater and pass in the absolute path to your root plugin file.

$gitHubUpdater = new GitHubUpdater(__FILE__);

For example, __FILE__ might resolve to:

/var/www/domains/example.org/wp-content/plugins/<pluginDir>/<pluginSlug>.php

Configure: Personal Access Token (Optional)

If your GitHub repository is private, then set your access token:

$gitHubUpdater->setAccessToken('github_pat_XXXXXXXXX');

It's not recommended to hardcode a token like you see above.

Either define a constant in wp-config.php:

define( 'GITHUB_ACCESS_TOKEN', 'github_pat_XXXXXXXXXX' );

And then pass in the constant:

$gitHubUpdater->setAccessToken(GITHUB_ACCESS_TOKEN);

Or save your access token in wp_options and pass it via get_option():

$gitHubUpdater->setAccessToken(get_option('github_access_token'));

Configure: Production Branch (Optional)

If your production branch is not the default main, then specify it:

$gitHubUpdater->setBranch('master');

Configure: Plugin Icon (Optional)

Specify a relative path from the plugin root to configure a plugin icon:

$gitHubUpdater->setPluginIcon('assets/icon.png');

The icon appears on Dashboard > Updates next to your plugin.

Configure: Small Plugin Banner (Optional)

Specify a relative path from the plugin root to configure a small plugin banner:

$gitHubUpdater->setPluginBannerSmall('assets/banner-772x250.jpg');

The banner will appear in the modal when clicking [View details] on your plugin.

Configure: Large Plugin Banner (Optional)

Specify a relative path from the plugin root to configure a large plugin banner:

$gitHubUpdater->setPluginBannerLarge('assets/banner-1544x500.jpg');

The banner will appear in the modal when clicking [View details] on your plugin.

Configure: Changelog (Optional)

Specify a relative path from the plugin root to your changelog:

$gitHubUpdater->setChangelog('CHANGELOG.md');

This should be a Markdown file and will populate the Changelog tab when clicking [View details] on your plugin. GitHubUpdater will use the most recent file from GitHub so that a user can review changes before updating.

The Markdown to HTML converter currently only supports:

  • Headers (#, ##, ###, etc.)
  • Unordered lists (-)
  • Blockquotes (>)
  • Code blocks (using three backticks to start and end block)
  • Paragraphs

And only formats:

  • Bold text (**Foo**)
  • Italic text (*Foo*)
  • Code (using single backtick to wrap text)

Add GitHubUpdater (Required)

Add all necessary hooks to WordPress to keep your plugin updated moving forward:

$gitHubUpdater->add();

This should be the last method call after GitHubUpdater has been configured.

Final Thoughts

If you want a deep dive into how GitHubUpdater works, check out this blog post. That said, while the fundamentals in the blog post are still being used, GitHubUpdater has changed quite a bit since it was written.

About

WordPress plugin to demonstrate how `GitHubUpdater` can enable WordPress to check for and update a custom plugin that's hosted in either a public or private repository on GitHub.

Topics

Resources

Stars

Watchers

Forks

Languages