26 lines
681 B
JavaScript
26 lines
681 B
JavaScript
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
|
|
}
|
|
}
|