mit.db/index.js

95 lines
1.9 KiB
JavaScript
Raw Normal View History

2022-07-05 01:30:38 +02:00
var client = [];
2022-07-04 19:37:50 +02:00
client.config = require('./config.js').settings;
const MapDB = require('quickmap.db');
const db = new MapDB('database.json');
2022-07-05 13:26:02 +02:00
async function setup() {
var isset = await db.get('client.issetupped')
if (!isset) {
await db.set('client.issetupped', true)
}
}
setup()
2022-07-05 13:27:19 +02:00
/*
2022-07-04 19:37:50 +02:00
var fs = require('fs');
var data = fs.readFileSync('./data/database.json');
2022-07-05 13:27:19 +02:00
var elements = JSON.parse(data); */
2022-07-04 19:37:50 +02:00
const express = require("express");
const app = express();
const cors=require('cors');
app.listen(client.config.port,
() => console.log("Server Start at the port "+client.config.port));
app.use(express.static('public'));
app.use(cors());
async function authenticate(token) {
if (!client.config.auth.includes(token)) {
return;
}
}
// All dates in the database
app.get('/api/:auth/database', alldata);
function alldata(request, response) {
var token = request.params.auth;
authenticate(token)
response.send(elements);
}
// One element in the database
app.get('/api/:auth/database/:element/', searchElement);
2022-07-05 01:29:50 +02:00
async function searchElement(request, response) {
2022-07-04 19:37:50 +02:00
var token = request.params.auth;
authenticate(token)
var word = request.params.element;
var elements = await db.get(word)
if(elements[word]) {
var reply = elements[word];
}
else {
var reply = {
status:"Not Found"
}
}
response.send(reply);
}
// Set a db variable
app.get('/api/:auth/database/:element/set/:data', set);
async function set(request, response) {
var token = request.params.auth;
authenticate(token)
var element = request.params.element;
var data = request.params.data;
await db.set(element, data)
const res = await db.get(element)
if(res) {
var reply = res;
}
else {
var reply = {
status:"Not Found"
}
}
response.send(reply);
2022-07-05 01:29:03 +02:00
}