Skip to content

Commit

Permalink
imp: improved types and utils
Browse files Browse the repository at this point in the history
  • Loading branch information
ssi02014 committed Nov 7, 2024
1 parent 211ffb5 commit a0af948
Show file tree
Hide file tree
Showing 12 changed files with 162 additions and 144 deletions.
44 changes: 23 additions & 21 deletions dist/purify.cjs.js

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion dist/purify.cjs.js.map

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

44 changes: 23 additions & 21 deletions dist/purify.es.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -112,15 +112,12 @@ function addToSet(set, array) {
/**
* Clean up an array to harden against CSPP
*
* @param array - The array to be cleaned.
* @returns The cleaned version of the array
* @param {T[]} array - The array to be cleaned.
* @returns {null[]} The cleaned version of the array
*/
function cleanArray(array) {
for (let index = 0; index < array.length; index++) {
const isPropertyExist = objectHasOwnProperty(array, index);
if (!isPropertyExist) {
array[index] = null;
}
array[index] = null;
}
return array;
}
Expand Down Expand Up @@ -496,6 +493,7 @@ function createDOMPurify() {
* _parseConfig
*
* @param {Object} cfg optional config literal
* @returns {void}
*/
// eslint-disable-next-line complexity
const _parseConfig = function _parseConfig() {
Expand Down Expand Up @@ -748,31 +746,32 @@ function createDOMPurify() {
/**
* _removeAttribute
*
* @param {String} name an Attribute name
* @param {Node} node a DOM node
* @param {string} name an Attribute name
* @param {Element} element a DOM node
* @returns {void}
*/
const _removeAttribute = function _removeAttribute(name, node) {
const _removeAttribute = function _removeAttribute(name, element) {
try {
arrayPush(DOMPurify.removed, {
attribute: node.getAttributeNode(name),
from: node
attribute: element.getAttributeNode(name),
from: element
});
} catch (_) {
arrayPush(DOMPurify.removed, {
attribute: null,
from: node
from: element
});
}
node.removeAttribute(name);
element.removeAttribute(name);
// We void attribute values for unremovable "is"" attributes
if (name === 'is' && !ALLOWED_ATTR[name]) {
if (RETURN_DOM || RETURN_DOM_FRAGMENT) {
try {
_forceRemove(node);
_forceRemove(element);
} catch (_) {}
} else {
try {
node.setAttribute(name, '');
element.setAttribute(name, '');
} catch (_) {}
}
}
Expand Down Expand Up @@ -842,16 +841,16 @@ function createDOMPurify() {
* _isClobbered
*
* @param {Node} elm element to check for clobbering attacks
* @return {Boolean} true if clobbered, false if safe
* @return {boolean} true if clobbered, false if safe
*/
const _isClobbered = function _isClobbered(elm) {
return elm instanceof HTMLFormElement && (typeof elm.nodeName !== 'string' || typeof elm.textContent !== 'string' || typeof elm.removeChild !== 'function' || !(elm.attributes instanceof NamedNodeMap) || typeof elm.removeAttribute !== 'function' || typeof elm.setAttribute !== 'function' || typeof elm.namespaceURI !== 'string' || typeof elm.insertBefore !== 'function' || typeof elm.hasChildNodes !== 'function');
};
/**
* Checks whether the given object is a DOM node.
*
* @param {Node} object object to check whether it's a DOM node
* @return {Boolean} true is object is a DOM node
* @param {unknown} object object to check whether it's a DOM node
* @return {boolean} true is object is a DOM node
*/
const _isNode = function _isNode(object) {
return typeof Node === 'function' && object instanceof Node;
Expand All @@ -863,6 +862,7 @@ function createDOMPurify() {
* @param entryPoint Name of the hook's entry point
* @param currentNode node to work on with the hook
* @param {Object} data additional hook parameters
* @returns {void}
*/
function _executeHook(entryPoint, currentNode, data) {
if (!hooks[entryPoint]) {
Expand Down Expand Up @@ -974,7 +974,7 @@ function createDOMPurify() {
* @param {string} lcTag Lowercase tag name of containing element.
* @param {string} lcName Lowercase attribute name.
* @param {string} value Attribute value.
* @return {Boolean} Returns true if `value` is valid, otherwise false.
* @return {boolean} Returns true if `value` is valid, otherwise false.
*/
// eslint-disable-next-line complexity
const _isValidAttribute = function _isValidAttribute(lcTag, lcName, value) {
Expand Down Expand Up @@ -1009,7 +1009,7 @@ function createDOMPurify() {
* for more sophisticated checking see https://github.com/sindresorhus/validate-element-name
*
* @param {string} tagName name of the tag of the node to sanitize
* @returns {boolean} Returns true if the tag name meets the basic criteria for a custom element, otherwise false.
* @returns {RegExpMatchArray} Returns true if the tag name meets the basic criteria for a custom element, otherwise false.
*/
const _isBasicCustomElement = function _isBasicCustomElement(tagName) {
return tagName !== 'annotation-xml' && stringMatch(tagName, CUSTOM_ELEMENT);
Expand All @@ -1022,7 +1022,8 @@ function createDOMPurify() {
* @protect removeAttribute
* @protect setAttribute
*
* @param {Node} currentNode to sanitize
* @param {Element} currentNode to sanitize
* @returns {void}
*/
const _sanitizeAttributes = function _sanitizeAttributes(currentNode) {
/* Execute a hook if present */
Expand Down Expand Up @@ -1138,6 +1139,7 @@ function createDOMPurify() {
* _sanitizeShadowDOM
*
* @param {DocumentFragment} fragment to iterate over recursively
* @returns {void}
*/
const _sanitizeShadowDOM = function _sanitizeShadowDOM(fragment) {
let shadowNode = null;
Expand Down
2 changes: 1 addition & 1 deletion dist/purify.es.mjs.map

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Loading

0 comments on commit a0af948

Please sign in to comment.