cfg_text_replace.php 9.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259
  1. <?php
  2. /*
  3. *
  4. * OGP - Open Game Panel
  5. * Copyright (C) 2008 - 2018 The OGP Development Team
  6. *
  7. * http://www.opengamepanel.org/
  8. *
  9. * This program is free software; you can redistribute it and/or
  10. * modify it under the terms of the GNU General Public License
  11. * as published by the Free Software Foundation; either version 2
  12. * of the License, or any later version.
  13. *
  14. * This program is distributed in the hope that it will be useful,
  15. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  17. * GNU General Public License for more details.
  18. *
  19. * You should have received a copy of the GNU General Public License
  20. * along with this program; if not, write to the Free Software
  21. * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  22. *
  23. */
  24. if (empty($server_home["ip"]))
  25. $server_home["ip"] = $ip;
  26. if (empty($server_home["port"]))
  27. $server_home["port"] = $port;
  28. $server_home['ip_port'] = $server_home['ip'] . ':' . $server_home['port'];
  29. $server_home["true"] = "";
  30. $last_param = json_decode($db->getLastParam($server_home["home_id"]), True);
  31. $server_home["max_players"] = isset($cli_param_data['PLAYERS']) ? $cli_param_data['PLAYERS'] : $last_param['players'];
  32. $server_home["webhost_ip"] = $_SERVER['SERVER_ADDR'];
  33. if (array_key_exists("mod_cfg_id", $server_home))
  34. $server_home["incremental"] = $db->incrementalNumByHomeId( $server_home["home_id"], $server_home["mod_cfg_id"], $server_home["remote_server_id"] );
  35. $server_home["map"] = clean_server_param_value(isset($cli_param_data['MAP']) ? $cli_param_data['MAP'] : $last_param['map'], $server_xml->cli_allow_chars);
  36. $isWin = preg_match('/CYGWIN/', $remote->what_os());
  37. if( isset($server_xml->gameq_query_name) )
  38. {
  39. $server_home["query_port"] = get_query_port($server_xml, $server_home['port']);
  40. }
  41. elseif( isset($server_xml->lgsl_query_name) )
  42. {
  43. $get_q_and_s = lgsl_port_conversion((string)$server_xml->lgsl_query_name, $server_home['port'], "", "");
  44. $server_home["query_port"] = $get_q_and_s['1'];
  45. }
  46. $replace_texts = $server_xml->replace_texts->text;
  47. $replace_id = 0;
  48. if($replace_texts)
  49. {
  50. foreach ($replace_texts as $text => $array )
  51. {
  52. $param = (string)$array['key'];
  53. if ($param == 'home_path' && $isWin) {
  54. $info_param = rtrim($remote->exec('cygpath -w /')) . $server_home[$param];
  55. } else {
  56. $info_param = $server_home[$param];
  57. }
  58. $replacements[$replace_id]['info_param'] = $info_param;
  59. foreach ($array as $key => $value )
  60. {
  61. if ($key == "default")
  62. $replacements[$replace_id]['default'] = (string)$value;
  63. if ($key == "var")
  64. $replacements[$replace_id]['var'] = (string)$value;
  65. if ($key == "filepath")
  66. $replacements[$replace_id]['filepath'] = (string)$value;
  67. if ($key == "options")
  68. $replacements[$replace_id]['options'] = (string)$value;
  69. if ($key == "occurrence")
  70. $replacements[$replace_id]['occurrence'] = (string)$value;
  71. }
  72. $replace_id++;
  73. }
  74. }
  75. $custom_fields = json_decode($db->getCustomFields($server_home["home_id"]), True);
  76. $fields = $server_xml->custom_fields->field;
  77. if($fields)
  78. {
  79. foreach ($fields as $text => $array )
  80. {
  81. foreach ($array as $key => $value )
  82. {
  83. if ($key == "default_value")
  84. {
  85. if (array_key_exists((string)$array['key'], (array)$custom_fields))
  86. $replacements[$replace_id]['info_param'] = strip_real_escape_string((string)$custom_fields[(string)$array['key']]);
  87. else
  88. $replacements[$replace_id]['info_param'] = (string)$value;
  89. }
  90. if ($key == "default")
  91. $replacements[$replace_id]['default'] = (string)$value;
  92. if ($key == "var")
  93. $replacements[$replace_id]['var'] = (string)$value;
  94. if ($key == "filepath")
  95. $replacements[$replace_id]['filepath'] = (string)$value;
  96. if ($key == "options")
  97. $replacements[$replace_id]['options'] = (string)$value;
  98. if ($key == "occurrence")
  99. $replacements[$replace_id]['occurrence'] = (string)$value;
  100. }
  101. $replace_id++;
  102. }
  103. }
  104. foreach($replacements as $key => $replacement)
  105. {
  106. $filepath = $replacement['filepath'];
  107. $file_replacements[$filepath][$key] = $replacement;
  108. }
  109. /* echo "<xmp>";
  110. print_r($file_replacements);
  111. echo "</xmp>"; */
  112. require_once('includes/lib_remote.php');
  113. $remote = new OGPRemoteLibrary($server_home['agent_ip'], $server_home['agent_port'], $server_home['encryption_key'], $server_home['timeout']);
  114. foreach($file_replacements as $filepath => $replacements)
  115. {
  116. $file_info = $remote->remote_readfile($server_home['home_path']."/$filepath",$file_content);
  117. if ( $file_info === 0 )
  118. {
  119. $remote->exec( "touch ".$server_home['home_path']."/$filepath" );
  120. $file_info = "";
  121. }
  122. foreach($replacements as $replacement)
  123. {
  124. $info_param = $replacement['info_param'];
  125. $default = $replacement['default'];
  126. $var = $replacement['var'];
  127. $options = $replacement['options'];
  128. $occurrence = !isset($replacement['occurrence']) || empty($replacement['occurrence']) || !is_numeric($replacement['occurrence']) || $replacement['occurrence'] < 1 ? false : $replacement['occurrence'];
  129. if( !in_array( $options, array("tags","tagValueByName","sc","sqc") ) )
  130. {
  131. $match_found = preg_match("/$default/m", $file_content);
  132. if($var == "")
  133. {
  134. $preg_info_param = preg_quote($info_param, "/");
  135. if ($options == "s")//separated
  136. $match_info_param = preg_match("/^\s$preg_info_param/m", $file_content);
  137. elseif ($options == "q")//quoted
  138. $match_info_param = preg_match("/^\"$preg_info_param\"/m", $file_content);
  139. elseif ($options == "sq")//separated & quoted
  140. $match_info_param = preg_match("/^\s\"$preg_info_param\"/m", $file_content);
  141. elseif ($options == "")
  142. $match_info_param = preg_match("/^$preg_info_param/m", $file_content);
  143. if($match_info_param == 1)
  144. continue;
  145. }
  146. }
  147. else
  148. $match_found = 1;
  149. if(!$match_found or $match_found === 0)
  150. {
  151. if ($options == "s")//separated
  152. $file_content .= "\n$var $info_param";
  153. elseif ($options == "q")//quoted
  154. $file_content .= "\n$var\"" . str_replace('"', '\"', $info_param) . "\"";
  155. elseif ($options == "sq")//separated & quoted
  156. $file_content .= "\n$var \"" . str_replace('"', '\"', $info_param) . "\"";
  157. elseif ($options == "key-regex")
  158. {
  159. $var = str_replace("%key%", $info_param, $var);
  160. $file_content .= "\n$var";
  161. }
  162. elseif ($options == "")
  163. $file_content .= "\n$var$info_param";
  164. }
  165. else
  166. {
  167. if ($options == "tags"){
  168. if($occurrence !== false){
  169. $file_content = preg_replace_nth("/(<$default$var>)(.*)(<\/$default>)/m", '${1}'.$info_param.'${3}', $file_content, $occurrence);
  170. }else{
  171. $file_content = preg_replace("/(<$default$var>)(.*)(<\/$default>)/m", '${1}'.$info_param.'${3}', $file_content, 1);
  172. }
  173. }
  174. elseif ($options == "tagValueByName"){
  175. if($occurrence !== false){
  176. $file_content = preg_replace_nth('/('.$default.'.*name="'.$var.'".*value=)(".*")/m', '${1}"' . str_replace('"', '\"', $info_param) . '"', $file_content, $occurrence);
  177. }else{
  178. $file_content = preg_replace('/('.$default.'.*name="'.$var.'".*value=)(".*")/m', '${1}"' . str_replace('"', '\"', $info_param) . '"', $file_content, 1);
  179. }
  180. }
  181. elseif($options == "s"){//separated
  182. if($occurrence !== false){
  183. $file_content = preg_replace_nth("/$default/m", "$var $info_param", $file_content, $occurrence);
  184. }else{
  185. $file_content = preg_replace("/$default/m", "$var $info_param", $file_content, 1);
  186. }
  187. }
  188. elseif ($options == "q"){//quoted
  189. if($occurrence !== false){
  190. $file_content = preg_replace_nth("/$default/m", "$var\"" . str_replace('"', '\"', $info_param) . "\"", $file_content, $occurrence);
  191. }else{
  192. $file_content = preg_replace("/$default/m", "$var\"" . str_replace('"', '\"', $info_param) . "\"", $file_content, 1);
  193. }
  194. }
  195. elseif ($options == "sq"){//separated & quoted
  196. if($occurrence !== false){
  197. $file_content = preg_replace_nth("/$default/m", "$var \"" . str_replace('"','\"',$info_param) . "\"", $file_content, $occurrence);
  198. }else{
  199. $file_content = preg_replace("/$default/m", "$var \"" . str_replace('"','\"',$info_param) . "\"", $file_content, 1);
  200. }
  201. }
  202. elseif ($options == "sc"){//separated & ending with a comma (used in JC2MP Example)
  203. if($occurrence !== false){
  204. $file_content = preg_replace_nth("/$default/m", "$var $info_param,", $file_content, $occurrence);
  205. }else{
  206. $file_content = preg_replace("/$default/m", "$var $info_param,", $file_content, 1);
  207. }
  208. }
  209. elseif ($options == "sqc"){//separated & quoted & ending with a comma
  210. if($occurrence !== false){
  211. $file_content = preg_replace_nth("/$default/m", "$var \"" . str_replace('"', '\"', $info_param) . "\",", $file_content, $occurrence);
  212. }else{
  213. $file_content = preg_replace("/$default/m", "$var \"" . str_replace('"', '\"', $info_param) . "\",", $file_content, 1);
  214. }
  215. }
  216. elseif ($options == "key-regex")//replace %key% in <var> and use a regular expression
  217. {
  218. $var = str_replace("%key%", $info_param, $var);
  219. if($occurrence !== false){
  220. $file_content = preg_replace_nth("/$default/m", "$var", $file_content, $occurrence);
  221. }else{
  222. $file_content = preg_replace("/$default/m", "$var", $file_content, 1);
  223. }
  224. }
  225. else{
  226. if($occurrence !== false){
  227. $file_content = preg_replace_nth("/$default/m", "$var$info_param", $file_content, $occurrence);
  228. }else{
  229. $file_content = preg_replace("/$default/m", "$var$info_param", $file_content, 1);
  230. }
  231. }
  232. }
  233. if ( get_magic_quotes_gpc_wrapper() )
  234. $file_content=stripslashes($file_content);
  235. }
  236. //echo "<xmp>".$file_content."</xmp>";
  237. $remote->remote_writefile($server_home['home_path'] . "/" . $filepath, $file_content);
  238. }
  239. ?>