Skip to content

Latest commit

 

History

History
83 lines (56 loc) · 2.47 KB

README.md

File metadata and controls

83 lines (56 loc) · 2.47 KB

NioGoogleAuthenticator

NioGoogleAuthenticator is a collection of Elixir convenience functions to generate secrets and validate tokens used in conjunction with Google Authenticator. It also includes functions that automatically add a secret to an Ecto.Changeset.

Installation

Add nio_google_authenticator to your list of dependencies in mix.exs:

def deps do
[{:nio_google_authenticator, "~> 2.0.0"}]
end

Usage

Creating a secret:

.generate_secret

Creating a token:

.generate_token(secret)

This method is best used for automatic testing.

Creating the URL that yields a scannable QR code for a Google Authenticator mobile app:

.generate_url(secret, label, issuer \\ @issuer)

where issuer can be configured universally using:

config :nio_google_authenticator, issuer: "Neuvians"

This will yield a URL in the following format:

https://chart.googleapis.com/chart?cht=qr&chs=200x200&chl=otpauth%3A%2F%2Ftotp%2FLABEL%3Fissuer%3DNeuvians%26secret%3DBM7SUJ4MLRN2UPI6

Validating a token

.validate_token(secret, token) or .validate_token(secret, token, options)

options is a keyword list for the following:

token_length default 6 interval_length default 30 window default 0

this will either return {:ok, :pass} or {:error, :invalid_token}

Ecto.Changeset usage

There are two additional functions which you can pass an Ecto.Changeset which will automatically add a secret to the changeset. For both function you can specify the attribute to change (ex. .add_secret_to_changeset(changeset, :my_secret_field)) but if none is specified :ga_secret is used.

Adding a secret to a changeset

To add a secret inside a changeset pipe you can call add_secret_to_changeset(changeset). This will only add the secret if the passed attribute or :ga_secret is nil. Otherwise it is ignored.

Regenerating a secret in a changeset

If you would like to renegerate a secret you can use .regenerate_secret_in_changeset(changeset) which will always replace an existing value.

Example in Ecto.Model
defmodule User do
    use Ecto.Schema
    import Ecto.Changeset

    schema "users" do
      field :name, :string
      field :ga_secret, :string
    end

    def changeset(user, params \\ %{}) do
      user
      |> cast(params, ~w(name, ga_secret))
      |> validate_required(params, ~w(name, ga_secret))
      |> NioGoogleAuthenticator.Changeset.add_secret_to_changeset
    end
  end

Version

2.1.2

License

MIT