Вход Регистрация
Файл: Just Wallet 2.0.4/application/controllers/account/Vouchers.php
Строк: 298
<?php defined('BASEPATH') OR exit('No direct script access allowed');

/**
 * Just Wallet
 * Copyright (c), Just Didigital Tech
 * Author code Anna Kantemirova and Sergey Plaxin
 * Site developer http://justigniter.io/
 * License https://codecanyon.net/licenses/terms/regular
**/

class Vouchers 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('vouchers_model');
      
        
// set constants
        
define('REFERRER'"referrer");
        
define('THIS_URL'base_url('account/vouchers'));
        
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;
        }
    }
  
    
/**
    * Vouchers
    */
    
function index()
    {

        
$user $this->users_model->get_user($this->user['id']);
        
$username $user['username'];
        
        
// 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'))
        {
            
$id_xss $this->security->xss_clean($this->input->get('id'));
            
$id_string str_replace(' ''-'$id_xss);
            
$id_replace preg_replace('/[^A-Za-z0-9-]/'''$id_string);
            
$filters['id'] = $id_replace;
        }
        
        
// 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);
                }

                
// redirect using new filter(s)
                
redirect(THIS_URL "?sort={$sort}&dir={$dir}&limit={$limit}&offset={$offset}{$filter}");
            }

            
$vouchers $this->vouchers_model->get_user_vouchers($limit$offset$filters$sort$dir$username);    
        }
        
        
// setup page header data
        
$this->set_title(sprintf(lang('users vouchers menu'), $this->settings->site_name));
        
// reload the new user data and store in session

        
$data $this->includes;
                    
        
$vouchers $this->vouchers_model->get_user_vouchers($limit$offset$filters$sort$dir$username);
        
        
$user $this->users_model->get_user($this->user['id']);
                    
        
// build pagination
        
$this->pagination->initialize(array(
            
'base_url'   => THIS_URL "?sort={$sort}&dir={$dir}&limit={$limit}{$filter}",
            
'total_rows' => $vouchers['total'],
            
'per_page'   => $limit
        
));
            
        
// set content data
        
$content_data = array(
            
'user'       => $user,
            
'username'   => $username,
            
'this_url'   => THIS_URL,
            
'vouchers'   => $vouchers['results'],
            
'total'      => $vouchers['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/vouchers/index'$content_dataTRUE);
        
$this->load->view($this->template$data);

    }
    
    
/**
    *  New voucher page
    */
    
function new_voucher()
    {

        
// setup page header data
        
$this->set_title(sprintf(lang('users vouchers menu'), $this->settings->site_name));
            
// reload the new user data and store in session
        
$user $this->users_model->get_user($this->user['id']);
                    
        
$data $this->includes;

        
// set content data
        
$content_data = array(
            
'user'    => $user,
        );

        
// load views
        
$data['content'] = $this->load->view('account/vouchers/new_voucher'$content_dataTRUE);
        
$this->load->view($this->template$data);

    }
    
    
/**
    *  Activate page
    */
    
function activate_code()
    {

        
// setup page header data
        
$this->set_title(sprintf(lang('users vouchers menu'), $this->settings->site_name));
            
// reload the new user data and store in session
        
$user $this->users_model->get_user($this->user['id']);
                    
        
$data $this->includes;

        
// set content data
        
$content_data = array(
                
'user'    => $user,
        );

        
// load views
        
$data['content'] = $this->load->view('account/vouchers/activate_code'$content_dataTRUE);
        
$this->load->view($this->template$data);

    }
  
    
/**
    * Start new voucher
    */
    
function start_new_voucher()
    {
        
        
$user $this->users_model->get_user($this->user['id']);
        
        
$this->form_validation->set_rules('amount'lang('users transfer amount'), 'required|trim|numeric|greater_than[0]');
        
$this->form_validation->set_rules('currency'lang('users trans cyr'), 'required|trim|in_list[debit_base,debit_extra1,debit_extra2,debit_extra3,debit_extra4,debit_extra5]');
            
        if (
$this->form_validation->run() == FALSE)
        {
            
$this->session->set_flashdata('error'lang('users vouchers error_new'));
            
redirect(site_url("account/vouchers/new_voucher"));

        } else {

            if (
$user['fraud'] == 0) {

                if (
$user['login_status'] == 2) {

                    
$amount $this->input->post("amount"TRUE);
                    
$currency $this->input->post("currency"TRUE);
                        
                    
$percent $this->settings->com_transfer/"100";
                    
$fee $amount*$percent;
                    
$sum $fee+$amount;
                    
$total $user[$currency] - $sum;
                    
$hold_balance $this->transactions_model->hold_balance($user['username'], $currency);
                    
                    
// check user hold balance
                    
if ($total $hold_balance) {
                                
                        
$this->session->set_flashdata('error'lang('users error wallet'));
                        
redirect(site_url("account/vouchers/new_voucher"));
                                
                    } else {
                        
                        
// Check wallet
                        
if ($user[$currency] < $sum) {

                            
$this->session->set_flashdata('error'lang('users error wallet'));
                            
redirect(site_url("account/vouchers/new_voucher"));

                        } else {

                            
$hash_string =
                                
$user['username'].':'.$user['salt'].':'.
                                
$sum.':'.
                                
date('Y-m-d H:i:s');

                            
$code strtoupper(md5($hash_string));


                            
// update sender wallet
                            
$this->users_model->update_wallet_transfer($user['username'],
                                array(
                                    
$currency => $total,
                                )
                            );

                            
$label uniqid("cvc_");

                            
// add transaction for sender
                            
$transactions $this->transactions_model->add_transaction(array(
                                
"type"                 => "2",
                                
"sum"                  => $sum,
                                
"fee"                => $fee,
                                
"amount"             => $amount,
                                
"currency"            => $currency,
                                
"status"             => "2",
                                
"sender"             => $user['username'],
                                
"receiver"             => "system",
                                
"time"              => date('Y-m-d H:i:s'),
                                
"user_comment"      => 'Create voucher '.$code.'',
                                
"label"             => $label,
                                
"ip_address"         => $_SERVER["REMOTE_ADDR"],
                                
"protect"             => "none",
                                )
                            );

                            
// add voucher in base
                            
$voucher $this->vouchers_model->add_voucher(array(
                                
"code"                     => $code,
                                
"date_creature"         => date('Y-m-d H:i:s'),
                                
"creator"                => $user['username'],
                                
"amount"                 => $amount,
                                
"currency"                => $currency,
                                
"date_activation"         => "0000-00-00 00:00:00",
                                
"activator"             => "none",
                                
"status"                 => "1"
                                
)
                            );

                            
$this->session->set_flashdata('message'lang('users vouchers success_new'));
                            
redirect(site_url('account/vouchers'));

                        }
                        
                    }

                } else {

                    
$this->session->set_flashdata('error'lang('users error fraud'));
                    
redirect(site_url("account/cart"));

                } 
                
            } else {

                
$this->session->set_flashdata('error'lang('users error fraud'));
                
redirect(site_url("account/cart"));
                
            }
            
        }
        
    }
    
    
/**
    * Start activate code 
    */
    
function start_activate_code()
    {
        
        
$user $this->users_model->get_user($this->user['id']);
        
        
$this->form_validation->set_rules('code'lang('users vouchers code'), 'required|trim|max_length[50]|min_length[10]');
        
        if (
$this->form_validation->run() == FALSE)
        {

            
$this->session->set_flashdata('error'lang('users vouchers error'));
            
redirect(site_url("account/vouchers/activate_code"));

        } else {
            
            
$code $this->input->post("code"TRUE);
                
            
$check_code $this->vouchers_model->validate_code($code);
            
            
// if empty results, return to list
            
if ( ! $check_code or $check_code['status'] == 3)
            {
                    
                
$this->session->set_flashdata('error'lang('users vouchers error'));
                
redirect(site_url("account/vouchers/activate_code"));
                    
            } else {
                
                
$currency_code $check_code['currency'];
                
                
$label uniqid("anv_");
                
                
$transactions $this->transactions_model->add_transaction(array(
                    
"type"                     => "1",
                    
"sum"                      => $check_code['amount'],
                    
"fee"                    => "0.00",
                    
"amount"                 => $check_code['amount'],
                    
"currency"                => $currency_code,
                    
"status"                 => "2",
                    
"sender"                 => "system",
                    
"receiver"                 => $user['username'],
                    
"time"                  => date('Y-m-d H:i:s'),
                    
"user_comment"          => 'Activate voucher '.$check_code['code'].'',
                    
"admin_comment"         => "none",
                    
"label"                 => $label,
                    
"ip_address"             => $_SERVER["REMOTE_ADDR"],
                    
"protect"                 => "none",
                    )
                );
                
                
$total $user[$currency_code]+$check_code['amount'];
            
                
// update wallet
                
$this->users_model->update_wallet_transfer($user['username'],
                    array(
                        
$currency_code => $total,
                    )
                );
                    
                
// update status voucher
                
$this->vouchers_model->update_voucher($code,
                    array(
                        
"status"             => "2",
                        
"date_activation"     => date('Y-m-d H:i:s'),
                        
"activator"         => $user['username'],
                    )
                );
                    
                
$this->session->set_flashdata('message'lang('users vouchers success'));
                
redirect(site_url('account/transactions'));
                
            }
            
        }
        
    }
    
    
}
Онлайн: 0
Реклама