getView()->setPath('coupon'); } // public function getMemberService(): MemberService { if ($this->_memberService === null) { $this->_memberService = new MemberService(); } return $this->_memberService; } //IdcCouponUseMK.jsp -> domain_coupon_use.php //CLI 접속방법 : php index.php site/client/counpon/index //WEB 접속방법 : http://localhost/site/client/coupon/index public function index(array $params) { //사용자정보 if (!array_key_exists('client_code', $params)) { throw new \Exception("client_code 값이 정의되지 않았습니다."); } $client_code = $params['client_code']; $client = $this->getClientService()->getEntityByCode($client_code); if (!$client) { throw new \Exception("[$client_code]에 해당하는 사용자정보가 존재하지 않습니다."); } $this->client = $client; //전체 관리자정보(등록자) if (!array_key_exists('mkid', $params)) { throw new \Exception("mkid 값이 정의되지 않았습니다."); } $member_code = $params['mkid']; $member = $this->getMemberService()->getEntityByCode($member_code); if (!$member) { throw new \Exception("[$member_code]에 해당하는 관리자정보가 존재하지 않습니다."); } $this->member = $member; //쿠폰내역 $this->getServiceService()->getModel()->where("client_code", $client_code); $this->getServiceService()->getModel()->whereNotIn("service_line", ['vpn', 'test', 'soloLine', 'substitution']); //Query문 Rest여부 -> 같은조건에 Count 받고, 결과값을 받고 싶을때는 continue() $this->getServiceService()->getModel()->setContinue(true); $this->total = $this->getServiceService()->getCount(); //limit, offset 설정 $this->curPage = intval($params['curPage'] ?? $this->request->get('curPage') ?? 1); $this->perPage = intval($params['perPage'] ?? $this->request->get('perPage') ?? VIEW_LIST_PERPAGE); $this->getServiceService()->getModel()->limit($this->perPage); $this->getServiceService()->getModel()->offset(($this->curPage - 1) * $this->perPage); $this->services = $this->getServiceService()->getEntities(); $this->pagination = new Pagination($this->total, (int)$this->curPage, (int)$this->perPage); $total_coupon = 0; foreach ($this->services as $service) { $total_coupon += $service->getCoupon(); } $this->total_coupon = $total_coupon; return $this->render(__FUNCTION__); } //IdcCouponBuyMK.jsp -> domain_coupon_buy.php //CLI 접속방법 : php index.php site/client/counpon/insert_form //WEB 접속방법 : http://localhost/site/client/coupon/insert_form public function insert_form(array $params) { if (!array_key_exists('service_code', $params)) { throw new \Exception("service_code 값이 정의되지 않았습니다."); } $service_code = $params['service_code']; $service = $this->getServiceService()->getEntityByCode($service_code); if (!$service) { throw new \Exception("[$service_code]에 해당하는 서비스정보가 존재하지 않습니다."); } $this->service = $service; //사용자정보 $client = $this->getClientService()->getEntityByCode($service->getClientCode()); if (!$client) { throw new \Exception("[{$service->getClientCode()}]에 해당하는 사용자정보가 존재하지 않습니다."); } $this->client = $client; //전체 관리자정보(등록자) if (!array_key_exists('mkid', $params)) { throw new \Exception("mkid 값이 정의되지 않았습니다."); } $member_code = $params['mkid']; $member = $this->getMemberService()->getEntityByCode($member_code); if (!$member) { throw new \Exception("[$member_code]에 해당하는 관리자정보가 존재하지 않습니다."); } $this->member = $member; //쿠폰내역 $this->getServiceService()->getModel()->where("client_code", $client_code); $this->getServiceService()->getModel()->whereNotIn("service_line", ['vpn', 'test', 'soloLine', 'substitution']); //Query문 Rest여부 -> 같은조건에 Count 받고, 결과값을 받고 싶을때는 continue() $this->getServiceService()->getModel()->setContinue(true); $this->total = $this->getServiceService()->getCount(); //limit, offset 설정 $this->curPage = intval($params['curPage'] ?? $this->request->get('curPage') ?? 1); $this->perPage = intval($params['perPage'] ?? $this->request->get('perPage') ?? VIEW_LIST_PERPAGE); $this->getServiceService()->getModel()->limit($this->perPage); $this->getServiceService()->getModel()->offset(($this->curPage - 1) * $this->perPage); $this->services = $this->getServiceService()->getEntities(); $this->pagination = new Pagination($this->total, (int)$this->curPage, (int)$this->perPage); $total_coupon = 0; foreach ($this->services as $service) { $total_coupon += $service->getCoupon(); } $this->total_coupon = $total_coupon; return $this->render(__FUNCTION__); } //IdcCouponBuyMK.jsp -> domain_coupon_buy.php //CLI 접속방법 : php index.php site/client/counpon/insert_form //WEB 접속방법 : http://localhost/site/client/coupon/insert_form public function insert(array $params) { if (!array_key_exists('service_code', $params)) { throw new \Exception("service_code 값이 정의되지 않았습니다."); } $service_code = $params['service_code']; $service = $this->getServiceService()->getEntityByCode($service_code); if (!$service) { throw new \Exception("[$service_code]에 해당하는 서비스정보가 존재하지 않습니다."); } $this->service = $service; //사용자정보 $client = $this->getClientService()->getEntityByCode($service->getClientCode()); if (!$client) { throw new \Exception("[{$service->getClientCode()}]에 해당하는 사용자정보가 존재하지 않습니다."); } $this->client = $client; //전체 관리자정보(등록자) if (!array_key_exists('mkid', $params)) { throw new \Exception("mkid 값이 정의되지 않았습니다."); } $member_code = $params['mkid']; $member = $this->getMemberService()->getEntityByCode($member_code); if (!$member) { throw new \Exception("[$member_code]에 해당하는 관리자정보가 존재하지 않습니다."); } $this->member = $member; try { $this->getServiceService()->getModel()->setTransaction(true); //서비스 수정 $this->getServiceService()->getModel()->where("client_code", $client_code); $this->getServiceService()->update(); // $coupon_query = "update servicedb set coupon=(coupon-$_GET[onetime_sub]), coupon_use=(coupon_use+$_GET[onetime_sub]) where service_code='$_GET[service_code]'"; // @mysql_query($coupon_query, $db_connect) or die($db_i_error); // $onetime_query = "INSERT INTO `onetimedb` (`client_code`, `service_code`, `onetime_case`, `onetime_sub`, `onetime_amount`, `onetime_payment`, `onetime_nonpayment`, `onetime_accountStatus`, `onetime_request_date`, `onetime_payment_date`, `onetime_note`, `onetime_handle_date`, `onetime_manager`, `client_name`, `server_code`) VALUES ('$_GET[client_code]', '$_GET[service_code]', 'domain', '$_GET[onetime_sub]', '0', '0', '0', 'complete', '$_GET[onetime_request_date]', '$_GET[onetime_request_date]', '도메인 쿠폰사용 / $_GET[onetime_note]', '$_GET[onetime_request_date]', '$_GET[mkid]', '$member[name]', '$service[server_code]')"; // @mysql_query($onetime_query, $db_connect) or die($db_i_error); // $history_query = "INSERT INTO `historydb` (`service_code`, `server_code`, `behavior_case`, `behavior`, `behavior_date`, `note`, `client_name`) VALUES ('$_GET[service_code]', '$service[server_code]', '도메인 쿠폰 구매 / $_GET[onetime_sub] 개', '도메인 쿠폰 구매', '$_GET[onetime_request_date]', '$member[name]', '$service[Client_Name]')"; // @mysql_query($history_query, $db_connect) or die($db_i_error); $this->getServiceService()->getModel()->commit(); return $this->render(__FUNCTION__); } catch (\PDOException $e) { $this->getServiceService()->getModel()->rollback(); echo $e->getMessage(); return $this->redirect->back()->withInput()->with('error', ['message' => '쿠폰 사용에 실패하였습니다.']); } } } //Class