public static function listenRequest($src) { global $DB; $log = new log("pskb_listen/{$src}-" . SERVER . '-%d%m%Y.log', 'a', '%d.%m.%Y %H:%M:%S : '); ob_start(); var_dump(file_get_contents('php://input')); $out = ob_get_clean(); $log->writeln(iconv('utf8', 'cp1251', $out)); switch ($src) { case 'superCheck': $request = json_decode(file_get_contents('php://input')); if ($request) { $pskb = new self(); foreach ($request as $k => $pskb_req) { $pskb_req = new pskb_lc(json_encode($pskb_req)); $row = $pskb->getLCbyLCId($pskb_req->id); if ($pskb_req->history) { foreach ($pskb_req->history as $pskb_lc) { if (!$pskb_lc->id) { continue; } // Пытаемся определить uid если он пустой, подходит только для одноэтапной сделки // @todo с многоэтапными тоже что-то придумать надо if ($pskb_lc->uid == '' || $pskb_lc->uid == null) { $sql = 'SELECT s.id FROM pskb_lc pl INNER JOIN sbr s ON s.id = pl.sbr_id WHERE pl.lc_id = ? AND stages_cnt = 1'; // Запрос делаем что-бы точно проверить что этап в сделке один единственный $sbr_id = $DB->val($sql, $pskb_req->id); if ($sbr_id > 0) { $pskb_lc->uid = "{$sbr_id}-1"; } } if ($DB->val('SELECT id FROM pskb_lc_supercheck WHERE lc_id = ? AND uid = ? AND state = ? AND date = ? AND target = ?b', $pskb_req->id, "{$pskb_lc->uid}", $pskb_lc->state, $pskb_lc->date, $pskb_lc->target ? true : false) > 0) { continue; // В базе уже есть идентичная запись } $insert = array('lc_id' => $pskb_req->id, 'state' => $pskb_lc->state, 'date' => date('c', strtotime($pskb_lc->date)), 'uid' => "{$pskb_lc->uid}", 'target' => $pskb_lc->target ? true : false, 'sum' => $pskb_lc->sum, 'account' => $pskb_lc->account, 'ps' => $pskb_lc->ps); $DB->insert('pskb_lc_supercheck', $insert); continue; /* * @deprecated Пока все что ниже работать не должно просто пишем в базу историю которую возвращают */ $stg = sbr_meta::getStatePayout(explode('-', $pskb_lc->uid)); if ($pskb_lc->state == $stg['state']) { continue; } switch ($pskb_lc->state) { case self::PAYOUT_END: // отправлено по реквизитам // отправлено по реквизитам case self::PAYOUT_ERR: // зачислено в ВК // выплачено $sbr = new sbr($stg['emp_id']); $stage = $sbr->getStage($stg['stage_id']); $stage->getArbitrage(false, false); if ($stage->arbitrage && $stage->arbitrage['resolved']) { $emp_percent = abs(sbr::EMP - $stage->arbitrage['frl_percent']); $frl_percent = abs(sbr::FRL - $stage->arbitrage['frl_percent']); } else { $frl_percent = 1; } $frl_payout = true; $emp_payout = true; if ($frl_percent > 0) { $frl_payout = !$stage->payoutAgnt($stg['frl_id'], new self($stage->sbr->data['id']), $pskb_lc); } if ($emp_percent > 0) { $emp_payout = !$stage->payoutAgnt($stg['emp_id'], new self($stage->sbr->data['id']), $pskb_lc); } if (!$frl_payout && !$emp_payout) { continue; } break; } $lc = $pskb_req; if (!$lc->id || $lc->state == $row['state']) { continue; } switch ($lc->state) { case self::STATE_COVER: case self::STATE_END: if ($lc->state == self::STATE_END) { $up_data['ended'] = $pskb_lc->date; } break; case self::STATE_ERR: break; default: continue; } $up_data['state'] = $lc->state; $up_data['stateReason'] = $lc->stateReason; $pskb->upLC($up_data, $row['lc_id']); } } } } break; default: break; } return true; }