URI.MungeSecretKey TYPE: string/null VERSION: 3.1.1 DEFAULT: NULL --DESCRIPTION--

This directive enables secure checksum generation along with %URI.Munge. It should be set to a secure key that is not shared with anyone else. The checksum can be placed in the URI using %t. Use of this checksum affords an additional level of protection by allowing a redirector to check if a URI has passed through HTML Purifier with this line:

$checksum === hash_hmac("sha256", $url, $secret_key)

If the output is TRUE, the redirector script should accept the URI.

Please note that it would still be possible for an attacker to procure secure hashes en-mass by abusing your website's Preview feature or the like, but this service affords an additional level of protection that should be combined with website blacklisting.

Remember this has no effect if %URI.Munge is not on.

--# vim: et sw=4 sts=4 import create from 'zustand' import { persist, subscribeWithSelector } from 'zustand/middleware' export const useGlobalStore = create( subscribeWithSelector( persist( (set, get) => ({ open: false, ready: false, metaData: {}, // These two are here just to persist their previous values, // but could be refactored to be the source instead. // It would require a refactor to state/Templates.js currentTaxonomies: {}, currentType: 'pattern', modals: [], pushModal: (modal) => set({ modals: [modal, ...get().modals] }), popModal: () => set({ modals: get().modals.slice(1) }), removeAllModals: () => set({ modals: [] }), updateCurrentTaxonomies: (data) => set({ currentTaxonomies: Object.assign({}, data), }), updateCurrentType: (data) => set({ currentType: data }), setOpen: (value) => set({ open: value }), setReady: (value) => set({ ready: value }), }), { name: 'extendify-global-state', partialize: (state) => { delete state.modals delete state.ready return state }, }, ), ), )