-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathserver.js
55 lines (47 loc) · 1.52 KB
/
server.js
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
import 'dotenv/config';
import express from 'express';
import crate from 'node-crate';
const { PORT, CRATE_URL } = process.env;
// Connect to CrateDB.
crate.connect(CRATE_URL);
// Initialize Express.
const app = express();
app.set('views', new URL('./views', import.meta.url).pathname);
app.set('view engine', 'ejs');
app.use(express.static('static'));
app.use(express.json());
// Serve the home page.
app.get('/', async (req, res) => {
return res.render('homepage');
});
// Perform a geospatial search and return the results.
app.post('/search', async (req, res) => {
try {
let results;
// Let's see what sort of request this is...
if (req.body.point) {
// Simple point, use a WITHIN query.
results = await crate.execute(
'SELECT name, boundaries, forecast from shipping_forecast.regions WHERE WITHIN(?, boundaries) LIMIT 1',
[ req.body.point.geometry ]
);
} else if (req.body.shape) {
// User supplied a shape (polygon or polyine)
// Expects the body to be a GeoJSON representation:
// https://en.wikipedia.org/wiki/GeoJSON
results = await crate.execute(
'SELECT * FROM shipping_forecast.regions WHERE INTERSECTS(?, boundaries)',
[ req.body.shape.geometry ]
);
}
return res.json({ data: results.json });
} catch (e) {
// Probably an unparsable polygon.
console.error(e);
return res.json({ data: [] });
}
});
// Start the Express server.
app.listen(PORT, () => {
console.log(`Server listening on port ${PORT}.`);
});