main.js 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. const fs = require('fs');
  2. const express = require('express');
  3. const app = express();
  4. const app_serve = express();
  5. const mysql = require('mysql2')
  6. const db = mysql.createConnection({
  7. host: 'mc.andyxie.cn', user: 'instrunet', password: 'Moyingren2015', database: "instrunet_data"
  8. })
  9. const bodyParser = require("body-parser");
  10. const nrc = require('node-run-cmd')
  11. const https = require("node:https");
  12. app.use(bodyParser.json({"limit": "200mb"}));
  13. app.use(express.json());
  14. app_serve.use(bodyParser.json({"limit": "200mb"}));
  15. app_serve.use(express.json());
  16. app.post('/submit', function (req, res) {
  17. db.connect(function (err) {
  18. console.log(err);
  19. })
  20. res.header("Access-Control-Allow-Origin", "*");
  21. try {
  22. fetch(req.body.file).then(res => {
  23. res.arrayBuffer().then(r => fs.writeFileSync("./audio_file", Buffer.from(r)));
  24. })
  25. res.end("api_success");
  26. } catch (err) {
  27. res.status(500).send("Server Error");
  28. return
  29. }
  30. const callback = function (d) {
  31. console.log(d.toString());
  32. }
  33. const errcb = function (d) {
  34. console.log(d.toString());
  35. }
  36. let kind_of = "";
  37. switch (req.body.kind) {
  38. case 0:
  39. kind_of = "audio-separator ./audio_file --model_filename UVR-MDX-NET-Inst_HQ_5.onnx --mdx_segment_size 4000 --mdx_overlap 0.85 --output_format MP3 --mdx_batch_size 20 --output_dir output"
  40. break;
  41. case 1:
  42. kind_of = "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 "
  43. break;
  44. }
  45. 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 "], {
  46. onData: callback,
  47. onError: errcb
  48. }).then(() => {
  49. db.execute(("INSERT INTO instrunet_entry (uuid, song_name, album_name, link_to, databinary, artist,kind) VALUES (?,?,?,?,?,?,?)"), [crypto.randomUUID(), req.body.name, req.body.albumName, req.body.link, fs.readFileSync('./output/audio_file_(Instrumental)_UVR_MDXNET_KARA.mp3'), req.body.artist, req.body.kind])
  50. db.unprepare()
  51. })
  52. })
  53. /**
  54. * @openapi
  55. * /submit:
  56. * options:
  57. * description: Fuck You Google.
  58. */
  59. app.options('/submit', function (req, res) {
  60. res.header("Access-Control-Allow-Origin", "*");
  61. res.header("Access-Control-Allow-Headers", "Content-Type");
  62. res.end()
  63. })
  64. app.post('/search_api', function (req, res) {
  65. function OnFetched(err, rows) {
  66. try {
  67. res.header("Access-Control-Allow-Origin", "*");
  68. res.end(JSON.stringify(rows));
  69. } catch (e) {
  70. }
  71. }
  72. db.execute(`SELECT uuid, song_name, album_name, artist, kind
  73. FROM instrunet_entry
  74. WHERE song_name like '%${req.body.searchStr}%'
  75. or album_name like '%${req.body.searchStr}%'
  76. or artist like '%${req.body.searchStr}%'`, OnFetched)
  77. db.unprepare()
  78. })
  79. app.options('/search_api', function (req, res) {
  80. res.header("Access-Control-Allow-Origin", "*");
  81. res.header("Access-Control-Allow-Headers", "Content-Type");
  82. res.end()
  83. })
  84. app_serve.get('/:uuid', function (req, res) {
  85. async function Provider(err, rows) {
  86. try {
  87. res.header("Access-Control-Allow-Origin", "*");
  88. /** @type {ArrayBuffer}*/
  89. let buffer = rows[0].databinary
  90. res.setHeader('Content-Length', buffer.byteLength);
  91. db.execute(`SELECT song_name
  92. FROM instrunet_entry
  93. WHERE uuid = '${req.params.uuid}'`, (err, row) => {
  94. res.setHeader('Content-Disposition', 'attachment; filename=' + encodeURI(row[0].song_name) + '.mp3');
  95. res.send(buffer)
  96. res.end()
  97. })
  98. db.unprepare()
  99. } catch (e) {
  100. console.log(e)
  101. console.log("Triggered err");
  102. }
  103. }
  104. db.execute(`SELECT databinary
  105. FROM instrunet_entry
  106. WHERE uuid = '${req.params.uuid}'`, Provider)
  107. db.unprepare()
  108. })
  109. https.createServer({
  110. key: fs.readFileSync('andyxie.cn.key'),
  111. cert: fs.readFileSync('andyxie.cn.pem')
  112. }, app).listen(8080)
  113. // app.listen(8080)
  114. app_serve.listen(8079)