networks.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. import { docker } from '../server.js';
  2. export const Networks = async function(req, res) {
  3. let container_networks = [];
  4. let network_name = '';
  5. // List all containers
  6. let containers = await docker.listContainers({ all: true });
  7. // Loop through the containers to find out which networks are being used
  8. for (let i = 0; i < containers.length; i++) {
  9. // console.log(Object.keys(containers[i].NetworkSettings.Networks)[0]);
  10. try { network_name += containers[i].HostConfig.NetworkMode; } catch {}
  11. try { container_networks.push(containers[i].NetworkSettings.Networks[network_name].NetworkID); } catch {}
  12. }
  13. // List all networks
  14. let networks = await docker.listNetworks({ all: true });
  15. // Uses template literals to build the networks table
  16. let network_list = `
  17. <thead>
  18. <tr>
  19. <th class="w-1"><input class="form-check-input m-0 align-middle" name="select" type="checkbox" aria-label="Select all" onclick="selectAll()"></th>
  20. <th><label class="table-sort" data-sort="sort-name">Name</label></th>
  21. <th><label class="table-sort" data-sort="sort-city">ID</label></th>
  22. <th><label class="table-sort" data-sort="sort-score">Status</label></th>
  23. <th><label class="table-sort" data-sort="sort-date">Created</label></th>
  24. <th><label class="table-sort" data-sort="sort-progress">Action</label></th>
  25. </tr>
  26. </thead>
  27. <tbody class="table-tbody">`
  28. for (let i = 0; i < networks.length; i++) {
  29. let status = '';
  30. // Check if the network is in use
  31. try { if (container_networks.includes(networks[i].Id)) { status = `In use`; } } catch {}
  32. // Create the row for the network entry
  33. let details = `
  34. <tr>
  35. <td><input class="form-check-input m-0 align-middle" name="select" value="${networks[i].Id}" type="checkbox" aria-label="Select"></td>
  36. <td class="sort-name">${networks[i].Name}</td>
  37. <td class="sort-city">${networks[i].Id}</td>
  38. <td class="sort-score text-green">${status}</td>
  39. <td class="sort-date" data-date="1628122643">${networks[i].Created}</td>
  40. <td class="text-end"><a class="btn" href="#">Details</a></td>
  41. </tr>`
  42. // Add the row to the network list
  43. network_list += details;
  44. }
  45. network_list += `</tbody>`
  46. res.render("networks", {
  47. name: req.session.user,
  48. role: req.session.role,
  49. avatar: req.session.user.charAt(0).toUpperCase(),
  50. network_list: network_list,
  51. network_count: networks.length,
  52. alert: '',
  53. });
  54. }
  55. export const removeNetwork = async function(req, res) {
  56. // Grab the list of networks
  57. let networks = req.body.select;
  58. // Make sure the value is an array
  59. if (typeof(networks) == 'string') { networks = [networks]; }
  60. // Loop through the array
  61. for (let i = 0; i < networks.length; i++) {
  62. if (networks[i] != 'on') {
  63. try {
  64. let network = docker.getNetwork(networks[i]);
  65. await network.remove();
  66. }
  67. catch {
  68. console.log(`Unable to remove network: ${networks[i]}`);
  69. }
  70. }
  71. }
  72. res.redirect("/networks");
  73. }