mirror of
				https://github.com/advplyr/audiobookshelf.git
				synced 2025-11-04 03:17:00 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			40 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
const sanitizeHtml = require('../libs/sanitizeHtml')
 | 
						|
const { entities } = require("./htmlEntities");
 | 
						|
 | 
						|
function sanitize(html) {
 | 
						|
  const sanitizerOptions = {
 | 
						|
    allowedTags: [
 | 
						|
      'p', 'ol', 'ul', 'li', 'a', 'strong', 'em', 'del', 'br'
 | 
						|
    ],
 | 
						|
    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;
 | 
						|
  })
 | 
						|
}
 |