main.js 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. var express = require('express');
  2. var app = express();
  3. var app_serve = express();
  4. var fs = require("fs");
  5. const sqlite3 = require('sqlite3').verbose();
  6. const db = new sqlite3.Database('./database.db');
  7. const jwt = require("jsonwebtoken");
  8. const bodyParser = require("body-parser");
  9. const {spawn} = require("child_process");
  10. const nrc = require('node-run-cmd')
  11. const https = require("node:https");
  12. const {encode} = require("html-entities");
  13. const querystring = require("node:querystring");
  14. // var key = fs.readFileSync('./andyxie.cn.key')
  15. // var cert = fs.readFileSync('./andyxie.cn.pem')
  16. console.log(crypto.randomUUID())
  17. app.use(bodyParser.json({"limit": "200mb"}));
  18. app.use(express.json());
  19. app_serve.use(bodyParser.json({"limit": "200mb"}));
  20. app_serve.use(express.json());
  21. const stmt = db.prepare("INSERT INTO instrument_entry (uuid, song_name, album_name, link_to, binary, artist) VALUES (?,?,?,?,?,?)")
  22. app.post('/submit', function (req, res) {
  23. res.header("Access-Control-Allow-Origin", "*");
  24. try {
  25. fetch(req.body.file).then(res => {
  26. res.arrayBuffer().then(r => fs.writeFileSync("./audio_file", Buffer.from(r)));
  27. })
  28. res.end("api_success");
  29. } catch (err) {
  30. res.status(500).send("Server Error");
  31. return
  32. }
  33. var callback = function (d) {
  34. console.log(d.toString());
  35. }
  36. var errcb = function (d) {
  37. console.log(d.toString());
  38. }
  39. nrc.run(["pip install audio-separator", "audio-separator ./audio_file --model_filename UVR_MDXNET_KARA.onnx --mdx_segment_size 4000 --mdx_overlap 0.85 --output_format MP3 --mdx_batch_size 20 --output_dir output "], {
  40. onData: callback,
  41. onError: errcb
  42. }).then(r => {
  43. stmt.run(crypto.randomUUID(), req.body.name, req.body.albumName, req.body.link, fs.readFileSync('./output/audio_file_(Instrumental)_UVR_MDXNET_KARA.mp3'), req.body.artist)
  44. })
  45. })
  46. app.options('/submit', function (req, res) {
  47. res.header("Access-Control-Allow-Origin", "*");
  48. res.header("Access-Control-Allow-Headers", "Content-Type");
  49. res.end()
  50. })
  51. app.post('/search_api', function (req, res) {
  52. function OnFetched(err, rows) {
  53. try {
  54. res.header("Access-Control-Allow-Origin", "*");
  55. console.log("Triggered");
  56. res.end(JSON.stringify(rows));
  57. } catch (e) {
  58. }
  59. }
  60. console.log(req.body.searchStr)
  61. db.all(`SELECT id, uuid, song_name, album_name, artist
  62. FROM instrument_entry
  63. WHERE song_name like '%${req.body.searchStr}%'
  64. or album_name like '%${req.body.searchStr}%'
  65. or artist like '%${req.body.searchStr}%'`, OnFetched)
  66. })
  67. app.post('/fetch', function (req, res) {
  68. function Provider(err, rows) {
  69. try {
  70. res.header("Access-Control-Allow-Origin", "*");
  71. console.log(rows[0].binary)
  72. var str = URL.createObjectURL(new Blob(rows[0].binary))
  73. console.log(str)
  74. res.end(JSON.stringify({data: Buffer.from(rows[0].binary).toString('base64')}));
  75. } catch (e) {
  76. console.log(e)
  77. console.log("Triggered err");
  78. }
  79. }
  80. console.log(req.body.uuid)
  81. db.all(`SELECT "binary"
  82. FROM instrument_entry
  83. WHERE uuid = '${req.body.uuid}'`, Provider)
  84. })
  85. app.options('/fetch', function (req, res) {
  86. res.header("Access-Control-Allow-Origin", "*");
  87. res.header("Access-Control-Allow-Headers", "Content-Type");
  88. res.end()
  89. })
  90. app.options('/search_api', function (req, res) {
  91. res.header("Access-Control-Allow-Origin", "*");
  92. res.header("Access-Control-Allow-Headers", "Content-Type");
  93. res.end()
  94. })
  95. app_serve.get('/:uuid', function (req, res) {
  96. async function Provider(err, rows) {
  97. try {
  98. res.header("Access-Control-Allow-Origin", "*");
  99. /** @type {ArrayBuffer}*/
  100. var buffer = rows[0].binary
  101. res.setHeader('Content-Length', buffer.byteLength);
  102. db.all(`SELECT "song_name"
  103. FROM instrument_entry
  104. WHERE uuid = '${req.params.uuid}'`, (err, row) => {
  105. res.setHeader('Content-Disposition', 'attachment; filename=' + encodeURI(row[0].song_name)+'.mp3' );
  106. res.send(buffer)
  107. res.end()
  108. })
  109. } catch (e) {
  110. console.log(e)
  111. console.log("Triggered err");
  112. }
  113. }
  114. db.all(`SELECT "binary"
  115. FROM instrument_entry
  116. WHERE uuid = '${req.params.uuid}'`, Provider)
  117. })
  118. https.createServer({
  119. key: fs.readFileSync('andyxie.cn.key'),
  120. cert: fs.readFileSync('andyxie.cn.pem')
  121. },app).listen(8080)
  122. app_serve.listen(8079)