如何在Codeigniter上进行实时用户活动跟踪功能?

时间:2019-04-25 04:46:10

标签: codeigniter user-activity

我正在寻找如何在我的Codeigniter网站上跟踪用户活动(例如:XXX在帖子上发表评论/登录的XXX /分享了帖子等的XXX; XXX是已注册的用户/ IP地址)。

是否有建议执行此功能,因为我已经研究了几天,却一无所知。

1 个答案:

答案 0 :(得分:0)

通常我什至不会回答这样的问题,因为它范围太广,但是由于我有一个类似的系统,因此我将分享我的方法。 请注意,我对此不提供任何支持,但是这是给您的一个想法和/或开发自己的实现。

假设我们要记录用户登录/失败:

    if ($this->ion_auth->login($identity, $this->input->post('password'), false)) {
        $this->curr_user->update_ip();
        $this->activity->log('logged_in');
        $this->response->success()->json();
    } else {
        $this->activity->log('login_failed', array('username' => $identity));
        $this->response->error($this->ion_auth->errors())->json();
    }

在重定向/呈现输出之前,但在完成所需的操作(插入/更新,登录等)之后,我们只需调用log函数。

模型

log函数使用switch语句使消息保持同质,并出于查询目的将某些信息与主消息分开。老实说,在这里使用switch语句并不是一件很优雅的事情,特别是如果您有很多消息,因此实现一个表来保存消息并不是一个坏主意,但这可以满足我的需求。

get_logs是一个很棒的小功能,它将所有数据合并并按操作发生的日期将其呈现在排序列表中。

class User_activity_model extends CI_Model {

    /**
     * Admin-only viewable log types
     * 
     * @var array
     */
    private $admin_types = array('page_access', 'user_registered', 'logged_in', 'login_failed', 'login_failed_sa', 'delete');

    /**
     * Main user activity logging function
     * 
     * @param string $action
     * @param array $arr Additional attributes per case
     * @return void
     */
    public function log($action, $arr = array()) {
        switch ($action) {
            default:
                return;
            case 'backup_created':
                $msg = "{username} created a backup {$arr['filename']} at {time}.";
                break;
            case 'backup_restored':
                $msg = "{username} restored backup {$arr['filename']} at {time}.";
                break;
            case 'user_registered':
                $msg = "{$arr['first_name']} {$arr['last_name']} registered with username: {$arr['username']}.";
                break;
            case 'added':
                $msg = "{username} added item {$arr['id']} to the {$arr['table']} table.";
                break;
            case 'modified':
                $msg = "{username} modified item {$arr['id']} in the {$arr['table']} table.";
                break;
            case 'deleted':
                $msg = "{username} deleted item {$arr['id']} from the {$arr['table']} table.";
                break;
            case 'published':
                $msg = "{username} published item {$arr['id']} from the {$arr['table']} table.";
                break;
            case 'unpublished':
                $msg = "{username} unpublished item {$arr['id']} from the {$arr['table']} table.";
                break;
            case 'logged_in':
                $ip = $this->input->ip_address();
                $msg = "{username} logged in at {time} from IP {$ip}.";
                break;
            case 'login_failed':
                $ip = $this->input->ip_address();
                $msg = "Someone tried to login with username {$arr['username']} at {time} from IP {$ip}.";
                break;
            case 'login_failed_sa':
                $ip = $this->input->ip_address();
                $msg = "Someone tried to login with social auth provider {$arr['provider']} at {time} from IP {$ip}.";
                break;
            case 'page_access':
                $identity = $this->ion_auth->logged_in() ? '{username}' : "Someone (IP: {$this->input->ip_address()})";
                $msg = "{$identity} tried to access a page they didn't have permission for: {$arr['uri']}.";
                break;
            case 'logout':
                $msg = "{username} logged out at {time}.";
                break;
            case 'user_forgotten':
                $msg = 'Someone deleted their account.';
                break;
        }
        $this->add($action, $msg);
    }

    /**
     * Adds identifier information to the insert query
     * 
     * @param string $action
     * @param string $msg
     * @return void
     */
    private function add($action, $msg) {
        $data = array(
            'ip' => $this->input->ip_address(),
            'action' => $action,
            'type' => in_array($action, $this->admin_types) ? 'admin' : 'all',
            'message' => $msg
        );
        if ($this->ion_auth->logged_in()) {
            $data['username'] = $this->curr_user->details()->username;
            $data['user_id'] = $this->curr_user->id();
        }
        $this->db->set('time', 'NOW()', false);
        $this->db->insert('user_activity', $data);
    }

    /**
     * Generates log array
     * 
     * Format:
     * 
     * array(
     *       [date]
     *             array(
     *                   [0] = message1
     *                   [1] = message2
     * 
     * @param boolean $admin_only Show all logs?
     * @return boolean|object Logs object, FALSE otherwise
     */
    public function get_logs($admin_only = true) {
        if (!$admin_only) {
            $this->db->where('type !=', 'admin');
        }
        $this->db->limit(10000);
        $this->db->order_by('time', 'DESC');
        $query = $this->db->get('user_activity');
        if ($query->num_rows() < 1) {
            return false;
        }
        $rows = $query->result();
        $data = new \stdClass();
        foreach ($rows as $row) {
            // replace {time} with timezone converted time
            $time = $this->timezone->convert($row->time);
            $row->message = str_replace('{time}', $time, $row->message);
            $username = is_null($row->username) ? $this->lang->line('deleted_user') : $row->username;
            $row->message = str_replace('{username}', $username, $row->message);
            // date Y-m-d acts as key for messages on that day
            $key = date('Y-m-d', strtotime($time));
            $data->{$key}[] = $row;
        }
        return $data;
    }

    /**
     * Truncates user_activity table
     * 
     * @return boolean
     */
    public function delete_logs() {
        return $this->db->truncate('user_activity');
    }

    /**
     * Stub for automate hook to add 'added' activity
     * 
     * @param array $data
     */
    public function automate_activity_add($data) {
        $this->activity->log('added', array('table' => $data['table'], 'id' => $data['id']));
    }

    /**
     * Stub for automate hook to add 'modified' activity
     * 
     * @param array $data
     */
    public function automate_activity_modify($data) {
        $this->activity->log('modified', array('table' => $data['table'], 'id' => $data['id']));
    }

}

数据库

enter image description here

db dump:https://pastebin.com/wCEnUigH