fix: sanitize SVG uploads
This commit is contained in:
25
server/jobs/sanitize-svg.js
Normal file
25
server/jobs/sanitize-svg.js
Normal file
@@ -0,0 +1,25 @@
|
||||
const fs = require('fs-extra')
|
||||
const { JSDOM } = require('jsdom')
|
||||
const createDOMPurify = require('dompurify')
|
||||
|
||||
/* global WIKI */
|
||||
|
||||
module.exports = async (svgPath) => {
|
||||
WIKI.logger.info(`Sanitizing SVG file upload...`)
|
||||
|
||||
try {
|
||||
let svgContents = await fs.readFile(svgPath, 'utf8')
|
||||
|
||||
const window = new JSDOM('').window
|
||||
const DOMPurify = createDOMPurify(window)
|
||||
|
||||
svgContents = DOMPurify.sanitize(svgContents)
|
||||
|
||||
await fs.writeFile(svgPath, svgContents)
|
||||
WIKI.logger.info(`Sanitized SVG file upload: [ COMPLETED ]`)
|
||||
} catch (err) {
|
||||
WIKI.logger.error(`Failed to sanitize SVG file upload: [ FAILED ]`)
|
||||
WIKI.logger.error(err.message)
|
||||
throw err
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user