el.xwx.moe/api/server.js

91 lines
1.8 KiB
JavaScript

const express = require('express');
const app = express();
const { MongoClient } = require('mongodb');
const cors = require('cors');
const config = require('../src/config.json');
const getData = require('./modules/getData.js')
const port = config.api.port;
const URI = config.api.mongodb_URI;
const database = config.api.database_name;
const collection = config.api.collection_name;
const client = new MongoClient(URI);
app.use(cors());
app.use(express.json());
app.get('/api', async (req, res) => {
const data = await getDoc();
res.send(data);
});
app.post('/api', async (req, res) => {
const pageToVisit = req.body.link;
try {
const dataResult = await getData(pageToVisit, req.body._id);
req.body.title = dataResult;
insertDoc(req.body);
} catch (err) {
console.log(err);
insertDoc(req.body);
} finally {
res.send('DONE!');
}
});
app.delete('/api', async (req, res) => {
const id = req.body.id.toString();
await deleteDoc(id);
res.send(`Bookmark with _id:${id} deleted.`);
});
async function insertDoc(doc) {
try {
const db = client.db(database);
const list = db.collection(collection);
const result = await list.insertOne(doc);
}
catch(err) {
console.log(err);
}
}
async function getDoc() {
try {
const db = client.db(database);
const list = db.collection(collection);
const result = await list.find({}).toArray();
return result;
}
catch(err) {
console.log(err);
}
}
async function deleteDoc(doc) {
try {
const db = client.db(database);
const list = db.collection(collection);
const result = await list.deleteOne({"_id": doc});
return result;
}
catch(err) {
console.log(err);
}
}
app.listen(port, () => {
console.log(`Success! running on port ${port}.`);
client.connect();
});