sanitizehtml on event description
This commit is contained in:
@@ -4,6 +4,7 @@ const crypto = require('crypto')
|
|||||||
const jwt = require('jsonwebtoken')
|
const jwt = require('jsonwebtoken')
|
||||||
const { Op } = require('sequelize')
|
const { Op } = require('sequelize')
|
||||||
const jsonwebtoken = require('jsonwebtoken')
|
const jsonwebtoken = require('jsonwebtoken')
|
||||||
|
const sanitizeHtml = require('sanitize-html')
|
||||||
const config = require('config')
|
const config = require('config')
|
||||||
const mail = require('../mail')
|
const mail = require('../mail')
|
||||||
const { user: User, event: Event, tag: Tag, place: Place } = require('../models')
|
const { user: User, event: Event, tag: Tag, place: Place } = require('../models')
|
||||||
@@ -65,12 +66,15 @@ const userController = {
|
|||||||
* add event
|
* add event
|
||||||
*/
|
*/
|
||||||
async addEvent (req, res) {
|
async addEvent (req, res) {
|
||||||
|
if (req.err) {
|
||||||
|
debug(req.err)
|
||||||
|
return res.status(400).json(req.err.toString())
|
||||||
|
}
|
||||||
const body = req.body
|
const body = req.body
|
||||||
|
|
||||||
const eventDetails = {
|
const eventDetails = {
|
||||||
title: body.title,
|
title: body.title,
|
||||||
// remove html tags
|
// remove html tags
|
||||||
description: body.description ? body.description.replace(/(<([^>]+)>)/ig, '') : '',
|
description: sanitizeHtml(body.description),
|
||||||
multidate: body.multidate,
|
multidate: body.multidate,
|
||||||
start_datetime: body.start_datetime,
|
start_datetime: body.start_datetime,
|
||||||
end_datetime: body.end_datetime,
|
end_datetime: body.end_datetime,
|
||||||
@@ -88,8 +92,10 @@ const userController = {
|
|||||||
// create place if needed
|
// create place if needed
|
||||||
let place
|
let place
|
||||||
try {
|
try {
|
||||||
place = await Place.findOrCreate({ where: { name: body.place_name },
|
place = await Place.findOrCreate({
|
||||||
defaults: { address: body.place_address } })
|
where: { name: body.place_name },
|
||||||
|
defaults: { address: body.place_address }
|
||||||
|
})
|
||||||
.spread((place, created) => place)
|
.spread((place, created) => place)
|
||||||
await event.setPlace(place)
|
await event.setPlace(place)
|
||||||
event.place = place
|
event.place = place
|
||||||
@@ -124,6 +130,9 @@ const userController = {
|
|||||||
},
|
},
|
||||||
|
|
||||||
async updateEvent (req, res) {
|
async updateEvent (req, res) {
|
||||||
|
if (req.err) {
|
||||||
|
return res.status(400).json(req.err.toString())
|
||||||
|
}
|
||||||
const body = req.body
|
const body = req.body
|
||||||
const event = await Event.findByPk(body.id)
|
const event = await Event.findByPk(body.id)
|
||||||
if (!req.user.is_admin && event.userId !== req.user.id) {
|
if (!req.user.is_admin && event.userId !== req.user.id) {
|
||||||
@@ -140,15 +149,15 @@ const userController = {
|
|||||||
body.image_path = req.file.filename
|
body.image_path = req.file.filename
|
||||||
}
|
}
|
||||||
|
|
||||||
body.description = body.description
|
body.description = sanitizeHtml(body.description)
|
||||||
.replace(/(<([^>]+)>)/ig, '') // remove all tags from description
|
|
||||||
|
|
||||||
await event.update(body)
|
await event.update(body)
|
||||||
let place
|
let place
|
||||||
try {
|
try {
|
||||||
place = await Place.findOrCreate({ where: { name: body.place_name },
|
place = await Place.findOrCreate({
|
||||||
defaults: { address: body.place_address } })
|
where: { name: body.place_name },
|
||||||
.spread((place, created) => place)
|
defaults: { address: body.place_address }
|
||||||
|
}).spread((place, created) => place)
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
console.log('error', e)
|
console.log('error', e)
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user