pagantis /
orders-api-client
| 1 | <?php |
||
| 2 | |||
| 3 | /** |
||
| 4 | * PLEASE FILL YOUR PUBLIC KEY AND PRIVATE KEY |
||
| 5 | */ |
||
| 6 | const PUBLIC_KEY = ''; //Set your public key |
||
| 7 | const PRIVATE_KEY = ''; //Set your private key |
||
| 8 | const ORDER_ID = ''; |
||
| 9 | |||
| 10 | try { |
||
| 11 | session_start(); |
||
| 12 | $method = (isset($_GET['action']) && $_GET['action']) ? ($_GET['action']) : 'createOrder'; |
||
| 13 | call_user_func($method); |
||
| 14 | } catch (Exception $e) { |
||
| 15 | echo $e->getMessage(); |
||
| 16 | exit; |
||
| 17 | } |
||
| 18 | |||
| 19 | /** |
||
| 20 | * Create order in Pagantis |
||
| 21 | * |
||
| 22 | * @throws Exception |
||
| 23 | */ |
||
| 24 | function createOrder() |
||
| 25 | { |
||
| 26 | // There are 3 objects which are mandatory: User object, ShoppingCart object and Configuration object. |
||
| 27 | //1. User Object |
||
| 28 | writeLog('Creating User object'); |
||
| 29 | writeLog('Adding the address of the user'); |
||
| 30 | $userAddress = array(); |
||
| 31 | $userAddress['zip_code'] = '28008'; |
||
| 32 | $userAddress['full_name'] = 'MarĂa Sanchez Escudero'; |
||
| 33 | $userAddress['country_code'] = 'ES'; |
||
| 34 | $userAddress['city'] = 'Madrid'; |
||
| 35 | $userAddress['address'] = 'Paseo de la Castellana, 95'; |
||
| 36 | $userAddress['dni'] = '59661738Z'; |
||
| 37 | $userAddress['fix_phone'] = '911231234'; |
||
| 38 | $userAddress['mobile_phone'] = '600123123'; |
||
| 39 | $userAddress['national_id'] = '59661738Z'; |
||
| 40 | |||
| 41 | $orderBillingAddress = $userAddress; |
||
| 42 | |||
| 43 | $orderShippingAddress = array(); |
||
| 44 | $orderShippingAddress['zip_code'] = '08029'; |
||
| 45 | $orderShippingAddress['full_name'] = 'Alberto Escudero Sanchez'; |
||
| 46 | $orderShippingAddress['country_code'] = 'ES'; |
||
| 47 | $orderShippingAddress['city'] = 'Barcelona'; |
||
| 48 | $orderShippingAddress['address'] = 'Avenida de la diagonal 525'; |
||
| 49 | $orderShippingAddress['dni'] = '77695544A'; |
||
| 50 | $orderShippingAddress['fix_phone'] = '931232345'; |
||
| 51 | $orderShippingAddress['mobile_phone'] = '600123124'; |
||
| 52 | $orderShippingAddress['national_id'] = '77695544A'; |
||
| 53 | |||
| 54 | writeLog('Adding the purchases of the customer, if there are.'); |
||
| 55 | $orderHistory = array ( |
||
| 56 | 0 => array ( |
||
| 57 | 'date' => '2020-01-31', |
||
| 58 | 'amount' => 989, |
||
| 59 | ), |
||
| 60 | 1 => array ( |
||
| 61 | 'date' => '2020-01-31', |
||
| 62 | 'amount' => 898, |
||
| 63 | ) |
||
| 64 | ); |
||
| 65 | |||
| 66 | writeLog('Adding the information of the user'); |
||
| 67 | $orderUser = array(); |
||
| 68 | $orderUser['full_name'] = 'MarĂa Sanchez Escudero'; |
||
| 69 | $orderUser['email'] = '[email protected]'; |
||
| 70 | $orderUser['date_of_birth'] = '1985-12-30'; |
||
| 71 | $orderUser['address'] = ''; |
||
| 72 | $orderUser['dni'] = '59661738Z'; |
||
| 73 | $orderUser['national_id'] = '59661738Z'; |
||
| 74 | $orderUser['fix_phone'] = '911231234'; |
||
| 75 | $orderUser['mobile_phone'] = '600123123'; |
||
| 76 | $orderUser['address'] = $userAddress; |
||
| 77 | $orderUser['billing_address'] = $orderBillingAddress; |
||
| 78 | $orderUser['shipping_address'] = $orderShippingAddress; |
||
| 79 | $orderUser['order_history'] = $orderHistory; |
||
| 80 | writeLog('Created User object'); |
||
| 81 | |||
| 82 | //2. ShoppingCart Object |
||
| 83 | writeLog('Creating ShoppingCart object'); |
||
| 84 | writeLog('Adding cart products. Minimum 1 required'); |
||
| 85 | |||
| 86 | $product = array(); |
||
| 87 | $product['amount'] = '59999'; |
||
| 88 | $product['quantity'] = 1; |
||
| 89 | $product['description'] = 'TV LG UltraPlana'; |
||
| 90 | |||
| 91 | $details = array(); |
||
| 92 | $details['shipping_cost'] = 0; |
||
| 93 | $details['products'][0] = $product; |
||
| 94 | |||
| 95 | $orderShoppingCart = array(); |
||
| 96 | $orderShoppingCart['details'] = $details; |
||
| 97 | $orderShoppingCart['order_reference'] = ORDER_ID; |
||
| 98 | $orderShoppingCart['promoted_amount'] = 0; // This amount means that the merchant will asume the interests. |
||
| 99 | $orderShoppingCart['total_amount'] = 59999; |
||
| 100 | writeLog('Created OrderShoppingCart object'); |
||
| 101 | |||
| 102 | //3. Configuration Object |
||
| 103 | writeLog('Creating Configuration object'); |
||
| 104 | writeLog('Adding urls to redirect the user according each case'); |
||
| 105 | $confirmUrl = "http://$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]?action=confirmOrder"; |
||
| 106 | $errorUrl = "http://$_SERVER[HTTP_HOST]$_SERVER[REQUEST_URI]?action=cancelOrder"; |
||
| 107 | |||
| 108 | $orderConfigurationUrls = array(); |
||
| 109 | $orderConfigurationUrls['cancel'] = $errorUrl; |
||
| 110 | $orderConfigurationUrls['ko'] = $errorUrl; |
||
| 111 | $orderConfigurationUrls['authorized_notification_callback'] = $confirmUrl; |
||
| 112 | $orderConfigurationUrls['rejected_notification_callback'] = $confirmUrl; |
||
| 113 | $orderConfigurationUrls['ok'] = $confirmUrl; |
||
| 114 | |||
| 115 | writeLog('Adding channel info'); |
||
| 116 | $orderChannel = array(); |
||
| 117 | $orderChannel['assisted_sale'] = false; |
||
| 118 | $orderChannel['type'] = 'ONLINE'; |
||
| 119 | |||
| 120 | $orderConfiguration = array(); |
||
| 121 | $orderConfiguration['channel'] = $orderChannel; |
||
| 122 | $orderConfiguration['urls'] = $orderConfigurationUrls; |
||
| 123 | writeLog('Created Configuration object'); |
||
| 124 | |||
| 125 | $order = array(); |
||
| 126 | $order['configuration'] = $orderConfiguration; |
||
| 127 | $order['shopping_cart'] = $orderShoppingCart; |
||
| 128 | $order['user'] = $orderUser; |
||
| 129 | |||
| 130 | writeLog('Preparing connection'); |
||
| 131 | if (PUBLIC_KEY=='' || PRIVATE_KEY == '') { |
||
|
0 ignored issues
–
show
introduced
by
Loading history...
|
|||
| 132 | throw new \Exception('You need set the public and private key'); |
||
| 133 | } |
||
| 134 | |||
| 135 | writeLog('Creating Pagantis order'); |
||
| 136 | $params_json = json_encode($order); |
||
| 137 | |||
| 138 | $cliente = curl_init(); |
||
| 139 | curl_setopt($cliente, CURLOPT_URL, "https://api.pagamastarde.com/v2/orders/"); |
||
| 140 | curl_setopt($cliente, CURLOPT_POST, 1); |
||
| 141 | curl_setopt($cliente, CURLOPT_SSL_VERIFYPEER, false); |
||
| 142 | curl_setopt($cliente, CURLOPT_POSTFIELDS, $params_json); |
||
| 143 | curl_setopt($cliente, CURLOPT_RETURNTRANSFER, true); |
||
| 144 | curl_setopt($cliente, CURLOPT_HTTPHEADER, array( |
||
| 145 | "Content-Type:application/json", |
||
| 146 | "Authorization: Bearer ".PRIVATE_KEY |
||
| 147 | )); |
||
| 148 | |||
| 149 | $raw_response = curl_exec($cliente); |
||
| 150 | $order = json_decode($raw_response); |
||
| 151 | if (is_object($order)) { |
||
| 152 | //If the order is correct and created then we have the redirection URL here: |
||
| 153 | $url = $order->action_urls->form; |
||
| 154 | $_SESSION['order_id'] = $order->id; |
||
| 155 | writeLog(json_encode( |
||
| 156 | $order, |
||
| 157 | JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES | JSON_PRETTY_PRINT |
||
| 158 | )); |
||
| 159 | } else { |
||
| 160 | throw new \Exception('Order not created'); |
||
| 161 | } |
||
| 162 | |||
| 163 | // You can use our test credit cards to fill the Pagantis form |
||
| 164 | writeLog("Redirecting to Pagantis form => $url"); |
||
| 165 | header('Location:'. $url); |
||
| 166 | } |
||
| 167 | |||
| 168 | /** |
||
| 169 | * Confirm order in Pagantis |
||
| 170 | * |
||
| 171 | * @throws Exception |
||
| 172 | */ |
||
| 173 | function confirmOrder() |
||
| 174 | { |
||
| 175 | /* Once the user comes back to the OK url or there is a notification upon callback url you will have to confirm |
||
| 176 | * the reception of the order. If not it will expire and will never be paid. |
||
| 177 | * |
||
| 178 | * Add this parameters in your database when you create a order and map it to your own order. Or search orders by |
||
| 179 | * your own order id. Both options are possible. |
||
| 180 | */ |
||
| 181 | |||
| 182 | writeLog('Getting order information'); |
||
| 183 | |||
| 184 | writeLog('Preparing connection'); |
||
| 185 | if (PUBLIC_KEY=='' || PRIVATE_KEY == '') { |
||
|
0 ignored issues
–
show
|
|||
| 186 | throw new \Exception('You need set the public and private key'); |
||
| 187 | } |
||
| 188 | |||
| 189 | $cliente = curl_init(); |
||
| 190 | curl_setopt($cliente, CURLOPT_URL, "https://api.pagamastarde.com/v2/orders/".$_SESSION['order_id']."/"); |
||
| 191 | curl_setopt($cliente, CURLOPT_RETURNTRANSFER, true); |
||
| 192 | curl_setopt($cliente, CURLOPT_HTTPHEADER, array( |
||
| 193 | "Content-Type:application/json", |
||
| 194 | "Authorization: Bearer ".PRIVATE_KEY |
||
| 195 | )); |
||
| 196 | |||
| 197 | $raw_response = curl_exec($cliente); |
||
| 198 | $order = json_decode($raw_response); |
||
| 199 | if (is_object($order) && $order->status == "AUTHORIZED") { |
||
| 200 | //If the order exists, and the status is authorized, means you can mark the order as paid. |
||
| 201 | |||
| 202 | //DO WHATEVER YOU NEED TO DO TO MARK THE ORDER AS PAID IN YOUR OWN SYSTEM. |
||
| 203 | writeLog('Confirming order'); |
||
| 204 | |||
| 205 | $cliente = curl_init(); |
||
| 206 | curl_setopt($cliente, CURLOPT_URL, "https://api.pagamastarde.com/v2/orders/".$order->id."/confirm"); |
||
| 207 | curl_setopt($cliente, CURLOPT_CUSTOMREQUEST, "PUT"); |
||
| 208 | curl_setopt($cliente, CURLOPT_RETURNTRANSFER, true); |
||
| 209 | curl_setopt($cliente, CURLOPT_HTTPHEADER, array( |
||
| 210 | "Content-Type:application/json", |
||
| 211 | "Authorization: Bearer ".PRIVATE_KEY |
||
| 212 | )); |
||
| 213 | |||
| 214 | $raw_response = curl_exec($cliente); |
||
| 215 | $order = json_decode($raw_response); |
||
| 216 | writeLog("Order confirmed"); |
||
| 217 | writeLog(json_encode( |
||
| 218 | $order, |
||
| 219 | JSON_UNESCAPED_UNICODE | JSON_UNESCAPED_SLASHES | JSON_PRETTY_PRINT |
||
| 220 | )); |
||
| 221 | $message = "The order {$_SESSION['order_id']} has been confirmed successfully"; |
||
| 222 | } else { |
||
| 223 | $message = "The order {$_SESSION['order_id']} can't be confirmed"; |
||
| 224 | } |
||
| 225 | |||
| 226 | /* The order has been marked as paid and confirmed in Pagantis so you will send the product to your customer and |
||
| 227 | * Pagantis will pay you in the next 24h. |
||
| 228 | */ |
||
| 229 | |||
| 230 | echo $message; |
||
| 231 | exit; |
||
|
0 ignored issues
–
show
|
|||
| 232 | } |
||
| 233 | |||
| 234 | /** |
||
| 235 | * Action after redirect to cancelUrl |
||
| 236 | */ |
||
| 237 | function cancelOrder() |
||
| 238 | { |
||
| 239 | $message = "The order {$_SESSION['order_id']} can't be created"; |
||
| 240 | |||
| 241 | echo $message; |
||
| 242 | exit; |
||
|
0 ignored issues
–
show
|
|||
| 243 | } |
||
| 244 | |||
| 245 | /** |
||
| 246 | * UTILS |
||
| 247 | */ |
||
| 248 | |||
| 249 | /** |
||
| 250 | * Write log file |
||
| 251 | * |
||
| 252 | * @param $message |
||
| 253 | */ |
||
| 254 | function writeLog($message) |
||
| 255 | { |
||
| 256 | file_put_contents('pagantis.log', "$message.\n", FILE_APPEND); |
||
| 257 | } |
||
| 258 |