Skip to content

Commit

Permalink
Merge pull request #1054 from davecardwell/main
Browse files Browse the repository at this point in the history
feat: allow specifying a hook with `removeHook()`
  • Loading branch information
cure53 authored Dec 28, 2024
2 parents 0ce2d47 + 1b0935e commit 0455d21
Show file tree
Hide file tree
Showing 13 changed files with 143 additions and 54 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -427,7 +427,7 @@ Feature releases will not be announced to this list.
Many people helped and help DOMPurify become what it is and need to be acknowledged here!
[hash_kitten ❤️](https://twitter.com/hash_kitten), [kevin_mizu ❤️](https://twitter.com/kevin_mizu), [icesfont ❤️](/~https://github.com/icesfont), [reduckted ❤️](/~https://github.com/reduckted), [dcramer 💸](/~https://github.com/dcramer), [JGraph 💸](/~https://github.com/jgraph), [baekilda 💸](/~https://github.com/baekilda), [Healthchecks 💸](/~https://github.com/healthchecks), [Sentry 💸](/~https://github.com/getsentry), [jarrodldavis 💸](/~https://github.com/jarrodldavis), [CynegeticIO](/~https://github.com/CynegeticIO), [ssi02014 ❤️](/~https://github.com/ssi02014), [GrantGryczan](/~https://github.com/GrantGryczan), [Lowdefy](https://twitter.com/lowdefy), [granlem](https://twitter.com/MaximeVeit), [oreoshake](/~https://github.com/oreoshake), [tdeekens ❤️](/~https://github.com/tdeekens), [peernohell ❤️](/~https://github.com/peernohell), [is2ei](/~https://github.com/is2ei), [SoheilKhodayari](/~https://github.com/SoheilKhodayari), [franktopel](/~https://github.com/franktopel), [NateScarlet](/~https://github.com/NateScarlet), [neilj](/~https://github.com/neilj), [fhemberger](/~https://github.com/fhemberger), [Joris-van-der-Wel](/~https://github.com/Joris-van-der-Wel), [ydaniv](/~https://github.com/ydaniv), [terjanq](https://twitter.com/terjanq), [filedescriptor](/~https://github.com/filedescriptor), [ConradIrwin](/~https://github.com/ConradIrwin), [gibson042](/~https://github.com/gibson042), [choumx](/~https://github.com/choumx), [0xSobky](/~https://github.com/0xSobky), [styfle](/~https://github.com/styfle), [koto](/~https://github.com/koto), [tlau88](/~https://github.com/tlau88), [strugee](/~https://github.com/strugee), [oparoz](/~https://github.com/oparoz), [mathiasbynens](/~https://github.com/mathiasbynens), [edg2s](/~https://github.com/edg2s), [dnkolegov](/~https://github.com/dnkolegov), [dhardtke](/~https://github.com/dhardtke), [wirehead](/~https://github.com/wirehead), [thorn0](/~https://github.com/thorn0), [styu](/~https://github.com/styu), [mozfreddyb](/~https://github.com/mozfreddyb), [mikesamuel](/~https://github.com/mikesamuel), [jorangreef](/~https://github.com/jorangreef), [jimmyhchan](/~https://github.com/jimmyhchan), [jameydeorio](/~https://github.com/jameydeorio), [jameskraus](/~https://github.com/jameskraus), [hyderali](/~https://github.com/hyderali), [hansottowirtz](/~https://github.com/hansottowirtz), [hackvertor](/~https://github.com/hackvertor), [freddyb](/~https://github.com/freddyb), [flavorjones](/~https://github.com/flavorjones), [djfarrelly](/~https://github.com/djfarrelly), [devd](/~https://github.com/devd), [camerondunford](/~https://github.com/camerondunford), [buu700](/~https://github.com/buu700), [buildog](/~https://github.com/buildog), [alabiaga](/~https://github.com/alabiaga), [Vector919](/~https://github.com/Vector919), [Robbert](/~https://github.com/Robbert), [GreLI](/~https://github.com/GreLI), [FuzzySockets](/~https://github.com/FuzzySockets), [ArtemBernatskyy](/~https://github.com/ArtemBernatskyy), [@garethheyes](https://twitter.com/garethheyes), [@shafigullin](https://twitter.com/shafigullin), [@mmrupp](https://twitter.com/mmrupp), [@irsdl](https://twitter.com/irsdl),[ShikariSenpai](/~https://github.com/ShikariSenpai), [ansjdnakjdnajkd](/~https://github.com/ansjdnakjdnajkd), [@asutherland](https://twitter.com/asutherland), [@mathias](https://twitter.com/mathias), [@cgvwzq](https://twitter.com/cgvwzq), [@robbertatwork](https://twitter.com/robbertatwork), [@giutro](https://twitter.com/giutro), [@CmdEngineer\_](https://twitter.com/CmdEngineer_), [@avr4mit](https://twitter.com/avr4mit) and especially [@securitymb ❤️](https://twitter.com/securitymb) & [@masatokinugawa ❤️](https://twitter.com/masatokinugawa)
[hash_kitten ❤️](https://twitter.com/hash_kitten), [kevin_mizu ❤️](https://twitter.com/kevin_mizu), [icesfont ❤️](/~https://github.com/icesfont), [reduckted ❤️](/~https://github.com/reduckted), [dcramer 💸](/~https://github.com/dcramer), [JGraph 💸](/~https://github.com/jgraph), [baekilda 💸](/~https://github.com/baekilda), [Healthchecks 💸](/~https://github.com/healthchecks), [Sentry 💸](/~https://github.com/getsentry), [jarrodldavis 💸](/~https://github.com/jarrodldavis), [CynegeticIO](/~https://github.com/CynegeticIO), [ssi02014 ❤️](/~https://github.com/ssi02014), [GrantGryczan](/~https://github.com/GrantGryczan), [Lowdefy](https://twitter.com/lowdefy), [granlem](https://twitter.com/MaximeVeit), [oreoshake](/~https://github.com/oreoshake), [tdeekens ❤️](/~https://github.com/tdeekens), [peernohell ❤️](/~https://github.com/peernohell), [is2ei](/~https://github.com/is2ei), [SoheilKhodayari](/~https://github.com/SoheilKhodayari), [franktopel](/~https://github.com/franktopel), [NateScarlet](/~https://github.com/NateScarlet), [neilj](/~https://github.com/neilj), [fhemberger](/~https://github.com/fhemberger), [Joris-van-der-Wel](/~https://github.com/Joris-van-der-Wel), [ydaniv](/~https://github.com/ydaniv), [terjanq](https://twitter.com/terjanq), [filedescriptor](/~https://github.com/filedescriptor), [ConradIrwin](/~https://github.com/ConradIrwin), [gibson042](/~https://github.com/gibson042), [choumx](/~https://github.com/choumx), [0xSobky](/~https://github.com/0xSobky), [styfle](/~https://github.com/styfle), [koto](/~https://github.com/koto), [tlau88](/~https://github.com/tlau88), [strugee](/~https://github.com/strugee), [oparoz](/~https://github.com/oparoz), [mathiasbynens](/~https://github.com/mathiasbynens), [edg2s](/~https://github.com/edg2s), [dnkolegov](/~https://github.com/dnkolegov), [dhardtke](/~https://github.com/dhardtke), [wirehead](/~https://github.com/wirehead), [thorn0](/~https://github.com/thorn0), [styu](/~https://github.com/styu), [mozfreddyb](/~https://github.com/mozfreddyb), [mikesamuel](/~https://github.com/mikesamuel), [jorangreef](/~https://github.com/jorangreef), [jimmyhchan](/~https://github.com/jimmyhchan), [jameydeorio](/~https://github.com/jameydeorio), [jameskraus](/~https://github.com/jameskraus), [hyderali](/~https://github.com/hyderali), [hansottowirtz](/~https://github.com/hansottowirtz), [hackvertor](/~https://github.com/hackvertor), [freddyb](/~https://github.com/freddyb), [flavorjones](/~https://github.com/flavorjones), [djfarrelly](/~https://github.com/djfarrelly), [devd](/~https://github.com/devd), [camerondunford](/~https://github.com/camerondunford), [buu700](/~https://github.com/buu700), [buildog](/~https://github.com/buildog), [alabiaga](/~https://github.com/alabiaga), [Vector919](/~https://github.com/Vector919), [Robbert](/~https://github.com/Robbert), [GreLI](/~https://github.com/GreLI), [FuzzySockets](/~https://github.com/FuzzySockets), [ArtemBernatskyy](/~https://github.com/ArtemBernatskyy), [@garethheyes](https://twitter.com/garethheyes), [@shafigullin](https://twitter.com/shafigullin), [@mmrupp](https://twitter.com/mmrupp), [@irsdl](https://twitter.com/irsdl),[ShikariSenpai](/~https://github.com/ShikariSenpai), [ansjdnakjdnajkd](/~https://github.com/ansjdnakjdnajkd), [@asutherland](https://twitter.com/asutherland), [@mathias](https://twitter.com/mathias), [@cgvwzq](https://twitter.com/cgvwzq), [@robbertatwork](https://twitter.com/robbertatwork), [@giutro](https://twitter.com/giutro), [@CmdEngineer\_](https://twitter.com/CmdEngineer_), [@avr4mit](https://twitter.com/avr4mit), [davecardwell](/~https://github.com/davecardwell) and especially [@securitymb ❤️](https://twitter.com/securitymb) & [@masatokinugawa ❤️](https://twitter.com/masatokinugawa)
## Testing powered by
Expand Down
35 changes: 20 additions & 15 deletions dist/purify.cjs.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -329,44 +329,49 @@ interface DOMPurify {
addHook(entryPoint: 'uponSanitizeAttribute', hookFunction: UponSanitizeAttributeHook): void;
/**
* Remove a DOMPurify hook at a given entryPoint
* (pops it from the stack of hooks if more are present)
* (pops it from the stack of hooks if hook not specified)
*
* @param entryPoint entry point for the hook to remove
* @returns removed(popped) hook
* @param hookFunction optional specific hook to remove
* @returns removed hook
*/
removeHook(entryPoint: BasicHookName): NodeHook | undefined;
removeHook(entryPoint: BasicHookName, hookFunction?: NodeHook): NodeHook | undefined;
/**
* Remove a DOMPurify hook at a given entryPoint
* (pops it from the stack of hooks if more are present)
* (pops it from the stack of hooks if hook not specified)
*
* @param entryPoint entry point for the hook to remove
* @returns removed(popped) hook
* @param hookFunction optional specific hook to remove
* @returns removed hook
*/
removeHook(entryPoint: ElementHookName): ElementHook | undefined;
removeHook(entryPoint: ElementHookName, hookFunction?: ElementHook): ElementHook | undefined;
/**
* Remove a DOMPurify hook at a given entryPoint
* (pops it from the stack of hooks if more are present)
* (pops it from the stack of hooks if hook not specified)
*
* @param entryPoint entry point for the hook to remove
* @returns removed(popped) hook
* @param hookFunction optional specific hook to remove
* @returns removed hook
*/
removeHook(entryPoint: DocumentFragmentHookName): DocumentFragmentHook | undefined;
removeHook(entryPoint: DocumentFragmentHookName, hookFunction?: DocumentFragmentHook): DocumentFragmentHook | undefined;
/**
* Remove a DOMPurify hook at a given entryPoint
* (pops it from the stack of hooks if more are present)
* (pops it from the stack of hooks if hook not specified)
*
* @param entryPoint entry point for the hook to remove
* @returns removed(popped) hook
* @param hookFunction optional specific hook to remove
* @returns removed hook
*/
removeHook(entryPoint: 'uponSanitizeElement'): UponSanitizeElementHook | undefined;
removeHook(entryPoint: 'uponSanitizeElement', hookFunction?: UponSanitizeElementHook): UponSanitizeElementHook | undefined;
/**
* Remove a DOMPurify hook at a given entryPoint
* (pops it from the stack of hooks if more are present)
* (pops it from the stack of hooks if hook not specified)
*
* @param entryPoint entry point for the hook to remove
* @returns removed(popped) hook
* @param hookFunction optional specific hook to remove
* @returns removed hook
*/
removeHook(entryPoint: 'uponSanitizeAttribute'): UponSanitizeAttributeHook | undefined;
removeHook(entryPoint: 'uponSanitizeAttribute', hookFunction?: UponSanitizeAttributeHook): UponSanitizeAttributeHook | undefined;
/**
* Removes all DOMPurify hooks at a given entryPoint
*
Expand Down
8 changes: 7 additions & 1 deletion 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.

35 changes: 20 additions & 15 deletions dist/purify.es.d.mts
Original file line number Diff line number Diff line change
Expand Up @@ -329,44 +329,49 @@ interface DOMPurify {
addHook(entryPoint: 'uponSanitizeAttribute', hookFunction: UponSanitizeAttributeHook): void;
/**
* Remove a DOMPurify hook at a given entryPoint
* (pops it from the stack of hooks if more are present)
* (pops it from the stack of hooks if hook not specified)
*
* @param entryPoint entry point for the hook to remove
* @returns removed(popped) hook
* @param hookFunction optional specific hook to remove
* @returns removed hook
*/
removeHook(entryPoint: BasicHookName): NodeHook | undefined;
removeHook(entryPoint: BasicHookName, hookFunction?: NodeHook): NodeHook | undefined;
/**
* Remove a DOMPurify hook at a given entryPoint
* (pops it from the stack of hooks if more are present)
* (pops it from the stack of hooks if hook not specified)
*
* @param entryPoint entry point for the hook to remove
* @returns removed(popped) hook
* @param hookFunction optional specific hook to remove
* @returns removed hook
*/
removeHook(entryPoint: ElementHookName): ElementHook | undefined;
removeHook(entryPoint: ElementHookName, hookFunction?: ElementHook): ElementHook | undefined;
/**
* Remove a DOMPurify hook at a given entryPoint
* (pops it from the stack of hooks if more are present)
* (pops it from the stack of hooks if hook not specified)
*
* @param entryPoint entry point for the hook to remove
* @returns removed(popped) hook
* @param hookFunction optional specific hook to remove
* @returns removed hook
*/
removeHook(entryPoint: DocumentFragmentHookName): DocumentFragmentHook | undefined;
removeHook(entryPoint: DocumentFragmentHookName, hookFunction?: DocumentFragmentHook): DocumentFragmentHook | undefined;
/**
* Remove a DOMPurify hook at a given entryPoint
* (pops it from the stack of hooks if more are present)
* (pops it from the stack of hooks if hook not specified)
*
* @param entryPoint entry point for the hook to remove
* @returns removed(popped) hook
* @param hookFunction optional specific hook to remove
* @returns removed hook
*/
removeHook(entryPoint: 'uponSanitizeElement'): UponSanitizeElementHook | undefined;
removeHook(entryPoint: 'uponSanitizeElement', hookFunction?: UponSanitizeElementHook): UponSanitizeElementHook | undefined;
/**
* Remove a DOMPurify hook at a given entryPoint
* (pops it from the stack of hooks if more are present)
* (pops it from the stack of hooks if hook not specified)
*
* @param entryPoint entry point for the hook to remove
* @returns removed(popped) hook
* @param hookFunction optional specific hook to remove
* @returns removed hook
*/
removeHook(entryPoint: 'uponSanitizeAttribute'): UponSanitizeAttributeHook | undefined;
removeHook(entryPoint: 'uponSanitizeAttribute', hookFunction?: UponSanitizeAttributeHook): UponSanitizeAttributeHook | undefined;
/**
* Removes all DOMPurify hooks at a given entryPoint
*
Expand Down
8 changes: 7 additions & 1 deletion dist/purify.es.mjs
Original file line number Diff line number Diff line change
Expand Up @@ -37,8 +37,10 @@ if (!construct) {
};
}
const arrayForEach = unapply(Array.prototype.forEach);
const arrayLastIndexOf = unapply(Array.prototype.lastIndexOf);
const arrayPop = unapply(Array.prototype.pop);
const arrayPush = unapply(Array.prototype.push);
const arraySplice = unapply(Array.prototype.splice);
const stringToLowerCase = unapply(String.prototype.toLowerCase);
const stringToString = unapply(String.prototype.toString);
const stringMatch = unapply(String.prototype.match);
Expand Down Expand Up @@ -1315,7 +1317,11 @@ function createDOMPurify() {
}
arrayPush(hooks[entryPoint], hookFunction);
};
DOMPurify.removeHook = function (entryPoint) {
DOMPurify.removeHook = function (entryPoint, hookFunction) {
if (hookFunction !== undefined) {
const index = arrayLastIndexOf(hooks[entryPoint], hookFunction);
return index === -1 ? undefined : arraySplice(hooks[entryPoint], index, 1)[0];
}
return arrayPop(hooks[entryPoint]);
};
DOMPurify.removeHooks = function (entryPoint) {
Expand Down
Loading

0 comments on commit 0455d21

Please sign in to comment.