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-11.13.0.pre.alpha.fontawesome1 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.13.0 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.12.1.pre.alpha.charts1 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.12.1 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.13.0.pre.alpha.fileupload1 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.12.0 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.11.0.pre.alpha.paginate2 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.11.0.pre.alpha.dialog2 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.11.0.pre.alpha.paginate1 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.11.0.pre.alpha.renderer1 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.11.0.pre.alpha.dialog1 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.11.0 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.10.0.pre.alpha.pre.bold1 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.10.0.pre.alpha.pagination1 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.10.0 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.9.0 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.9.0.pre.alpha.fileupload1 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.8.1 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.8.0 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js
playbook_ui-11.7.0.pre.alpha.table1 app/pb_kits/playbook/pb_passphrase/useHaveIBeenPwned.js