Your IP : 216.73.216.93


Current Path : /home/users/unlimited/www/facebook.codeskitter.site/xhr/
Upload File :
Current File : /home/users/unlimited/www/facebook.codeskitter.site/xhr/coinbase.php

<?php
if ($f == "coinbase") {
	if ($s == 'create') {
		if (!empty($_GET['amount']) && is_numeric($_GET['amount']) && $_GET['amount'] > 0) {
	        try {

	            $amount = Wo_Secure($_GET['amount']);
	            $ch = curl_init();

	            curl_setopt($ch, CURLOPT_URL, 'https://api.commerce.coinbase.com/charges');
	            curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
	            curl_setopt($ch, CURLOPT_POST, 1);
	            $postdata =  array('name' => 'Top Up Wallet','description' => 'Top Up Wallet','pricing_type' => 'fixed_price','local_price' => array('amount' => $amount , 'currency' => $wo['config']['currency']), 'metadata' => array('user_id' => $wo['user']['user_id'],'amount' => $amount),"redirect_url" => $wo['config']['site_url'] . "/requests.php?f=coinbase&s=coinbase_handle&user_id=".$wo['user']['user_id'],'cancel_url' => $wo['config']['site_url'] . "/requests.php?f=coinbase&s=coinbase_cancel&user_id=".$wo['user']['user_id']);


	            curl_setopt($ch, CURLOPT_POSTFIELDS,json_encode($postdata));

	            $headers = array();
	            $headers[] = 'Content-Type: application/json';
	            $headers[] = 'X-Cc-Api-Key: '.$wo['config']['coinbase_key'];
	            $headers[] = 'X-Cc-Version: 2018-03-22';
	            curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);

	            $result = curl_exec($ch);
	            if (curl_errno($ch)) {
	                $data = array(
	                    'status' => 400,
	                    'error' => curl_error($ch)
	                );
	            }
	            curl_close($ch);
	            $result = json_decode($result,true);
	            if (!empty($result) && !empty($result['data']) && !empty($result['data']['hosted_url']) && !empty($result['data']['id']) && !empty($result['data']['code'])) {
	            	$db->insert(T_PENDING_PAYMENTS,array('user_id' => $wo['user']['user_id'],
	                                                     'payment_data' => $result['data']['code'],
	                                                     'method_name' => 'coinbase',
	                                                     'time' => time()));
	                $data['status'] = 200;
	                $data['url'] = $result['data']['hosted_url'];
	            }
	        }
	        catch (Exception $e) {
	            $data = array(
	                'status' => 400,
	                'error' => $e->getMessage()
	            );
	        }
	    }
	    else{
	        $data['status'] = 400;
	        $data['error'] = $wo['lang']['invalid_amount_value'];
	    }
	    header("Content-type: application/json");
        echo json_encode($data);
        exit();
	}
	if ($s == 'coinbase_handle') {
	    if (!empty($_GET['user_id']) && is_numeric($_GET['user_id'])) {

	    	$user_data = '';
	        $coinbase_code = '';
	        $user_id = Wo_Secure($_GET['user_id']);
		    $payment_data           = $db->objectBuilder()->where('user_id',$user_id)->where('method_name', 'coinbase')->orderBy('id','DESC')->getOne(T_PENDING_PAYMENTS);
	        if (!empty($payment_data)) {
	            $user_data           = $db->objectBuilder()->where('user_id',$user_id)->getOne(T_USERS);
	            $coinbase_code = $payment_data->payment_data;
	        }

	        if (!empty($user_data)) {

	            $ch = curl_init();

	            curl_setopt($ch, CURLOPT_URL, 'https://api.commerce.coinbase.com/charges/'.$coinbase_code);
	            curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
	            $headers = array();
	            $headers[] = 'Content-Type: application/json';
	            $headers[] = 'X-Cc-Api-Key: '.$wo['config']['coinbase_key'];
	            $headers[] = 'X-Cc-Version: 2018-03-22';
	            curl_setopt($ch, CURLOPT_HTTPHEADER, $headers);

	            $result = curl_exec($ch);
	            if (curl_errno($ch)) {
	                $url = Wo_SeoLink('index.php?link1=wallet');
	                header("Location: " . $url);
	                exit();
	            }
	            curl_close($ch);
	            $result = json_decode($result,true);
	            if (!empty($result) && !empty($result['data']) && !empty($result['data']['pricing']) && !empty($result['data']['pricing']['local']) && !empty($result['data']['pricing']['local']['amount']) && !empty($result['data']['payments']) && !empty($result['data']['payments'][0]['status']) && $result['data']['payments'][0]['status'] == 'CONFIRMED') {
	            	$amount = (int)$result['data']['pricing']['local']['amount'];
	            	if (Wo_ReplenishingUserBalance($amount)) {
	            		$db->where('user_id', $user_data->user_id)->where('payment_data', $coinbase_code)->delete(T_PENDING_PAYMENTS);
		                $amount                 = Wo_Secure($amount);
		                $create_payment_log             = mysqli_query($sqlConnect, "INSERT INTO " . T_PAYMENT_TRANSACTIONS . " (`userid`, `kind`, `amount`, `notes`) VALUES ('" . $wo['user']['id'] . "', 'WALLET', '" . $amount . "', 'Coinbase')");
		                $_SESSION['replenished_amount'] = $amount;
		                if (!empty($_COOKIE['redirect_page'])) {
		                    $redirect_page = preg_replace('/on[^<>=]+=[^<>]*/m', '', $_COOKIE['redirect_page']);
		                    $redirect_page = preg_replace('/\((.*?)\)/m', '', $redirect_page);
		                    header("Location: " . $redirect_page);
		                } else {
		                    header("Location: " . Wo_SeoLink('index.php?link1=wallet'));
		                }
		                exit();
		            } else {
		                header("Location: " . Wo_SeoLink('index.php?link1=wallet'));
		                exit();
		            }
	            }
	        }
	    }
	    header("Location: " . Wo_SeoLink('index.php?link1=wallet'));
		exit();
	}
	if ($s == 'coinbase_cancel') {
	    if (!empty($_GET['user_id']) && is_numeric($_GET['user_id'])) {
	        $user_id = Wo_Secure($_GET['user_id']);
	        $user = $db->where('user_id',$user_id)->getOne(T_USERS);
	        if (!empty($user)) {
	            $db->where('user_id', $user->user_id)->where('method_name', 'coinbase')->delete(T_PENDING_PAYMENTS);
	        }
	    }
	    header("Location: " . Wo_SeoLink('index.php?link1=wallet'));
		exit();
	}
}