1
0
mirror of https://github.com/oceanprotocol/market.git synced 2024-06-25 18:56:50 +02:00
market/src/@utils/cookies.ts

58 lines
1.6 KiB
TypeScript
Raw Normal View History

GDPR Compliance (#796) * add cookie utils * add gdpr metadata for ppc * add graphql typeDefs for GDPR metadata * add ppc variable to app config * add ppc user preference * add switch component * add ppc components * add cookie consent provider * add consent provider to wrapRootElement * add ppc to app component * add cookie button to footer component * add ppc to site metadata query * add styles for buttons in footer * add switch component unit tests * renewed siteMetadata json for testing * add gdpr metadata for testing * add cookie module unit test * add cookie module tests * add customizable format to time component * add english privacy policy * add privacy policy slugs to user preferences and appConfig * add privacy policy components * add autolink for policy md navigation * only show language select for multiple policies * add gatsby policy page creation * use new privacy slug user preference * add to top button styling for markdown pages * add policies for de, es & fr * add pointer events to toTop buttons css * add privacy policy basic unit test * outsource scroll button component * import cleanup * add customizable delay for debounce * add scroll button unit tests * add disclaimer component * add disclaimer fields as optional fields in PublishJsonData * add acces type disclaimer * adjusted help for desc and author fields * add disclaimer unit tests * minor adjustment to test * add print button to history page * naming changes for better readability * add cookies hash to policies * ppc disabled per default * fix react unknown prop for disclaimer * minor adjustments to cookie utils * add gdpr example file * change exposed gdpr metadata scope by useConsent * update README * readme fixes * emoji fix * added imprint * adjustments to gdpr.json structure and related graphql type * add default values for ppc * Update app.config.js Fixed typo. * change variable name for consistency, remove console logs * readability * adjust css selector order to be consistent * Update fr.md updated policy * Update es.md updated policy * Update en.md updated policy * Update de.md * fix type issue * replace language select input with links * remove scroll button from codebase * change privacy policy route to /privacy * remove Do Not Track detection * add size to checkbox / radio inputs * replace switch component with checkbox inputs * fix plain text links * remove console log * refactor privacy policy pages to use PageMarkdown template * setup useUserPreferences mock for unit tests * unit tests forprivacy policy components * setup discalimer to use alert component * Apply .env suggestions from code review Co-authored-by: Jamie Hewitt <jamie.hewitt15@gmail.com> * move gdpr example to gdpr.json * adjustments to address .env approach for appConfig.privacyPreferenceCenter * update readme * add small styling option to ppc * update README * add ppc unit tests * update comments * Update README.md Co-authored-by: Jamie Hewitt <jamie.hewitt15@gmail.com> * Merge print into profile history * add inifiniteApproval to UserPreference fixture * changed default styling of PPC to small Co-authored-by: Frederic Schwill <41265505+fr-3deric@users.noreply.github.com> Co-authored-by: MeikeMolitor <88214332+MeikeMolitor@users.noreply.github.com> Co-authored-by: Jamie Hewitt <jamie.hewitt15@gmail.com>
2021-10-12 10:00:57 +02:00
import Cookies from 'js-cookie'
export enum SAME_SITE_OPTIONS {
STRICT = 'strict',
LAX = 'lax',
NONE = 'none'
}
export const DEFAULT_COOKIE_OPTIONS = {
expires: 365,
sameSite: SAME_SITE_OPTIONS.STRICT
}
export function getLegacyCookieName(cookieName: string): string {
return `${cookieName}-legacy`
}
// Cookie legacy system adopted from react-cookie-consent
// SEE: https://github.com/Mastermindzh/react-cookie-consent
export function getCookieValue(cookieName: string): string {
let cookieValue = Cookies.get(cookieName)
// if the cookieValue is undefined check for the legacy cookie
if (cookieValue === undefined) {
cookieValue = Cookies.get(getLegacyCookieName(cookieName))
}
return cookieValue
}
export function setCookie(
cookieName: string,
cookieValue: string | boolean,
cookieOptions = DEFAULT_COOKIE_OPTIONS
): void {
const cookieSecurity = location ? location.protocol === 'https:' : true
const options = { ...cookieOptions, security: cookieSecurity }
// Fallback for older browsers where can not set SameSite=None
// SEE: https://web.dev/samesite-cookie-recipes/#handling-incompatible-clients
if (cookieOptions.sameSite === SAME_SITE_OPTIONS.NONE)
Cookies.set(getLegacyCookieName(cookieName), cookieValue.toString(), {
...options,
sameSite: null
})
// set the regular cookie
Cookies.set(cookieName, cookieValue.toString(), options)
}
export function deleteCookie(cookieName: string): void {
const cookiesWithLegacy = [cookieName, getLegacyCookieName(cookieName)]
cookiesWithLegacy.forEach((cookie) => {
Cookies.remove(cookie)
})
}