tftp.html 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. .hidden{
  6. display:none;
  7. }
  8. .disabled{
  9. opacity: 0.5;
  10. pointer-events: none;
  11. }
  12. </style>
  13. </head>
  14. <body>
  15. <div class="ui form">
  16. <div class="field">
  17. <label>Default User for TFTP Access</label>
  18. <select id="defaultUser" class="ui search dropdown" >
  19. <option value="">Select a user account</option>
  20. </select>
  21. <small>All TFTP file operations will be performed using this user's permissions and storage quota.</small>
  22. </div>
  23. <div class="field">
  24. <label>Listening Port</label>
  25. <div class="ui labeled input">
  26. <input id="listeningPort" type="number" placeholder="69" min="69" onchange="updateTFTPPort(this.value)">
  27. </div>
  28. <small>Default TFTP port is 69. Changing this port requires TFTP clients to explicitly specify the port.</small>
  29. </div>
  30. <br><br>
  31. <div id="ok" class="ui secondary inverted green segment" style="display:none;">
  32. <i class="checkmark icon"></i> Setting Applied
  33. </div>
  34. <div id="error" class="ui secondary inverted red segment" style="display:none;">
  35. <i class="remove icon"></i> <span class="msg">Something went wrong</span>
  36. </div>
  37. </div>
  38. <br><br>
  39. <script>
  40. $(".ui.dropdown").dropdown();
  41. $(document).ready(function(){
  42. //Load user list for default user selection
  43. $.get("../../system/users/list?noicon=true", function(data){
  44. if (data.error !== undefined){
  45. console.log(data.error);
  46. }else{
  47. data.forEach(user => {
  48. let username = user[0];
  49. $("#defaultUser").append(`<option value="${username}">${username}</option>`);
  50. });
  51. }
  52. //Select the current default user
  53. initDefaultTFTPUsername(function(){
  54. $("#defaultUser").on('change', function(){
  55. updateDefaultUser(this.value);
  56. });
  57. });
  58. });
  59. });
  60. function initTFTPServerStatus(){
  61. //Load current system status
  62. $.get("../../system/storage/tftp/status", function(data){
  63. if (data.error !== undefined){
  64. console.log(data.error);
  65. }else{
  66. if (data.Enabled == false){
  67. $("#listeningPort").parent().addClass("disabled");
  68. }
  69. $("#listeningPort").val(data.Port);
  70. $(".port").text(data.Port);
  71. //Set default user
  72. if (data.DefaultUser && data.DefaultUser != ""){
  73. $("#defaultUser").dropdown("set selected", data.DefaultUser);
  74. }
  75. //Set user groups
  76. if (data.UserGroups && data.UserGroups.length > 0){
  77. $("#grouplist").dropdown("set selected", data.UserGroups);
  78. }
  79. }
  80. $(".ui.checkbox").checkbox();
  81. });
  82. }
  83. function showOk(){
  84. $("#ok").stop().finish().slideDown("fast").delay(3000).slideUp("fast");
  85. }
  86. function showError(msg){
  87. $("#error .msg").text(msg);
  88. $("#error").stop().finish().slideDown("fast").delay(3000).slideUp("fast");
  89. }
  90. function updateDefaultUser(username){
  91. if (username == ""){
  92. showError("Please select a valid user");
  93. return;
  94. }
  95. $.ajax({
  96. url: "../../system/storage/tftp/defaultUser",
  97. method: "POST",
  98. data: {username: username},
  99. success: function(data){
  100. if (data.error !== undefined){
  101. showError(data.error);
  102. }else{
  103. showOk();
  104. }
  105. },
  106. error: function(){
  107. showError("Failed to update default user");
  108. }
  109. });
  110. }
  111. function updateTFTPPort(port){
  112. if (port < 1 || port > 65535){
  113. showError("Invalid port number");
  114. return;
  115. }
  116. $.ajax({
  117. url: "../../system/storage/tftp/setPort",
  118. method: "GET",
  119. data: {port: port},
  120. success: function(data){
  121. if (data.error !== undefined){
  122. showError(data.error);
  123. }else{
  124. showOk();
  125. //Reload status to reflect changes
  126. setTimeout(initTFTPServerStatus, 500);
  127. }
  128. },
  129. error: function(){
  130. showError("Failed to update port");
  131. }
  132. });
  133. }
  134. function initDefaultTFTPUsername(callback){
  135. $.get("../../system/storage/tftp/defaultUser", function(data){
  136. if (data.error !== undefined){
  137. console.log(data.error);
  138. }else{
  139. if (data != ""){
  140. $("#defaultUser").dropdown("set selected", data);
  141. }
  142. }
  143. if (callback){
  144. callback();
  145. }
  146. });
  147. }
  148. </script>
  149. </body>
  150. </html>