getLastParam($server_home["home_id"]), True);
$server_home["max_players"] = isset($cli_param_data['PLAYERS']) ? $cli_param_data['PLAYERS'] : $last_param['players'];
$server_home["webhost_ip"] = $_SERVER['SERVER_ADDR'];
$server_home["incremental"] = $db->incrementalNumByHomeId( $server_home["home_id"], $server_home["mod_cfg_id"], $server_home["remote_server_id"] );
$server_home["map"] = clean_server_param_value(isset($cli_param_data['MAP']) ? $cli_param_data['MAP'] : $last_param['map'], $server_xml->cli_allow_chars);
$isWin = preg_match('/CYGWIN/', $remote->what_os());
if( isset($server_xml->gameq_query_name) )
{
$server_home["query_port"] = get_query_port($server_xml, $server_home['port']);
}
elseif( isset($server_xml->lgsl_query_name) )
{
$get_q_and_s = lgsl_port_conversion((string)$server_xml->lgsl_query_name, $server_home['port'], "", "");
$server_home["query_port"] = $get_q_and_s['1'];
}
$replace_texts = $server_xml->replace_texts->text;
$replace_id = 0;
if($replace_texts)
{
foreach ($replace_texts as $text => $array )
{
$param = (string)$array['key'];
if ($param == 'home_path' && $isWin) {
$info_param = rtrim($remote->exec('cygpath -w /')) . $server_home[$param];
} else {
$info_param = $server_home[$param];
}
$replacements[$replace_id]['info_param'] = $info_param;
foreach ($array as $key => $value )
{
if ($key == "default")
$replacements[$replace_id]['default'] = (string)$value;
if ($key == "var")
$replacements[$replace_id]['var'] = (string)$value;
if ($key == "filepath")
$replacements[$replace_id]['filepath'] = (string)$value;
if ($key == "options")
$replacements[$replace_id]['options'] = (string)$value;
if ($key == "occurrence")
$replacements[$replace_id]['occurrence'] = (string)$value;
}
$replace_id++;
}
}
$custom_fields = json_decode($db->getCustomFields($server_home["home_id"]), True);
$fields = $server_xml->custom_fields->field;
if($fields)
{
foreach ($fields as $text => $array )
{
foreach ($array as $key => $value )
{
if ($key == "default_value")
{
if (array_key_exists((string)$array['key'], $custom_fields))
$replacements[$replace_id]['info_param'] = strip_real_escape_string((string)$custom_fields[(string)$array['key']]);
else
$replacements[$replace_id]['info_param'] = (string)$value;
}
if ($key == "default")
$replacements[$replace_id]['default'] = (string)$value;
if ($key == "var")
$replacements[$replace_id]['var'] = (string)$value;
if ($key == "filepath")
$replacements[$replace_id]['filepath'] = (string)$value;
if ($key == "options")
$replacements[$replace_id]['options'] = (string)$value;
if ($key == "occurrence")
$replacements[$replace_id]['occurrence'] = (string)$value;
}
$replace_id++;
}
}
foreach($replacements as $key => $replacement)
{
$filepath = $replacement['filepath'];
$file_replacements[$filepath][$key] = $replacement;
}
/* echo "
";
print_r($file_replacements);
echo ""; */
require_once('includes/lib_remote.php');
$remote = new OGPRemoteLibrary($server_home['agent_ip'], $server_home['agent_port'], $server_home['encryption_key'], $server_home['timeout']);
foreach($file_replacements as $filepath => $replacements)
{
$file_info = $remote->remote_readfile($server_home['home_path']."/$filepath",$file_content);
if ( $file_info === 0 )
{
$remote->exec( "touch ".$server_home['home_path']."/$filepath" );
$file_info = "";
}
foreach($replacements as $replacement)
{
$info_param = $replacement['info_param'];
$default = $replacement['default'];
$var = $replacement['var'];
$options = $replacement['options'];
$occurrence = !isset($replacement['occurrence']) || empty($replacement['occurrence']) || !is_numeric($replacement['occurrence']) || $replacement['occurrence'] < 1 ? false : $replacement['occurrence'];
if( !in_array( $options, array("tags","tagValueByName","sc","sqc") ) )
{
$match_found = preg_match("/$default/m", $file_content);
if($var == "")
{
$preg_info_param = preg_quote($info_param, "/");
if ($options == "s")//separated
$match_info_param = preg_match("/^\s$preg_info_param/m", $file_content);
elseif ($options == "q")//quoted
$match_info_param = preg_match("/^\"$preg_info_param\"/m", $file_content);
elseif ($options == "sq")//separated & quoted
$match_info_param = preg_match("/^\s\"$preg_info_param\"/m", $file_content);
elseif ($options == "")
$match_info_param = preg_match("/^$preg_info_param/m", $file_content);
if($match_info_param == 1)
continue;
}
}
else
$match_found = 1;
if(!$match_found or $match_found === 0)
{
if ($options == "s")//separated
$file_content .= "\n$var $info_param";
elseif ($options == "q")//quoted
$file_content .= "\n$var\"" . str_replace('"', '\"', $info_param) . "\"";
elseif ($options == "sq")//separated & quoted
$file_content .= "\n$var \"" . str_replace('"', '\"', $info_param) . "\"";
elseif ($options == "key-regex")
{
$var = str_replace("%key%", $info_param, $var);
$file_content .= "\n$var";
}
elseif ($options == "")
$file_content .= "\n$var$info_param";
}
else
{
if ($options == "tags"){
if($occurrence !== false){
$file_content = preg_replace_nth("/(<$default$var>)(.*)(<\/$default>)/m", '${1}'.$info_param.'${3}', $file_content, $occurrence);
}else{
$file_content = preg_replace("/(<$default$var>)(.*)(<\/$default>)/m", '${1}'.$info_param.'${3}', $file_content, 1);
}
}
elseif ($options == "tagValueByName"){
if($occurrence !== false){
$file_content = preg_replace_nth('/('.$default.'.*name="'.$var.'".*value=)(".*")/m', '${1}"' . str_replace('"', '\"', $info_param) . '"', $file_content, $occurrence);
}else{
$file_content = preg_replace('/('.$default.'.*name="'.$var.'".*value=)(".*")/m', '${1}"' . str_replace('"', '\"', $info_param) . '"', $file_content, 1);
}
}
elseif($options == "s"){//separated
if($occurrence !== false){
$file_content = preg_replace_nth("/$default/m", "$var $info_param", $file_content, $occurrence);
}else{
$file_content = preg_replace("/$default/m", "$var $info_param", $file_content, 1);
}
}
elseif ($options == "q"){//quoted
if($occurrence !== false){
$file_content = preg_replace_nth("/$default/m", "$var\"" . str_replace('"', '\"', $info_param) . "\"", $file_content, $occurrence);
}else{
$file_content = preg_replace("/$default/m", "$var\"" . str_replace('"', '\"', $info_param) . "\"", $file_content, 1);
}
}
elseif ($options == "sq"){//separated & quoted
if($occurrence !== false){
$file_content = preg_replace_nth("/$default/m", "$var \"" . str_replace('"','\"',$info_param) . "\"", $file_content, $occurrence);
}else{
$file_content = preg_replace("/$default/m", "$var \"" . str_replace('"','\"',$info_param) . "\"", $file_content, 1);
}
}
elseif ($options == "sc"){//separated & ending with a comma (used in JC2MP Example)
if($occurrence !== false){
$file_content = preg_replace_nth("/$default/m", "$var $info_param,", $file_content, $occurrence);
}else{
$file_content = preg_replace("/$default/m", "$var $info_param,", $file_content, 1);
}
}
elseif ($options == "sqc"){//separated & quoted & ending with a comma
if($occurrence !== false){
$file_content = preg_replace_nth("/$default/m", "$var \"" . str_replace('"', '\"', $info_param) . "\",", $file_content, $occurrence);
}else{
$file_content = preg_replace("/$default/m", "$var \"" . str_replace('"', '\"', $info_param) . "\",", $file_content, 1);
}
}
elseif ($options == "key-regex")//replace %key% in and use a regular expression
{
$var = str_replace("%key%", $info_param, $var);
if($occurrence !== false){
$file_content = preg_replace_nth("/$default/m", "$var", $file_content, $occurrence);
}else{
$file_content = preg_replace("/$default/m", "$var", $file_content, 1);
}
}
else{
if($occurrence !== false){
$file_content = preg_replace_nth("/$default/m", "$var$info_param", $file_content, $occurrence);
}else{
$file_content = preg_replace("/$default/m", "$var$info_param", $file_content, 1);
}
}
}
if ( get_magic_quotes_gpc_wrapper() )
$file_content=stripslashes($file_content);
}
//echo "".$file_content."";
$remote->remote_writefile($server_home['home_path'] . "/" . $filepath, $file_content);
}
?>