Log-Tracker, the tracking companion to Apix-Log
An extension for the Apix-Log PSR-3 logger which adds log tracking to:
Features:
- Send tracking data asynchnonously (non-blocking).
- Handles batched/deferred mode.
- 100% Unit tested and compliant with PSR0, PSR1 and PSR2.
- Continuously integrated against all modern PHP versions (5.3 all the way through 7.3,
including HHVM). - Home repo is on on github, and the Composer package is on packagist.
Feel free to comment, send pull requests and patches...
Install the latest version via composer:
$ composer require apix/log-tracker
You require at least PHP 5.3.
use Apix\Log;
$options = [
'tid' => '<UA-XX-XX>', // Tracking/Property ID (required).
//'cid' => '<UUID-v4>', // Anonymous Client ID UUIDv4 (if not provided, auto-generated one).
//... // Any numbers of Google Analytics Parameters (see notes).
];
$ga_logger = new GoogleAnalytics($options);
$ga_logger->setDeferred(true); // Enable batched mode (recommneded).
$dataToTrack = $ga_logger->getPage('http://foo.tld/...', 'Welcome page');
//$dataToTrack = $ga_logger->getEvent('category', 'action', 'label', 'value');
//$dataToTrack = $ga_logger->getSocial('action', 'network', 'target');
//$dataToTrack = $ga_logger->getException('description');
//$dataToTrack = $ga_logger->getApp('name', 'version', 'id');
$ga_logger->notice('GA Tracking', $dataToTrack);
Notes:
- The log level and message are not forwarded to Google Analytics (TBD).
- If required, you can add some additional Google Analytics Parameters to the
options
array such asuip
(user IP),ua
(user agent), etc... If not provided, these will be generated and/or guessed from the current context.
use Apix\Log;
$dashbot_logger = new Dashbot('<API-Key');
//$dashbot_logger->setPlatform('facebook'); // 'generic' (default), 'slack', 'kik'.
//$dashbot_logger->setGlobalTag('myTag'); // Useful to combined metrics.
$messages_received = ["text" => "Hi, bot", "userId" => "..."];
$dataToTrack = $dashbot_logger->incoming($messages_received);
//$dataToTrack = $dashbot_logger->incoming($messages_received, "localTag"); // Override the global tag
$messages_sent = ["text" => "Hello, user", "userId" => "..."];
$dataToTrack = $logger->outgoing($messages_sent);
$dashbot_logger->info('Dashbot Tracking', $dataToTrack);
Notes:
- The log level and message are not forwarded to Dashbot (TBD).
- A local tag (which override the main global tag) can be passed to the
incoming
andoutgoing
methods as a second argument.
Please for now just follow Apix Log Examples.