Ecosyste.ms: Packages

An open API service providing package, version and dependency metadata of many open source software ecosystems and registries.

Top 5.4% on proxy.golang.org
Top 3.1% forks on proxy.golang.org

proxy.golang.org : github.com/1password/spg

Package spg provides 1Password's Strong Password Generator engine for uniform and flexible password generation. The Strong Password Generator package offers the underlying engine for flexible specification of generated password requirements and ensuring that the generated passwords it returns follow a uniform distribution. The clients of this package are expected to manage what is presented to users. This engine offers far greater flexibility than should normally be exposed to users. 1. The user will create either a character recipe, r, with NewCharRecipe() or a word (or syllable) list recipe, r, with NewWLRecipe(). 2. The user will call the r.Generate() method of a recipe, r, to generate a password, pwd. 3. The returned password, pwd, has a String() method, which does the obvious thing and Entropy field, which contains the min-Entropy based on the recipe. The word list generator produces things like "correct horse battery staple", but when the list is of pronounceable syllables, it can also be set up to produce things like Lengths for these are specified in terms of the number of elements drawn from the list to be included in these passwords (not counting the separators). Although the above examples all have different lengths in terms of number of characters, they were all specified as Length 4. The passwords that one gets depend on the word list recipe, WLRecipe, and the actual word list provided. Character-based are your typical notion of generated password, however these can be specified in ways to produce only numeric PINs if desired. The passwords generated are a function of the CharRecipe. The word list and character recipes (WLRecipe, CharRecipe) implement a Generator interface with two methods, Generate and Entropy. Generate returns a Password. There is a fair amount of internal structure to a Password object, but the ones you are most after is available through the Password.String() method and the Entropy field. Entropy returns the entropy of a password that would be generated given the current recipe. Entropy is a highly misleading concept when applied to passwords. In the general case it is either an incoherent concept or the wrong concept to use when talking about the strength of a password. It does, however, make sense when a password is drawn uniformly from a space of possible passwords. When the distribution is uniform, the (Shannon) entropy is the same as the min-entropy (based on probability of getting the most likely result). This package does ensure that passwords are generated uniformly given the recipe passed to the generator, with the exception of the interaction of capitalizaton for some wordlists. In those cases, min-entropy is reported. That is, where min-entropy is not the same as Shannon Entropy Entropy() returns the min-entropy. Entropy is a function solely of the recipe. This package is Copyright 2017, 2018 by AgileBits, Inc and is licensed under the Apache 2.0 agreement.

Registry - Source - Documentation - JSON
purl: pkg:golang/github.com/1password/spg
Keywords: golang-package, password-generator
License: Apache-2.0
Latest release: over 1 year ago
First release: over 3 years ago
Namespace: github.com/1password
Stars: 183 on GitHub
Forks: 19 on GitHub
See more repository details: repos.ecosyste.ms
Last synced: 12 days ago

    Loading...
    Readme
    Loading...