/** * */ public function batchInvoice() { $json = file_get_contents('php://input'); $json = json_decode($json); $invoices = array(); try { if (!property_exists($json, 'customers')) { throw new \Expressly\Exception\GenericException('Invalid JSON request'); } foreach ($json->customers as $customer) { if (!property_exists($customer, 'email')) { continue; } $user = ExpresslyHelper::get_user_by_email($customer->email); if (null !== $user) { $vmOrders = VmModel::getModel('orders')->getOrdersList($user->id); $invoice = new \Expressly\Entity\Invoice(); $invoice->setEmail($customer->email); foreach ($vmOrders as $vmOrder) { $vmOrderDetails = VmModel::getModel('orders')->getOrder($vmOrder->virtuemart_order_id); if ($vmOrderDetails['details']['BT']->created_on > $customer->from && $vmOrderDetails['details']['BT']->created_on < $customer->to) { // TODO: Need to review this values $total = $vmOrderDetails['details']['BT']->order_subtotal; $tax = $vmOrderDetails['details']['BT']->order_tax; // ==== $count = count($vmOrderDetails['items']); $order = new \Expressly\Entity\Order(); $order->setId($vmOrderDetails['details']['BT']->virtuemart_order_id)->setDate(new \DateTime($vmOrderDetails['details']['BT']->created_on))->setItemCount($count)->setTotal($total, $tax); if (!empty($vmOrderDetails['details']['BT']->coupon_code)) { $order->setCoupon($vmOrderDetails['details']['BT']->coupon_code); } $invoice->addOrder($order); } } $invoices[] = $invoice; } } $presenter = new \Expressly\Presenter\BatchInvoicePresenter($invoices); ExpresslyHelper::send_json($presenter->toArray()); } catch (\Expressly\Exception\GenericException $e) { $this->app['logger']->error($e); ExpresslyHelper::send_json(array()); } }