mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-10-27 11:18:14 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			48 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| const sanitizeHtml = require('../libs/sanitizeHtml')
 | |
| const { entities } = require('./htmlEntities')
 | |
| 
 | |
| /**
 | |
|  *
 | |
|  * @param {string} html
 | |
|  * @returns {string}
 | |
|  * @throws {Error} if input is not a string
 | |
|  */
 | |
| function sanitize(html) {
 | |
|   if (typeof html !== 'string') {
 | |
|     throw new Error('sanitizeHtml: input must be a string')
 | |
|   }
 | |
| 
 | |
|   const sanitizerOptions = {
 | |
|     allowedTags: ['p', 'ol', 'ul', 'li', 'a', 'strong', 'em', 'del', 'br', 'b', 'i'],
 | |
|     disallowedTagsMode: 'discard',
 | |
|     allowedAttributes: {
 | |
|       a: ['href', 'name', 'target']
 | |
|     },
 | |
|     allowedSchemes: ['http', 'https', 'mailto'],
 | |
|     allowProtocolRelative: false
 | |
|   }
 | |
| 
 | |
|   return sanitizeHtml(html, sanitizerOptions)
 | |
| }
 | |
| module.exports.sanitize = sanitize
 | |
| 
 | |
| function stripAllTags(html, shouldDecodeEntities = true) {
 | |
|   const sanitizerOptions = {
 | |
|     allowedTags: [],
 | |
|     disallowedTagsMode: 'discard'
 | |
|   }
 | |
| 
 | |
|   let sanitized = sanitizeHtml(html, sanitizerOptions)
 | |
|   return shouldDecodeEntities ? decodeHTMLEntities(sanitized) : sanitized
 | |
| }
 | |
| module.exports.stripAllTags = stripAllTags
 | |
| 
 | |
| function decodeHTMLEntities(strToDecode) {
 | |
|   return strToDecode.replace(/\&([^;]+);?/g, function (entity) {
 | |
|     if (entity in entities) {
 | |
|       return entities[entity]
 | |
|     }
 | |
|     return entity
 | |
|   })
 | |
| }
 |