Download the PHP package lorenzo/audit-stash without Composer
On this page you can find all versions of the php package lorenzo/audit-stash. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download lorenzo/audit-stash
More information about lorenzo/audit-stash
Files in lorenzo/audit-stash
Package audit-stash
Short Description Flexible and rock solid audit log tracking plugin for cakephp
License MIT
Informations about the package audit-stash
AuditStash Plugin For CakePHP
This plugin implements an "audit trail" for any of your Table classes in your application, that is, the ability of recording any creation, modification or delete of the entities of any particular table.
By default, this plugin stores the audit logs into Elasticsearch, as we have found that it is a fantastic storage engine for append-only streams of data and provides really powerful features for finding changes in the historic data.
Even though we suggest storing the logs in Elasticsearch, this plugin is generic enough so you can implement your own persisting strategies, if so you wish.
Installation
You can install this plugin into your CakePHP application using composer and executing the following lines in the root of your application.
For using the default storage engine (ElasticSearch) you need to install the official elastic-search
plugin, by executing
the following lines:
Configuration
Elastic Search
You now need to add the datasource configuration to your config/app.php
file:
Tables / Regular Databases
If you want to use a regular database, respectively an engine that can be used via the CakePHP ORM API, then you can use the table persister that ships with this plugin.
To do so you need to configure the AuditStash.persister
option accordingly. In your config/app_local.php
file add the
following configuration:
The plugin will then by default try to store the logs in a table named audit_logs
, via a table class with the alias
AuditLogs
, which you could create/overwrite in your application if you need.
You can find a migration in the config/migration
folder of this plugin which you can apply to your database, this will
add a table named audit_logs
with all the default columns - alternatively create the table manually. After that you
can bake the corresponding table class.
Table Persister Configuration
The table persister supports various configuration options, please refer to
its API documentation for further information. Generally configuration can be
applied via its setConfig()
method:
Using AuditStash
Enabling the Audit Log in any of your table classes is as simple as adding a behavior in the initialize()
function:
Remember to execute the command line each time you change the schema of your table!
Configuring The Behavior
The AuditLog
behavior can be configured to ignore certain fields of your table, by default it ignores the created
and modified
fields:
If you prefer, you can use a whitelist
instead. This means that only the fields listed in that array will be tracked by the behavior:
If you have fields that contain sensitive information but still want to track their changes you can use the sensitive
configuration:
Storing The Logged In User
It is often useful to store the identifier of the user that is triggering the changes in a certain table. For this purpose, AuditStash
provides the RequestMetadata
listener class, that is capable of storing the current URL, IP and logged in user. You need to add this
listener to your application in the AppController::beforeFilter()
method:
The above code assumes that you will trigger the table operations from the controller, using the default Table class for the controller. If you plan to use other Table classes for saving or deleting inside the same controller, it is advised that you attach the listener globally:
Storing Extra Information In Logs
AuditStash
is also capable of storing arbitrary data for each of the logged events. You can use the ApplicationMetadata
listener or
create your own. If you choose to use ApplicationMetadata
, your logs will contain the app_name
key stored and any extra information
your may have provided. You can configure this listener anywhere in your application, such as the bootstrap.php
file or, again, directly
in your AppController.
Implementing your own metadata listeners is as simple as attaching the listener to the AuditStash.beforeLog
event. For example:
Implementing Your Own Persister Strategies
There are valid reasons for wanting to use a different persist engine for your audit logs. Luckily, this plugin allows you to implement
your own storage engines. It is as simple as implementing the PersisterInterface
interface:
Finally, you need to configure AuditStash
to use your new persister. In the config/app.php
file add the following
lines:
or if you are using as standalone via
The configuration contains the fully namespaced class name of your persister.
Working With Transactional Queries
Occasionally, you may want to wrap a number of database changes in a transaction, so that it can be rolled back if one
part of the process fails. There are two ways to accomplish this. The easiest is to change your save strategy to use
afterSave
instead of afterCommit
. In your applications configuration, such as config/app.php
:
That's it if you use afterSave. You should read up on the difference between the two as there are drawbacks: https://book.cakephp.org/4/en/orm/table-objects.html#aftersave
If you are using the default afterCommit, in order to create audit logs during a transaction, some additional setup is
required. First create the file src/Model/Audit/AuditTrail.php
with the following:
Anywhere you wish to use Connection::transactional()
, you will need to first include the following at the top of the file:
Your transaction should then look similar to this example of a BookmarksController:
This will save all audit info for your objects, as well as audits for any associated data. Please note, $result
must
be an instance of an Object. Do not change the text "Model.afterCommit".
Testing
By default, the test suite will not run elastic. If you are an elastic user and wish to test against a local instance then you will need to set the environment variable: