A WordPress plugin which logs and displays relevant activity within your blog or network.
|Author:||Tomas Buteler (profile at wordpress.org)|
|WordPress version required:||3.0.1|
|WordPress version tested:||3.5.1|
|Added to WordPress repository:||25-05-2013|
Warning! This plugin has not been updated in over 2 years. It may no longer be maintained or supported and may have compatibility issues when used with more recent versions of WordPress.
|Total downloads:||2 096|
Click to start download
The Activity Logs plugin will record most of the changes that occur in your WordPress blog or multisite network, making it easy for you to keep on track of what everyone is doing, or to catch up on what happened since you last checked in.
It's a very simple to use plugin (though it offers good extensibility to advanced users and plugin authors): just activate it and the logs will be recorded automatically, and an activity stream will appear on your dashboard.
The Activity Logs plugin keeps track of post, pages, custom post types and comments transitions, settings changes, plugin activations, import, export, user and site management in a simple, seamless way.
I don’t see a settings page for this plugin. Can I configure it somehow?
A little bit, yes. Although the idea is to allow users to install and forget, admins have some configuration options available. To do so, define the constants below in your
wp-config.php file (or anywhere else, as long as they’re defined before the
init action takes place).
Values defined here are the plugins defaults, which can be overriden.
Time range, in seconds, that will cause our activity log to ignore repeat actions. Note that activity will still be logged, but won’t be displayed in the dashboard:
// Logs 60 seconds apart will be treated as the same action (same type, same logger only) define('CK_LOG_TIME_IGNORE', 60);
Maximum number of rows reserved for activity logs in custom table:
// 0 means no limit define('CK_LOG_MAX_ROWS', 0);
Amount of logs to load on dashboard widget at a time:
Can I create my own loggers?
Yes. There are many filters and actions to hook into, but the default loggers take into account core functionality only. This includes custom post types, but not custom functionality which most plugins add to WordPress. Luckily, you can easily set your own loggers by using the following function:
cookspin_register_logger( $name, // A slug-like name for this logger, shorter than 255 characters $category, // A slug-like name for the logger's category. For the default list, see below $args // See below );
Here are the default categories (and slugs) for loggers. These are meant to mimick the default sections of the WordPress admin menu. Your custom logger can go into any of these, and you can create your own categories as well (though you will have to specify labels and CSS / icons via filters):
The third and final argument of the function is actually an array of arguments. Let’s go through the options one by one. (Note that omitting “required” arguments might not cause the function to fail, but will prevent the log from displaying properly.)
hook(string)(required): Which action should we hook to? Every time it fires, our log will record an entry. Important: If you’re hooking to filters and not actions, set the
priority(integer)(optional): Priority of the logger function compared to all other functions hooked to this action.
n_params(integer)(optional): How many arguments does the logger function need from the action? If more than one, this has to be specified.
cb(string)(required): The actual callback which will define what information gets recorded on the database.
print_cb(string)(required): A callback which is used to generate a readable version of the log.
hook_to_filter(boolean)(optional): Do you want to log something everytime a filter is applied? You can do that too, but you need to set this to true. Failure to do so will prevent the filter you’re hooking to from working properly, and can break stuff.
ignore_cmp(string or array of strings)(optional): Sometimes ignoring logs based on the time they were recorded is not enough to prevent you from showing actions which have no actual impact. Here you can specify any of the following, which correspond to the activity log’s table columns: ‘object_type’, ‘object_id’, ‘log_code’, ‘user_id’.
- Initial public release.