Wordpress private repository for plugins.
Provide updates for plugins WpGet does that, keeping all packages and providing to the wordpress installation. Using token based authentication all process are kept secure.
Easy to setup Setup is easy. Just a copy of the bundle to the server and few steps more. Plugin integration is very easy, just a class to add.
Api oriented All core feature are exposed by API. This will allow you to integrate the delivery process with other tools in the company.
Ui to get control A simple ui show what package are loaded and give you the power.
Low Server Requirements Just a webserver with php and a database. For few data, using SQLite, neither database.
Wordpress is the most used CMS in the world with the most important plugin system. It's easy for a developer to create and publish a new plugin into the public reposiory. But what if i had to create and mantain a private plugin? Im speaking about:
- a plugin with an high intellectual content,
- a plugin not ready for the public, maybe focused on some particular business case
- a custom super-plugin built used to inject custom plugin dependency
There are actually these opportunities into public repository:
- Make a free plugin
- Make a paied plugin (but placing into main repository it is available to everyone open to buy it)
- Intall you plugin manually
Firts two option are the most widely adopted by public plugin sellers, while the third one is a very common practice into agency or companies that have some common plugin reused in many websites.
WpGet came to give a forth opportuninty. It is conceived as a private repository where you can push plugins and allow wordpress installation to update from that source, in addiction to the standard platform. For who comes from other technlogy WpGet is similar to NuGet, Maven or NPM package manager.
Here a siple diagram to explain how WpGet works.
It can be done using curl, wget, php or any other tool able to send an HttpRequest in multipart/form POST mode.
CURL EXAMPLE
curl -H "Authorization: Bearer <ACCESS_TOKEN>" \
-F "name=package" \
-F "version=1.1.1" \
-F "reposlug=default" \
-F "file=@/C/temp/wgettest/package_v1.0.0.zip" \
http://localhost:3000/web/catalog/Package
POWERSHELL EXAMPLE
Invoke-RestMethod -Header @{"Authorization" = "Bearer <ACCESS_TOKEN>"} -Method Post -InFile $filePath -ContentType "multipart/form-data" -Uri http(s)://www.your-site.wpget/ui/catalog/Package?name=<packageName>&version=X.Y.Z
Any other needs or suggestion? Please open a issue
This is easy. We have prepared a ready-to-use php updater class that interact with plugin repository to keep plugin updated. This needs only to setup some wordpress settings (repository url and access token). After that your plugin will check for newer version using WpGet and will download them using the private repository. Easy!
For now, just copy and paste this class into your plugin. In next future we are going to deliver this using a composer package and a public wordpress plugin. After copying the file, and before including it in the plugin, some variables must be set. This can be done in the plugin itself or in another file, for example the wp-config.php file. The variable are:
// repository config data
define( 'WPGET_REPO_SLUG','test000' );
define( 'WPGET_PACKAGE_NAME','my-plugin' );
define( 'WPGET_API_URL','http://localhost:3000/web/' );
define( 'WPGET_TOKEN_READ','FnrvNuzwKodEgIqxsBctbFc2SxMncM');
// plugin info
// plugin filename
define( 'WPGET_PLUGIN_FILE', 'plugin-test.php' );
// plugin directory
define( 'WPGET_PLUGIN_DIR', 'plugin-test' );
An example of complete yaml file it can be found inside plugin zip file here
version: 1.2.4 # versione in form major.minor.build
name: name of the package
description: >
Long description that can contains also html statements
<h1> but remember to indent all lines with spaces to be YAML compliant! </h1>
changelog: Write here changelogs. This also can be a multiline field...
This application requieres PHP 7+ and a database. Any eloquent database is supported, but atm WpGet is tested only over MySQL platfrorm that's also the development one. About webserver, no limitation. Apache or Nginx are equivlent, but must be configured to serve php requests. Php modules needed are just mbstring and the pdo_xxx where xxx is the db driver according with configuration.
Topic | Version |
---|---|
PHP | 7+ |
DB | MySQL or other eloquent supported database |
ext | mbstring, pdo_xxx |
Web | apache, nginx,... |
Note for apache users: You may have problem with authentication headers. In case, Please check this resource
A. Setup the server Starting from released bundle:
- Download and copy budle somewhere in server
- Configure web server to server /web folder. Yes, You do not have to expose the full package, but only this folder.
- There isn't any url rewriting needs, so in most cases that's all on server side
- Edit /config/settings.php updating connection string. More info here.
B. Configure
- Enter http(s)://www.your-site.wpget/ui/
- First access will install database structure.
- First time you can login using admin\admin credential
- Change password under user managment
- Now you are ready to start using WpGet *
Usage
Dev: extend and contribute