/yii2-activity

User activity tracking module for Yii2

Primary LanguagePHPMIT LicenseMIT

Progress Github all releases GitHub version Progress GitHub license

Yii2 Activity Module

User activity tracking system for Yii2

Requirements

  • PHP 5.6 or higher
  • Yii2 v.2.0.20 and newest
  • Yii2 Base module (required)
  • Yii2 Users module (required)

Installation

To install the module, run the following command in the console:

$ composer require "wdmg/yii2-activity:dev-master"

After configure db connection, run the following command in the console:

$ php yii activity/init

And select the operation you want to perform:

  1. Apply all module migrations
  2. Revert all module migrations

Migrations

In any case, you can execute the migration and create the initial data, run the following command in the console:

$ php yii migrate --migrationPath=@vendor/wdmg/yii2-activity/migrations

Configure

To add a module to the project, add the following data in your configuration file:

'modules' => [
    ...
    'activity' => [
        'class' => 'wdmg\activity\Module',
        'routePrefix' => 'admin'
    ],
    ...
],

Usecase

Use the setActivity($message = null, $action = null, $type = null, $level = 1) method to log events and user actions, you can use the construction

<?php

    if($model->login()) {
        $activity = new Activity;
        $activity->setActivity('User has successfully login.', 'login', 'info', 2);
        ...
    }
    
    // or from component
    
    if($model->login()) {
        Yii::$app->activity->set('User has successfully login.', 'login', 'info', 2);
        ...
    }
    
?>

Routing

Use the Module::dashboardNavItems() method of the module to generate a navigation items list for NavBar, like this:

<?php
    echo Nav::widget([
    'options' => ['class' => 'navbar-nav navbar-right'],
        'label' => 'Modules',
        'items' => [
            Yii::$app->getModule('activity')->dashboardNavItems(),
            ...
        ]
    ]);
?>

Status and version [in progress development]

  • v.1.1.7 - Added extra options to composer.json and navbar menu icon
  • v.1.1.6 - Added choice param for non interactive mode
  • v.1.1.5 - Module refactoring