DocumentationCore ConceptsArchitecture Foundations

Architecture Foundations

Don’t forget that

we are working using a WordPress plugin…

This document explains the architecture foundations of a WP Bones plugin. It covers the request lifecycle, starting with the main plugin file {plugin-name}.php, which contains WordPress comments to identify the plugin. The main file is renamed by WP Bones based on the plugin name. It also discusses the default plugin structure, which provides a flexible starting point for organizing both large and small plugins, similar to Laravel, with no restrictions on class locations as long as Composer can autoload them.

Request Lifecycle

The entry point is the <plugin name>/{plugin-name}.php. The {plugin-name}.php contains the WordPress comments used to identify the plugin:

<?php
 
/**
 * Plugin Name: WP Kirk
 * Plugin URI: https://github.com/wpbones/WPKirk
 * Description: WP Bones template WordPress plugin
 * Version: 1.6.0
 * Requires at least: 6.2
 * Requires PHP: 7.4
 * Author: Giovambattista Fazioli
 * Author URI: https://wpbones.com/
 * License: GPLv2 or later
 * License URI: http://www.gnu.org/licenses/gpl-2.0.html
 * Text Domain: wp-kirk
 * Domain Path: languages
 *
 */

As you know, you may use any filename for your main PHP file. In fact, WordPress will recognize the main plugin file by the PHP comment in the file head. The main plugin file will be renamed to your-plugin.php by the WP Bones command line tool. For example, if you create a plugin named My Plugin, the main file will be my-plugin.php. See Get plugin information for more details.

So, the entry point of a plugin is {your-plugin-name}.php.

Of course, you can edit the {your-plugin-name}.php file to set your WordPress comment information. The rest of the code is handled by WP Bones.

Plugin Structure

The default WP Bones plugin structure is intended to provide a great starting point for both large and small plugins. Of course, you are free to organize your application as you like. Similarly, Laravel, WP Bones imposes almost no restrictions on where any given class is located - as long as Composer can autoload the class.

The root directory

Let’s look at a default standard WP Bones plugin folder tree:

Additional directories

You may use the following additional directories:

Check out REST API and custom pages for more information.

The root files

Also, you will find a set of files in the root of the plugin:

    • bonescommand line PHP script
    • composer.jsonused by composer
    • composer.lockused by composer
    • gulpfile.jsscript used by Gulp
    • {your-plugin-name}.phpentry point of plugin
    • namespaceused by bones command
    • package.jsonused by npm
    • readme.txtWordPress readme file
  • The bones file is the command line PHP script, likewise artisan in Laravel environment.
  • The composer.json and composer.lock are used by Composer.
  • The gulpfile.js is the script used by Gulp. This file is prepared with the main tasks to process styles and scripts. Before using it, you should install Gulp and npm.
  • The {your-plugin-name}.php is the entry point of the plugin.
  • The namespace is a file used by the bones command. You can ignore it.
  • The package.json is used by npm. Feel free to add your own packages.
  • The readme.txt is the WordPress readme file to be used when you’ll submit your plugin to the WordPress repository.

The plugin directory

However, the most important folder is /plugin/. In this folder, you will find the main controllers of your plugin:

      • activation.php
      • deactivation.php

The config directory

All of the configuration files for the plugin are stored in the config/ directory. Each option is self-documented, so feel free to look through the files and get familiar with the options available to you.

      • menus.php
      • plugin.php

In the WP Kirk template plugin, you will find a sample custom.php file. This file contains:

<?php
 
if (!defined('ABSPATH')) {
    exit();
}
 
/*
|--------------------------------------------------------------------------
| Custom configuration
|--------------------------------------------------------------------------
|
| This is an example of a custom configuration. You may get this configuration
| by plugin instance.
| For example, in a view you can use `$this->config( 'custom.sample' )`.
|
*/
 
return [
  'sample' => 'Hello, Captain!'
];

It’s very easy to get a custom configuration by using $pluginInstance->config( 'custom.sample') .

Plugin instance

The plugin instance is the most important object in WP Bones. You will be able to get the plugin instance by using either WPKirk() function or the global static class WPKirk.

// plugin instance by global unique function
echo WPKirk()->Author;
 
// plugin instance by global static class
echo WPKirk::$plugin->Author;
 

Of course, if your plugin is named MyPlugin you will use MyPlugin() to get the instance. Same for the static class echo WPKirk::$plugin->Author;

Get plugin information

In the {your-plugin-name}.php file you may use the comment to insert some plugin information:

{your-plugin-name}.php
<?php
 
/**
 * Plugin Name: WP Kirk
 * Plugin URI: https://github.com/wpbones/WPKirk
 * Description: WP Bones template WordPress plugin
 * Version: 1.6.0
 * Requires at least: 6.2
 * Requires PHP: 7.4
 * Author: Giovambattista Fazioli
 * Author URI: https://wpbones.com/
 * License: GPLv2 or later
 * License URI: http://www.gnu.org/licenses/gpl-2.0.html
 * Text Domain: wp-kirk
 * Domain Path: languages
 *
 */

You can get this information by using the plugin instance:

echo $plugin->Author;
echo $plugin->TextDomain;