Sha256: a775e9db00eae5a363d169ab03ee231713f4a2fb12572ccb6bc28c5f637ea0b5

Contents?: true

Size: 1.47 KB

Versions: 153

Compression:

Stored size: 1.47 KB

Contents

import  { useEffect, useState } from 'react'

const checkHaveIBeenPwned = async function (passphrase) {
  const buffer = new TextEncoder('utf-8').encode(passphrase)
  const digest = await crypto.subtle.digest('SHA-1', buffer)
  const hashArray = Array.from(new Uint8Array(digest))
  const hashHex = hashArray.map((b) => b.toString(16).padStart(2, '0')).join('')

  const firstFive = hashHex.slice(0, 5)
  const endOfHash = hashHex.slice(5)

  const resp = await fetch(`https://api.pwnedpasswords.com/range/${firstFive}`)
  const text = await resp.text()

  const match = text.split('\n').some((line) => {
    //Each line is <sha-1-hash-suffix>:<count of incidents>
    return line.split(':')[0] === endOfHash.toUpperCase()
  })
  return match
}

/**
 * If the input hasn't changed in <delay> ms,
 * hit the haveibeenpwned api and check if the given passphrase is compromised
 */
export default function useHaveIBeenPwned(passphrase, minLength, delay = 400) {
  const [isPwned, setIsPwned] = useState(false)

  useEffect(
    () => {
      // only check the API for passphrases above the minimum size
      if (passphrase.length < minLength) {
        setIsPwned(false)
        return
      }

      const handler = setTimeout(() => {
        checkHaveIBeenPwned(passphrase)
          .then((pwned) => setIsPwned(pwned))
          .catch(() => setIsPwned(false))
      }, delay)

      return () => {
        clearTimeout(handler)
      }
    },
    [passphrase, minLength, delay]
  )

  return isPwned
}

Version data entries

153 entries across 153 versions & 1 rubygems

Version Path
playbook_ui-10.2.0 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-10.1.0 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-10.0.3.pre.alpha.walkthrough2 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-10.0.3.pre.alpha.walkthrough app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-10.0.1.alpha.railscusticon app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-10.0.2.pre.alpha.pre.iconfix app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-10.0.1.alpha.rtflexfix app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-10.0.0.pre.alphafonts app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-10.0.1 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-10.0.0 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-9.19.0.pre.alpha.pre.fonts2 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-9.19.0 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-9.19.0.pre.alphafonts app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-9.18.0.flow.bin.alpha app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-9.18.0 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-9.17.0 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-9.17.0.pre.decouple.website2 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-9.16.0 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-9.15.0 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-9.15.0.pre.decouple.website1 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js