upload server into github

This commit is contained in:
Nikiroy78 2023-03-19 14:01:35 +03:00
parent 02014d4194
commit c5da9f3265
7 changed files with 90 additions and 12 deletions

1
.gitignore vendored
View File

@ -1,2 +1 @@
node_modules/
root/*.*

28
command-executor.js Normal file
View File

@ -0,0 +1,28 @@
const fs = require('fs');
const mime = require('mime');
const route = (app, options, path, facticalPath) => {
app.get(path, async (req, res) => {
let data = fs.readFileSync(`./root${facticalPath}`);
let mimeType = mime.getType(`./root${facticalPath}`);
res.set('Content-Type', mimeType);
res.send(data);
});
}
module.exports = (app, options) => ({
exec : (command) => {
switch (command.split(' ')[0]) {
case '':
return;
case 'route':
return route(app, options,
command.split(' ')[1],
command.split(' ')[2]
);
default:
throw new Error(`Unknown command: ${command.split(' ')[0]}`);
}
}
});

1
init.txt Normal file
View File

@ -0,0 +1 @@
route /page /page.html

33
package-lock.json generated
View File

@ -5,7 +5,8 @@
"packages": {
"": {
"dependencies": {
"express": "^4.18.2"
"express": "^4.18.2",
"mime": "^3.0.0"
}
},
"node_modules/accepts": {
@ -326,14 +327,14 @@
}
},
"node_modules/mime": {
"version": "1.6.0",
"resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
"integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==",
"version": "3.0.0",
"resolved": "https://registry.npmjs.org/mime/-/mime-3.0.0.tgz",
"integrity": "sha512-jSCU7/VB1loIWBZe14aEYHU/+1UMEHoaO7qxCOVJOw9GgH72VAWppxNcjU+x9a2k3GSIBXNKxXQFqRvvZ7vr3A==",
"bin": {
"mime": "cli.js"
},
"engines": {
"node": ">=4"
"node": ">=10.0.0"
}
},
"node_modules/mime-db": {
@ -495,6 +496,17 @@
"node": ">= 0.8.0"
}
},
"node_modules/send/node_modules/mime": {
"version": "1.6.0",
"resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
"integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==",
"bin": {
"mime": "cli.js"
},
"engines": {
"node": ">=4"
}
},
"node_modules/send/node_modules/ms": {
"version": "2.1.3",
"resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",
@ -830,9 +842,9 @@
"integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w=="
},
"mime": {
"version": "1.6.0",
"resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
"integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg=="
"version": "3.0.0",
"resolved": "https://registry.npmjs.org/mime/-/mime-3.0.0.tgz",
"integrity": "sha512-jSCU7/VB1loIWBZe14aEYHU/+1UMEHoaO7qxCOVJOw9GgH72VAWppxNcjU+x9a2k3GSIBXNKxXQFqRvvZ7vr3A=="
},
"mime-db": {
"version": "1.52.0",
@ -943,6 +955,11 @@
"statuses": "2.0.1"
},
"dependencies": {
"mime": {
"version": "1.6.0",
"resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz",
"integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg=="
},
"ms": {
"version": "2.1.3",
"resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz",

View File

@ -1,5 +1,6 @@
{
"dependencies": {
"express": "^4.18.2"
"express": "^4.18.2",
"mime": "^3.0.0"
}
}

4
readme.md Normal file
View File

@ -0,0 +1,4 @@
## List of commands (init.txt)
```
route <file> <path> | Routing to path with file
```

View File

@ -1,10 +1,38 @@
const express = require('express');
const fs = require('fs');
var app = express();
app.use(express.static('root'));
const port = !process.argv[2] ? 3000 : Number.isInteger(Number(process.argv[2])) ? Number(process.argv[2]) : 3000
fs.readFile("./init.txt", "utf8", async (err, data) => {
if (err) {
throw err;
}
else {
// console.log(data);
let commands = data.split('\n');
let options = {
// dotfiles: 'ignore',
// etag: false,
// extensions: ['htm', 'html'],
// index: "index.html",
// maxAge: '1d',
// redirect: true,
// setHeaders: async (res, path, stat) => {
// res.set('ЗАГОЛОВОК', ДАННЫЕ) СДЕЛАЕМ ПОЗЖЕ
// }
};
let executor = require('./command-executor')(app, options);
for (let command of commands) {
executor.exec(command);
}
app.use(express.static('root', options));
}
});
app.listen(
port, (err) => {
if (err) throw err;