Object

tsec.passwordhashers.jca

SCryptUtil

Related Doc: package jca

Permalink

object SCryptUtil extends ManagedRandom

SCrypt util scala adaption for Will Glozer's (@wg on github) SCryptUtil, improving on SHA1PRNGs, bad security in particular.

SCrypt described here: http://www.tarsnap.com/scrypt.html

The hashed output is an extended implementation of the Modular Crypt Format that also includes the scrypt algorithm parameters.

Format: $s0$PARAMS$SALT$KEY.

<dl>

PARAMS
<dt>32-bit hex integer containing log2(N) (16 bits), r (8 bits), and p (8 bits)</dt>
SALT
<dt>base64-encoded salt</dt>
KEY
<dt>base64-encoded derived key</dt> </dl>

s0 identifies version 0 of the scrypt format, using a 128-bit salt and 256-bit derived key.

Source
SCryptUtil.scala
Linear Supertypes
ManagedRandom, AnyRef, Any
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. SCryptUtil
  2. ManagedRandom
  3. AnyRef
  4. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Value Members

  1. final def !=(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  4. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  5. def check(passwd: Array[Byte], hashed: String): Boolean

    Permalink

    Compare the supplied plaintext password to a hashed password.

    Compare the supplied plaintext password to a hashed password.

    passwd

    Plaintext password.

    hashed

    scrypt hashed password.

    returns

    true if passwd matches hashed value.

  6. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  7. final def eq(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  8. def equals(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  9. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  10. final def getClass(): Class[_]

    Permalink
    Definition Classes
    AnyRef → Any
  11. def hashCode(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  12. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  13. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  14. def nextBytes(bytes: Array[Byte]): Unit

    Permalink
    Definition Classes
    ManagedRandom
  15. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  16. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  17. def scrypt(passwd: Array[Byte], N: Int, r: Int, p: Int): String

    Permalink

    Hash the supplied plaintext password and generate output in the format described in

    Hash the supplied plaintext password and generate output in the format described in

    passwd

    Password.

    N

    CPU cost parameter.

    r

    Memory cost parameter.

    p

    Parallelization parameter.

    returns

    The hashed password.

  18. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  19. def toString(): String

    Permalink
    Definition Classes
    AnyRef → Any
  20. final def wait(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  21. final def wait(arg0: Long, arg1: Int): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  22. final def wait(arg0: Long): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )

Inherited from ManagedRandom

Inherited from AnyRef

Inherited from Any

Ungrouped