Skip to content

Commit

Permalink
Improve: README.md and related PHPDocs
Browse files Browse the repository at this point in the history
  • Loading branch information
BenceSzalai committed Nov 29, 2020
1 parent a22b5c1 commit 53416e0
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 40 deletions.
71 changes: 32 additions & 39 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ Original based on:
Homepage: http://www.d-herrmann.de/projects/monolog-mysql-handler/

# Disclaimer
This is a very simple handler for monolog. This version works for custom plugin development, but I would not advise to distrubte this code in a public repository for general use on high traffic sites. You have been warned.
This is a very simple handler for monolog. This version works for custom plugin development, but I would not advise to distribute this code in a public repository for general use on high traffic sites. You have been warned.

# Installation
monolog-wordpress is available via composer. Just add the following line to your required section in composer.json and do a `php composer.phar update` or your choice of composer update method.
Expand All @@ -26,32 +26,29 @@ Since Monolog v2 broke compatibility with PHP versions before v7.1 some may want
Apart from the compatibility differences stated above the features of v1 and v2 are going to be kept the same as much as possible.

# Usage
Just use it as any other Monolog Handler, push it to the stack of your Monolog Logger instance. The Handler however needs some parameters:
Just use it as any other Monolog Handler, push it to the stack of your Monolog Logger instance. The Handler however has some parameters:

- **$wpdb** Global instance of your DB connection.
- **$table** The table name where the logs should be stored
- **$additionalFields** simple array of additional database fields, which should be stored in the database. The columns are created automatically, and the fields can later be used in the extra context section of a record. See examples below. _Defaults to an empty array()_
- **$level** can be any of the standard Monolog logging levels. Use Monologs statically defined contexts. _Defaults to Logger::DEBUG_
- **$bubble** _Defaults to true_
- `$wpdb`: The instance of your DB connection. To use the global connection of WordPress, use `null`. Otherwise, use a `\wpdb` instance. _Default: `null`_
- `$table`: Name of the database table to store the logs in. The 'wp_' (or other configured) prefix will be added automatically. _Default: `'logs'`_
- `$additionalFields`: simple array of additional database fields, which should be stored in the database. The columns are created automatically, and the fields can later be used in the extra context section of a record. See examples below. _Defaults to an empty `array()`_
- `$level`: The minimum logging level at which this handler will be triggered. Can be any of the standard Monolog logging levels. Use Monologs statically defined contexts. _Defaults to `Logger::DEBUG`_
- `$bubble`: Whether the messages that are handled can bubble up the stack or not. _Defaults to `true`_

# Examples
Given that $wpdb is your database instance, you could use the class as follows:
Given that the global `$wpdb` is your database instance, you could use the class as follows:

```php
// Import class
use WordPressHandler\WordPressHandler;

// Ensure access to global $wpdb
global $wpdb;

// Create WordPressHandler
$wordPressHandler = new WordPressHandler($wpdb, "log", array('username', 'userid'), \Monolog\Logger::DEBUG);
$wordPressHandler = new WordPressHandler(null, "log", array('username', 'userid'), \Monolog\Logger::DEBUG);

// Configure maximum number of rows to keep (old entries are deleted when reached)
$wordPressHandler->set_max_table_rows( 250000 );
$wordPressHandler->conf_table_size_limiter( 250000 );

// Setup array of extra fields
$record = ['extra' => []];
$record = array('extra' => array());

// Create database table if needed, add extra fields from above
$wordPressHandler->initialize($record);
Expand All @@ -64,7 +61,7 @@ $logger = new \Monolog\Logger($context);
$logger->pushHandler($wordPressHandler);

// Now you can use the logger, and further attach additional information
$logger->addWarning("This is a great message, woohoo!", array('username' => 'John Doe', 'userid' => 245));
$logger->warning("This is a great message, woohoo!", array('username' => 'John Doe', 'userid' => 245));
```

Required code to set up tables on plugin activation:
Expand All @@ -73,33 +70,34 @@ Required code to set up tables on plugin activation:
require __DIR__.'/vendor/autoload.php';

// Create the logs table if it doesn't already exist on plugin activation
function register_activation_hook(__FILE__, function() {
global $wpdb;

register_activation_hook(__FILE__, 'my_plugin_activation');
function my_plugin_activation() {
$handler = new \WordPressHandler\WordPressHandler(
$wpdb, "logs",
null, "logs",
array('username', 'userid'),
\Monolog\Logger::DEBUG
);

// setup array of extra fields
$record = ['extra' => []];
$record = array('extra' => array());

// creates database table if needed, add extra fields from above
$handler->initialize($record);
});
}
```

// Now somewhere else in my plugin where I want to use the logger
Now somewhere else in my plugin where I want to use the logger:
```php
$logger = new \Monolog\Logger('channel');
$handler = new \WordPressHandler\WordPressHandler(
$wpdb, "logs",
[],
null, "logs",
array(),
\Monolog\Logger::DEBUG
);
$handler->initialized = true; // Don't do any extra work - we've already done it.
$logger->pushHandler($handler);

$logger->warn('Some message');
$logger->warning('Some message');
```

Example code to delete tables on plugin deactivation:
Expand All @@ -109,11 +107,10 @@ register_uninstall_hook(__FILE__, 'my_plugin_uninstall');
function my_plugin_uninstall()
{
require __DIR__."/vendor/autoload.php";
global $wpdb;

$handler = new \WordPressHandler\WordPressHandler(
$wpdb, "logs",
[],
null, "logs",
array(),
\Monolog\Logger::DEBUG
);
$handler->uninitialize();
Expand All @@ -124,18 +121,14 @@ function my_plugin_uninstall()
Example to use in your custom WordPress Plugin

```php
use WordPressHandler\WordPressHandler;

require __DIR__ . '/vendor/autoload.php';

add_action( 'plugins_loaded', 'demo_function' );
function demo_function(){
require __DIR__ . '/vendor/autoload.php';

// Import class
use WordPressHandler\WordPressHandler;

// Ensure access to global $wpdb
global $wpdb;

// Create WordPressHandler
$wordPressHandler = new WordPressHandler($wpdb, "log", array('app', 'version'), \Monolog\Logger::DEBUG);
// Create a WordPressHandler instance
$wordPressHandler = new WordPressHandler(null, "log", array('app', 'version'), \Monolog\Logger::DEBUG);

// Create logger
$context = 'test-plugin-logging';
Expand All @@ -145,7 +138,7 @@ function demo_function(){
$logger->pushHandler($wordPressHandler);

// Now you can use the logger, and further attach additional information
$logger->addWarning("This is a great message, woohoo!", array('app' => 'Test Plugin', 'version' => '2.4.5'));
$logger->warning("This is a great message, woohoo!", array('app' => 'Test Plugin', 'version' => '2.4.5'));
}
```

Expand Down
2 changes: 1 addition & 1 deletion src/WordPressHandler/WordPressHandler.php
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ class WordPressHandler extends AbstractProcessingHandler
* @param \wpdb|null $custom_wpdb The {@see \wpdb} object of database connection.
* Set to `null` to automatically use the global $wpdb of WordPress.
* Default: null
* @param string $table Name of the table in the database to store the logs in.
* @param string $table Name of the database table to store the logs in.
* The 'wp_' (or other configured) prefix will be added automatically.
* Default: 'logs'
* @param string[] $additionalFields Additional Context Parameters to store in database
Expand Down

0 comments on commit 53416e0

Please sign in to comment.