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

Variables

None

Stats

MD5 8a882986e2ec694e66fbfa044266c582
Eval Count 2
Decode Time 291 ms