Файл: Just Wallet 2.0.4/application/controllers/admin/Verification.php
Строк: 346
<?php defined('BASEPATH') OR exit('No direct script access allowed');
class Verification extends Admin_Controller {
    
    /**
     * @var string
     */
    private $_redirect_url;
    /**
     * Constructor
     */
    function __construct()
    {
        parent::__construct();
        // load the language files
        $this->lang->load('users');
            
                // load the logs model
                $this->load->model('verification_model');
                $this->load->model('support_model');
                $this->load->model('users_model');
                $this->load->model('template_model');
                $this->load->library('notice');
            
                // set constants
        define('REFERRER', "referrer");
        define('THIS_URL', base_url('admin/verification'));
              define('THIS_URL_2', base_url('admin/verification/untreated'));
        define('DEFAULT_LIMIT', $this->settings->per_page_limit);
        define('DEFAULT_OFFSET', 0);
        define('DEFAULT_SORT', "id");
        define('DEFAULT_DIR', "desc");
        // use the url in session (if available) to return to the previous filter/sorted/paginated list
        if ($this->session->userdata(REFERRER))
        {
            $this->_redirect_url = $this->session->userdata(REFERRER);
        }
        else
        {
            $this->_redirect_url = THIS_URL;
        }
    }
    /**
     * All
     */
    function index()
    {
        // get parameters
        $limit  = $this->input->get('limit')  ? $this->input->get('limit', TRUE)  : DEFAULT_LIMIT;
        $offset = $this->input->get('offset') ? $this->input->get('offset', TRUE) : DEFAULT_OFFSET;
        $sort   = $this->input->get('sort')   ? $this->input->get('sort', TRUE)   : DEFAULT_SORT;
        $dir    = $this->input->get('dir')    ? $this->input->get('dir', TRUE)    : DEFAULT_DIR;
            
        // get filters
        $filters = array();
        if ($this->input->get('id', TRUE))
        {
            $id_xss = $this->security->xss_clean($this->input->get('id'));
                        $id_replace = htmlentities($id_xss, ENT_QUOTES, "UTF-8");
            $filters['id'] = $id_replace;
        }
        if ($this->input->get('user', TRUE))
        {
            $user_xss = $this->security->xss_clean($this->input->get('user'));
                        $user_replace = htmlentities($user_xss, ENT_QUOTES, "UTF-8");
            $filters['user'] = $user_replace;
        }
        if ($this->input->get('date', TRUE))
        {
            $date_xss = $this->security->xss_clean($this->input->get('date'));
                        $date_string = htmlentities($date_xss, ENT_QUOTES, "UTF-8");
            $filters['date'] = $date_string;
        }
            
                if ($this->input->get('code', TRUE))
        {
            $code_xss = $this->security->xss_clean($this->input->get('code'));
                        $code_string = htmlentities($code_xss, ENT_QUOTES, "UTF-8");
            $filters['code'] =$code_string;
        }
            
                // build filter string
        $filter = "";
        foreach ($filters as $key => $value)
        {
            $filter .= "&{$key}={$value}";
        }
            
        // are filters being submitted?
        if ($this->input->post())
        {
            if ($this->input->post('clear'))
            {
                // reset button clicked
                redirect(THIS_URL);
            }
            else
            {
                // apply the filter(s)
                $filter = "";
                if ($this->input->post('id'))
                {
                    $filter .= "&id=" . $this->input->post('id', TRUE);
                }
                if ($this->input->post('user'))
                {
                    $filter .= "&user=" . $this->input->post('user', TRUE);
                }
                if ($this->input->post('date'))
                {
                    $filter .= "&date=" . $this->input->post('date', TRUE);
                }
                            
                                if ($this->input->post('code'))
                {
                    $filter .= "&code=" . $this->input->post('code', TRUE);
                }
                // redirect using new filter(s)
                redirect(THIS_URL . "?sort={$sort}&dir={$dir}&limit={$limit}&offset={$offset}{$filter}");
            }
                    
            // get list
            $verification = $this->verification_model->get_all($limit, $offset, $filters, $sort, $dir);
                    
        }
            
        // save the current url to session for returning
        $this->session->set_userdata(REFERRER, THIS_URL . "?sort={$sort}&dir={$dir}&limit={$limit}&offset={$offset}{$filter}");
            
        // setup page header data
        $this
            ->add_js_theme("currency_i18n.js", TRUE )
            ->set_title( lang('admin verify menu') );
        
        $data = $this->includes;
            
        // get list
        $verification = $this->verification_model->get_all($limit, $offset, $filters, $sort, $dir);
            
        // build pagination
        $this->pagination->initialize(array(
            'base_url'   => THIS_URL . "?sort={$sort}&dir={$dir}&limit={$limit}{$filter}",
            'total_rows' => $verification['total'],
            'per_page'   => $limit
        ));
            
        // set content data
        $content_data = array(
            'this_url'   => THIS_URL,
            'verification'       => $verification['results'],
            'total'      => $verification['total'],
            'filters'    => $filters,
            'filter'     => $filter,
            'pagination' => $this->pagination->create_links(),
            'limit'      => $limit,
            'offset'     => $offset,
            'sort'       => $sort,
            'dir'        => $dir
        );
        // load views
        $data['content'] = $this->load->view('admin/verification/index', $content_data, TRUE);
        $this->load->view($this->template, $data);
    }
    
    /**
     * untreated
     */
    function untreated()
    {
        // get parameters
        $limit  = $this->input->get('limit')  ? $this->input->get('limit', TRUE)  : DEFAULT_LIMIT;
        $offset = $this->input->get('offset') ? $this->input->get('offset', TRUE) : DEFAULT_OFFSET;
        $sort   = $this->input->get('sort')   ? $this->input->get('sort', TRUE)   : DEFAULT_SORT;
        $dir    = $this->input->get('dir')    ? $this->input->get('dir', TRUE)    : DEFAULT_DIR;
            
        // get filters
        $filters = array();
        if ($this->input->get('id', TRUE))
        {
            $id_xss = $this->security->xss_clean($this->input->get('id'));
                        $id_replace = htmlentities($id_xss, ENT_QUOTES, "UTF-8");
            $filters['id'] = $id_replace;
        }
        if ($this->input->get('user', TRUE))
        {
            $user_xss = $this->security->xss_clean($this->input->get('user'));
                        $user_replace = htmlentities($user_xss, ENT_QUOTES, "UTF-8");
            $filters['user'] = $user_replace;
        }
        if ($this->input->get('date', TRUE))
        {
            $date_xss = $this->security->xss_clean($this->input->get('date'));
                        $date_string = htmlentities($date_xss, ENT_QUOTES, "UTF-8");
            $filters['date'] = $date_string;
        }
            
                if ($this->input->get('code', TRUE))
        {
            $code_xss = $this->security->xss_clean($this->input->get('code'));
                        $code_string = htmlentities($code_xss, ENT_QUOTES, "UTF-8");
            $filters['code'] =$code_string;
        }
            
                // build filter string
        $filter = "";
        foreach ($filters as $key => $value)
        {
            $filter .= "&{$key}={$value}";
        }
            
        // are filters being submitted?
        if ($this->input->post())
        {
            if ($this->input->post('clear'))
            {
                // reset button clicked
                redirect(THIS_URL_2);
            }
            else
            {
                // apply the filter(s)
                $filter = "";
                if ($this->input->post('id'))
                {
                    $filter .= "&id=" . $this->input->post('id', TRUE);
                }
                if ($this->input->post('user'))
                {
                    $filter .= "&user=" . $this->input->post('user', TRUE);
                }
                if ($this->input->post('date'))
                {
                    $filter .= "&date=" . $this->input->post('date', TRUE);
                }
                            
                                if ($this->input->post('code'))
                {
                    $filter .= "&code=" . $this->input->post('code', TRUE);
                }
                // redirect using new filter(s)
                redirect(THIS_URL_2 . "?sort={$sort}&dir={$dir}&limit={$limit}&offset={$offset}{$filter}");
            }
                    
            // get list
            $verification = $this->verification_model->get_untreated($limit, $offset, $filters, $sort, $dir);
                    
        }
            
        // save the current url to session for returning
        $this->session->set_userdata(REFERRER, THIS_URL_2 . "?sort={$sort}&dir={$dir}&limit={$limit}&offset={$offset}{$filter}");
            
        // setup page header data
        $this
            ->add_js_theme("currency_i18n.js", TRUE )
            ->set_title( lang('admin verify menu') );
        
        $data = $this->includes;
            
        // get list
        $verification = $this->verification_model->get_untreated($limit, $offset, $filters, $sort, $dir);
            
        // build pagination
        $this->pagination->initialize(array(
            'base_url'   => THIS_URL_2 . "?sort={$sort}&dir={$dir}&limit={$limit}{$filter}",
            'total_rows' => $verification['total'],
            'per_page'   => $limit
        ));
            
        // set content data
        $content_data = array(
            'this_url'   => THIS_URL_2,
            'verification'       => $verification['results'],
            'total'      => $verification['total'],
            'filters'    => $filters,
            'filter'     => $filter,
            'pagination' => $this->pagination->create_links(),
            'limit'      => $limit,
            'offset'     => $offset,
            'sort'       => $sort,
            'dir'        => $dir
        );
        // load views
        $data['content'] = $this->load->view('admin/verification/untreated', $content_data, TRUE);
        $this->load->view($this->template, $data);
    }
    
    /**
     * Edit email template
     */
    function edit($id = NULL)
    {
        // make sure we have a numeric id
        if (is_null($id) OR ! is_numeric($id))
        {
            redirect($this->_redirect_url);
        }
        // get the data
        $request = $this->verification_model->get_request($id);
                
        // if empty results, return to list
        if ( ! $request)
        {
            redirect($this->_redirect_url);
        }
        
                $user = $this->users_model->get_username($request['user']);
        // setup page header data
        $this->set_title( lang('admin verify detail') );
        $data = $this->includes;
        // set content data
        $content_data = array(
            'this_url'              => THIS_URL,
                        'user'      => $user,
            'cancel_url'           => $this->_redirect_url,
            'request'      => $request,
            'request_id'   => $id
        );
        // load views
        $data['content'] = $this->load->view('admin/verification/detail', $content_data, TRUE);
        $this->load->view($this->template, $data);
    }
    
    function confirm_request($id)
  {
        
        // get the data
    $request = $this->verification_model->get_request($id);
        
        // if empty results, return to list
    if ( ! $request)
    {
       redirect($this->_redirect_url);
    }
        
        $user = $this->users_model->get_username($request['user']);
        
        if ($request['status'] != 1) {
            
            // update user status
            $this->users_model->update_setting_user($user['id'],
                array(
                    "verify_status"   => "2",
                    )
                );
            
            // update request status
            $this->verification_model->update_verification($request['code'],
                array(
                    "status"   =>   "1"
                    )
                );
            
            $email_template = $this->template_model->get_email_template(7);
                
            if($email_template['status'] == "1") {
            
                // variables to replace
                $site_name = $this->settings->site_name;
                $link = site_url('account/settings/verification');
                $name_user = $user['first_name'] . ' ' . $user['last_name'];
                $rawstring = $email_template['message'];
                // what will we replace
                $placeholders = array('[SITE_NAME]','[SITE_LINK]','[NAME]');
                $vals_1 = array($site_name, $link, $name_user);
                //replace
                $str_1 = str_replace($placeholders, $vals_1, $rawstring);
                $this -> email -> from($this->settings->site_email, $this->settings->site_name);
                $this->email->to($user['email']);
                //$this -> email -> to($user['email']);
                $this -> email -> subject($email_template['title']);
                $this -> email -> message($str_1);
                $this->email->send();
            
            }
            
            $sms_template = $this->template_model->get_sms_template(6);
                            
                                    if($sms_template['status'] == "1") {
                                        
                                        $rawstring = $sms_template['message'];
                                        $result = $this->sms->send_sms($user['phone'], $sms_template['message']);
                                        
                                    }
            
            $this->session->set_flashdata('message', lang('users settings id_doc_success'));
            redirect(site_url("admin/verification"));
            
        } else {
            
            $this->session->set_flashdata('error', lang('admin verify error'));
            redirect(site_url("admin/verification"));
            
        }
        
    }
    
    function reject_request($id)
  {
        // get the data
    $request = $this->verification_model->get_request($id);
        
        // if empty results, return to list
    if ( ! $request)
    {
       redirect($this->_redirect_url);
    }
        
        $user = $this->users_model->get_username($request['user']);
        
        $this->form_validation->set_rules('comment', lang('admin settings comment'), 'required');
        
        if ($this->form_validation->run() == TRUE) {
            
            $comment = $this->security->xss_clean($this->input->post("comment"));
        
            if ($request['status'] != 2) {
                // update request status
                $this->verification_model->update_verification($request['code'],
                    array(
                        "status"    =>   "2",
                        "comment"   =>   $comment
                        )
                    );
                
                $email_template = $this->template_model->get_email_template(8);
                
                if($email_template['status'] == "1") {
                    // variables to replace
                    $site_name = $this->settings->site_name;
                    $link = site_url('account/settings/verification');
                    $name_user = $user['first_name'] . ' ' . $user['last_name'];
                    
                    $rawstring = $email_template['message'];
                    // what will we replace
                    $placeholders = array('[SITE_NAME]','[SITE_LINK]','[COMMENT]','[NAME]');
                    $vals_1 = array($site_name, $link, $comment, $name_user);
                    //replace
                    $str_1 = str_replace($placeholders, $vals_1, $rawstring);
                    $this -> email -> from($this->settings->site_email, $this->settings->site_name);
                    $this->email->to($user['email']);
                    //$this -> email -> to($user['email']);
                    $this -> email -> subject($email_template['title']);
                    $this -> email -> message($str_1);
                    $this->email->send();
                }
                
                $sms_template = $this->template_model->get_sms_template(7);
                            
                                    if($sms_template['status'] == "1") {
                                        
                                        $rawstring = $sms_template['message'];
                                        $result = $this->sms->send_sms($user['phone'], $sms_template['message']);
                                        
                                    }
            } else {
                $this->session->set_flashdata('error', lang('admin verify error'));
                redirect(site_url("admin/verification"));
            }
            
            $this->session->set_flashdata('message', lang('users settings id_doc_success'));
            redirect(site_url("admin/verification"));
            
        } else {
            
            $this->session->set_flashdata('error', lang('admin verify error'));
            redirect(site_url("admin/verification"));
            
        }
        
    }
    
    function delete($id)
  {
        // make sure we have a numeric id
    if (is_null($id) OR ! is_numeric($id))
    {
         redirect($this->_redirect_url);
    }
      $del = $this->verification_model->delete_doc($id);
        $this->session->set_flashdata('message', lang('admin verify del_success'));
        redirect(site_url("admin/verification"));
    }
}