https://eacdoojigger.earthasylum.com/
{eac}Doojigger - A new path to rapid plugin development. A powerful, extensible, multi-function architectural framework and utility plugin for WordPress. {eac}Doojigger streamlines the plugin development process and allows you to create professional-grade plugins in a fraction of the time.
Document Header
Homepage:https://eacDoojigger.earthasylum.com/ Author:EarthAsylum Consulting Current Version:2.6.2 Last Updated:07-Sep-2024 Requires WordPress Version:5.8 Compatible up to:6.6 Requires PHP Version:7.4 Contributors:EarthAsylum Consulting, kevinburkholder License:EarthAsylum Consulting Proprietary License - {eac}PLv1 License URI:https://eacDoojigger.earthasylum.com/end-user-license-agreement/ Tags:plugin development, rapid development, multi-function, security, encryption, debugging, administration, contextual-help, session management, maintenance mode, plugin framework, plugin derivative, plugin extensions, toolkit GitHub URI:https://github.com/EarthAsylum/docs.eacDoojigger/wiki
Description
Summary
{eac}Doojigger by EarthAsylum Consulting is a multi functional and highly extensible WordPress plugin that provides existing extensions covering file access, security, debugging, encryption, session management, maintenance mode, administration tools, and more.
{eac}Doojigger is not only a fully functional plugin, but more so, an architectural development platform (using shared/abstract code) enabling the effortless creation of full featured...
- Custom Derivative plugins.
- Create your own plugin using a robust, efficient, and clean foundation.
- Custom {eac}Doojigger Extensions.
- Add easy-to-code, task-oriented extensions to your plugin or to {eac}Doojigger.
- Custom Extension Plugins.
- Load your custom extensions as their own WordPress plugins.
Rather than updating or customizing themes and functions, it is often best to isolate your custom code in a plugin or plugin extension so that code is not lost when the theme is changed or updated. Themes should only be used and customized with code pertinent to the look and feel of your site. Any code that should be retained after changing a theme belongs in a plugin or plugin extension. This keeps your code reusable and theme independent.
{eac}Doojigger makes purpose-driven, task-oriented, theme-independent, reliable, and efficient code easy to create and maintain.
Table of Contents
- Provided With {eac}Doojigger
- Custom Derivative Plugins
- Custom {eac}Doojigger Extensions
- Custom Extension Plugins
- Using {eac}Doojigger
- Automatic Updates
- Contextual Help
- Advanced Mode
Provided With {eac}Doojigger
Included Extensions & Traits | |
---|---|
file system access | Uses and provides easy access to the WP_Filesystem API for creating or updating files while maintaining permissions, compatibility, and security. |
WPMU Installer | Uses the file system extension to easily install or update programs or files within the WordPress directory structure. |
security | Adds a number of security options to your WordPress installation including changing the login url, setting password policies, limiting login attempts, disabling RSS/XML, limit REST access, block IP addresses, set global cookie flags, and more. |
AbuseIPDB API | Ability to block access by IP address based on AnuseIPDB 'Abuse Confidence Level'. |
debugging | Adds powerful debugging and detailed logging tools with controls for WordPress debugging options. |
PSR-3 Logging | Standard logging methods with ability to subscribe to log events. |
encryption | Adds easy to use data encryption and decryption filters using AES (a NIST FIPS-approved cryptographic algorithm) with authentication tag. |
session | Manages PHP sessions using well-known session managers or through WordPress transients. |
maintenance mode | Enables a custom "Maintenance Mode" when you need to disable front-end access to your site(s). |
admin tools | Adds cache management and plugin option backup/restore, export/import. |
ajax action | Adds an easy to use ajax responder (accessable from any extension) as well as a purely asynchronous device fingerprint action. |
material icons | Adds Google's Material Icons to WordPress. |
cookie compliance | Set cookies with WP Consent API compatible consent parameters. |
shared PHP traits | Several useful, usable PHP traits such as plugin loader, plugin updater, plugin help, standard (common) dashboard options, date/time methods, version compare methods, and zip archive. |
Extras & Examples | { explore on github } { documentation wiki } { download zip } |
---|---|
myAwesomePlugin | Example, skeleton plugin derivative. Start here with your first plugin. |
myAwesomeExtension | Example, skeleton plugin extension. Start here with your first extension. |
myFunctions | A functional skeleton extension plugin intended to replace (or augment) custom theme functions.php , including custom stylesheet and javascript. |
myOptionsTest | A functional example plugin that produces a settings screen with all input field types. Includes example input field filters and sanitization. |
A debugging test api | Extension that provides testing via url through the debugging extension (not intended for production sites). |
{eac}Doojigger Utilities | |
---|---|
{eac}DoojiggerAutoloader | The required auto-loader to automatically load {eac}Doojigger (and derivative) classes and traits. |
{eac}DoojiggerEnvironment | The Environment Switcher to set WP environment from the network (multi-site) settings page. |
{eac}DoojiggerActionTimer | The timer/tracking utility to track the load/execution timing of WordPress actions and filters (as well as custom events) when WordPress loads. |
Available Derivative Plugins | |
---|---|
{eac}SoftwareRegistry | A full-featured Software Registration/Licensing Server (used by {eac}Doojigger). |
Available Extension Plugins | WordPress Repository |
---|---|
{eac}SimpleSMTP | Configure WordPress wp_mail and phpmailer to use your SMTP (outgoing) mail server when sending email. |
{eac}SimpleAWS | Includes and enables use of the Amazon Web Services (AWS) PHP Software Development Kit (SDK). |
{eac}SimpleCDN | Enables the use of Content Delivery Network assets on your WordPress site, significantly decreasing your page load times and improving the user experience. |
{eac}ObjectCache | A light-weight and very efficient drop-in persistent object cache that uses a fast SQLite database to cache WordPress objects. |
{eac}Readme | Translates a WordPress style markdown 'readme.txt' file and provides shortcodes to access header lines, section blocks, or the entire document. |
{eac}SimpleGTM | Installs the Google Tag Manager (gtm) or Google Analytics (gtag) script, sets default consent options, and enables tracking of views, searches, and, with WooCommerce, e-commerce actions. |
{eac}MetaPixel | installs the Facebook/Meta Pixel to enable tracking of PageView, ViewContent, AddToCart, InitiateCheckout and Purchase events. |
Custom Derivative Plugins
Once {eac}Doojigger is installed and registered, you, the developer, can create your own plugin using the abstract classes and traits provided.
- First, create a simple plugin loader using your plugin class name (myAwesomePlugin.php). This is the primary plugin file and must contain the required WordPress headers; it will use the plugin_loader trait provided by {eac}Doojigger.
- Second, create your actual plugin class (myAwesomePlugin.class.php) that gets loaded by your plugin loader. This class extends the {eac}Doojigger abstract classes (abstract_context, abstract_frontend, abstract_backend) which include all of the management and utility code needed for a full-featured, full-functioning plugin.
- Third, upload and install your plugin.
Your plugin code need only focus on your particular requirements. The WordPress code and many utility functions have been taken care of for you.
See detailed instructions and examples (found in the Extras/Plugins/ folder).
Custom {eac}Doojigger Extensions
An extension is a PHP program class that adds functionality to the base plugin. Extensions can be coded for specific needs and can be as simple or complex as needed.
- First, create an extension class (myAwesomeExtension.extension.php) that extends the extension abstract class (abstract_extension).
- Second, upload your extension to the plugin's 'Extensions' folder.
Custom extensions may also be uploaded to your theme folder (preferable a child theme), in the ../eacDoojigger/Extensions folder.
See detailed instructions and examples (found in the Extras/Extensions/ folder).
Custom Extension Plugins
Since uploading extensions to the plugin or theme folder risks overwriting those extensions when upgrading or re-installing the plugin or theme, it is very easy to add extensions as their own WordPress plugin. The plugin simply answers a filter from the base plugin telling it where to load additional extensions. These extensions then exist in their own plugin folder with no risk of being overwritten.
Using {eac}Doojigger
{eac}Doojigger provides many useful methods and hooks which can be accessed from your custom plugins or extensions, as well as from your theme functions or any code in WordPress.
See Using {eac}Doojigger (found in the Extras/UsingDoojigger/ folder) for details and examples,
- {eac}Doojigger PHP Reference documentation.
Automatic Updates
WordPress hosted plugins provide updating functionality automatically. Whenever a new version of a plugin is updated in the WordPress repository, update notifications are seen in your WordPress dashbord on the plugins page.
You can provide the same functionality with your externally or self hosted plugin with a few easy changes.
See Automatic Updates (found in the Extras/AutoUpdate/ folder) for more information.
Contextual Help
To complete your plugin and improve support, provide contextual help using the {eac}Doojigger interface to standard WordPress help functions.
Adding contextual help to your plugin and extension is easy using the methods built into {eac}Doojigger... and when using the proper filter, you can ensure that your help content only shows on your plugin page or extension tab.
See the Contextual Help page (found in the Extras/ContextualHelp/ folder) for complete details and examples.
Advanced Mode
Advanced Mode gives developers a method to implement options or features based on an advanced mode setting (or combination of settings). {eac}Doojigger uses a menu selection and license level to enable advanced mode, but custom derivatives may use other methods to implement advanced mode.
See Implementing and Using Advanced Mode for details.
Multi-Site Network
A multisite network is a collection of sites that all share the same WordPress installation core files. They can also share plugins and themes. The individual sites in the network are virtual sites in the sense that they do not have their own directories on your server, although they do have separate directories for media uploads within the shared installation, and they do have separate tables in the database.
{eac}Doojigger is well aware of multi-site/network environments where only a network administrator may install plugins and plugins may be network-activated (enabled for all sites) or site-activated (enabled for/by individual sites within the network).
{eac}Doojigger manages installation, activation, deactivation and un-installing properly based on the type of installation and activation. For example, when an {eac}Doojigger derivative plugin is network-activated, it is activated on all sites in the network. When un-installed, it is un-installed from all sites. When installed by the network administrator but not network activated, each site administrator may properly activate or de-activate the plugin.
{eac}Doojigger also manages options and transients on network installations differently than the WordPress defaults...
{eac}Doojigger makes a distinction between network installed (i.e. a plugin installed on a multisite network) and network activated (i.e. activated on all sites in a multisite network).
The WordPress +_network_option()
(e.g. get_network_option()
) and +_site_option()
(e.g. get_site_option()
) methods are essentially the same and fallback to +_option()
methods (e.g. single-site get_option()
) if not installed on a multisite network. As well, +_site_transient()
methods fallback to +_transient()
when not on a multisite network.
WordPress does not check (nor should it) for the type of plugin activation (network wide vs. individual site).
{eac}Doojigger methods are different...
$this->+_network_option()
($this->get_network_option()
) methods only work on a multi-site installation when the plugin was network activated and do nothing (return default value) on a single-site activation.$this->+_site_option()
methods only use network methods if the plugin was network activated on a multi-site installation, otherwise these methods fallback to+_option()
(single-site) methods.$this->+_site_transient()
methods only use network methods if the plugin was network activated or if invoked by the network administrator, otherwise these methods fallback to+_transient()
(single-site) methods.
These are important differences and help make managing options and transients more effective in a network environment.
To illustrate these differences, if we run this code:
\add_option('my_test_option','my test');
\add_network_option(null,'my_test_option','my network test');
$this->add_option('my_test_option','my test');
$this->add_network_option('my_test_option','my network test');
We get this...
'get' option | Single site installation | Site activated | Network activated |
---|---|---|---|
get_option() |
'my network test' | 'my test' | 'my test' |
get_network_option() |
'my network test' | 'my network test' | 'my network test' |
get_site_option() |
'my network test' | 'my network test' | 'my network test' |
$this->get_option() |
'my test' | 'my test' | 'my test' |
$this->get_network_option() |
false | false | 'my network test' |
$this->get_site_option() |
'my test' | 'my test' | 'my network test' |
Add this code:
\add_site_option('my_test_option','my site test');
$this->add_site_option('my_test_option','my site test');
And we get this...
'get' option | Single site installation | Site activated | Network activated |
---|---|---|---|
get_option() |
'my site test' | 'my test' | 'my test' |
get_network_option() |
'my site test' | 'my site test' | 'my site test' |
get_site_option() |
'my site test' | 'my site test' | 'my site test' |
$this->get_option() |
'my site test' | 'my test' | 'my test' |
$this->get_network_option() |
false | false | 'my site test' |
$this->get_site_option() |
'my site test' | 'my site test' | 'my site test' |
In short,
- use
$this->add_option()
to add an option only used for an individual site. - use
$this->add_network_option()
to add an option only used when network activated on a multi-site installation. - use
$this->add_site_option()
to add an option used either for a single site or network-wide (all sites) when network activated.
Network Related Methods
Method Name | Description |
---|---|
$this->is_network_enabled() |
Returns true if plugin is network-enabled |
$this->forEachNetworkSite( $callback, ...$arguments ) |
Execute $callback on each active site in a network |
$this->switch_to_blog( $new_blog_id ) |
Switch the current WordPress blog |
$this->restore_current_blog() |
Restore the current blog, after calling switch_to_blog() |
* use $this->is_network_enabled()
to determine if the plugin is network activated. Extensions may use $this->is_network_enabled()
to determine if the extension is enabled at the network level or $this->plugin->is_network_enabled()
to determine if the plugin is network activated.
Using $this->switch_to_blog()
and $this->restore_current_blog()
over the corresponding WordPress functions ensures that options are correctly saved and loaded for the switched-from/to blogs.
More Information
{eac}Doojigger should be Network Activated on multi-site installations. Individual extensions and options may be configured on each site.
Some extension may use wp-config-transformer to update wp-config. Copyright 2011-2018 WP-CLI Development Group .
See Also
Information on building with and using {eac}Doojigger
- {eac}Doojigger Derivatives
- {eac}Doojigger Extensions
- {eac}Doojigger Options & Settings
- {eac}Doojigger Automatic Updates
- {eac}Doojigger Contextual Help
{eac}Doojigger Information and Examples
Plugins and Extensions built with {eac}Doojigger
-
{eac}SoftwareRegistry A full-featured Software Registration/Licensing Server built on {eac}Doojigger.
-
{eac}SimpleGTM Installs and configures the Google Tag Manager (GTM) or Google Analytics (GA4) script with optional tracking events.
-
{eac}SimpleSMTP An {eac}Doojigger extension to configure WordPress wp_mail and phpmailer to use your SMTP (outgoing) mail server when sending email.
-
{eac}SimpleAWS An {eac}Doojigger extension to include and enable use of the Amazon Web Services (AWS) PHP Software Development Kit (SDK).
-
{eac}SimpleCDN An {eac}Doojigger extension to enable the use of Content Delivery Network assets on your WordPress site, significantly decreasing your page load times and improving the user experience.
-
{eac}ObjectCache A light-weight and very efficient drop-in persistent object cache that uses a fast SQLite database to cache WordPress objects.
-
{eac}Readme An {eac}Doojigger extension to translate a WordPress style markdown 'readme.txt' file and provides shortcodes to access header lines, section blocks, or the entire document.
-
{eac}MetaPixel An {eac}Doojigger extension to install the Facebook/Meta Pixel to enable tracking of PageView, ViewContent, AddToCart, InitiateCheckout and Purchase events.
Installation
Automatic Plugin Installation
Due to the nature of this plugin, it is NOT available from the WordPress Plugin Repository and can not be installed from the WordPress Dashboard » Plugins » Add New » Search feature.
Upload via WordPress Dashboard
Installation of this plugin can be managed from the WordPress Dashboard » Plugins » Add New page. Click the [Upload Plugin] button, then select the eacDoojigger.zip file from your computer.
See Managing Plugins -> Upload via WordPress Admin
Manual Plugin Installation
You can install the plugin manually by extracting the eacDoojigger.zip file and uploading the 'eacDoojigger' folder to the 'wp-content/plugins' folder on your WordPress server.
See Managing Plugins -> Manual Plugin Installation
Activation
On activation, custom tables and default settings/options are created. Be sure to visit the 'Settings' page to ensure proper configuration.
{eac}Doojigger should be Network Activated on multi-site installations.
Updates
Updates are managed from the WordPress Dashboard » 'Plugins' » 'Installed Plugins' page. When a new version is available, a notice is presented under this plugin. Clicking on the 'update now' link will install the update; clicking on the 'View details' will provide more information on the update from which you can click on the 'Install Update Now' button.
When updated, any custom tables and/or option changes are applied. Be sure to visit the 'Settings' page.
Deactivation
On deactivation, the plugin makes no changes to the system but will not be loaded until reactivated.
Uninstall
When uninstalled, the plugin will delete custom tables, settings, and transient data based on the options selected in the general settings. If settings have been backed up, the backup is retained and can be restored if/when re-installed. Tables are not backed up.
FAQ
Is {eac}Doojigger stable and reliable?
Version 2 has been meticulously updated to provide not only new features and efficiencies, but many other improvements, including stability and reliability. The code base of {eac}Doojigger has been in proprietary use (and in development) over years and on several websites. However, there is a nearly infinte number of website configurations and uses that can't possibly be tested. If you run into any issues, problems, bugs or simply change requests, I'd be more than happy to address them and to work with you.
Where can I find more information about ...
- creating a derivative plugin
- creating a custom extension
- defining and using options & settings in my plugin or extension
- providing automatic updates for my plugin
- providing contextual help for my plugin or extension
- using features of {eac}Doojigger
The {eac}Doojigger Extras (now at this Github Repository) includes examples and documentation:
Who is EarthAsylum Consulting?
EarthAsylum Consulting is a one-person consulting agency in business since 2005. I have some 30 years experience in technology and software development for a disperse range of businesses.
Currently, and for the last decade or more, my focus has been on internet-based business software & technology management.
In developing {eac}Doojigger, and other plugins based on it, I hope to find a small revenue stream to help keep me going.
To that end, your support is greatly appreciated. It will enable me to continue developing quality software and provide support to current and future clients (and to enjoy a cup of coffee occasionally).
Learn more here...
Thank you! Kevin Burkholder
Screen Shots
-
General settings
-
Tools settings
-
Debugging settings
-
Security settings
-
Advanced Mode Menu
-
My Awesome Plugin with My Awesome Extension
-
My Awesome Plugin Contextual Help
Copyright
Copyright © 2019-2024, EarthAsylum Consulting, All rights reserved.
This is proprietary, copyrighted software.
-
Title to the Software will remain the exclusive intellectual property of EarthAsylum Consulting.
-
You, the customer, are granted a non-exclusive, non-transferable, license to access, install, and use this software in accordance with the license level purchased.
-
You are not permitted to share, distribute, or make available this software to any third-party.
Upgrade Notice
2.0.0
To upgrade to version 2.0 of {eac}Doojigger : 1. Disable all derivative plugins; 2. Upgrade {eac}Doojigger; 3. Upgrade all derivative plugins; 4. Re-enable all derivative plugins.
Change Log
Version 2.6.2 – September 7, 2024
- Removed Ajax device fingerprinting.
- Purge expired transients on cache clearing and automatically (daily).
- Force minimum transient expiration with transient sessions.
- New
text_to_array()
function to split textarea to array of lines. - New AbuseIPDB api (security) extension to block by IP address based on abuse score.
- Enhanced security extension...
- Block REST index list, WP core REST routes, non-rest json requests.
- CORS headers w/white-list domains.
- Updated wpconfig-transformer to v1.3.6
- Reworked/simplified installed mu autoloader and autoloader class with new 'autoload.php'.
- Removed
setEmailNotification()
from autoloader and emailFatalNotice standard option. - Changed advanced mode link on settings page (essentials|advanced).
- Reworked debugging extension and logging with new logger helper compatible with PSR-3 logging.
- See : https://eacdoojigger.earthasylum.com/how-to/#use-debugging-logger-methods
- New PSR-3 logging method :
$this->log( $level, $message, $context )
- Or e.g. :
eacDoojigger->log('error', $message, $context )
- Support/compliance with WP Consent API.
- New cookie methods supporting WP Consent API (if active).
- See: https://eacdoojigger.earthasylum.com/how-to/#wp-consent-api-and-cookies
set_cookie(string $name, string $value, $expires=0, array $options=[], $consent=[])
- Allow/default session access from derivative plugins when using
setVariable()
andgetVariable()
. - Added action
{pluginname}_startup
afterplugins_loaded
, before loading extensions. - Session debugging filter for
eacDoojigger_debugging
.
Version 2.6.1 – July 6, 2024
- Session manager extension:
- Use session_set_cookie_params if session_start().
- uses WC->session getters and setters.
- Start session on demand not on 'init'.
- Adjust session_save_data (shutdown) priority (8).
- Added generic session manager using external plugin (or not).
- Removed (outdated) 'WP Session Manager' support.
- Option input field type allow 'toggle' as alias for 'switch'.
- For option validation ('validate'=>...), false value triggers generic error notice.
- doing_ajax() checks wp_doing_ajax (admin-ajax.php) and 'XMLHttpRequest' (other).
- $this->isAjaxRequest() method deprecated for $this->doing_ajax().
- Removed user id from visitorId().
- Save visitorId using setVariable() (maybe session).
- isNewVisitor() checks variable.
Version 2.6.0 – June 4, 2024
- EAC_DOOJIGGER_VERSION constant deprecated in favor of EACDOOJIGGER_VERSION.
- Fixed upgrade notice in plugin update notice trait.
- New getRelease() method returns 'Stable Tag' and 'Last Updated' from readme.
- Include header values from readme.txt in pluginData.
- Add stable release on plugins page when different than version.
- Moved plugin updater actions from plugin loader to new
eacDoojiggerPluginUpdater
class.- Loaded once in eacDoojiggerAutoloader.
- Handles all derivative and extension plugins.
- Reduces individual plugin footprint and redundancy.
- Allows updating even when plugin is disabled or not network enabled on multi-site.
- Improved "Advanced Mode" with isAdvancedMode(), setAdvancedMode(), and allowAdvancedMode().
- derivative plugins must call allowAdvancedMode(true) to enable, and may overload functions or use 'allow_advanced_mode' filter to implement.
- filter
$this->apply_filters('is_advanced_mode',false,'settings');
- Added 'advanced' attribute to settings fields to suppress field when not isAdvancedMode().
- Made (most) options_settingspage* methods public so html_input trait can access them.
- New code-editor trait, loads code-mirror and wp_editor with consistant options/styling.
- Change to tiny-mce parameters and toolbars for html fields.
- Improved ajaxAction extension.
- Added fingerprint option (using https://github.com/thumbmarkjs/thumbmarkjs).
- Added
{pluginName}_{className}_{methodName}
filter in dispatcher.- e.g.
eacDoojigger_ajaxAction_deviceFingerprint
- e.g.
- Added 'settings-grid-item-label' and 'settings-grid-item-input-{type}' class to settings divs.
- Change 'Requires at least' to WordPress 5.8.
- Several improvements to admin screen styling/layout.
- Improved admin theme support using admin colors (from $_wp_admin_css_colors).
- Changes to some javascript loading code (inc. defer admin script).
- Support replaceable meta in options attributes, Ex. 'Title' => '[label] [info]'.
- label, default, title, before, after, info, tooltip, help
- Added $this->wp_kses() custom wp_kses method with extended tags.
- Now processes all (string) admin field option attributes through $this->wp_kses().
- New 'script' field attribute since script tags no longer allowed in other attributes.
- $this->minifyString() (used for inline scripts/css) now uses $this->wp_kses().
- Added 'tooltip' attribute to settings fields with jQuery hover tooltip.
- Automatically populated with field 'info' when not set or set to true.
- added tooltip filter to disable auto-populate.
$this->add_filter("automatic_tooltips", function($bool, $groupName, $groupMeta){...});
- Added input field filters before rendering fields.
$this->add_filter("options_group_meta_{$groupName}", function($groupMeta){...});
$this->add_filter("options_field_meta_{$fieldName}", function($fieldMeta, $fieldValue){...});
- Added actions to wpmu_installer extension.
do_action('eacDoojigger_installer_invoke', $installAction, $installMethod, $installOptions, $onSuccess)
do_action('eacDoojigger_installer_install', $installOptions)
do_action('eacDoojigger_installer_update', $installOptions)
do_action('eacDoojigger_installer_uninstall', $installOptions)
do_action('eacDoojigger_installer_delete', $installOptions)
- Added filters to file_system extension.
$fs = apply_filters('eacDoojigger_load_filesystem',$wp_filesystem,true,'file system required',[]);
$fs = apply_filters('eacDoojigger_link_filesystem',$wp_filesystem,true,'file system required',[]);
- Fix call/use of WC() in session_manager to prevent erros if woocommerce has been disabled.