Файл: Just Wallet 2.0.4/application/controllers/account/Transactions.php
Строк: 441
<?php defined('BASEPATH') OR exit('No direct script access allowed');
class Transactions extends Private_Controller {
    /**
     * Constructor
     */
    function __construct()
    {
        parent::__construct();
        // load the language file
        $this->lang->load('users');
        // load the users model
        $this->load->model('users_model');
                $this->load->model('transactions_model');
                $this->load->model('disputes_model');
                $this->load->library('fixer');
            
                // set constants
        define('REFERRER', "referrer");
        define('THIS_URL', base_url('account/transactions'));
        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;
        }
    }
  
     /**
     * Default
     */
    function index()
    {
        $user = $this->users_model->get_user($this->user['id']);
        
        // 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_string = htmlentities($id_xss, ENT_QUOTES, "UTF-8");
            $filters['id'] = $id_string;
    }
        
        if ($this->input->get('time'))
    {
      $time_xss = $this->security->xss_clean($this->input->get('time'));
            $time_string = htmlentities($time_xss, ENT_QUOTES, "UTF-8");
            $filters['time'] = $time_string;
    }
        
        if ($this->input->get('sender'))
    {
      $sender_xss = $this->security->xss_clean($this->input->get('sender'));
            $sender_string = htmlentities($sender_xss, ENT_QUOTES, "UTF-8");
            $filters['sender'] = $sender_string;
    }
        
        if ($this->input->get('receiver'))
    {
      $receiver_xss = $this->security->xss_clean($this->input->get('receiver'));
            $receiver_string = htmlentities($receiver_xss, ENT_QUOTES, "UTF-8");
            $filters['receiver'] = $receiver_string;
    }
        
        if ($this->input->get('sum'))
    {
      $sum_xss = $this->security->xss_clean($this->input->get('sum'));
            $sum_string = htmlentities($sum_xss, ENT_QUOTES, "UTF-8");
            $filters['sum'] = $sum_string;
    }
        
        if ($this->input->get('user_comment'))
    {
      $user_comment_xss = $this->security->xss_clean($this->input->get('user_comment'));
            $user_comment_string = htmlentities($user_comment_xss, ENT_QUOTES, "UTF-8");
            $filters['user_comment'] = $user_comment_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('time'))
                {
                    $filter .= "&time=" . $this->input->post('time', TRUE);
                }
                            
                                if ($this->input->post('sender'))
                {
                    $filter .= "&sender=" . $this->input->post('sender', TRUE);
                }
                            
                                if ($this->input->post('receiver'))
                {
                    $filter .= "&receiver=" . $this->input->post('receiver', TRUE);
                }
                            
                                if ($this->input->post('sum'))
                {
                    $filter .= "&sum=" . $this->input->post('sum', TRUE);
                }
                            
                                if ($this->input->post('user_comment'))
                {
                    $filter .= "&user_comment=" . $this->input->post('user_comment', TRUE);
                }
                // redirect using new filter(s)
                redirect(THIS_URL . "?sort={$sort}&dir={$dir}&limit={$limit}&offset={$offset}{$filter}");
            }
                    
            $history = $this->transactions_model->get_user_transactions($limit, $offset, $filters, $sort, $dir, $user['username']);
                
        }
        
     // setup page header data
     $this->set_title(sprintf(lang('users title history'), $this->settings->site_name));
        // reload the new user data and store in session
    $data = $this->includes;
                    
        $history = $this->transactions_model->get_user_transactions($limit, $offset, $filters, $sort, $dir, $user['username']);
                    
        // build pagination
        $this->pagination->initialize(array(
            'base_url'   => THIS_URL . "?sort={$sort}&dir={$dir}&limit={$limit}{$filter}",
            'total_rows' => $history['total'],
            'per_page'   => $limit
        ));
            
        // set content data
        $content_data = array(
            'user'       => $user,
            'username'   => $username,
            'this_url'   => THIS_URL,
            'history'    => $history['results'],
            'total'      => $history['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('account/transactions/index', $content_data, TRUE);
        $this->load->view($this->template, $data);
    }
    
    
    /**
    * Detail transaction
    */
    function detail($id = NULL)
    {
        $user = $this->users_model->get_user($this->user['id']);
            
        // make sure we have a numeric id
        if (is_null($id) OR ! is_numeric($id))
        {
            redirect($this->_redirect_url);
        }
        // get the data
        $transactions = $this->transactions_model->get_detail_transactions($id, $user['username']);
        // if empty results, return to list
        if ( ! $transactions)
        {
            redirect($this->_redirect_url);
        }
            
            //Check dispute history
            $dispute_history = $this->disputes_model->get_history_dispute($id);
            if ( $dispute_history)
            {
                $dispute_mode = "0"; // no start dispute
            } else {
                $dispute_mode = "1"; // yes start dispute
            }
            
        // setup page header data
        $this->set_title( lang('users title history') );
        $data = $this->includes;
        // set content data
        $content_data = array(
            'this_url'           => THIS_URL,
            'user'              => $user,
            'dispute_mode'      => $dispute_mode,
            'cancel_url'        => $this->_redirect_url,
            'transactions'      => $transactions,
            'transactions_id'   => $id
        );
        // load views
        $data['content'] = $this->load->view('account/transactions/detail', $content_data, TRUE);
        $this->load->view($this->template, $data);
    }
    
    /**
     * Start confirm protect transaction
   */
    
    function protect_confirm()
    {
        
        $user = $this->users_model->get_user($this->user['id']);
        
        $this->form_validation->set_rules('code_protect', lang('users transfer code_protect'), 'required|trim|numeric|max_length[4]|min_length[4]');
        $this->form_validation->set_rules('id', lang('users col user_id'), 'required|trim|numeric|min_length[1]');
        
        if ($this->form_validation->run() == TRUE) {
            
            $id = $this->input->post("id", TRUE);
            
            $transactions = $this->transactions_model->get_transactions($id);
            
            $check_start_user = $this->users_model->get_username($transactions['receiver']);
        
            $sender_transfer = $this->users_model->get_username($transactions['sender']);
            $wallet = $transactions['currency'];
            
            $code_protect = $this->input->post("code_protect", TRUE);
            
            if ($user['username'] == $check_start_user['username']) {
                
                // check protect
                if ($transactions['protect'] != "none") {
            
                    // check status
                    if ($transactions['status'] == 1) {
                        if ($code_protect == $transactions['protect']) {
                            // Calculation of the amount to be credited to receiver
                            $transfer = $user[$wallet]+$transactions['amount'];
                            // update transaction history
                            $this->transactions_model->update_dispute_transactions($transactions['id'],
                                array(
                                    "status"        => "2",
                                )
                            );
                            // update wallet sender
                            $this->users_model->update_user($transactions['receiver'],
                                array(
                                    $transactions['currency']  => $transfer,
                                    )
                            );
                            $this->session->set_flashdata('message', lang('users transfer success'));
                            redirect(site_url("account/transactions"));
                        } else {
                            
                            // add attempt
                            $attempt = $transactions['protect_attempts'] + "1";
                            
                            // update transaction history
                            $this->transactions_model->update_dispute_transactions($transactions['id'],
                                array(
                                    "protect_attempts"   => $attempt,
                                )
                            );
                            
                            $transactions = $this->transactions_model->get_transactions($id);
                            
                            if($transactions['protect_attempts'] >= 3) {
                                
                                // update wallet sender
                                $this->users_model->update_user($transactions['receiver'],
                                    array(
                                        "fraud"  => "1",
                                    )
                                );
                                
                                // update transaction history
                                $this->transactions_model->update_dispute_transactions($transactions['id'],
                                    array(
                                        "status"        => "3",
                                    )
                                );
                                
                                // Calculation of the amount to be credited to sender
                                $return = $sender_transfer[$wallet]+$transactions['amount'];
                                
                                // update wallet sender
                                $this->users_model->update_user($transactions['sender'],
                                    array(
                                        $transactions['currency']  => $return,
                                    )
                                );
                                
                            }
                            $this->session->set_flashdata('error', lang('users error invalid_form'));
                            redirect(site_url("account/transactions"));
                        }
                    } else {
                        $this->session->set_flashdata('error', lang('users error invalid_form'));
                        redirect(site_url("account/transactions"));
                    }
                } else {
                    $this->session->set_flashdata('error', lang('users error invalid_form'));
                    redirect(site_url("account/transactions"));
                }
                
            } else {
                
                $this->session->set_flashdata('error', lang('users error invalid_form'));
                redirect(site_url("account/transactions"));
                
            }
            
        } else {
            
            $this->session->set_flashdata('error', lang('users error invalid_form'));
            redirect(site_url("account/transactions"));
            
        }
        
    }
    
    
    /**
     * Start refund protect transaction
   */
    function protect_refund($id)
    {
        // make sure we have a numeric id
    if (is_null($id) OR ! is_numeric($id))
    {
        redirect(site_url("account/transactions"));
    }
        
        // get the data
    $transactions = $this->transactions_model->get_transactions($id);
        
        $user = $this->users_model->get_user($this->user['id']);
        
        $check_start_user = $this->users_model->get_username($transactions['receiver']);
        
        $sender_transfer = $this->users_model->get_username($transactions['sender']);
        
        $wallet = $transactions['currency'];
        
        // check status
        if ($transactions['status'] == 1) {
        
            // check protect
            if ($transactions['protect'] != "none") {
                // Calculation of the amount to be credited to sender
                $return = $sender_transfer[$wallet]+$transactions['amount'];
                if ($user['username'] == $check_start_user['username']) {
                    // update transaction history
                    $this->transactions_model->update_dispute_transactions($transactions['id'],
                        array(
                            "status"        => "3",
                        )
                    );
                    // update wallet sender
                    $this->users_model->update_user($transactions['sender'],
                        array(
                            $transactions['currency']  => $return,
                            )
                        );
                    $this->session->set_flashdata('message', lang('users refund success'));
                    redirect(site_url("account/transactions"));
                } else {
                    $this->session->set_flashdata('error', lang('users error invalid_form'));
                    redirect(site_url("account/transactions"));
                }
            } else {
                $this->session->set_flashdata('error', lang('users error invalid_form'));
                redirect(site_url("account/transactions"));
            }
            
        } else {
            
            $this->session->set_flashdata('error', lang('users error invalid_form'));
            redirect(site_url("account/transactions"));
            
        }
        
    }
  
}