<?php


class ControllerAuditHelper extends Controller {
   private $error = array();
   private $a = array(
                    'user'            => '',
                    'ipaddr'          => '',
                    'action'          => '',
                    'ref'             => '',
                    'date1'           => '',
                    'date2'           => '',
                    'order'           => '',
                    'sort'            => '',
                    'page_len'        => 50
                    );


   public function index(){

      $this->id = "content";
      $this->template = "audit/helper.tpl";
      $this->layout = "common/layout-empty";


      $request = Registry::get('request');
      $db = Registry::get('db');

      $this->load->model('audit/audit');

      if(Registry::get('admin_user') == 0 && Registry::get('auditor_user') == 0) {
         die("go away");
      }


      $this->data['page'] = 0;
      if(isset($this->request->post['page'])) { $this->data['page'] = $this->request->post['page']; }

      $this->data['page_len'] = $this->a['page_len'] = get_page_length();

      $this->data['n'] = -1;



      if(isset($this->request->post)) {
         $this->fixup_request($this->request->post);
         list($this->data['n'], $this->data['messages']) = $this->model_audit_audit->search_audit($this->a);
      }

      $this->data['actions'][ACTION_UNKNOWN] = '??';
      $this->data['actions'][ACTION_LOGIN] = $this->data['text_login2'];
      $this->data['actions'][ACTION_LOGIN_FAILED] = $this->data['text_login_failed'];
      $this->data['actions'][ACTION_LOGOUT] = $this->data['text_logout2'];
      $this->data['actions'][ACTION_VIEW_MESSAGE] = $this->data['text_view_message2'];
      $this->data['actions'][ACTION_VIEW_HEADER] = $this->data['text_view_header'];
      $this->data['actions'][ACTION_UNAUTHORIZED_VIEW_MESSAGE] = $this->data['text_unauthorized_view_message'];
      $this->data['actions'][ACTION_RESTORE_MESSAGE] = $this->data['text_restore_message'];
      $this->data['actions'][ACTION_DOWNLOAD_MESSAGE] = $this->data['text_download_message2'];
      $this->data['actions'][ACTION_SEARCH] = $this->data['text_search2'];
      $this->data['actions'][ACTION_SAVE_SEARCH] = $this->data['text_save_search'];
      $this->data['actions'][ACTION_CHANGE_USER_SETTINGS] = $this->data['text_change_user_settings'];
      $this->data['actions'][ACTION_REMOVE_MESSAGE] = $this->data['text_remove_message2'];
      $this->data['actions'][ACTION_UNAUTHORIZED_REMOVE_MESSAGE] = $this->data['text_unauthorized_remove_message'];
      $this->data['actions'][ACTION_DOWNLOAD_ATTACHMENT] = $this->data['text_download_attachment2'];
      $this->data['actions'][ACTION_UNAUTHORIZED_DOWNLOAD_ATTACHMENT] = $this->data['text_unauthorized_download_attachment'];
      $this->data['actions'][ACTION_VIEW_JOURNAL] = $this->data['text_view_journal'];
      $this->data['actions'][ACTION_MARK_MESSAGE_FOR_REMOVAL] = $this->data['text_remove_request'];
      $this->data['actions'][ACTION_MARK_AS_PRIVATE] = $this->data['text_mark_private'];
      $this->data['actions'][ACTION_REJECT_REMOVAL] = $this->data['text_rejected_removal'];




      /* paging info */

      $this->data['prev_page'] = $this->data['page'] - 1;
      $this->data['next_page'] = $this->data['page'] + 1;

      $this->data['total_pages'] = ceil($this->data['n'] / $this->data['page_len'])-1;

      $this->data['hits_from'] = $this->data['page'] * $this->data['page_len'] + 1;
      $this->data['hits_to'] = ($this->data['page']+1) * $this->data['page_len'];

      if($this->data['hits_to'] > $this->data['n']) { $this->data['hits_to'] = $this->data['n']; }


      $this->render();
   }


   private function fixup_request($data = array()) {
      $ndate = 0;
      global $actions;

      if(!isset($data['search']) || $data['search'] == $this->data['text_enter_search_terms']) { return; }

      $s = preg_replace("/:/", ": ", $data['search']);
      $s = preg_replace("/,/", " ", $s);
      $s = preg_replace("/\s{1,}/", " ", $s);
      $b = explode(" ", $s);

      foreach ($b as $k => $v) {
         if($v == '') { continue; }

         if(preg_match("/(login|loginfailed|logout|view|download|search|restore|journal)$/", $v) && isset($actions[$v])) { $this->a['action'] .= "\t" . $actions[$v]; }
         if(preg_match("/\@/", $v)) { $this->a['user'] .= "\t" . $v; }
         if(preg_match("/\d{1,3}\.\d{1,3}\.(\d{1,3}|\*)\.(\d{1,3}|\*)/", $v)) { $this->a['ipaddr'] .= "\t" . $v; }
         if(preg_match("/^\d{1,}$/", $v)) { $this->a['ref'] .= "\t" . $v; }
         if(preg_match("/\d{4}(\-|\.)(\d{1,2}|\*)(\-|\.)(\d{1,2}|\*)/", $v) || preg_match("/(\d{1,2}|\*)\/(\d{1,2}|\*)\/\d{4}/", $v)) {
            $ndate++;
            $this->a["date$ndate"] = $v;
         }
      }

      $this->a['user'] = preg_replace("/^\t/", "", $this->a['user']);
      $this->a['ipaddr'] = preg_replace("/^\t/", "", $this->a['ipaddr']);
      $this->a['ref'] = preg_replace("/^\t/", "", $this->a['ref']);
      $this->a['action'] = preg_replace("/^\t/", "", $this->a['action']);

      if(isset($data['sort'])) { $this->a['sort'] = $data['sort']; }
      if(isset($data['order'])) { $this->a['order'] = $data['order']; }
      if(isset($data['page'])) { $this->a['page'] = $data['page']; }
      if(isset($data['page_len'])) { $this->a['page_len'] = $data['page_len']; }

   }


}

?>