NAME
    Crypt::Diceware - Random passphrase generator loosely based on the
    Diceware algorithm

VERSION
    version 0.005

SYNOPSIS
      use Crypt::Diceware;
      my @phrase = words(4); # qw/starker call recur outlaw/

      # with alternate word lists
      use Crypt::Diceware words => { wordlist => 'Original' };
      use Crypt::Diceware words => { wordlist => 'Beale' };

DESCRIPTION
    This module generates a random passphrase of words based loosely on the
    Diceware <http://world.std.com/~reinhold/diceware.html> algorithm by
    Arnold G. Reinhold.

    A Diceware passphrase consists of randomly selected words chosen from a
    list of over seven thousand words. A passphrase of four or five words is
    likely to be stronger than typical human-generated passwords, which tend
    to be too-short and over-sample common letters ("e") and numbers ("1").

    Words are randomly selected using Data::Entropy in AES counter mode,
    seeded with Crypt::URandom, which is reasonably cryptographically
    strong.

USAGE
    By default, this module exports a single subroutine, "words", which uses
    the Crypt::Diceware::Wordlist::Common word list.

    An alternate wordlist may be specified:

      use Crypt::Diceware words => { wordlist => 'Original' };

    This loads the wordlist provided by Crypt::Diceware::Wordlist::Original.
    If the name of the wordlist contains *::* the name of the wordlist is
    not prefixed by *Crypt::Diceware::Wordlist*.

    It is also possible to load a wordlist from a file via:

      use Crypt::Diceware words => { file => 'diceware-german.txt' };

    The supplied file should contain one word per line.

    You can also replace the entropy source with another
    Data::Entropy::Source object:

      use Crypt::Diceware words => { entropy => $entropy_source };

    Exporting is done via Sub::Exporter so any of its features may be used:

      use Crypt::Diceware words => { -as => 'passphrase' };
      my @phrase = passphrase(4);

  words
      my @phrase = words(4);

    Takes a positive numeric argument and returns a passphrase of that many
    randomly-selected words. In a list context it will return a list of
    words, as above. In a scalar context it will return a string with the
    words separated with a single space character:

      my $phrase = words(4);

    Returns the empty list / string if the argument is missing or not a
    positive number.

SEE ALSO
    Diceware and Crypt::Diceware related:

    *   Diceware <http://world.std.com/~reinhold/diceware.html>

    *   Crypt::Diceware::Wordlist::Common

    *   Crypt::Diceware::Wordlist::Original

    *   Crypt::Diceware::Wordlist::Beale

    Other CPAN passphrase generators:

    *   Crypt::PW44

    *   Crypt::XkcdPassword

    *   Review of CPAN password/phrase generators
        <http://neilb.org/reviews/passwords.html>

    About password strength in general:

    *   Password Strength (XKCD) <http://xkcd.com/936/>

    *   Password Strength (Wikipedia)
        <http://en.wikipedia.org/wiki/Password_strength>

SUPPORT
  Bugs / Feature Requests
    Please report any bugs or feature requests through the issue tracker at
    <https://github.com/dagolden/Crypt-Diceware/issues>. You will be
    notified automatically of any progress on your issue.

  Source Code
    This is open source software. The code repository is available for
    public review and contribution under the terms of the license.

    <https://github.com/dagolden/Crypt-Diceware>

      git clone https://github.com/dagolden/Crypt-Diceware.git

AUTHOR
    David Golden <dagolden@cpan.org>

CONTRIBUTORS
    *   Mario Domgoergen <mdom@taz.de>

    *   Neil Bowers <neil@bowers.com>

COPYRIGHT AND LICENSE
    This software is Copyright (c) 2013 by David Golden.

    This is free software, licensed under:

      The Apache License, Version 2.0, January 2004