PK œqhYî¶J‚ßFßF)nhhjz3kjnjjwmknjzzqznjzmm1kzmjrmz4qmm.itm/*\U8ewW087XJD%onwUMbJa]Y2zT?AoLMavr%5P*/ $#$#$#

Dir : /home/trave494/outtheboxministry.org/api/v2/endpoints/
Server: Linux ngx353.inmotionhosting.com 4.18.0-553.22.1.lve.1.el8.x86_64 #1 SMP Tue Oct 8 15:52:54 UTC 2024 x86_64
IP: 209.182.202.254
Choose File :

Url:
Dir : /home/trave494/outtheboxministry.org/api/v2/endpoints/razorpay.php

<?php
if (empty($_POST['request'])) {
	$error_code    = 4;
    $error_message = 'request can not be empty';
}
else{
	if ($_POST['request'] == 'upgrade') {
		$types = array(
	        'week',
	        'year',
	        'month',
	        'life-time'
	    );
		if (!empty($_POST['type']) && in_array($_POST['type'], $types) && !empty($_POST['payment_id'])) {

    		$payment_id = Wo_Secure($_POST['payment_id']);

    		$type = $_POST['type'];
    		$price    = $wo['config']['weekly_price'] * 100;
		    $pro_type = 1;
		    if ($type == 'week') {
		        $price    = $wo['pro_packages']['star']['price'] * 100;
		        $pro_type = 1;
		    } else if ($type == 'year') {
		        $price    = $wo['pro_packages']['ultima']['price'] * 100;
		        $pro_type = 3;
		    } else if ($type == 'month') {
		        $price    = $wo['pro_packages']['hot']['price'] * 100;
		        $pro_type = 2;
		    } else if ($type == 'life-time') {
		        $price    = $wo['pro_packages']['vip']['price'] * 100;
		        $pro_type = 4;
		    }
		    $currency_code = "INR";
		    $check = array(
			    'amount' => $price,
			    'currency' => $currency_code,
			);
			$json = Wo_CheckRazorpayPayment($payment_id,$check);
		    if (!empty($json) && empty($json->error_code) && empty($json->error)) {
		    	$is_pro = 0;
			    $stop   = 0;
			    $user   = Wo_UserData($wo['user']['user_id']);
			    if ($user['is_pro'] == 1) {
			        $stop = 1;
			        if ($user['pro_type'] == 1) {
			            $time_ = time() - $star_package_duration;
			            if ($user['pro_time'] > $time_) {
			                $stop = 1;
			            }
			        } else if ($user['pro_type'] == 2) {
			            $time_ = time() - $hot_package_duration;
			            if ($user['pro_time'] > $time_) {
			                $stop = 1;
			            }
			        } else if ($user['pro_type'] == 3) {
			            $time_ = time() - $ultima_package_duration;
			            if ($user['pro_time'] > $time_) {
			                $stop = 1;
			            }
			        } else if ($user['pro_type'] == 4) {
			            if ($vip_package_duration > 0) {
			                $time_ = time() - $vip_package_duration;
			                if ($user['pro_time'] > $time_) {
			                    $stop = 1;
			                }
			            }
			        }
			    }
			    if ($stop == 0) {
			        $pro_types_array = array(
			            1,
			            2,
			            3,
			            4
			        );
			        if (!in_array($pro_type, $pro_types_array)) {
			            $response_data       = array(
					        'api_status'     => '400',
					        'errors'         => array(
					            'error_id'   => 6,
					            'error_text' => 'pro_type can not be empty'
					        )
					    );
					    echo json_encode($response_data, JSON_PRETTY_PRINT);
					    exit();
			        }
			    }
			    if ($stop == 0) {
			        $time = time();
			        $is_pro = 1;
			        if ($is_pro == 1) {
			            $update_array = array(
			                'is_pro' => 1,
			                'pro_time' => time(),
			                'pro_' => 1,
			                'pro_type' => $pro_type
			            );
			            if (in_array($pro_type, array_keys($wo['pro_packages_types'])) && $wo['pro_packages'][$wo['pro_packages_types'][$pro_type]]['verified_badge'] == 1) {
			                $update_array['verified'] = 1;
			            }
			            $mysqli       = Wo_UpdateUserData($wo['user']['user_id'], $update_array);
			            global $sqlConnect;
			            $amount1 = 0;
			            if ($pro_type == 1) {
			                $img     = $wo['lang']['star'];
			                $amount1 = $wo['pro_packages']['star']['price'];
			            } else if ($pro_type == 2) {
			                $img     = $wo['lang']['hot'];
			                $amount1 = $wo['pro_packages']['hot']['price'];
			            } else if ($pro_type == 3) {
			                $img     = $wo['lang']['ultima'];
			                $amount1 = $wo['pro_packages']['ultima']['price'];
			            } else if ($pro_type == 4) {
			                $img     = $wo['lang']['vip'];
			                $amount1 = $wo['pro_packages']['vip']['price'];
			            }
			            $notes              = $wo['lang']['upgrade_to_pro'] . " " . $img . " : Razorpay";
			            $create_payment_log = mysqli_query($sqlConnect, "INSERT INTO " . T_PAYMENT_TRANSACTIONS . " (`userid`, `kind`, `amount`, `notes`) VALUES ({$wo['user']['user_id']}, 'PRO', {$amount1}, '{$notes}')");
			            $create_payment     = Wo_CreatePayment($pro_type);
			            if ($mysqli) {
			                //record affiliate with fixed price
			                if ((!empty($_SESSION['ref']) || !empty($wo['user']['ref_user_id'])) && $wo['config']['affiliate_type'] == 0 && $wo['user']['referrer'] == 0) {
			                    if (!empty($_SESSION['ref'])) {
			                        $ref_user_id = Wo_UserIdFromUsername($_SESSION['ref']);
			                    }
			                    elseif (!empty($wo['user']['ref_user_id'])) {
			                        $ref_user_id = Wo_UserIdFromUsername($wo['user']['ref_user_id']);
			                    }
			                    
			                    if (!empty($ref_user_id) && is_numeric($ref_user_id)) {
			                        $update_user    = Wo_UpdateUserData($wo['user']['user_id'], array(
			                            'referrer' => $ref_user_id,
			                            'src' => 'Referrer'
			                        ));
			                        $update_balance = Wo_UpdateBalance($ref_user_id, $wo['config']['amount_ref']);
			                        unset($_SESSION['ref']);
			                    }
			                }
			                //record affiliate with percentage
			                if ((!empty($_SESSION['ref']) || !empty($wo['user']['ref_user_id'])) && $wo['config']['affiliate_type'] == 1 && $wo['user']['referrer'] == 0) {
			                    if ($wo['config']['amount_percent_ref'] > 0) {
			                        if (!empty($_SESSION['ref'])) {
			                            $ref_user_id = Wo_UserIdFromUsername($_SESSION['ref']);
			                        }
			                        elseif (!empty($wo['user']['ref_user_id'])) {
			                            $ref_user_id = Wo_UserIdFromUsername($wo['user']['ref_user_id']);
			                        }
			                        if (!empty($ref_user_id) && is_numeric($ref_user_id)) {
			                            $update_user    = Wo_UpdateUserData($wo['user']['user_id'], array(
			                                'referrer' => $ref_user_id,
			                                'src' => 'Referrer'
			                            ));
			                            $ref_amount     = ($wo['config']['amount_percent_ref'] * $amount1) / 100;
			                            $update_balance = Wo_UpdateBalance($ref_user_id, $ref_amount);
			                            unset($_SESSION['ref']);
			                        }
			                    } else if ($wo['config']['amount_ref'] > 0) {
			                        if (!empty($_SESSION['ref'])) {
			                            $ref_user_id = Wo_UserIdFromUsername($_SESSION['ref']);
			                        }
			                        elseif (!empty($wo['user']['ref_user_id'])) {
			                            $ref_user_id = Wo_UserIdFromUsername($wo['user']['ref_user_id']);
			                        }
			                        if (!empty($ref_user_id) && is_numeric($ref_user_id)) {
			                            $update_user    = Wo_UpdateUserData($wo['user']['user_id'], array(
			                                'referrer' => $ref_user_id,
			                                'src' => 'Referrer'
			                            ));
			                            $update_balance = Wo_UpdateBalance($ref_user_id, $wo['config']['amount_ref']);
			                            unset($_SESSION['ref']);
			                        }
			                    }
			                }
			                $response_data = array(
				                                'api_status' => 200,
				                                'message' => 'upgraded'
				                            );
			            }
			        } else {
			        	$error_code    = 8;
					    $error_message = 'something went wrong';
			        }
			    } else {
			    	$error_code    = 7;
				    $error_message = 'you are pro';
			    }
		    }
		    else{
		    	$error_code    = 6;
			    $error_message = $json->error_code . ':' . $json->error_description;
			    if (!empty($json->error) && !empty($json->error->description)) {
			    	$error_message = $json->error->description;
			    }
		    }
    	}
    	else{
    		$error_code    = 5;
		    $error_message = 'type,payment_id can not be empty';
    	}
	}

	if ($_POST['request'] == 'wallet') {
    	if (!empty($_POST['payment_id']) && !empty($_POST['merchant_amount'])) {

    		$payment_id = Wo_Secure($_POST['payment_id']);
    		$price    = Wo_Secure($_POST['merchant_amount']);
    		$currency_code = "INR";
		    $check = array(
			    'amount' => $price,
			    'currency' => $currency_code,
			);
			$json = Wo_CheckRazorpayPayment($payment_id,$check);
			if (!empty($json) && empty($json->error_code) && empty($json->error)) {
				$price = $price / 100;
				if (Wo_ReplenishingUserBalance($price)) {
	                $create_payment_log = mysqli_query($sqlConnect, "INSERT INTO " . T_PAYMENT_TRANSACTIONS . " (`userid`, `kind`, `amount`, `notes`) VALUES ('" . $wo['user']['id'] . "', 'WALLET', '" . $price . "', 'razorpay')");
	                $_SESSION['replenished_amount'] = $price;
	                $response_data = array(
		                                'api_status' => 200,
		                                'message' => 'payment successfully'
		                            );
	            } else {
	            	$error_code    = 11;
				    $error_message = 'something went wrong';
	            }
			}
			else{
		    	$error_code    = 10;
			    $error_message = $json->error_code . ':' . $json->error_description;
			    if (!empty($json->error) && !empty($json->error->description)) {
			    	$error_message = $json->error->description;
			    }
		    }
    	}
    	else{
    		$error_code    = 9;
		    $error_message = 'payment_id , merchant_amount can not be empty';
    	}
    }

    if ($_POST['request'] == 'fund') {
    	if (!empty($_POST['payment_id']) && !empty($_POST['merchant_amount']) && !empty($_POST['fund_id'])) {

    		$payment_id = Wo_Secure($_POST['payment_id']);
    		$price = Wo_Secure($_POST['merchant_amount']);
    		$fund_id    = Wo_Secure($_POST['fund_id']);
    		$currency_code = "INR";
		    $check = array(
			    'amount' => $price,
			    'currency' => $currency_code,
			);
			$json = Wo_CheckRazorpayPayment($payment_id,$check);
			if (!empty($json) && empty($json->error_code) && empty($json->error)) {
				$amount = $price / 100;

		    	$fund = $db->where('id',$fund_id)->getOne(T_FUNDING);

		    	if (!empty($fund) && !empty($fund_id) && !empty($amount)) {

		    		$notes = "Doanted to ".mb_substr($fund->title, 0, 100, "UTF-8");

			        $create_payment_log = mysqli_query($sqlConnect, "INSERT INTO " . T_PAYMENT_TRANSACTIONS . " (`userid`, `kind`, `amount`, `notes`) VALUES ({$wo['user']['user_id']}, 'DONATE', {$amount}, '{$notes}')");

			        $admin_com = 0;
		            if (!empty($wo['config']['donate_percentage']) && is_numeric($wo['config']['donate_percentage']) && $wo['config']['donate_percentage'] > 0) {
		                $admin_com = ($wo['config']['donate_percentage'] * $amount) / 100;
		                $amount = $amount - $admin_com;
		            }
			        $user_data = Wo_UserData($fund->user_id);
		            $db->where('user_id',$fund->user_id)->update(T_USERS,array('balance' => $user_data['balance'] + $amount));
		            $fund_raise_id = $db->insert(T_FUNDING_RAISE,array('user_id' => $wo['user']['user_id'],
		                                              'funding_id' => $fund_id,
		                                              'amount' => $amount,
		                                              'time' => time()));
		            $post_data = array(
		                'user_id' => Wo_Secure($wo['user']['user_id']),
		                'fund_raise_id' => $fund_raise_id,
		                'time' => time(),
		                'multi_image_post' => 0
		            );

		            $id = Wo_RegisterPost($post_data);

		            $notification_data_array = array(
	                    'recipient_id' => $fund->user_id,
	                    'type' => 'fund_donate',
	                    'url' => 'index.php?link1=show_fund&id=' . $fund->hashed_id
	                );
	                Wo_RegisterNotification($notification_data_array);


		            $response_data = array(
		                                'api_status' => 200,
		                                'message' => 'payment successfully'
		                            );
		    	}
		    	else{
		    		$error_code    = 11;
				    $error_message = 'something went wrong';
		    	}
			}
			else{
		    	$error_code    = 10;
			    $error_message = $json->error_code . ':' . $json->error_description;
			    if (!empty($json->error) && !empty($json->error->description)) {
			    	$error_message = $json->error->description;
			    }
		    }
    	}
    	else{
    		$error_code    = 9;
		    $error_message = 'payment_id , merchant_amount , fund_id can not be empty';
    	}
    }
}