ftp_admin.php 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  1. <script type="text/javascript" src="js/modules/ftp.js"></script>
  2. <?php
  3. /*
  4. *
  5. * OGP - Open Game Panel
  6. * Copyright (C) 2008 - 2018 The OGP Development Team
  7. *
  8. * http://www.opengamepanel.org/
  9. *
  10. * This program is free software; you can redistribute it and/or
  11. * modify it under the terms of the GNU General Public License
  12. * as published by the Free Software Foundation; either version 2
  13. * of the License, or any later version.
  14. *
  15. * This program is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. * GNU General Public License for more details.
  19. *
  20. * You should have received a copy of the GNU General Public License
  21. * along with this program; if not, write to the Free Software
  22. * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  23. *
  24. */
  25. function exec_ogp_module()
  26. {
  27. include_once('includes/lib_remote.php');
  28. global $db;
  29. global $view;
  30. if(isset($_POST['add_ftp_user']))
  31. {
  32. $success = true;
  33. $server_row = $db->getRemoteServer($_POST['remote_server_id']);
  34. $remote = new OGPRemoteLibrary($server_row['agent_ip'],$server_row['agent_port'],$server_row['encryption_key'],$server_row['timeout']);
  35. $post_ftp_login = strip_real_escape_string($_POST['ftp_login']);
  36. $post_ftp_password = strip_real_escape_string($_POST['ftp_password']);
  37. $post_full_path = strip_real_escape_string($_POST['full_path']);
  38. $host_stat = $remote->status_chk();
  39. // Validation
  40. if(strlen($post_ftp_login) > 20){
  41. print_failure( get_lang("ftp_account_username_too_long") );
  42. $success = false;
  43. }
  44. if(strlen($post_ftp_password) > 20){
  45. print_failure( get_lang("ftp_account_password_too_long") );
  46. $success = false;
  47. }
  48. $ftp_accounts_list = $remote->ftp_mgr("list");
  49. $ftp_accounts = explode("\n",$ftp_accounts_list);
  50. $user_exists = FALSE;
  51. foreach($ftp_accounts as $ftp_account)
  52. {
  53. if( $ftp_account != "" )
  54. {
  55. list($ftp_login, $ftp_path) = explode("\t",$ftp_account);
  56. $ftp_login = trim($ftp_login);
  57. if ($ftp_login == $post_ftp_login)
  58. {
  59. $user_exists = TRUE;
  60. break;
  61. }
  62. }
  63. }
  64. if( $user_exists === TRUE )
  65. {
  66. print_failure( get_lang("ftp_account_already_exists") );
  67. }
  68. else
  69. {
  70. if($success)
  71. $remote->ftp_mgr("useradd", $post_ftp_login, $post_ftp_password, $post_full_path);
  72. }
  73. }
  74. if(isset($_POST['del_ftp_user_y']))
  75. {
  76. $ftp_login = strip_real_escape_string($_POST['ftp_login']);
  77. $server_row = $db->getRemoteServer($_POST['remote_server_id']);
  78. $remote = new OGPRemoteLibrary($server_row['agent_ip'],$server_row['agent_port'],$server_row['encryption_key'],$server_row['timeout']);
  79. $remote->ftp_mgr("userdel", $ftp_login);
  80. $home_info = $db->getHomeByFtpLogin($server_row['remote_server_id'], $ftp_login);
  81. $db->changeFtpStatus('disabled',$home_info['home_id']);
  82. }
  83. if(isset($_POST['edit_ftp_user']))
  84. {
  85. $server_row = $db->getRemoteServer($_POST['remote_server_id']);
  86. $remote = new OGPRemoteLibrary($server_row['agent_ip'],$server_row['agent_port'],$server_row['encryption_key'],$server_row['timeout']);
  87. $ftp_login = strip_real_escape_string($_POST['ftp_login']);
  88. $settings = "";
  89. foreach($_POST as $key => $value)
  90. {
  91. if ($key != "edit_ftp_user" and $key != "ftp_login" and $key != "remote_server_id")
  92. {
  93. $clean_value = strip_real_escape_string($value);
  94. $account_settings .= "$key\t$clean_value\n";
  95. }
  96. }
  97. $remote->ftp_mgr("usermod", $ftp_login, $account_settings );
  98. }
  99. echo "<h2>" . get_lang("ftp_admin") . "</h2>";
  100. $servers = $db->getRemoteServers();
  101. if ($servers !== false) {
  102. echo "<tr><td colspan='3' >
  103. <form method=POST >
  104. <table class='center' style='width:100%' ><tr>
  105. <td>". get_lang("remote_server") ." <select style='width:250px' name='remote_server_id' >";
  106. foreach ( $servers as $server_row )
  107. {
  108. $display_ip = checkDisplayPublicIP($server_row['display_public_ip'],$server_row['agent_ip']);
  109. echo "<option value='" . $server_row['remote_server_id'] . "' >" . $server_row['remote_server_name'] . " (" . $display_ip . ":" . $server_row['agent_port'] . ")</option>";
  110. }
  111. echo "</select>
  112. </td>
  113. <td>". get_lang("login") ."<input type=text name='ftp_login' /></td>
  114. <td>". get_lang("password") ."<input type=text name='ftp_password' /></td>
  115. <td>". get_lang("full_path") ."<input type=text name='full_path' /></td>
  116. </tr>
  117. <tr>
  118. <td colspan=4 ><input style='width:100%;' type=submit name='add_ftp_user' value='". get_lang("add_ftp_account") ."' /></td>
  119. </tr>
  120. </table>
  121. </form>
  122. </td></tr>";
  123. ?>
  124. <table id="servermonitor" class="tablesorter" data-sortlist='[[2,0]]'>
  125. <thead>
  126. <tr>
  127. <th class="header sorter-false"></th><th><?php print_lang('remote_server'); ?></th><th><?php print_lang('login'); ?></th><th><?php print_lang('server_name'); ?></th><th><?php print_lang('full_path'); ?></th>
  128. </tr>
  129. </thead>
  130. <tbody>
  131. <?php
  132. foreach ( $servers as $server_row )
  133. {
  134. $display_ip = checkDisplayPublicIP($server_row['display_public_ip'],$server_row['agent_ip']);
  135. $remote = new OGPRemoteLibrary($server_row['agent_ip'],$server_row['agent_port'],$server_row['encryption_key'],$server_row['timeout']);
  136. $host_stat = $remote->status_chk();
  137. $status = ( $host_stat === 0 or $host_stat === -1 ) ? "<span class='failure'>". get_lang("offline") ."</span>" : "<span class='success'>". get_lang("online") ."</span>";
  138. if( $host_stat === 1)
  139. {
  140. $ftp_accounts_list = $remote->ftp_mgr("list");
  141. $ftp_accounts = explode("\n", $ftp_accounts_list);
  142. foreach($ftp_accounts as $ftp_account)
  143. {
  144. if( !empty($ftp_account))
  145. {
  146. list($ftp_login, $ftp_path) = explode("\t", $ftp_account);
  147. $ftp_login = trim($ftp_login);
  148. $home_info = $db->getHomeByFtpLogin($server_row['remote_server_id'], $ftp_login);
  149. $expandme = ( ( isset($_POST['ftp_login']) and $ftp_login == strip_real_escape_string($_POST['ftp_login']) ) AND ( isset($_POST['remote_server_id']) and $home_info['remote_server_id'] == $_POST['remote_server_id'] ) ) ? "expandme" : "";
  150. $home_name = isset( $home_info['home_name'] ) ? $home_info['home_name'] : $ftp_path;
  151. echo "<tr class='maintr $expandme'><td class='collapsible' ></td><td>".$server_row['remote_server_name']." (".$display_ip.")</td><td><b class='failure' >$ftp_login</td><td>" . htmlentities($home_name) . "</td><td>$ftp_path</td></tr>
  152. <tr class='expand-child' ><td colspan='4' >
  153. <form method=POST >
  154. <table>";
  155. $account_details = $remote->ftp_mgr("show",$ftp_login);
  156. $ftp_account_detail_list = explode("\n",$account_details);
  157. foreach($ftp_account_detail_list as $detail_line)
  158. {
  159. if( !empty($detail_line))
  160. {
  161. list($key,$value) = explode(" : ",$detail_line);
  162. $key = trim($key);
  163. $value = trim($value);
  164. $blacklist = array("Login", "Password", "UID", "GID", "ftp_user_id", "username",
  165. "username_prefix", "password", "sys_userid", "sys_groupid",
  166. "sys_perm_user", "sys_perm_group", "sys_perm_other",
  167. "server_id", "parent_domain_id", "uid", "gid" );
  168. if( in_array($key, $blacklist) )
  169. continue;
  170. if(substr($value, -1) == ')')
  171. {
  172. $value_parts = explode(" ", $value);
  173. if(is_numeric($value_parts[0]))
  174. {
  175. if(count($value_parts) > 1)
  176. {
  177. $value = array_shift($value_parts);
  178. $advert = implode(" ", $value_parts);
  179. }
  180. }
  181. else
  182. {
  183. $first_pos = array_shift($value_parts);
  184. $parts = preg_split('/:|-/', $first_pos);
  185. if(count(array_filter($parts, 'is_numeric')) === 2)
  186. {
  187. $value = $first_pos;
  188. $advert = implode(" ", $value_parts);
  189. }
  190. }
  191. }
  192. if ($key == "Allowed local IPs" or $key == "ul_ratio" or $key == "ForceSsl" or ( count($ftp_account_detail_list) == 4 and $key == "Directory" ) )
  193. echo "</table>\n</td><td>\n<table>\n";
  194. if ($key == "Directory" )
  195. $value = str_replace( "/./", "", $value );
  196. if($key == "Username")
  197. $readOnly = true;
  198. echo "<tr><td>$key</td><td>
  199. <input type=text name='$key' value='$value' ";
  200. if(isset($readOnly) && ($readOnly)){
  201. echo "readonly ";
  202. }
  203. if(isset($advert))
  204. echo "/>".
  205. "</td><td>$advert</td></tr>\n";
  206. else
  207. echo "/>".
  208. "</td></tr>\n";
  209. unset($readOnly, $key, $value, $advert);
  210. }
  211. }
  212. echo "<tr>
  213. <td colspan='2' >
  214. <center>
  215. <input type=hidden name='remote_server_id' value='".$server_row['remote_server_id']."'/>
  216. <input type=hidden name='ftp_login' value=\"" . str_replace('"', '&quot;', $ftp_login) . "\"/>
  217. <input type=submit name='edit_ftp_user' value='". get_lang("change_account_details") ."' />
  218. </center>
  219. </td>
  220. <td>
  221. <input type='image' name='del_ftp_user' onsubmit='submit-form();' src='modules/administration/images/remove.gif'>". get_lang("remove_account") ."</input>
  222. </td>
  223. </tr>
  224. </table>
  225. </form>
  226. </td>
  227. </tr>";
  228. }
  229. }
  230. } // end: host_stat === 1
  231. } // end: foreach $servers as $server_row
  232. } else {
  233. echo get_lang('no_remote_servers');
  234. }
  235. echo "</tbody>";
  236. echo "</table>\n";
  237. }