dashboard.js 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  1. const User = require('../database/UserModel');
  2. const { readFileSync, writeFileSync, appendFileSync, readdirSync } = require('fs');
  3. const { execSync } = require("child_process");
  4. const { siteCard } = require('../components/siteCard');
  5. const { containerExec } = require('../functions/system')
  6. exports.Dashboard = async function (req, res) {
  7. if (req.session.role == "admin") {
  8. // get user data with matching UUID from sqlite database
  9. let user = await User.findOne({ where: { UUID: req.session.UUID } });
  10. let caddy = 'd-none';
  11. if (process.env.Proxy_Manager == 'enabled') {
  12. caddy = '';
  13. }
  14. // Render the home page
  15. res.render("pages/dashboard", {
  16. name: user.first_name + ' ' + user.last_name,
  17. role: user.role,
  18. avatar: user.avatar,
  19. isLoggedIn: true,
  20. site_list: req.app.locals.site_list,
  21. caddy: caddy
  22. });
  23. } else {
  24. // Redirect to the login page
  25. res.redirect("/login");
  26. }
  27. }
  28. exports.AddSite = async function (req, res) {
  29. let { domain, type, host, port } = req.body;
  30. if ((req.session.role == "admin") && ( domain && type && host && port)) {
  31. let { domain, type, host, port } = req.body;
  32. // build caddyfile
  33. let caddyfile = `${domain} {`
  34. caddyfile += `\n\t${type} ${host}:${port}`
  35. caddyfile += `\n\theader {`
  36. caddyfile += `\n\t\tStrict-Transport-Security "max-age=31536000; includeSubDomains; preload"`
  37. caddyfile += `\n\t}`
  38. caddyfile += `\n}`
  39. // save caddyfile
  40. writeFileSync(`./caddyfiles/sites/${domain}.Caddyfile`, caddyfile, function (err) { console.log(err) });
  41. // format caddyfile
  42. let format = {
  43. container: 'DweebProxy',
  44. command: `caddy fmt --overwrite /etc/caddy/sites/${domain}.Caddyfile`
  45. }
  46. await containerExec(format, function(err, data) {
  47. if (err) {
  48. console.error(err);
  49. return;
  50. }
  51. console.log(`Formatted ${domain}.Caddyfile`);
  52. });
  53. ///////////////// convert caddyfile to json
  54. let convert = {
  55. container: 'DweebProxy',
  56. command: `caddy adapt --config /etc/caddy/sites/${domain}.Caddyfile --pretty >> /etc/caddy/sites/${domain}.json`
  57. }
  58. await containerExec(convert, function(err, data) {
  59. if (err) {
  60. console.error(err);
  61. return;
  62. }
  63. console.log(`Converted ${domain}.Caddyfile to JSON`);
  64. });
  65. ////////////// reload caddy
  66. let reload = {
  67. container: 'DweebProxy',
  68. command: `caddy reload --config /etc/caddy/Caddyfile`
  69. }
  70. await containerExec(reload, function(err, data) {
  71. if (err) {
  72. console.error(err);
  73. return;
  74. }
  75. console.log(`Reloaded Caddy Config`);
  76. });
  77. let site = siteCard(type, domain, host, port, 0);
  78. req.app.locals.site_list += site;
  79. res.redirect("/");
  80. } else {
  81. // Redirect
  82. console.log('not admin or missing info')
  83. res.redirect("/");
  84. }
  85. }
  86. exports.RemoveSite = async function (req, res) {
  87. if (req.session.role == "admin") {
  88. for (const [key, value] of Object.entries(req.body)) {
  89. execSync(`rm ./caddyfiles/sites/${value}.Caddyfile`, (err, stdout, stderr) => {
  90. if (err) { console.error(`error: ${err.message}`); return; }
  91. if (stderr) { console.error(`stderr: ${stderr}`); return; }
  92. console.log(`removed ${value}.Caddyfile`);
  93. });
  94. }
  95. let reload = {
  96. container: 'DweebProxy',
  97. command: `caddy reload --config /etc/caddy/Caddyfile`
  98. }
  99. await containerExec(reload);
  100. console.log('Removed Site(s)')
  101. res.redirect("/refreshsites");
  102. } else {
  103. res.redirect("/");
  104. }
  105. }
  106. exports.RefreshSites = async function (req, res) {
  107. let domain, type, host, port;
  108. let id = 1;
  109. if (req.session.role == "admin") {
  110. // Clear site_list.ejs
  111. req.app.locals.site_list = "";
  112. // check if ./caddyfiles/sites contains any .json files, then delete them
  113. try {
  114. let files = readdirSync('./caddyfiles/sites/');
  115. files.forEach(file => {
  116. if (file.includes(".json")) {
  117. execSync(`rm ./caddyfiles/sites/${file}`, (err, stdout, stderr) => {
  118. if (err) { console.error(`error: ${err.message}`); return; }
  119. if (stderr) { console.error(`stderr: ${stderr}`); return; }
  120. console.log(`removed ${file}`);
  121. });
  122. }
  123. });
  124. } catch (error) { console.log("No .json files to delete") }
  125. // get list of Caddyfiles
  126. let sites = readdirSync('./caddyfiles/sites/');
  127. sites.forEach(site_name => {
  128. // convert the caddyfile of each site to json
  129. let convert = {
  130. container: 'DweebProxy',
  131. command: `caddy adapt --config ./caddyfiles/sites/${site_name} --pretty >> ./caddyfiles/sites/${site_name}.json`
  132. }
  133. containerExec(convert);
  134. try {
  135. // read the json file
  136. let site_file = readFileSync(`./caddyfiles/sites/${site_name}.json`, 'utf8');
  137. // fix whitespace and parse the json file
  138. site_file = site_file.replace(/ /g, " ");
  139. site_file = JSON.parse(site_file);
  140. } catch (error) { console.log("No .json file to read") }
  141. // get the domain, type, host, and port from the json file
  142. try { domain = site_file.apps.http.servers.srv0.routes[0].match[0].host[0] } catch (error) { console.log("No Domain") }
  143. try { type = site_file.apps.http.servers.srv0.routes[0].handle[0].routes[0].handle[1].handler } catch (error) { console.log("No Type") }
  144. try { host = site_file.apps.http.servers.srv0.routes[0].handle[0].routes[0].handle[1].upstreams[0].dial.split(":")[0] } catch (error) { console.log("Not Localhost") }
  145. try { port = site_file.apps.http.servers.srv0.routes[0].handle[0].routes[0].handle[1].upstreams[0].dial.split(":")[1] } catch (error) { console.log("No Port") }
  146. // build the site card
  147. let site = siteCard(type, domain, host, port, id);
  148. // append the site card to site_list
  149. req.app.locals.site_list += site;
  150. id++;
  151. });
  152. res.redirect("/");
  153. } else {
  154. // Redirect to the login page
  155. res.redirect("/");
  156. }
  157. }
  158. exports.DisableSite = async function (req, res) {
  159. if (req.session.role == "admin") {
  160. console.log(req.body)
  161. console.log('Disable Site')
  162. res.redirect("/");
  163. } else {
  164. // Redirect to the login page
  165. res.redirect("/login");
  166. }
  167. }
  168. exports.EnableSite = async function (req, res) {
  169. if (req.session.role == "admin") {
  170. console.log(req.body)
  171. console.log('Enable Site')
  172. res.redirect("/");
  173. } else {
  174. // Redirect to the login page
  175. res.redirect("/login");
  176. }
  177. }