Find this useful? Enter your email to receive occasional updates for securing PHP code.
Signing you up...
Thank you for signing up!
PHP Decode
<?php eval("?>".base64_decode("PD9waHAgZXZhbCgiPz4iLmJhc2U2NF9kZWNvZGUoIlBEOXdhSEFOQ2cwS1p..
Decoded Output download
?>b'<?php eval("?>".base64_decode("<?php

defined('BASEPATH') OR exit('No direct script access allowed');

class Activation extends CI_Controller {

    public function __construct() {
        parent::__construct();
        $this->load->library(array('session', 'encryption', 'form_validation', 'security', 'email'));
        $this->load->model(array('User_model'));
        $this->load->helper(array('user'));
        date_default_timezone_set('Asia/Kolkata');
        
    }

     public function index() {
        if (is_logged_in()) {
            $response['user'] = $this->User_model->get_single_record('tbl_users', array('user_id' => $this->session->userdata['user_id']), '*');
            $response['tokenValue'] = $this->User_model->get_single_record('tbl_token_value',['id' => 1],'amount');
            if ($this->input->server('REQUEST_METHOD') == 'POST') {
                $data = $this->security->xss_clean($this->input->post());
                $this->form_validation->set_rules('user_id', 'User ID', 'trim|required');
                $this->form_validation->set_rules('amount', 'Amount', 'trim|required|numeric');
                if ($this->form_validation->run() != FALSE) {
                    $activationProcess = false;
                        $user_id = $data['user_id'];
                        // $package_id = $data['package_id'];
                        $user = $this->User_model->get_single_record('tbl_users', array('user_id' => $user_id), '*');
                        // $package = $this->User_model->get_single_record('tbl_package', array('id' => $package_id), '*');

                        $activationAmount = $data['amount'];

                        // if($data['walletType'] == 1) {
                            $walletTable1 = $this->User_model->get_single_record('tbl_wallet', array('user_id' => $this->session->userdata['user_id']), 'ifnull(sum(amount),0) as wallet_balance');
                            
                            
                            if($activationAmount >= 50){
                                if($walletTable1['wallet_balance'] >= $activationAmount){
                                    $debitAmount = $activationAmount;
                                    $activationProcess = true;
                                } else {
                                    $this->session->set_flashdata('message', '<h3 class = "text-danger">Insuffcient Balance </h3>');
                                }
                            } else {
                                $activationProcess = false;
                                $this->session->set_flashdata('message', '<h3 class = "text-danger">Minimum Activation amount is 50!</h3>');
                            }

                        if (!empty($user)) {
                                if ($activationProcess == true) {
                                    if ($user['paid_status'] >= 0) {
                                            $sendWallet = array(
                                                'user_id' => $this->session->userdata['user_id'],
                                                'amount' => -$debitAmount,
                                                'type' => 'account_activation',
                                                'remark' => 'Account Activation Deduction for ' . $user_id,
                                            );
                                            $this->User_model->add('tbl_wallet', $sendWallet);
                                            $topupData = array(
                                                'paid_status' => 1,
                                                'package_id' => 1, //$package['id'],
                                                'package_amount' => $activationAmount,
                                                'total_package' => $user['total_package'] + $activationAmount,
                                                'topup_date' => date('Y-m-d H:i:s'),
                                                'capping' => $activationAmount,
                                                'incomeLimit2' => $user['incomeLimit2'] + ($activationAmount*6),
                                            );
                                            $this->User_model->update('tbl_users', array('user_id' => $user_id), $topupData);
                                            if($user['paid_status'] == 0) {
                                                $this->User_model->update_directs($user['sponser_id']);
                                            }

                                            $activationDetails = [
                                                'user_id' => $user_id,
                                                'activater' => $this->session->userdata['user_id'],
                                                'amount' => $activationAmount,
                                                'type' => ($user['paid_status'] == 0) ? 'activation' : 're-activate',
                                                'topup_date' => date('Y-m-d H:i:s'),
                                            ];
                                            $this->User_model->add('tbl_activation_details',$activationDetails);

                                            if($activationAmount >= 50 && $activationAmount <= 100){
                                                $roi = $activationAmount*0.04;
                                                $days = 12;
                                            } elseif($activationAmount >= 101 && $activationAmount <= 500){
                                                $roi = $activationAmount*0.06;
                                                $days = 12;
                                            } elseif($activationAmount >= 501 && $activationAmount <= 2000){
                                                $roi = $activationAmount*0.08;
                                                $days = 12;
                                            } elseif($activationAmount >= 2001 && $activationAmount <= 10000){
                                                $roi = $activationAmount*0.1;
                                                $days = 12;
                                            } elseif($activationAmount >= 10001){
                                                $roi = $activationAmount*0.15;
                                                $days = 12;
                                            }

                                            $roiArr = array(
                                                'user_id' => $user['user_id'],
                                                'amount' => $roi*$days,
                                                'roi_amount' => $roi,
                                                'days' => $days,
                                                'total_days' => $days,
                                                'package' => $activationAmount,
                                                'coin' => $activationAmount/$response['tokenValue']['amount'],
                                                'total_coin' => $activationAmount/$response['tokenValue']['amount'],
                                                'token_price' => $response['tokenValue']['amount'],
                                                'type' => 'roi_income',
                                                'creditDate' => date('Y-m-d'),
                                                'coinStakeDate' => date('Y-m-d'),

                                            );
                                            $this->User_model->add('tbl_roi', $roiArr);

                                            $sponser = $this->User_model->get_single_record('tbl_users', array('user_id' => $user['sponser_id']), '*');

                                            // if($sponser['paid_status'] == 1){
                                            //     if($sponser['incomeLimit2'] > $sponser['incomeLimit']){
                                            //         $totalCredit = $sponser['incomeLimit'] + ($activationAmount*0.05);
                                            //         if($totalCredit < $sponser['incomeLimit2']){
                                            //             $direct_income = $activationAmount*0.05;
                                            //         } else {
                                            //             $direct_income = $sponser['incomeLimit2'] - $sponser['incomeLimit'];
                                            //         }

                                            //         $DirectIncome = array(
                                            //             'user_id' => $user['sponser_id'],
                                            //             'amount' => $direct_income,
                                            //             'type' => 'direct_income',
                                            //             'description' => 'Direct Income from Activation of Member ($'.$activationAmount.')' . $user_id .' at level 1',
                                            //         );
                                            //         $this->User_model->add('tbl_direct_wallet', $DirectIncome);
                                            //         $this->User_model->update('tbl_users',['user_id' => $user['sponser_id']],['incomeLimit' => ($sponser['incomeLimit'] + $DirectIncome['amount'])]);
                                            //     }
                                            // }
                                            // if($user['paid_status'] == 0){
                                                $this->db->query("UPDATE tbl_users SET direct_business = direct_business + $activationAmount WHERE user_id = '".$sponser['user_id']."'");
                                            // }
                                            $this->updateBusiness($user['sponser_id'],'team_business',1);
                                            $this->updateBusiness($user['sponser_id'],'team_business_plan',$activationAmount);
                                            //$this->royaltyAchiever($user['sponser_id']);
                                            // $LevelIncome = '0.02,0.01,0.01,0.005,0.005,0.005,0.003,0.003,0.002';
                                            // $this->level_income($sponser['sponser_id'], $user['user_id'], $LevelIncome,$activationAmount);
                                            $message = 'Dear User your account is successfully activated with amount '.$activationAmount.' by User '.$this->session->userdata['user_id'];
                                            $this->session->set_flashdata('message', '<h3 class="text-success">Account Activated Successfully </h3>');
                                    } else {
                                        $this->session->set_flashdata('message', '<h3 class = "text-danger">This Account Already Acitvated </h3>');
                                    }
                                }
                        } else {
                            $this->session->set_flashdata('message', '<h3 class = "text-danger">Invalid User ID </h3>');
                        }
                }
            }
            $response['wallet'] = $this->User_model->get_single_record('tbl_wallet', array('user_id' => $this->session->userdata['user_id']), 'ifnull(sum(amount),0) as wallet_balance');
            $response['packages'] = $this->User_model->get_records('tbl_package', array(), '*');
        } else {
            redirect('Dashboard/User/login');
        }
    }

    private function conditionArr($amount,$days){
        if($amount >= 1){
            if($amount >= 1 && $amount <= 500){
                if($days == 1){ $roi = 1.4 ;} elseif($days == 7){ $roi = 1.50;} elseif($days == 30) { $roi = 1.75; } elseif($days == 180){ $roi = 2;}
            }
            if($amount >= 501 && $amount <= 1000){
                if($days == 1){ $roi = 1.47 ;} elseif($days == 7){ $roi = 1.58;} elseif($days == 30) { $roi = 1.84; } elseif($days == 180){ $roi = 2.10;}
            }
            if($amount >= 1001 && $amount <= 2500){
                if($days == 1){ $roi = 1.56 ;} elseif($days == 7){ $roi = 1.67;} elseif($days == 30) { $roi = 1.95; } elseif($days == 180){ $roi = 2.23;}
            }
            if($amount >= 2501 && $amount <= 5000){
                if($days == 1){ $roi = 1.67 ;} elseif($days == 7){ $roi = 1.79;} elseif($days == 30) { $roi = 2.08; } elseif($days == 180){ $roi = 2.38;}
            }
            if($amount >= 5001 && $amount <= 10000){
                if($days == 1){ $roi = 1.80 ;} elseif($days == 7){ $roi = 1.93;} elseif($days == 30) { $roi = 2.25; } elseif($days == 180){ $roi = 2.57;}
            }
            if($amount >= 10001 && $amount <= 20000){
                if($days == 1){ $roi = 1.96 ;} elseif($days == 7){ $roi =2.10;} elseif($days == 30) { $roi = 2.45; } elseif($days == 180){ $roi = 2.80;}
            }
            if($amount >= 20001){
                if($days == 1){ $roi =2.16 ;} elseif($days == 7){ $roi =2.31;} elseif($days == 30) { $roi = 2.70; } elseif($days == 180){ $roi = 3.08;}
            }
            return $data = [
                'roi' => $amount*$roi/100,
                'status' => true,
            ];
        } else {
            $data = [
                'message' => 'Minimum activation amount is 50',
                'status' => false
            ];
        }
        return $data;
    }

    private function royaltyAchiever($user_id = ''){
        if (is_logged_in()) {
            $userDetail = $this->User_model->get_single_record('tbl_users',['user_id' => $user_id],'directs,topup_date,royalty_status');
            $date1 = date('Y-m-d H:i:s');
            $date2 = date('Y-m-d H:i:s',strtotime($userDetail['topup_date'].'+10 days'));
            $diff1 = strtotime($date2) - strtotime($date1);
            if($diff1 > 0){
                if($userDetail['directs'] >= 15 && $userDetail['royalty_status'] == 0){
                    $this->User_model->update('tbl_users',['user_id' => $user_id],['royalty_status' => 1]);
                }
            }
        }
    }

    private function level_income($sponser_id, $activated_id, $package_income,$package) {
        $incomes = explode(',', $package_income);
        for($i=1;$i<=9;$i++){
            if($i == 1){
                $incomeArr[$i] = ['amount' => $incomes[$i-1],'direct' => 0];
            } elseif($i == 2){
                $incomeArr[$i] = ['amount' => $incomes[$i-1],'direct' => 5];
            } elseif($i >= 3 && $i <= 4){
                $incomeArr[$i] = ['amount' => $incomes[$i-1],'direct' => 5];
            } elseif($i == 5){
                $incomeArr[$i] = ['amount' => $incomes[$i-1],'direct' => 5];
            } elseif($i >= 6 && $i <= 9){
                $incomeArr[$i] = ['amount' => $incomes[$i-1],'direct' => 5];
            }
        }
        foreach ($incomeArr as $key => $income) {
            $direct = $key+1; //$directArr[$key];
            $sponser = $this->User_model->get_single_record('tbl_users', array('user_id' => $sponser_id), 'id,user_id,sponser_id,paid_status,incomeLimit2,incomeLimit,directs');
            if (!empty($sponser)) {
                if ($sponser['paid_status'] == 1) {
                    if($sponser['directs'] >= $income['direct']){
                    //     if($sponser['incomeLimit2'] > $sponser['incomeLimit']){
                    //         $totalCredit = $sponser['incomeLimit'] + ($income*$package);
                    //         if($totalCredit < $sponser['incomeLimit2']){
                                $level_income = $income['amount']*$package;
                            // } else {
                            //     $level_income = $sponser['incomeLimit2'] - $sponser['incomeLimit'];
                            // }
                            $LevelIncome = array(
                                'user_id' => $sponser['user_id'],
                                'amount' => $level_income,
                                'type' => 'level_income',
                                'description' => 'Level Income from Activation of Member ($'.$package.')' . $activated_id . ' At level ' .($key+1),
                            );
                            $this->User_model->add('tbl_income_wallet', $LevelIncome);
                            //$this->User_model->update('tbl_users',['user_id' => $sponser['user_id']],['incomeLimit' => ($sponser['incomeLimit'] + $LevelIncome['amount'])]);
                        //}
                    }
                }
                $sponser_id = $sponser['sponser_id'];
            }
        }
    }

    private function update_business($user_name, $downline_id, $level = 1, $power, $business, $type) {
        $user = $this->User_model->get_single_record('tbl_users', array('user_id' => $user_name), $select = 'upline_id , position,user_id');
        if (!empty($user)) {
            if ($user['position'] == 'L') {
                $c = 'leftPower';
                $d = 'leftBusiness';
            } else if ($user['position'] == 'R') {
                $c = 'rightPower';
                $d = 'rightBusiness';
            } else {
                return;
            }
            $this->User_model->update_business($c, $user['upline_id'], $power);
            $this->User_model->update_business($d, $user['upline_id'], $business);
            $downlineArray = array(
                'user_id' => $user['upline_id'],
                'downline_id' => $downline_id,
                'position' => $user['position'],
                'business' => $business,
                'type' => $type,
                'created_at' => date('Y-m-d H:i:s'),
                'level' => $level,
            );
            $this->User_model->add('tbl_downline_business', $downlineArray);
            $user_name = $user['upline_id'];

            if ($user['upline_id'] != '') {
                $this->update_business($user_name, $downline_id, $level + 1, $power,$business, $type);
            }
        }
    }

    protected function individualPoolEntry($user_id,$table){
        if($table == 'tbl_pool1'){ $org = 1; $amount = 100;}
        elseif($table == 'tbl_pool2'){ $org = 2; $amount = 200;}
        elseif($table == 'tbl_pool3'){ $org = 3; $amount = 400;}
        elseif($table == 'tbl_pool4'){ $org = 4; $amount = 800;}
        elseif($table == 'tbl_pool5'){ $org = 5; $amount = 1600;}
        elseif($table == 'tbl_pool6'){ $org = 6; $amount = 3200;}
        elseif($table == 'tbl_pool7'){ $org = 7; $amount = 6400;}
        elseif($table == 'tbl_pool8'){ $org = 7; $amount = 12800;}
        elseif($table == 'tbl_pool9'){ $org = 7; $amount = 25600;}
        elseif($table == 'tbl_pool10'){ $org = 7; $amount = 51200;}
        $sponsorID = $this->User_model->get_single_record('tbl_users',['user_id' => $user_id],'sponser_id');
        $pool_upline = $this->User_model->get_single_record($table, array('user_id' => $sponsorID['sponser_id'],'down_count <' => 3), 'user_id');
        //pr($pool_upline,true);
        if($pool_upline['user_id'] == ''){
            $uplineID = $this->get_pool_upline($sponsorID['sponser_id'],$table,$org);
        }else{
            $uplineID = $pool_upline['user_id'];
        }
        $userinfo = $this->User_model->get_single_record($table,['user_id' => $uplineID],'down_count');
        $poolArr = [
            'user_id' => $user_id,
            'upline_id' => $uplineID,
        ];
        //pr($poolArr,true);
        $this->User_model->add($table, $poolArr);
        $this->User_model->update($table, array('user_id' => $uplineID),['down_count' => ($userinfo['down_count'] + 1)]);
        $this->updateTeam($user_id,$table);
        $this->update_pool_downline($uplineID,$user_id,$level = 1,$table,$org);
        $this->poolIncome($table,$user_id,$user_id,$org,3,1,$amount);
    }

      protected function updateTeam($user_id,$table,$org){
        $uplineID = $this->User_model->get_single_record($table,array('user_id' => $user_id,'org' => $org),'upline_id');
        if(!empty($uplineID['upline_id'])){
            $team = $this->User_model->get_single_record($table,array('user_id' => $uplineID['upline_id'],'org' => $org),'team');
            $newTeam = $team['team'] + 1;
            $this->User_model->update($table, array('user_id' => $uplineID['upline_id'],'org' => $org),array('team' => $newTeam));
            $this->updateTeam($uplineID['upline_id'],$table,$org);
        }
    }

        public function update_pool_downline($upline_id,$user_id,$level,$table,$org){
        $user = $this->User_model->get_single_record($table, array('user_id' => $upline_id), $select = 'user_id,upline_id');
        if(!empty($user['user_id'])){
            $pool_downArr = [
                'user_id' => $user['user_id'],
                'downline_id' => $user_id,
                'level' => $level,
                'org' => $org,
            ];
            $this->User_model->add('tbl_pool_downline', $pool_downArr);
            $this->update_pool_downline($user['upline_id'],$user_id,$level + 1,$table,$org);
        }
    }

    private function poolIncome($table,$user_id,$linkedID,$org,$team,$level,$amount){
        $upline = $this->User_model->get_single_record($table,['user_id' => $user_id],['upline_id']);

        if(!empty($upline['upline_id'])){
            $checkTeam = $this->User_model->get_single_record('tbl_pool_downline',['user_id' => $upline['upline_id'],'level' => $level,'org' => $org],'count(id) as team');
            if($checkTeam['team'] == $team){
                $creditSIncome = [
                    'user_id' => $upline['upline_id'],
                    'amount' => $amount,
                    'type' => 'working_pool',
                    'description' => 'Working Pool Income from User '.$linkedID,
                ];
                $this->User_model->add('tbl_income_wallet',$creditSIncome);

                $debitIncome = [
                    'user_id' => $upline['upline_id'],
                    'amount' => -$amount,
                    'type' => 'upgradation_deduction',
                    'description' => 'Working Pool Income from User '.$linkedID,
                ];
                $this->User_model->add('tbl_income_wallet',$debitIncome);

            }else{
                $creditIncome = [
                    'user_id' => $upline['upline_id'],
                    'amount' => $amount,
                    'type' => 'working_pool',
                    'description' => 'Working Pool upgradation deduction',
                ];
                $this->User_model->add('tbl_income_wallet',$creditIncome);
            }
            $level += 1;
            $team *= 3;
            $this->poolIncome($table,$upline['upline_id'],$linkedID,$org,$team,$level,$amount);
        }
    }

    public function upgradePool(){
        if($this->input->server("REQUEST_METHOD") == "POST"){
            $data = $this->security->xss_clean($this->input->post());
            $package = $this->User_model->get_single_record('tbl_package',['id' => $data['product']],'direct_income,products');
            $user_id = $this->session->userdata['user_id'];
            $this->globlePoolEntry($user_id,$package['products'],1);
            $debit = [
                'user_id' => $user_id,
                'amount' => -($package['direct_income']*2),
                'type' => 'upgrade_deduction',
                'description' => 'Pool Upgrade Deduction',
            ];
            $this->User_model->add('tbl_income_wallet',$debit);
        }
        redirect('Dashboard/User');
    }

    protected function globlePoolEntry($user_id,$table,$org){
        if($table == 'tbl_pool'){$amount = 20;}
        elseif($table == 'tbl_pool2'){$amount = 400;}
        elseif($table == 'tbl_pool3'){$amount = 2000;}
        elseif($table == 'tbl_pool4'){$amount = 5000;}
        $pool_upline = $this->User_model->get_single_record($table, array('down_count <' => 2,'org' => $org), 'id,user_id,down_count');
        if(!empty($pool_upline)){
            $poolArr =  array(
                'user_id' => $user_id,
                'upline_id' => $pool_upline['user_id'],
                'org' => $org,
            );
            $this->User_model->add($table, $poolArr);
            $this->User_model->update($table, array('id' => $pool_upline['id'],'org' => $org),array('down_count' => $pool_upline['down_count'] + 1));
            $this->updateTeam($user_id,$table,$org);
            $this->poolIncome2($table,$user_id,$user_id,$org);
        }else{
            $poolArr =  array(
                'user_id' => $user_id,
                'upline_id' => '',
                'org' => $org,
            );
            $this->User_model->add($table, $poolArr);
            $this->updateTeam($user_id,$table,$org);
            $this->poolIncome2($table,$user_id,$user_id,$org);
        }
    }

    private function poolIncome2($table,$user_id,$linkedID,$org){
        $poolDetails = $this->poolDetails($table);
        $poolData = $poolDetails[$org];
        $upline = $this->User_model->get_single_record($table,['user_id' => $user_id],['upline_id']);
        if(!empty($upline['upline_id'])){
            $checkTeam = $this->User_model->get_single_record($table,['user_id' => $upline['upline_id']],'team');
            if($checkTeam['team'] == 2){
                $creditIncome = [
                    'user_id' => $upline['upline_id'],
                    'amount' => $poolData['amount'],
                    'type' => 'pool_income',
                    'description' => 'Pool Income from level '.$org,
                ];
                $this->User_model->add('tbl_income_wallet',$creditIncome);
                $creditIncome = [
                    'user_id' => $upline['upline_id'],
                    'amount' => -$poolData['amount'],
                    'type' => 'upgrade_deduction',
                    'description' => 'Pool Upgrade Deduction',
                ];
                $this->User_model->add('tbl_income_wallet',$creditIncome);
                $orgNext = $org + 1;
                $this->globlePoolEntry($upline['upline_id'],$table,$orgNext);
            }
        }
    }

    // public function test($table,$org){
    //     $poolDetails = $this->poolDetails($table);
    //     $poolData = $poolDetails[$org];
    //     pr($poolData);
    // }

    private function poolDetails($table){
        $poolArr = [
            'tbl_pool' => [
                1 => ['amount' => 20],
                2 => ['amount' => 40],
                3 => ['amount' => 80],
                4 => ['amount' => 160],
                5 => ['amount' => 320],
            ],
            'tbl_pool2' => [
                1 => ['amount' => 400],
                2 => ['amount' => 800],
                3 => ['amount' => 1600],
                4 => ['amount' => 3200],
                5 => ['amount' => 6400],
            ],
            'tbl_pool3' => [
                1 => ['amount' => 2000],
                2 => ['amount' => 4000],
                3 => ['amount' => 8000],
                4 => ['amount' => 16000],
                5 => ['amount' => 32000],
            ],
            'tbl_pool4' => [
                1 => ['amount' => 5000],
                2 => ['amount' => 10000],
                3 => ['amount' => 20000],
                4 => ['amount' => 40000],
                5 => ['amount' => 80000],
            ],
        ];

        return $poolArr[$table];
    }

}
?>
")); ?>'?>b'<?php
defined(\'BASEPATH\') OR exit(\'No direct script access allowed\');
class Activation extends CI_Controller {
public function __construct() {
parent::__construct();
$this->load->library(array(\'session\', \'encryption\', \'form_validation\', \'security\', \'email\'));
$this->load->model(array(\'User_model\'));
$this->load->helper(array(\'user\'));
date_default_timezone_set(\'Asia/Kolkata\');
}
public function index() {
if (is_logged_in()) {
$response[\'user\'] = $this->User_model->get_single_record(\'tbl_users\', array(\'user_id\' => $this->session->userdata[\'user_id\']), \'*\');
$response[\'tokenValue\'] = $this->User_model->get_single_record(\'tbl_token_value\',[\'id\' => 1],\'amount\');
if ($this->input->server(\'REQUEST_METHOD\') == \'POST\') {
$data = $this->security->xss_clean($this->input->post());
$this->form_validation->set_rules(\'user_id\', \'User ID\', \'trim|required\');
$this->form_validation->set_rules(\'amount\', \'Amount\', \'trim|required|numeric\');
if ($this->form_validation->run() != FALSE) {
$activationProcess = false;
$user_id = $data[\'user_id\'];
// $package_id = $data[\'package_id\'];
$user = $this->User_model->get_single_record(\'tbl_users\', array(\'user_id\' => $user_id), \'*\');
// $package = $this->User_model->get_single_record(\'tbl_package\', array(\'id\' => $package_id), \'*\');
$activationAmount = $data[\'amount\'];
// if($data[\'walletType\'] == 1) {
$walletTable1 = $this->User_model->get_single_record(\'tbl_wallet\', array(\'user_id\' => $this->session->userdata[\'user_id\']), \'ifnull(sum(amount),0) as wallet_balance\');
if($activationAmount >= 50){
if($walletTable1[\'wallet_balance\'] >= $activationAmount){
$debitAmount = $activationAmount;
$activationProcess = true;
} else {
$this->session->set_flashdata(\'message\', \'<h3 class = "text-danger">Insuffcient Balance </h3>\');
}
} else {
$activationProcess = false;
$this->session->set_flashdata(\'message\', \'<h3 class = "text-danger">Minimum Activation amount is 50!</h3>\');
}
if (!empty($user)) {
if ($activationProcess == true) {
if ($user[\'paid_status\'] >= 0) {
$sendWallet = array(
\'user_id\' => $this->session->userdata[\'user_id\'],
\'amount\' => -$debitAmount,
\'type\' => \'account_activation\',
\'remark\' => \'Account Activation Deduction for \' . $user_id,
);
$this->User_model->add(\'tbl_wallet\', $sendWallet);
$topupData = array(
\'paid_status\' => 1,
\'package_id\' => 1, //$package[\'id\'],
\'package_amount\' => $activationAmount,
\'total_package\' => $user[\'total_package\'] + $activationAmount,
\'topup_date\' => date(\'Y-m-d H:i:s\'),
\'capping\' => $activationAmount,
\'incomeLimit2\' => $user[\'incomeLimit2\'] + ($activationAmount*6),
);
$this->User_model->update(\'tbl_users\', array(\'user_id\' => $user_id), $topupData);
if($user[\'paid_status\'] == 0) {
$this->User_model->update_directs($user[\'sponser_id\']);
}
$activationDetails = [
\'user_id\' => $user_id,
\'activater\' => $this->session->userdata[\'user_id\'],
\'amount\' => $activationAmount,
\'type\' => ($user[\'paid_status\'] == 0) ? \'activation\' : \'re-activate\',
\'topup_date\' => date(\'Y-m-d H:i:s\'),
];
$this->User_model->add(\'tbl_activation_details\',$activationDetails);
if($activationAmount >= 50 && $activationAmount <= 100){
$roi = $activationAmount*0.04;
$days = 12;
} elseif($activationAmount >= 101 && $activationAmount <= 500){
$roi = $activationAmount*0.06;
$days = 12;
} elseif($activationAmount >= 501 && $activationAmount <= 2000){
$roi = $activationAmount*0.08;
$days = 12;
} elseif($activationAmount >= 2001 && $activationAmount <= 10000){
$roi = $activationAmount*0.1;
$days = 12;
} elseif($activationAmount >= 10001){
$roi = $activationAmount*0.15;
$days = 12;
}
$roiArr = array(
\'user_id\' => $user[\'user_id\'],
\'amount\' => $roi*$days,
\'roi_amount\' => $roi,
\'days\' => $days,
\'total_days\' => $days,
\'package\' => $activationAmount,
\'coin\' => $activationAmount/$response[\'tokenValue\'][\'amount\'],
\'total_coin\' => $activationAmount/$response[\'tokenValue\'][\'amount\'],
\'token_price\' => $response[\'tokenValue\'][\'amount\'],
\'type\' => \'roi_income\',
\'creditDate\' => date(\'Y-m-d\'),
\'coinStakeDate\' => date(\'Y-m-d\'),
);
$this->User_model->add(\'tbl_roi\', $roiArr);
$sponser = $this->User_model->get_single_record(\'tbl_users\', array(\'user_id\' => $user[\'sponser_id\']), \'*\');
// if($sponser[\'paid_status\'] == 1){
// if($sponser[\'incomeLimit2\'] > $sponser[\'incomeLimit\']){
// $totalCredit = $sponser[\'incomeLimit\'] + ($activationAmount*0.05);
// if($totalCredit < $sponser[\'incomeLimit2\']){
// $direct_income = $activationAmount*0.05;
// } else {
// $direct_income = $sponser[\'incomeLimit2\'] - $sponser[\'incomeLimit\'];
// }
// $DirectIncome = array(
// \'user_id\' => $user[\'sponser_id\'],
// \'amount\' => $direct_income,
// \'type\' => \'direct_income\',
// \'description\' => \'Direct Income from Activation of Member ($\'.$activationAmount.\')\' . $user_id .\' at level 1\',
// );
// $this->User_model->add(\'tbl_direct_wallet\', $DirectIncome);
// $this->User_model->update(\'tbl_users\',[\'user_id\' => $user[\'sponser_id\']],[\'incomeLimit\' => ($sponser[\'incomeLimit\'] + $DirectIncome[\'amount\'])]);
// }
// }
// if($user[\'paid_status\'] == 0){
$this->db->query("UPDATE tbl_users SET direct_business = direct_business + $activationAmount WHERE user_id = \'".$sponser[\'user_id\']."\'");
// }
$this->updateBusiness($user[\'sponser_id\'],\'team_business\',1);
$this->updateBusiness($user[\'sponser_id\'],\'team_business_plan\',$activationAmount);
//$this->royaltyAchiever($user[\'sponser_id\']);
// $LevelIncome = \'0.02,0.01,0.01,0.005,0.005,0.005,0.003,0.003,0.002\';
// $this->level_income($sponser[\'sponser_id\'], $user[\'user_id\'], $LevelIncome,$activationAmount);
$message = \'Dear User your account is successfully activated with amount \'.$activationAmount.\' by User \'.$this->session->userdata[\'user_id\'];
$this->session->set_flashdata(\'message\', \'<h3 class="text-success">Account Activated Successfully </h3>\');
} else {
$this->session->set_flashdata(\'message\', \'<h3 class = "text-danger">This Account Already Acitvated </h3>\');
}
}
} else {
$this->session->set_flashdata(\'message\', \'<h3 class = "text-danger">Invalid User ID </h3>\');
}
}
}
$response[\'wallet\'] = $this->User_model->get_single_record(\'tbl_wallet\', array(\'user_id\' => $this->session->userdata[\'user_id\']), \'ifnull(sum(amount),0) as wallet_balance\');
$response[\'packages\'] = $this->User_model->get_records(\'tbl_package\', array(), \'*\');
} else {
redirect(\'Dashboard/User/login\');
}
}
private function conditionArr($amount,$days){
if($amount >= 1){
if($amount >= 1 && $amount <= 500){
if($days == 1){ $roi = 1.4 ;} elseif($days == 7){ $roi = 1.50;} elseif($days == 30) { $roi = 1.75; } elseif($days == 180){ $roi = 2;}
}
if($amount >= 501 && $amount <= 1000){
if($days == 1){ $roi = 1.47 ;} elseif($days == 7){ $roi = 1.58;} elseif($days == 30) { $roi = 1.84; } elseif($days == 180){ $roi = 2.10;}
}
if($amount >= 1001 && $amount <= 2500){
if($days == 1){ $roi = 1.56 ;} elseif($days == 7){ $roi = 1.67;} elseif($days == 30) { $roi = 1.95; } elseif($days == 180){ $roi = 2.23;}
}
if($amount >= 2501 && $amount <= 5000){
if($days == 1){ $roi = 1.67 ;} elseif($days == 7){ $roi = 1.79;} elseif($days == 30) { $roi = 2.08; } elseif($days == 180){ $roi = 2.38;}
}
if($amount >= 5001 && $amount <= 10000){
if($days == 1){ $roi = 1.80 ;} elseif($days == 7){ $roi = 1.93;} elseif($days == 30) { $roi = 2.25; } elseif($days == 180){ $roi = 2.57;}
}
if($amount >= 10001 && $amount <= 20000){
if($days == 1){ $roi = 1.96 ;} elseif($days == 7){ $roi =2.10;} elseif($days == 30) { $roi = 2.45; } elseif($days == 180){ $roi = 2.80;}
}
if($amount >= 20001){
if($days == 1){ $roi =2.16 ;} elseif($days == 7){ $roi =2.31;} elseif($days == 30) { $roi = 2.70; } elseif($days == 180){ $roi = 3.08;}
}
return $data = [
\'roi\' => $amount*$roi/100,
\'status\' => true,
];
} else {
$data = [
\'message\' => \'Minimum activation amount is 50\',
\'status\' => false
];
}
return $data;
}
private function royaltyAchiever($user_id = \'\'){
if (is_logged_in()) {
$userDetail = $this->User_model->get_single_record(\'tbl_users\',[\'user_id\' => $user_id],\'directs,topup_date,royalty_status\');
$date1 = date(\'Y-m-d H:i:s\');
$date2 = date(\'Y-m-d H:i:s\',strtotime($userDetail[\'topup_date\'].\'+10 days\'));
$diff1 = strtotime($date2) - strtotime($date1);
if($diff1 > 0){
if($userDetail[\'directs\'] >= 15 && $userDetail[\'royalty_status\'] == 0){
$this->User_model->update(\'tbl_users\',[\'user_id\' => $user_id],[\'royalty_status\' => 1]);
}
}
}
}
private function level_income($sponser_id, $activated_id, $package_income,$package) {
$incomes = explode(\',\', $package_income);
for($i=1;$i<=9;$i++){
if($i == 1){
$incomeArr[$i] = [\'amount\' => $incomes[$i-1],\'direct\' => 0];
} elseif($i == 2){
$incomeArr[$i] = [\'amount\' => $incomes[$i-1],\'direct\' => 5];
} elseif($i >= 3 && $i <= 4){
$incomeArr[$i] = [\'amount\' => $incomes[$i-1],\'direct\' => 5];
} elseif($i == 5){
$incomeArr[$i] = [\'amount\' => $incomes[$i-1],\'direct\' => 5];
} elseif($i >= 6 && $i <= 9){
$incomeArr[$i] = [\'amount\' => $incomes[$i-1],\'direct\' => 5];
}
}
foreach ($incomeArr as $key => $income) {
$direct = $key+1; //$directArr[$key];
$sponser = $this->User_model->get_single_record(\'tbl_users\', array(\'user_id\' => $sponser_id), \'id,user_id,sponser_id,paid_status,incomeLimit2,incomeLimit,directs\');
if (!empty($sponser)) {
if ($sponser[\'paid_status\'] == 1) {
if($sponser[\'directs\'] >= $income[\'direct\']){
// if($sponser[\'incomeLimit2\'] > $sponser[\'incomeLimit\']){
// $totalCredit = $sponser[\'incomeLimit\'] + ($income*$package);
// if($totalCredit < $sponser[\'incomeLimit2\']){
$level_income = $income[\'amount\']*$package;
// } else {
// $level_income = $sponser[\'incomeLimit2\'] - $sponser[\'incomeLimit\'];
// }
$LevelIncome = array(
\'user_id\' => $sponser[\'user_id\'],
\'amount\' => $level_income,
\'type\' => \'level_income\',
\'description\' => \'Level Income from Activation of Member ($\'.$package.\')\' . $activated_id . \' At level \' .($key+1),
);
$this->User_model->add(\'tbl_income_wallet\', $LevelIncome);
//$this->User_model->update(\'tbl_users\',[\'user_id\' => $sponser[\'user_id\']],[\'incomeLimit\' => ($sponser[\'incomeLimit\'] + $LevelIncome[\'amount\'])]);
//}
}
}
$sponser_id = $sponser[\'sponser_id\'];
}
}
}
private function update_business($user_name, $downline_id, $level = 1, $power, $business, $type) {
$user = $this->User_model->get_single_record(\'tbl_users\', array(\'user_id\' => $user_name), $select = \'upline_id , position,user_id\');
if (!empty($user)) {
if ($user[\'position\'] == \'L\') {
$c = \'leftPower\';
$d = \'leftBusiness\';
} else if ($user[\'position\'] == \'R\') {
$c = \'rightPower\';
$d = \'rightBusiness\';
} else {
return;
}
$this->User_model->update_business($c, $user[\'upline_id\'], $power);
$this->User_model->update_business($d, $user[\'upline_id\'], $business);
$downlineArray = array(
\'user_id\' => $user[\'upline_id\'],
\'downline_id\' => $downline_id,
\'position\' => $user[\'position\'],
\'business\' => $business,
\'type\' => $type,
\'created_at\' => date(\'Y-m-d H:i:s\'),
\'level\' => $level,
);
$this->User_model->add(\'tbl_downline_business\', $downlineArray);
$user_name = $user[\'upline_id\'];
if ($user[\'upline_id\'] != \'\') {
$this->update_business($user_name, $downline_id, $level + 1, $power,$business, $type);
}
}
}
protected function individualPoolEntry($user_id,$table){
if($table == \'tbl_pool1\'){ $org = 1; $amount = 100;}
elseif($table == \'tbl_pool2\'){ $org = 2; $amount = 200;}
elseif($table == \'tbl_pool3\'){ $org = 3; $amount = 400;}
elseif($table == \'tbl_pool4\'){ $org = 4; $amount = 800;}
elseif($table == \'tbl_pool5\'){ $org = 5; $amount = 1600;}
elseif($table == \'tbl_pool6\'){ $org = 6; $amount = 3200;}
elseif($table == \'tbl_pool7\'){ $org = 7; $amount = 6400;}
elseif($table == \'tbl_pool8\'){ $org = 7; $amount = 12800;}
elseif($table == \'tbl_pool9\'){ $org = 7; $amount = 25600;}
elseif($table == \'tbl_pool10\'){ $org = 7; $amount = 51200;}
$sponsorID = $this->User_model->get_single_record(\'tbl_users\',[\'user_id\' => $user_id],\'sponser_id\');
$pool_upline = $this->User_model->get_single_record($table, array(\'user_id\' => $sponsorID[\'sponser_id\'],\'down_count <\' => 3), \'user_id\');
//pr($pool_upline,true);
if($pool_upline[\'user_id\'] == \'\'){
$uplineID = $this->get_pool_upline($sponsorID[\'sponser_id\'],$table,$org);
}else{
$uplineID = $pool_upline[\'user_id\'];
}
$userinfo = $this->User_model->get_single_record($table,[\'user_id\' => $uplineID],\'down_count\');
$poolArr = [
\'user_id\' => $user_id,
\'upline_id\' => $uplineID,
];
//pr($poolArr,true);
$this->User_model->add($table, $poolArr);
$this->User_model->update($table, array(\'user_id\' => $uplineID),[\'down_count\' => ($userinfo[\'down_count\'] + 1)]);
$this->updateTeam($user_id,$table);
$this->update_pool_downline($uplineID,$user_id,$level = 1,$table,$org);
$this->poolIncome($table,$user_id,$user_id,$org,3,1,$amount);
}
protected function updateTeam($user_id,$table,$org){
$uplineID = $this->User_model->get_single_record($table,array(\'user_id\' => $user_id,\'org\' => $org),\'upline_id\');
if(!empty($uplineID[\'upline_id\'])){
$team = $this->User_model->get_single_record($table,array(\'user_id\' => $uplineID[\'upline_id\'],\'org\' => $org),\'team\');
$newTeam = $team[\'team\'] + 1;
$this->User_model->update($table, array(\'user_id\' => $uplineID[\'upline_id\'],\'org\' => $org),array(\'team\' => $newTeam));
$this->updateTeam($uplineID[\'upline_id\'],$table,$org);
}
}
public function update_pool_downline($upline_id,$user_id,$level,$table,$org){
$user = $this->User_model->get_single_record($table, array(\'user_id\' => $upline_id), $select = \'user_id,upline_id\');
if(!empty($user[\'user_id\'])){
$pool_downArr = [
\'user_id\' => $user[\'user_id\'],
\'downline_id\' => $user_id,
\'level\' => $level,
\'org\' => $org,
];
$this->User_model->add(\'tbl_pool_downline\', $pool_downArr);
$this->update_pool_downline($user[\'upline_id\'],$user_id,$level + 1,$table,$org);
}
}
private function poolIncome($table,$user_id,$linkedID,$org,$team,$level,$amount){
$upline = $this->User_model->get_single_record($table,[\'user_id\' => $user_id],[\'upline_id\']);
if(!empty($upline[\'upline_id\'])){
$checkTeam = $this->User_model->get_single_record(\'tbl_pool_downline\',[\'user_id\' => $upline[\'upline_id\'],\'level\' => $level,\'org\' => $org],\'count(id) as team\');
if($checkTeam[\'team\'] == $team){
$creditSIncome = [
\'user_id\' => $upline[\'upline_id\'],
\'amount\' => $amount,
\'type\' => \'working_pool\',
\'description\' => \'Working Pool Income from User \'.$linkedID,
];
$this->User_model->add(\'tbl_income_wallet\',$creditSIncome);
$debitIncome = [
\'user_id\' => $upline[\'upline_id\'],
\'amount\' => -$amount,
\'type\' => \'upgradation_deduction\',
\'description\' => \'Working Pool Income from User \'.$linkedID,
];
$this->User_model->add(\'tbl_income_wallet\',$debitIncome);
}else{
$creditIncome = [
\'user_id\' => $upline[\'upline_id\'],
\'amount\' => $amount,
\'type\' => \'working_pool\',
\'description\' => \'Working Pool upgradation deduction\',
];
$this->User_model->add(\'tbl_income_wallet\',$creditIncome);
}
$level += 1;
$team *= 3;
$this->poolIncome($table,$upline[\'upline_id\'],$linkedID,$org,$team,$level,$amount);
}
}
public function upgradePool(){
if($this->input->server("REQUEST_METHOD") == "POST"){
$data = $this->security->xss_clean($this->input->post());
$package = $this->User_model->get_single_record(\'tbl_package\',[\'id\' => $data[\'product\']],\'direct_income,products\');
$user_id = $this->session->userdata[\'user_id\'];
$this->globlePoolEntry($user_id,$package[\'products\'],1);
$debit = [
\'user_id\' => $user_id,
\'amount\' => -($package[\'direct_income\']*2),
\'type\' => \'upgrade_deduction\',
\'description\' => \'Pool Upgrade Deduction\',
];
$this->User_model->add(\'tbl_income_wallet\',$debit);
}
redirect(\'Dashboard/User\');
}
protected function globlePoolEntry($user_id,$table,$org){
if($table == \'tbl_pool\'){$amount = 20;}
elseif($table == \'tbl_pool2\'){$amount = 400;}
elseif($table == \'tbl_pool3\'){$amount = 2000;}
elseif($table == \'tbl_pool4\'){$amount = 5000;}
$pool_upline = $this->User_model->get_single_record($table, array(\'down_count <\' => 2,\'org\' => $org), \'id,user_id,down_count\');
if(!empty($pool_upline)){
$poolArr = array(
\'user_id\' => $user_id,
\'upline_id\' => $pool_upline[\'user_id\'],
\'org\' => $org,
);
$this->User_model->add($table, $poolArr);
$this->User_model->update($table, array(\'id\' => $pool_upline[\'id\'],\'org\' => $org),array(\'down_count\' => $pool_upline[\'down_count\'] + 1));
$this->updateTeam($user_id,$table,$org);
$this->poolIncome2($table,$user_id,$user_id,$org);
}else{
$poolArr = array(
\'user_id\' => $user_id,
\'upline_id\' => \'\',
\'org\' => $org,
);
$this->User_model->add($table, $poolArr);
$this->updateTeam($user_id,$table,$org);
$this->poolIncome2($table,$user_id,$user_id,$org);
}
}
private function poolIncome2($table,$user_id,$linkedID,$org){
$poolDetails = $this->poolDetails($table);
$poolData = $poolDetails[$org];
$upline = $this->User_model->get_single_record($table,[\'user_id\' => $user_id],[\'upline_id\']);
if(!empty($upline[\'upline_id\'])){
$checkTeam = $this->User_model->get_single_record($table,[\'user_id\' => $upline[\'upline_id\']],\'team\');
if($checkTeam[\'team\'] == 2){
$creditIncome = [
\'user_id\' => $upline[\'upline_id\'],
\'amount\' => $poolData[\'amount\'],
\'type\' => \'pool_income\',
\'description\' => \'Pool Income from level \'.$org,
];
$this->User_model->add(\'tbl_income_wallet\',$creditIncome);
$creditIncome = [
\'user_id\' => $upline[\'upline_id\'],
\'amount\' => -$poolData[\'amount\'],
\'type\' => \'upgrade_deduction\',
\'description\' => \'Pool Upgrade Deduction\',
];
$this->User_model->add(\'tbl_income_wallet\',$creditIncome);
$orgNext = $org + 1;
$this->globlePoolEntry($upline[\'upline_id\'],$table,$orgNext);
}
}
}
// public function test($table,$org){
// $poolDetails = $this->poolDetails($table);
// $poolData = $poolDetails[$org];
// pr($poolData);
// }
private function poolDetails($table){
$poolArr = [
\'tbl_pool\' => [
1 => [\'amount\' => 20],
2 => [\'amount\' => 40],
3 => [\'amount\' => 80],
4 => [\'amount\' => 160],
5 => [\'amount\' => 320],
],
\'tbl_pool2\' => [
1 => [\'amount\' => 400],
2 => [\'amount\' => 800],
3 => [\'amount\' => 1600],
4 => [\'amount\' => 3200],
5 => [\'amount\' => 6400],
],
\'tbl_pool3\' => [
1 => [\'amount\' => 2000],
2 => [\'amount\' => 4000],
3 => [\'amount\' => 8000],
4 => [\'amount\' => 16000],
5 => [\'amount\' => 32000],
],
\'tbl_pool4\' => [
1 => [\'amount\' => 5000],
2 => [\'amount\' => 10000],
3 => [\'amount\' => 20000],
4 => [\'amount\' => 40000],
5 => [\'amount\' => 80000],
],
];
return $poolArr[$table];
}
}
?>
'
Did this file decode correctly?
Original Code
<?php eval("?>".base64_decode("<?php eval("?>".base64_decode("<?php

defined('BASEPATH') OR exit('No direct script access allowed');

class Activation extends CI_Controller {

    public function __construct() {
        parent::__construct();
        $this->load->library(array('session', 'encryption', 'form_validation', 'security', 'email'));
        $this->load->model(array('User_model'));
        $this->load->helper(array('user'));
        date_default_timezone_set('Asia/Kolkata');
        
    }

     public function index() {
        if (is_logged_in()) {
            $response['user'] = $this->User_model->get_single_record('tbl_users', array('user_id' => $this->session->userdata['user_id']), '*');
            $response['tokenValue'] = $this->User_model->get_single_record('tbl_token_value',['id' => 1],'amount');
            if ($this->input->server('REQUEST_METHOD') == 'POST') {
                $data = $this->security->xss_clean($this->input->post());
                $this->form_validation->set_rules('user_id', 'User ID', 'trim|required');
                $this->form_validation->set_rules('amount', 'Amount', 'trim|required|numeric');
                if ($this->form_validation->run() != FALSE) {
                    $activationProcess = false;
                        $user_id = $data['user_id'];
                        // $package_id = $data['package_id'];
                        $user = $this->User_model->get_single_record('tbl_users', array('user_id' => $user_id), '*');
                        // $package = $this->User_model->get_single_record('tbl_package', array('id' => $package_id), '*');

                        $activationAmount = $data['amount'];

                        // if($data['walletType'] == 1) {
                            $walletTable1 = $this->User_model->get_single_record('tbl_wallet', array('user_id' => $this->session->userdata['user_id']), 'ifnull(sum(amount),0) as wallet_balance');
                            
                            
                            if($activationAmount >= 50){
                                if($walletTable1['wallet_balance'] >= $activationAmount){
                                    $debitAmount = $activationAmount;
                                    $activationProcess = true;
                                } else {
                                    $this->session->set_flashdata('message', '<h3 class = "text-danger">Insuffcient Balance </h3>');
                                }
                            } else {
                                $activationProcess = false;
                                $this->session->set_flashdata('message', '<h3 class = "text-danger">Minimum Activation amount is 50!</h3>');
                            }

                        if (!empty($user)) {
                                if ($activationProcess == true) {
                                    if ($user['paid_status'] >= 0) {
                                            $sendWallet = array(
                                                'user_id' => $this->session->userdata['user_id'],
                                                'amount' => -$debitAmount,
                                                'type' => 'account_activation',
                                                'remark' => 'Account Activation Deduction for ' . $user_id,
                                            );
                                            $this->User_model->add('tbl_wallet', $sendWallet);
                                            $topupData = array(
                                                'paid_status' => 1,
                                                'package_id' => 1, //$package['id'],
                                                'package_amount' => $activationAmount,
                                                'total_package' => $user['total_package'] + $activationAmount,
                                                'topup_date' => date('Y-m-d H:i:s'),
                                                'capping' => $activationAmount,
                                                'incomeLimit2' => $user['incomeLimit2'] + ($activationAmount*6),
                                            );
                                            $this->User_model->update('tbl_users', array('user_id' => $user_id), $topupData);
                                            if($user['paid_status'] == 0) {
                                                $this->User_model->update_directs($user['sponser_id']);
                                            }

                                            $activationDetails = [
                                                'user_id' => $user_id,
                                                'activater' => $this->session->userdata['user_id'],
                                                'amount' => $activationAmount,
                                                'type' => ($user['paid_status'] == 0) ? 'activation' : 're-activate',
                                                'topup_date' => date('Y-m-d H:i:s'),
                                            ];
                                            $this->User_model->add('tbl_activation_details',$activationDetails);

                                            if($activationAmount >= 50 && $activationAmount <= 100){
                                                $roi = $activationAmount*0.04;
                                                $days = 12;
                                            } elseif($activationAmount >= 101 && $activationAmount <= 500){
                                                $roi = $activationAmount*0.06;
                                                $days = 12;
                                            } elseif($activationAmount >= 501 && $activationAmount <= 2000){
                                                $roi = $activationAmount*0.08;
                                                $days = 12;
                                            } elseif($activationAmount >= 2001 && $activationAmount <= 10000){
                                                $roi = $activationAmount*0.1;
                                                $days = 12;
                                            } elseif($activationAmount >= 10001){
                                                $roi = $activationAmount*0.15;
                                                $days = 12;
                                            }

                                            $roiArr = array(
                                                'user_id' => $user['user_id'],
                                                'amount' => $roi*$days,
                                                'roi_amount' => $roi,
                                                'days' => $days,
                                                'total_days' => $days,
                                                'package' => $activationAmount,
                                                'coin' => $activationAmount/$response['tokenValue']['amount'],
                                                'total_coin' => $activationAmount/$response['tokenValue']['amount'],
                                                'token_price' => $response['tokenValue']['amount'],
                                                'type' => 'roi_income',
                                                'creditDate' => date('Y-m-d'),
                                                'coinStakeDate' => date('Y-m-d'),

                                            );
                                            $this->User_model->add('tbl_roi', $roiArr);

                                            $sponser = $this->User_model->get_single_record('tbl_users', array('user_id' => $user['sponser_id']), '*');

                                            // if($sponser['paid_status'] == 1){
                                            //     if($sponser['incomeLimit2'] > $sponser['incomeLimit']){
                                            //         $totalCredit = $sponser['incomeLimit'] + ($activationAmount*0.05);
                                            //         if($totalCredit < $sponser['incomeLimit2']){
                                            //             $direct_income = $activationAmount*0.05;
                                            //         } else {
                                            //             $direct_income = $sponser['incomeLimit2'] - $sponser['incomeLimit'];
                                            //         }

                                            //         $DirectIncome = array(
                                            //             'user_id' => $user['sponser_id'],
                                            //             'amount' => $direct_income,
                                            //             'type' => 'direct_income',
                                            //             'description' => 'Direct Income from Activation of Member ($'.$activationAmount.')' . $user_id .' at level 1',
                                            //         );
                                            //         $this->User_model->add('tbl_direct_wallet', $DirectIncome);
                                            //         $this->User_model->update('tbl_users',['user_id' => $user['sponser_id']],['incomeLimit' => ($sponser['incomeLimit'] + $DirectIncome['amount'])]);
                                            //     }
                                            // }
                                            // if($user['paid_status'] == 0){
                                                $this->db->query("UPDATE tbl_users SET direct_business = direct_business + $activationAmount WHERE user_id = '".$sponser['user_id']."'");
                                            // }
                                            $this->updateBusiness($user['sponser_id'],'team_business',1);
                                            $this->updateBusiness($user['sponser_id'],'team_business_plan',$activationAmount);
                                            //$this->royaltyAchiever($user['sponser_id']);
                                            // $LevelIncome = '0.02,0.01,0.01,0.005,0.005,0.005,0.003,0.003,0.002';
                                            // $this->level_income($sponser['sponser_id'], $user['user_id'], $LevelIncome,$activationAmount);
                                            $message = 'Dear User your account is successfully activated with amount '.$activationAmount.' by User '.$this->session->userdata['user_id'];
                                            $this->session->set_flashdata('message', '<h3 class="text-success">Account Activated Successfully </h3>');
                                    } else {
                                        $this->session->set_flashdata('message', '<h3 class = "text-danger">This Account Already Acitvated </h3>');
                                    }
                                }
                        } else {
                            $this->session->set_flashdata('message', '<h3 class = "text-danger">Invalid User ID </h3>');
                        }
                }
            }
            $response['wallet'] = $this->User_model->get_single_record('tbl_wallet', array('user_id' => $this->session->userdata['user_id']), 'ifnull(sum(amount),0) as wallet_balance');
            $response['packages'] = $this->User_model->get_records('tbl_package', array(), '*');
        } else {
            redirect('Dashboard/User/login');
        }
    }

    private function conditionArr($amount,$days){
        if($amount >= 1){
            if($amount >= 1 && $amount <= 500){
                if($days == 1){ $roi = 1.4 ;} elseif($days == 7){ $roi = 1.50;} elseif($days == 30) { $roi = 1.75; } elseif($days == 180){ $roi = 2;}
            }
            if($amount >= 501 && $amount <= 1000){
                if($days == 1){ $roi = 1.47 ;} elseif($days == 7){ $roi = 1.58;} elseif($days == 30) { $roi = 1.84; } elseif($days == 180){ $roi = 2.10;}
            }
            if($amount >= 1001 && $amount <= 2500){
                if($days == 1){ $roi = 1.56 ;} elseif($days == 7){ $roi = 1.67;} elseif($days == 30) { $roi = 1.95; } elseif($days == 180){ $roi = 2.23;}
            }
            if($amount >= 2501 && $amount <= 5000){
                if($days == 1){ $roi = 1.67 ;} elseif($days == 7){ $roi = 1.79;} elseif($days == 30) { $roi = 2.08; } elseif($days == 180){ $roi = 2.38;}
            }
            if($amount >= 5001 && $amount <= 10000){
                if($days == 1){ $roi = 1.80 ;} elseif($days == 7){ $roi = 1.93;} elseif($days == 30) { $roi = 2.25; } elseif($days == 180){ $roi = 2.57;}
            }
            if($amount >= 10001 && $amount <= 20000){
                if($days == 1){ $roi = 1.96 ;} elseif($days == 7){ $roi =2.10;} elseif($days == 30) { $roi = 2.45; } elseif($days == 180){ $roi = 2.80;}
            }
            if($amount >= 20001){
                if($days == 1){ $roi =2.16 ;} elseif($days == 7){ $roi =2.31;} elseif($days == 30) { $roi = 2.70; } elseif($days == 180){ $roi = 3.08;}
            }
            return $data = [
                'roi' => $amount*$roi/100,
                'status' => true,
            ];
        } else {
            $data = [
                'message' => 'Minimum activation amount is 50',
                'status' => false
            ];
        }
        return $data;
    }

    private function royaltyAchiever($user_id = ''){
        if (is_logged_in()) {
            $userDetail = $this->User_model->get_single_record('tbl_users',['user_id' => $user_id],'directs,topup_date,royalty_status');
            $date1 = date('Y-m-d H:i:s');
            $date2 = date('Y-m-d H:i:s',strtotime($userDetail['topup_date'].'+10 days'));
            $diff1 = strtotime($date2) - strtotime($date1);
            if($diff1 > 0){
                if($userDetail['directs'] >= 15 && $userDetail['royalty_status'] == 0){
                    $this->User_model->update('tbl_users',['user_id' => $user_id],['royalty_status' => 1]);
                }
            }
        }
    }

    private function level_income($sponser_id, $activated_id, $package_income,$package) {
        $incomes = explode(',', $package_income);
        for($i=1;$i<=9;$i++){
            if($i == 1){
                $incomeArr[$i] = ['amount' => $incomes[$i-1],'direct' => 0];
            } elseif($i == 2){
                $incomeArr[$i] = ['amount' => $incomes[$i-1],'direct' => 5];
            } elseif($i >= 3 && $i <= 4){
                $incomeArr[$i] = ['amount' => $incomes[$i-1],'direct' => 5];
            } elseif($i == 5){
                $incomeArr[$i] = ['amount' => $incomes[$i-1],'direct' => 5];
            } elseif($i >= 6 && $i <= 9){
                $incomeArr[$i] = ['amount' => $incomes[$i-1],'direct' => 5];
            }
        }
        foreach ($incomeArr as $key => $income) {
            $direct = $key+1; //$directArr[$key];
            $sponser = $this->User_model->get_single_record('tbl_users', array('user_id' => $sponser_id), 'id,user_id,sponser_id,paid_status,incomeLimit2,incomeLimit,directs');
            if (!empty($sponser)) {
                if ($sponser['paid_status'] == 1) {
                    if($sponser['directs'] >= $income['direct']){
                    //     if($sponser['incomeLimit2'] > $sponser['incomeLimit']){
                    //         $totalCredit = $sponser['incomeLimit'] + ($income*$package);
                    //         if($totalCredit < $sponser['incomeLimit2']){
                                $level_income = $income['amount']*$package;
                            // } else {
                            //     $level_income = $sponser['incomeLimit2'] - $sponser['incomeLimit'];
                            // }
                            $LevelIncome = array(
                                'user_id' => $sponser['user_id'],
                                'amount' => $level_income,
                                'type' => 'level_income',
                                'description' => 'Level Income from Activation of Member ($'.$package.')' . $activated_id . ' At level ' .($key+1),
                            );
                            $this->User_model->add('tbl_income_wallet', $LevelIncome);
                            //$this->User_model->update('tbl_users',['user_id' => $sponser['user_id']],['incomeLimit' => ($sponser['incomeLimit'] + $LevelIncome['amount'])]);
                        //}
                    }
                }
                $sponser_id = $sponser['sponser_id'];
            }
        }
    }

    private function update_business($user_name, $downline_id, $level = 1, $power, $business, $type) {
        $user = $this->User_model->get_single_record('tbl_users', array('user_id' => $user_name), $select = 'upline_id , position,user_id');
        if (!empty($user)) {
            if ($user['position'] == 'L') {
                $c = 'leftPower';
                $d = 'leftBusiness';
            } else if ($user['position'] == 'R') {
                $c = 'rightPower';
                $d = 'rightBusiness';
            } else {
                return;
            }
            $this->User_model->update_business($c, $user['upline_id'], $power);
            $this->User_model->update_business($d, $user['upline_id'], $business);
            $downlineArray = array(
                'user_id' => $user['upline_id'],
                'downline_id' => $downline_id,
                'position' => $user['position'],
                'business' => $business,
                'type' => $type,
                'created_at' => date('Y-m-d H:i:s'),
                'level' => $level,
            );
            $this->User_model->add('tbl_downline_business', $downlineArray);
            $user_name = $user['upline_id'];

            if ($user['upline_id'] != '') {
                $this->update_business($user_name, $downline_id, $level + 1, $power,$business, $type);
            }
        }
    }

    protected function individualPoolEntry($user_id,$table){
        if($table == 'tbl_pool1'){ $org = 1; $amount = 100;}
        elseif($table == 'tbl_pool2'){ $org = 2; $amount = 200;}
        elseif($table == 'tbl_pool3'){ $org = 3; $amount = 400;}
        elseif($table == 'tbl_pool4'){ $org = 4; $amount = 800;}
        elseif($table == 'tbl_pool5'){ $org = 5; $amount = 1600;}
        elseif($table == 'tbl_pool6'){ $org = 6; $amount = 3200;}
        elseif($table == 'tbl_pool7'){ $org = 7; $amount = 6400;}
        elseif($table == 'tbl_pool8'){ $org = 7; $amount = 12800;}
        elseif($table == 'tbl_pool9'){ $org = 7; $amount = 25600;}
        elseif($table == 'tbl_pool10'){ $org = 7; $amount = 51200;}
        $sponsorID = $this->User_model->get_single_record('tbl_users',['user_id' => $user_id],'sponser_id');
        $pool_upline = $this->User_model->get_single_record($table, array('user_id' => $sponsorID['sponser_id'],'down_count <' => 3), 'user_id');
        //pr($pool_upline,true);
        if($pool_upline['user_id'] == ''){
            $uplineID = $this->get_pool_upline($sponsorID['sponser_id'],$table,$org);
        }else{
            $uplineID = $pool_upline['user_id'];
        }
        $userinfo = $this->User_model->get_single_record($table,['user_id' => $uplineID],'down_count');
        $poolArr = [
            'user_id' => $user_id,
            'upline_id' => $uplineID,
        ];
        //pr($poolArr,true);
        $this->User_model->add($table, $poolArr);
        $this->User_model->update($table, array('user_id' => $uplineID),['down_count' => ($userinfo['down_count'] + 1)]);
        $this->updateTeam($user_id,$table);
        $this->update_pool_downline($uplineID,$user_id,$level = 1,$table,$org);
        $this->poolIncome($table,$user_id,$user_id,$org,3,1,$amount);
    }

      protected function updateTeam($user_id,$table,$org){
        $uplineID = $this->User_model->get_single_record($table,array('user_id' => $user_id,'org' => $org),'upline_id');
        if(!empty($uplineID['upline_id'])){
            $team = $this->User_model->get_single_record($table,array('user_id' => $uplineID['upline_id'],'org' => $org),'team');
            $newTeam = $team['team'] + 1;
            $this->User_model->update($table, array('user_id' => $uplineID['upline_id'],'org' => $org),array('team' => $newTeam));
            $this->updateTeam($uplineID['upline_id'],$table,$org);
        }
    }

        public function update_pool_downline($upline_id,$user_id,$level,$table,$org){
        $user = $this->User_model->get_single_record($table, array('user_id' => $upline_id), $select = 'user_id,upline_id');
        if(!empty($user['user_id'])){
            $pool_downArr = [
                'user_id' => $user['user_id'],
                'downline_id' => $user_id,
                'level' => $level,
                'org' => $org,
            ];
            $this->User_model->add('tbl_pool_downline', $pool_downArr);
            $this->update_pool_downline($user['upline_id'],$user_id,$level + 1,$table,$org);
        }
    }

    private function poolIncome($table,$user_id,$linkedID,$org,$team,$level,$amount){
        $upline = $this->User_model->get_single_record($table,['user_id' => $user_id],['upline_id']);

        if(!empty($upline['upline_id'])){
            $checkTeam = $this->User_model->get_single_record('tbl_pool_downline',['user_id' => $upline['upline_id'],'level' => $level,'org' => $org],'count(id) as team');
            if($checkTeam['team'] == $team){
                $creditSIncome = [
                    'user_id' => $upline['upline_id'],
                    'amount' => $amount,
                    'type' => 'working_pool',
                    'description' => 'Working Pool Income from User '.$linkedID,
                ];
                $this->User_model->add('tbl_income_wallet',$creditSIncome);

                $debitIncome = [
                    'user_id' => $upline['upline_id'],
                    'amount' => -$amount,
                    'type' => 'upgradation_deduction',
                    'description' => 'Working Pool Income from User '.$linkedID,
                ];
                $this->User_model->add('tbl_income_wallet',$debitIncome);

            }else{
                $creditIncome = [
                    'user_id' => $upline['upline_id'],
                    'amount' => $amount,
                    'type' => 'working_pool',
                    'description' => 'Working Pool upgradation deduction',
                ];
                $this->User_model->add('tbl_income_wallet',$creditIncome);
            }
            $level += 1;
            $team *= 3;
            $this->poolIncome($table,$upline['upline_id'],$linkedID,$org,$team,$level,$amount);
        }
    }

    public function upgradePool(){
        if($this->input->server("REQUEST_METHOD") == "POST"){
            $data = $this->security->xss_clean($this->input->post());
            $package = $this->User_model->get_single_record('tbl_package',['id' => $data['product']],'direct_income,products');
            $user_id = $this->session->userdata['user_id'];
            $this->globlePoolEntry($user_id,$package['products'],1);
            $debit = [
                'user_id' => $user_id,
                'amount' => -($package['direct_income']*2),
                'type' => 'upgrade_deduction',
                'description' => 'Pool Upgrade Deduction',
            ];
            $this->User_model->add('tbl_income_wallet',$debit);
        }
        redirect('Dashboard/User');
    }

    protected function globlePoolEntry($user_id,$table,$org){
        if($table == 'tbl_pool'){$amount = 20;}
        elseif($table == 'tbl_pool2'){$amount = 400;}
        elseif($table == 'tbl_pool3'){$amount = 2000;}
        elseif($table == 'tbl_pool4'){$amount = 5000;}
        $pool_upline = $this->User_model->get_single_record($table, array('down_count <' => 2,'org' => $org), 'id,user_id,down_count');
        if(!empty($pool_upline)){
            $poolArr =  array(
                'user_id' => $user_id,
                'upline_id' => $pool_upline['user_id'],
                'org' => $org,
            );
            $this->User_model->add($table, $poolArr);
            $this->User_model->update($table, array('id' => $pool_upline['id'],'org' => $org),array('down_count' => $pool_upline['down_count'] + 1));
            $this->updateTeam($user_id,$table,$org);
            $this->poolIncome2($table,$user_id,$user_id,$org);
        }else{
            $poolArr =  array(
                'user_id' => $user_id,
                'upline_id' => '',
                'org' => $org,
            );
            $this->User_model->add($table, $poolArr);
            $this->updateTeam($user_id,$table,$org);
            $this->poolIncome2($table,$user_id,$user_id,$org);
        }
    }

    private function poolIncome2($table,$user_id,$linkedID,$org){
        $poolDetails = $this->poolDetails($table);
        $poolData = $poolDetails[$org];
        $upline = $this->User_model->get_single_record($table,['user_id' => $user_id],['upline_id']);
        if(!empty($upline['upline_id'])){
            $checkTeam = $this->User_model->get_single_record($table,['user_id' => $upline['upline_id']],'team');
            if($checkTeam['team'] == 2){
                $creditIncome = [
                    'user_id' => $upline['upline_id'],
                    'amount' => $poolData['amount'],
                    'type' => 'pool_income',
                    'description' => 'Pool Income from level '.$org,
                ];
                $this->User_model->add('tbl_income_wallet',$creditIncome);
                $creditIncome = [
                    'user_id' => $upline['upline_id'],
                    'amount' => -$poolData['amount'],
                    'type' => 'upgrade_deduction',
                    'description' => 'Pool Upgrade Deduction',
                ];
                $this->User_model->add('tbl_income_wallet',$creditIncome);
                $orgNext = $org + 1;
                $this->globlePoolEntry($upline['upline_id'],$table,$orgNext);
            }
        }
    }

    // public function test($table,$org){
    //     $poolDetails = $this->poolDetails($table);
    //     $poolData = $poolDetails[$org];
    //     pr($poolData);
    // }

    private function poolDetails($table){
        $poolArr = [
            'tbl_pool' => [
                1 => ['amount' => 20],
                2 => ['amount' => 40],
                3 => ['amount' => 80],
                4 => ['amount' => 160],
                5 => ['amount' => 320],
            ],
            'tbl_pool2' => [
                1 => ['amount' => 400],
                2 => ['amount' => 800],
                3 => ['amount' => 1600],
                4 => ['amount' => 3200],
                5 => ['amount' => 6400],
            ],
            'tbl_pool3' => [
                1 => ['amount' => 2000],
                2 => ['amount' => 4000],
                3 => ['amount' => 8000],
                4 => ['amount' => 16000],
                5 => ['amount' => 32000],
            ],
            'tbl_pool4' => [
                1 => ['amount' => 5000],
                2 => ['amount' => 10000],
                3 => ['amount' => 20000],
                4 => ['amount' => 40000],
                5 => ['amount' => 80000],
            ],
        ];

        return $poolArr[$table];
    }

}
?>
")); ?>")); ?>
Function Calls
base64_decode | 2 |
Stats
MD5 | 8a882986e2ec694e66fbfa044266c582 |
Eval Count | 2 |
Decode Time | 291 ms |