UserInteractions.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301
  1. import bodyParser from "body-parser";
  2. import express from "express";
  3. import session from "express-session";
  4. import cwh from "./Singletons.js";
  5. import fs from "fs";
  6. import webp from "webp-converter";
  7. import {detectBufferMime} from "mime-detect";
  8. export default function UserInteractions(opts) {
  9. async function sha256(message) {
  10. // encode as UTF-8
  11. const msgBuffer = new TextEncoder().encode(message);
  12. // hash the message
  13. const hashBuffer = await crypto.subtle.digest('SHA-256', msgBuffer);
  14. // convert ArrayBuffer to Array
  15. const hashArray = Array.from(new Uint8Array(hashBuffer));
  16. // convert bytes to hex string
  17. const hashHex = hashArray.map(b => b.toString(16).padStart(2, '0')).join('');
  18. return hashHex;
  19. }
  20. let app = opts.app;
  21. app.use(session({
  22. secret: "rtifhg5878fj",
  23. resave: false,
  24. saveUninitialized: false,
  25. cookie: {
  26. sameSite: "lax", secure: "auto"
  27. }
  28. }))
  29. app.use(bodyParser.json({"limit": "200mb"}));
  30. app.use(express.json());
  31. let db = opts.db;
  32. app.options("/*", (req, res) => {
  33. res.set(cwh).end("FUCK YOU CORS")
  34. })
  35. app.get("/delacc", async (req, res) => {
  36. if (!req.session.uuid) {
  37. res.set(cwh).status(500).json({code: 500, R: "IO"})
  38. return
  39. }
  40. let uuid = req.session.uuid;
  41. db.execute("DELETE FROM user WHERE uuid = ?", [uuid], async (err, rows) => {
  42. if (err) {
  43. res.set(cwh).status(500).json({code: 500, R: "ERR"})
  44. req.session.destroy()
  45. } else {
  46. req.session.destroy()
  47. res.set(cwh).status(200).json({code: 200, R: "SUCCESS"})
  48. }
  49. })
  50. })
  51. app.get("/userapi", (req, res) => {
  52. if (req.query.getname) {
  53. db.execute("SELECT username from user where uuid = ?", [req.query.uuid], (err, result) => {
  54. res.set(cwh).end(result[0].username);
  55. })
  56. } else {
  57. if (!req.session.uuid) {
  58. res.set(cwh).status(500).json({code: 500, R: "IO"})
  59. return
  60. }
  61. db.execute("SELECT username, email from user where uuid = ?", [req.session.uuid], (err, result) => {
  62. res.set(cwh).end(JSON.stringify({
  63. uuid: req.session.uuid,
  64. username: result[0].username,
  65. email: result[0].email,
  66. }));
  67. })
  68. }
  69. })
  70. app.get("/logout", (req, res) => {
  71. req.session.destroy()
  72. res.set(cwh).status(200)
  73. })
  74. app.post("/login", async function (req, res) {
  75. if (!req.body.username || !req.body.password) {
  76. res.set(cwh).status(500).json({code: 500, R: "IO"})
  77. } else {
  78. db.execute("SELECT uuid from user where username = ? and password = ?", [req.body.username, await sha256(req.body.password)], function (err, result) {
  79. if (result.length === 0) {
  80. res.set(cwh).status(500).json({code: 500, R: "DNE"})
  81. return;
  82. }
  83. req.session.uuid = result[0].uuid;
  84. res.set(cwh).status(200).json({
  85. code: 200,
  86. R: "SS",
  87. uid: result[0].uuid
  88. });
  89. })
  90. }
  91. })
  92. app.post("/playlist-owned", async function (req, res) {
  93. if (!req.session.uuid) {
  94. res.set(cwh).status(500).json({code: 500, R: "AD"})
  95. return;
  96. }
  97. db.execute("SELECT * from playlist where owner = ?", [req.session.uuid], function (err, result) {
  98. if (err) {
  99. console.log(err);
  100. res.set(cwh).status(500).json({code: 500, R: "AD"})
  101. return;
  102. }
  103. res.set(cwh).json(result);
  104. })
  105. })
  106. app.get("/playlist", async function (req, res) {
  107. db.execute("SELECT owner, uuid, content, private FROM playlist where uuid=?", [req.query.playlistuuid], function (err, result) {
  108. if (err) {
  109. console.log(err);
  110. res.set(cwh).status(500).json({code: 500, R: "AD"})
  111. return;
  112. }
  113. if (result.length === 0) {
  114. res.set(cwh).status(404).json({code: 404, R: "DNF"})
  115. return;
  116. }
  117. res.set(cwh).json(result[0]);
  118. })
  119. })
  120. app.get("/playlist-name", async function (req, res) {
  121. db.execute("SELECT title FROM playlist where uuid=?", [req.query.playlistuuid], function (err, result) {
  122. if (err) {
  123. console.log(err);
  124. res.set(cwh).status(500).json({code: 500, R: "AD"})
  125. return;
  126. }
  127. if (result.length === 0) {
  128. res.set(cwh).status(404).json({code: 404, R: "DNF"})
  129. return;
  130. }
  131. res.set(cwh).end(result[0].title);
  132. })
  133. })
  134. app.get('/playlist-tmb', async function (req, res) {
  135. db.execute("SELECT tmb FROM playlist where uuid=?", [req.query.playlistuuid], function (err, result) {
  136. if (err) {
  137. console.log(err);
  138. res.set(cwh).status(500).json({code: 500, R: "AD"})
  139. return;
  140. }
  141. if (result.length === 0) {
  142. res.set(cwh).status(404).json({code: 404, R: "DNF"})
  143. return;
  144. }
  145. res.set(cwh).json(result[0]);
  146. })
  147. })
  148. app.post("/remove-playlist", async function (req, res) {
  149. if (!req.session.uuid) {
  150. res.set(cwh).status(500).json({code: 500, R: "AD"})
  151. return;
  152. }
  153. if (req.body.playlistuuid) {
  154. db.execute("SELECT owner FROM playlist WHERE uuid = ?", [req.body.playlistuuid], function (err, result) {
  155. if (result.length === 0) {
  156. res.set(cwh).status(200).json({code: 301, R: "DNM"})
  157. }
  158. if (result[0].owner === req.session.uuid) {
  159. db.execute("DELETE FROM playlist WHERE uuid = ?", [req.body.playlistuuid], (err, result) => {
  160. if (err) {
  161. console.log(err);
  162. res.set(cwh).status(500).json({code: 500, R: "Err"})
  163. return
  164. }
  165. res.set(cwh).status(200).json({code: 200, R: "SS"})
  166. })
  167. } else {
  168. res.set(cwh).status(403).json({code: 403, R: "Forbidden"})
  169. }
  170. })
  171. }
  172. })
  173. app.post("/upload-playlist", async function (req, res) {
  174. if (!req.session.uuid) {
  175. res.set(cwh).status(500).json({code: 500, R: "AD"})
  176. return;
  177. }
  178. if (req.body.playlistuuid) {
  179. db.execute("SELECT owner FROM playlist WHERE uuid = ?", [req.body.playlistuuid], async function (err, result) {
  180. if (["image/png", "image/webp", "image/jpeg","image/jpg", "image/bmp"].indexOf((await detectBufferMime(Buffer.from(Object.values(req.body.tmb.data))))) === -1) {
  181. res.set(cwh).status(500).json({code: 500, R: "ILLEGAL IMAGE"})
  182. return;
  183. }
  184. if (result[0].owner === req.session.uuid) {
  185. let uuid = crypto.randomUUID();
  186. fs.writeFileSync("tmp/"+uuid, Buffer.from(Object.values(req.body.tmb.data)));
  187. try{
  188. await webp.cwebp("tmp/"+uuid, "tmp/"+uuid+".webp", "-q 80 -size 100000 -mt -metadata all", "-v")
  189. }catch(e){
  190. console.log(e)
  191. res.set(cwh).status(500).json({code: 500, R: "Err"})
  192. fs.rm("tmp/"+uuid, (err) => {
  193. if (err) {
  194. console.log(err);
  195. }
  196. });
  197. fs.rm("tmp/"+uuid+".webp", (err) => {
  198. if (err) {
  199. console.log(err);
  200. }
  201. });
  202. return;
  203. }
  204. let pl_cover = fs.readFileSync("tmp/"+uuid+".webp");
  205. fs.rm("tmp/"+uuid, (err) => {
  206. if (err) {
  207. console.log(err);
  208. }
  209. });
  210. fs.rm("tmp/"+uuid+".webp", (err) => {
  211. if (err) {
  212. console.log(err);
  213. }
  214. });
  215. res.set(cwh).status(200).json({code: 200, R: "SS"})
  216. db.execute("UPDATE playlist SET content = ?, private = ?, tmb = ?, title = ? WHERE uuid = ?", [req.body.content, req.body.private, pl_cover, req.body.title, req.body.playlistuuid], (err, result) => {
  217. if (err) {
  218. console.log(err);
  219. res.set(cwh).status(500).json({code: 500, R: "Err"})
  220. }
  221. })
  222. } else {
  223. res.set(cwh).status(403).json({code: 403, R: "Forbidden"})
  224. }
  225. })
  226. } else {
  227. let key = crypto.randomUUID();
  228. db.execute("INSERT INTO playlist(owner, uuid, content, private, tmb, title) values (?,?,?,?,?,?)", [req.session.uuid, key, req.body.content, req.body.private, req.body.tmb, req.body.title], function (err, result) {
  229. if (err) {
  230. console.log(err);
  231. res.set(cwh).status(500).json({code: 500, R: "AD"})
  232. return;
  233. }
  234. res.set(cwh).json({
  235. code: 200, R: "SS", UUID: key
  236. });
  237. })
  238. }
  239. })
  240. app.post("/register", function (req, res) {
  241. db.execute("SELECT uuid FROM user WHERE username = ?", [req.body.username], async function (err, rows) {
  242. if (!req.body.username || !req.body.password) {
  243. res.set(cwh).status(500).json({code: 500, R: "PE"})
  244. return;
  245. }
  246. if (err) {
  247. console.log(err);
  248. res.set(cwh).status(500).json({code: 500, R: "UNE"});
  249. return;
  250. }
  251. if (rows.length === 0) {
  252. db.execute("INSERT INTO user (uuid, username, email, password, avatar, time) values (?,?,?,?,?,?)", [crypto.randomUUID(), req.body.username, !req.body.email ? null : req.body.email, await sha256(req.body.password), null, Date.now()]);
  253. res.status(200).set(cwh).json({code: 200, R: "SS"});
  254. return;
  255. }
  256. res.set(cwh).status(500).json({code: 500, R: "UE"});
  257. return;
  258. })
  259. })
  260. }