Merge branch 'develop' into feature/api-helpers

This commit is contained in:
Maciej Ziarkowski 2020-01-02 15:44:35 +00:00
commit 00c77bfca7
4 changed files with 33 additions and 18 deletions

View File

@ -1,5 +1,6 @@
import express from 'express'; import express from 'express';
import { parseIntParam } from '../helpers';
import asyncController from '../routes/asyncController'; import asyncController from '../routes/asyncController';
import * as buildingService from '../services/building'; import * as buildingService from '../services/building';
import * as userService from '../services/user'; import * as userService from '../services/user';
@ -34,9 +35,10 @@ const getBuildingsByReference = asyncController(async (req: express.Request, res
// GET individual building, POST building updates // GET individual building, POST building updates
const getBuildingById = asyncController(async (req: express.Request, res: express.Response) => { const getBuildingById = asyncController(async (req: express.Request, res: express.Response) => {
const { building_id } = req.params; const buildingId = parseIntParam(req.params.building_id);
try { try {
const result = await buildingService.getBuildingById(building_id); const result = await buildingService.getBuildingById(buildingId);
res.send(result); res.send(result);
} catch(error) { } catch(error) {
console.error(error); console.error(error);
@ -61,11 +63,12 @@ const updateBuildingById = asyncController(async (req: express.Request, res: exp
}); });
async function updateBuilding(req: express.Request, res: express.Response, userId: string) { async function updateBuilding(req: express.Request, res: express.Response, userId: string) {
const { building_id } = req.params; const buildingId = parseIntParam(req.params.building_id);
const buildingUpdate = req.body; const buildingUpdate = req.body;
try { try {
const building = await buildingService.saveBuilding(building_id, buildingUpdate, userId); const building = await buildingService.saveBuilding(buildingId, buildingUpdate, userId);
if (typeof (building) === 'undefined') { if (typeof (building) === 'undefined') {
return res.send({ error: 'Database error' }); return res.send({ error: 'Database error' });
@ -81,9 +84,10 @@ async function updateBuilding(req: express.Request, res: express.Response, userI
// GET building UPRNs // GET building UPRNs
const getBuildingUPRNsById = asyncController(async (req: express.Request, res: express.Response) => { const getBuildingUPRNsById = asyncController(async (req: express.Request, res: express.Response) => {
const { building_id } = req.params; const buildingId = parseIntParam(req.params.building_id);
try { try {
const result = await buildingService.getBuildingUPRNsById(building_id); const result = await buildingService.getBuildingUPRNsById(buildingId);
if (typeof (result) === 'undefined') { if (typeof (result) === 'undefined') {
return res.send({ error: 'Database error' }); return res.send({ error: 'Database error' });
@ -100,9 +104,11 @@ const getBuildingLikeById = asyncController(async (req: express.Request, res: ex
if (!req.session.user_id) { if (!req.session.user_id) {
return res.send({ like: false }); // not logged in, so cannot have liked return res.send({ like: false }); // not logged in, so cannot have liked
} }
const { building_id } = req.params;
const buildingId = parseIntParam(req.params.building_id);
try { try {
const like = await buildingService.getBuildingLikeById(building_id, req.session.user_id); const like = await buildingService.getBuildingLikeById(buildingId, req.session.user_id);
// any value returned means like // any value returned means like
res.send({ like: like }); res.send({ like: like });
@ -112,9 +118,10 @@ const getBuildingLikeById = asyncController(async (req: express.Request, res: ex
}); });
const getBuildingEditHistoryById = asyncController(async (req: express.Request, res: express.Response) => { const getBuildingEditHistoryById = asyncController(async (req: express.Request, res: express.Response) => {
const { building_id } = req.params; const buildingId = parseIntParam(req.params.building_id);
try { try {
const editHistory = await buildingService.getBuildingEditHistory(building_id); const editHistory = await buildingService.getBuildingEditHistory(buildingId);
res.send({ history: editHistory }); res.send({ history: editHistory });
} catch(error) { } catch(error) {
@ -127,13 +134,13 @@ const updateBuildingLikeById = asyncController(async (req: express.Request, res:
return res.send({ error: 'Must be logged in' }); return res.send({ error: 'Must be logged in' });
} }
const { building_id } = req.params; const buildingId = parseIntParam(req.params.building_id);
const { like } = req.body; const { like } = req.body;
try { try {
const building = like ? const building = like ?
await buildingService.likeBuilding(building_id, req.session.user_id) : await buildingService.likeBuilding(buildingId, req.session.user_id) :
await buildingService.unlikeBuilding(building_id, req.session.user_id); await buildingService.unlikeBuilding(buildingId, req.session.user_id);
if (building.error) { if (building.error) {
return res.send(building); return res.send(building);

View File

@ -1,5 +1,6 @@
import express from 'express'; import express from 'express';
import { parseIntParam } from '../helpers';
import asyncController from '../routes/asyncController'; import asyncController from '../routes/asyncController';
import * as dataExtractService from '../services/dataExtract'; import * as dataExtractService from '../services/dataExtract';
@ -15,7 +16,7 @@ const getAllDataExtracts = asyncController(async function(req: express.Request,
const getDataExtract = asyncController(async function(req: express.Request, res: express.Response) { const getDataExtract = asyncController(async function(req: express.Request, res: express.Response) {
try { try {
const extractId = req.params.extract_id; const extractId = parseIntParam(req.params.extract_id);
const extract = await dataExtractService.getDataExtractById(extractId); const extract = await dataExtractService.getDataExtractById(extractId);
res.send({ extract: extract }); res.send({ extract: extract });
} catch (err) { } catch (err) {

9
app/src/api/helpers.ts Normal file
View File

@ -0,0 +1,9 @@
import { strictParseInt } from '../parse';
export function parseIntParam(param: string) {
const result = strictParseInt(param);
if (isNaN(result)) {
throw new Error('Invalid parameter format: not an integer');
}
return result;
}

View File

@ -6,13 +6,11 @@ import './welcome.css';
const Welcome = () => ( const Welcome = () => (
<div className="jumbotron welcome-float"> <div className="jumbotron welcome-float">
<h1 className="h1">Welcome to Colouring London</h1> <h1 className="h1">Welcome to Colouring London</h1>
<p className="lead"> <p className="lead">
Colouring London is a knowledge exchange platform collecting information on every Colouring London is a knowledge exchange platform set up by University College London to help make the city more sustainable. It provides open statistical data on the characteristics of the city's buildings and on the dynamic behaviour of the stock. We're working to collate, collect, generate, verify over fifty types of data and to visualise many of these datasets.
building in London, to help make the city more sustainable. We're developing it at University College London. Can you help us? We're looking for volunteers of all ages and abilities to help test the site and colour the buildings in.
</p> </p>
<p className="lead"> <p className="lead">
Our building data comes from many different sources. Though we are unable to vouch for their accuracy, we are currently experimenting with a range of features including 'data source', 'edit history', and 'entry verification', to assist you in checking reliability and judging how suitable the data are for your intended use. Our information comes from many different sources. As we are unable to vouch for data accuracy, we are currently experimenting with a range of features including 'data source', 'edit history', and 'entry verification', to assist you in checking reliability and judging how suitable the data are for your intended use. Your help in checking and adding data is very much appreciated.
</p> </p>
<p className="lead"> <p className="lead">
All data we collect are made <Link to="/data-extracts.html">openly available</Link>. We just ask you to credit Colouring London and read our <a href="https://www.pages.colouring.london/data-ethics">data ethics policy</a> when using or sharing our data, maps or <a href="https://github.com/tomalrussell/colouring-london">code</a>. All data we collect are made <Link to="/data-extracts.html">openly available</Link>. We just ask you to credit Colouring London and read our <a href="https://www.pages.colouring.london/data-ethics">data ethics policy</a> when using or sharing our data, maps or <a href="https://github.com/tomalrussell/colouring-london">code</a>.