NOTE: This build would be considered ALPHA. Having said that, WordPress plugins and other generated code using this tool has been used in production environment. Needs better documentation which is in the pipelines via a series of blog posts.s
An opinionated scaffolding tool for creating modern WordPress plugin.
It helps you kickstart new WordPress plugin, prescribing best practices and to help you stay productive. Not to say the least, it saves tons of man hours upfront and during the course of development.
The following functionality is provided out-of-the-box.
- A goodies-filled plugin boilerplate using PHP namespaces and composer.
- A dependancy injector container for managing plugin service objects and parameters.
- A powerful Object Relational Mapper (ORM). Define ORM model and link them to your database tables. Say goodbye to writing raw MySQL queries.
- An easy to use database schema migrations tool. Easily create and organise database table migrations (create/update table, add/remove columns) using a easy to Schema builder. Yes we do have a scaffolder for this too!
- A scaffolding command to WordPress plugin.
- A scaffolding command each to create, update and pivot a database migration resource.
- A scaffolding command to create an ORM model resource.
- A scaffolding command to create resource repository (Repository Pattern).
- A scaffolding command to create a resource transformer (Fractals from PHPLeague)
- A scaffoling command to create a resource API controller.
Installation
First, install Yeoman and generator-wp-forge using npm (we assume you have pre-installed node.js).
npm install -g yo
git clone git@github.com:outsourceappz/generator-wp-forge && cd generator-wp-forge
npm install
npm link
Then generate your new project:
yo wp-forge
Available Generators
Please note that all the generator commands need to be executed from the root directory of your custom-plugin folder along the lines of the following example
mkdir wp-content/plugins/my-custom-plugin
cd wp-content/plugins/my-custom-plugin
WordPress Plugin.
yo wp-forge:plugin
Create Database Migration.
Used to create a database table.
yo wp-forge:migration-create --tableName=my-database-table-name --schema="schema"
for example
yo wp-forge:migration-create --tableName=users --schema="first_name:string,last_name:string"
Note: To learn more about the schema database columns, please read https://laravel.com/docs/5.0/schema
Schema is a comma separated value of column-name and column-type key value pair.
So any of these will do:
username:string
body:text
age:integer
published_at:date
excerpt:text:nullable
email:string:unique:default('foo@example.com')
Update Database Migration.
Used to update an existing database table.
yo wp-forge:migration-update
Pivot Database Migration.
Used to create a pivot table for a has many and belongs to many
relation.
yo wp-forge:migration-pivot
ORM Model.
Used to create an ORM model file in App/Models folder.
yo wp-forge:model --tableName=my-database-table-name --className=model-name --schema="schema"
yo wp-forge:model --tableName=users --className=User --schema="first_name:string,last_name:string"
Repository class.
We recommend using a repository class which deals with the ORM model and abstracts away the database for other parts of the plugin.
yo wp-forge:repository --className=my-orm-class-name --schema="schema"
yo wp-forge:repository --className=User --schema="first_name:string,last_name:string"
Transformer class.
Used to create a transformer class, which is used to define the ORM database table fields and its related data. We use fractals package for this.
yo wp-forge:transformer --className=my-database-table-name --schema="schema"
yo wp-forge:transformer --className=User --schema="first_name:string,last_name:string"
Note: This currently works correctly for only string data types. Work in progress.
API class.
Used to create an API class (which utilises the transformer) which can be used by the wp_ajax_
WordPress action to create JSON based REST endpoints.
yo wp-forge:api --className=my-model-class-name --schema="schema"
yo wp-forge:api --className=User --schema="first_name:string,last_name:string"
Resource
This is a composite generator which can be used to generator migration-create
, model
, repository
, transformer
and api
generators at one go.
yo wp-forge:resource
License
GPLv2 - https://wordpress.org/about/gpl/