a31106378357b7b9cc44f2317010f9295f5b039d
Gitcub / server.js
'use strict';
const express = require('express');
const next = require('next');
const fs = require('fs');
const path = require('path');
const sqlite3 = require('sqlite3').verbose();
const repositoryDirectory = './user-content-access/';
const dbFile = './gitcub.db';
const dev = process.env.NODE_ENV !== 'production';
const port = 3000;
const app = next({ dev });
const handle = app.getRequestHandler();
const directoryExists = (path) => fs.existsSync(path) ? fs.statSync(path).isDirectory() : false;
const repositoryExists = (name, rows) => (
directoryExists(repositoryDirectory + name) && rows.some((x) => x.name === name)
);
const pathIsValid = (pathArray, rows) => {
if (pathArray.length > 0) {
if (repositoryExists(pathArray[0], rows)) {
if (directoryExists(repositoryDirectory + pathArray.join('/'))) {
return true;
} else return false;
} else return false;
} else return false;
}
const getAPIResult = (req, rows) => {
if (req.originalUrl.indexOf('\0') === -1) {
const pathNormalized = path.normalize(req.path);
const pathArray = pathNormalized.split('/').filter((x) => x.length > 0);
// remove 'api'
pathArray.shift();
if (pathIsValid(pathArray, rows)) {
const dirList = fs.readdirSync(
repositoryDirectory + pathArray.join('/'),
(err, files) => {
if (err) {
console.log(err);
} else return files;
}
);
const APIResult = {
resultType: 'data',
resultContent: dirList,
}
return APIResult;
} else {
const APIResult = {
resultType: 'error',
resultContent: 'Repository does not exist.',
}
return APIResult;
}
} else {
const APIResult = {
resultType: 'error',
resultContent: 'Null byte found in url. Nice try :)',
}
return APIResult;
}
}
app.prepare()
.then(() => {
const server = express();
const db = new sqlite3.Database(dbFile, sqlite3.OPEN_READWRITE);
server.get('/api/*', (req, res) => {
db.all('select name from repositories', (err, rows) => {
const APIResult = getAPIResult(req, rows);
res.json(APIResult);
});
});
server.get('*', (req, res) => {
return handle(req, res);
});
server.listen(port, () => {
console.log(`Example app listening on port ${port}`);
});
})
.catch((ex) => {
console.error(ex.stack);
process.exit(1);
});
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99