/* This macro will be parsed as PHP code (see http://www.php.net) The calculateshipping function is called every time a shipping calculation request is made by Shopify. The function must return an array of available shipping options, otherwise no shipping options will be returned to your customers. */ function calculateshipping($DATA) { /* do not edit above this line */ $_RATES = array(); //calculate total weight $w = 0; foreach ($DATA['items'] as $i) { $w += $i['quantity']*$i['grams']/1000; } $w = $w*2.20462; //in pounds $isresidential = true; if ($DATA['destination']['company_name'] !== null && $DATA['destination']['company_name'] != '') $isresidential = false; $_UPS_CLIENT_ID = "YOUR_CLIENT_ID"; $_UPS_CLIENT_SECRET = "YOUR_CLIENT_SECRET"; $_UPS_ACCOUNT = "YOUR_ACCOUNT_NUMBER"; //set to null if you DON'T want to use negotiated rates $packages = array( array('weight'=>$w, 'length'=>18, 'width'=>12, 'height'=>4), ); $rateClassification = '00'; //00=negotiated, 01=daily, 04=retail, 53=standard list rate $ups = new UPSRESTAPI($_UPS_CLIENT_ID,$_UPS_CLIENT_SECRET,$_UPS_ACCOUNT); $ups->setOrigin($DATA['origin']['city'],$DATA['origin']['province'],$DATA['origin']['postal_code'],$DATA['origin']['country']); $ups->setDestination($DATA['destination']['city'],$DATA['destination']['province'],$DATA['destination']['postal_code'],$DATA['destination']['country'],$isresidential,$DATA['destination']['address1']); $r = $ups->getRate($packages,'IMPERIAL',$e,$rateClassification); if ($r) { foreach ($r as $_r) { $_RATES[] = array( "service_name" => $_r['name'], "service_code" => $_r['code'], "total_price" => $_r['amount']*100, //in cents "currency" => "USD", ); } } return $_RATES; /* do not edit below this line */ }