needlogin = true; $me = new User(); $me->loadMe(); $this->me = $me; $this->layout()->set("me", $me); if (!$me->is(["Admin"])) { $this->redirect("Dashboard"); } } protected function indexAction() { $cpecounter = 0; $r = $this->request; $page = $r->s; $this->layout()->setTemplate("Cpeprovisioning/Index"); $cpeproducts = []; $this->layout->set("filter", $this->request->filter); $filter = $this->getPreparedFilter($this->request->filter); // pagination defaults $pagination = []; $pagination['start'] = $page; $pagination['count'] = 25; $pagination['maxItems'] = 0; $order_filter = $filter; //var_dump($filter);exit; /* * Get orderproducts in need of sending a CPE */ //var_dump($order_filter);exit; $orders = OrderModel::search($order_filter); $orderproductsprefetch = OrderProductModel::precache(); foreach ($orders as $order) { if ($order_filter["hide_delayed_finish"] && $order->finish_after) { // show at most 4 weeks before finish_after date //$after_ts = Layout::dateToInt($order->finish_after); if ($order->finish_after > date("U") + (31 * 86400)) { $this->log->debug("Before 4 weeks before finish_after oid " . $order->id); continue; } } if (is_array($orderproductsprefetch['terminations'][$order->id]) && count($orderproductsprefetch['terminations'][$order->id])) { if (!$order->cpeprovisioning_enabled && $orderproductsprefetch['terminations'][$order->id][0]['statuscode'] < TT_TERMSTATUS_CONNECTED) { continue; } } foreach ($orderproductsprefetch[$order->id] as $orderproduct) { if ($orderproduct['routerconfig_finished'] == 1) { if (!$filter['routerconfig_finished']) continue; } else { if ($filter['routerconfig_finished']) continue; } $productattributes = $orderproduct['attributes']; if (is_array($productattributes) && count($productattributes)) { // filter out products without bras_type if (array_key_exists("bras_type", $productattributes) && $productattributes) { $pagination['maxItems']++; if ($pagination['maxItems'] >= $pagination['start']+1 && $pagination['maxItems'] <= $pagination['start'] + $pagination['count']) { $cpeproducts[] = OrderProductModel::getOne($orderproduct['id']); } } else { $this->log->debug("no bras_type oid " . $order->id); continue; } } else { // ignore products without attributes $this->log->debug("no attributes oid " . $order->id); continue; } } } $this->layout()->set("pagination", $pagination); $this->layout()->set("products", $cpeproducts); } private function getPreparedFilter($filter) { $new_filter = []; if (!is_array($filter)) $filter = []; if (array_key_exists("hide_delayed_finish", $filter)) { if ($filter["hide_delayed_finish"] == "1") { $new_filter["hide_delayed_finish"] = true; } else { $new_filter["hide_delayed_finish"] = false; } unset($filter["hide_delayed_finish"]); } else { $new_filter["hide_delayed_finish"] = true; } if (array_key_exists("routerconfig_finished", $filter)) { if ($filter["routerconfig_finished"] == "1") { $new_filter["routerconfig_finished"] = true; $new_filter["hide_delayed_finish"] = false; } else { $new_filter["routerconfig_finished"] = false; $order_filter["finish_date"] = null; } unset($filter["routerconfig_finished"]); } else { $new_filter["routerconfig_finished"] = false; $order_filter["finish_date"] = null; } $new_filter['upgrade'] = 0; foreach ($filter as $name => $value) { $new_filter[$name] = $value; } //var_dump($new_filter);exit; return $new_filter; } protected function saveAction() { $r = $this->request; $id = $r->id; //var_dump($r);exit; if (is_numeric($id) && $id > 0) { $mode = "edit"; $cpeprovisioning = new Cpeprovisioning($id); if (!$cpeprovisioning->id) { $this->layout()->setFlash("Eintrag nicht gefunden", "error"); $this->redirect("Cpeprovisioning"); } } else { $mode = "add"; } $order_id = $r->order_id; $termination_id = $r->termination_id; if (!(is_numeric($termination_id) && $termination_id > 0) && !(is_numeric($order_id) && $order_id > 0)) { $this->layout()->setFlash("Anschluss oder Bestellung nicht gefunden", "error"); $this->redirect("Cpeprovisioning"); } $orderproduct = OrderProductModel::getFirst(["order_id" => $order_id, "termination_id" => $termination_id]); if (!$orderproduct) { $this->layout()->setFlash("Anschluss gehört nicht zur Bestellung", "error"); $this->redirect("Cpeprovisioning"); } $prov_data = []; $prov_data["termination_id"] = ($r->termination_id) ? $r->termination_id : null; $prov_data["order_id"] = $r->order_id; $prov_data["orderproduct_id"] = $r->orderproduct_id; $prov_data["routerconfig_finished"] = ($r->routerconfig_finished) ? 1 : 0; $prov_data["routertype"] = $r->routertype; $prov_data["shipping"] = ($r->shipping) ? 1 : 0; $prov_data["wifi_ssid"] = $r->wifi_ssid; $prov_data["wifi_pass"] = $r->wifi_pass; $prov_data["mac"] = $r->mac; $prov_data["vlan_public"] = (strlen($r->vlan_public)) ? $r->vlan_public : null; $prov_data["vlan_nat"] = (strlen($r->vlan_nat)) ? $r->vlan_nat : null; $prov_data["vlan_ipv6"] = (strlen($r->vlan_ipv6)) ? $r->vlan_ipv6 : null; $prov_data["ship_weight"] = (strlen($r->ship_weight)) ? $r->ship_weight : null; $prov_data["ship_length"] = (strlen($r->ship_length)) ? $r->ship_length : null; $prov_data["ship_width"] = (strlen($r->ship_width)) ? $r->ship_width : null; $prov_data["ship_height"] = (strlen($r->ship_height)) ? $r->ship_height : null; $prov_data["note"] = $r->note; $prov_data["edit_by"] = $this->me->id; if ($mode == "add") { $prov_data["create_by"] = $this->me->id; $cpeprovisioning = CpeprovisioningModel::create($prov_data); } else { $cpeprovisioning->update($prov_data); } //var_dump($prov_data);exit; $new_id = $cpeprovisioning->save(); if (!$new_id) { $this->layout()->setFlash("Fehler beim Speichern", "error"); $this->redirect("Cpeprovisioning"); } // saved successfully, if routerconfig_finished make Journal entry in Order if ($cpeprovisioning->routerconfig_finished) { $order_product = new OrderProduct($r->orderproduct_id); if ($cpeprovisioning->shipping) { $text = "CPE zu Produkt \"" . $order_product->product->name . "\" zum Versand vorbereitet.\n\n"; } else { $text = "CPE zu Produkt \"" . $order_product->product->name . "\" vorbereitet für Techniker zur Vorortinstallation.\n\n"; } $text .= "Router: " . $cpeprovisioning->routertype . "\n"; $text .= "Zugangstyp: " . $order_product->product->attributes['bras_type']->value . "\n"; if ($cpeprovisioning->vlan_public) { $text .= "Vlan Public: " . $cpeprovisioning->vlan_public . "\n"; } if ($cpeprovisioning->vlan_nat) { $text .= "Vlan NAT: " . $cpeprovisioning->vlan_nat . "\n"; } if ($cpeprovisioning->vlan_ipv6) { $text .= "Vlan IPv6: " . $cpeprovisioning->vlan_ipv6 . "\n"; } $journal = new OrderJournal(); $journal->order_id = $order_id; $journal->text = $text; $journal->create_by = $this->me->id; $journal->edit_by = $this->me->id; $journal_id = $journal->save(); if (!$journal_id) { $this->layout()->setFlash("Konnte nicht ins Bestelljournal schreiben!", "warning"); } else { $cpeprovisioning->order_journal_id = $journal_id; $cpeprovisioning->save(); } } // save ONT sn if ($r->ont_sn) { $termination = new Termination($termination_id); $orig_sn = $termination->getWorkflowvalue("ont_sn", "string"); if ($orig_sn === null) { $sn_item = WorkflowitemModel::getFirst(["name" => "ont_sn", "object_type" => "termination"]); //var_dump($sn_item);exit; //var_dump(mfValuecache::singleton()->get("wfItemvalue-item-".$sn_item->id."-object-".$termination_id));exit; if (!$sn_item->id) { $this->log->error("ont_sn workflow item not found"); } else { $sn_item->setObjectId($termination_id); $termination->workflowitems["ont_sn"] = $sn_item; //$sn_item->value->setValue($r->ont_sn); //$sn_item->value->save(); } } if ($r->ont_sn != $orig_sn) { $termination->workflowitems["ont_sn"]->value->setValue($r->ont_sn); $termination->workflowitems["ont_sn"]->value->save(); } } $query = []; if (is_numeric($this->request->s) && $this->request->s > 0) { $query["s"] = $this->request->s; } if (is_array($this->request->filter)) { $query["filter"] = $this->request->filter; } $qs = http_build_query($query); $this->layout()->setFlash("Eintrag erfolgreich gespeichert.", "success"); $this->redirect("Cpeprovisioning", "Index", $qs); } }