All Projects → aaronrenner → Phx_gen_auth

aaronrenner / Phx_gen_auth

An authentication system generator for Phoenix 1.5 applications.

Programming Languages

elixir
2628 projects

Projects that are alternatives of or similar to Phx gen auth

Pow
Robust, modular, and extendable user authentication system
Stars: ✭ 1,213 (+72.79%)
Mutual labels:  phoenix, authentication
Guardian auth
The Guardian Authentication Implementation Using Ecto/Postgresql Elixir Phoenix [ User Authentication ]
Stars: ✭ 15 (-97.86%)
Mutual labels:  phoenix, authentication
Passport
Provides authentication for phoenix application
Stars: ✭ 159 (-77.35%)
Mutual labels:  phoenix, authentication
Authex
Authex is an opinionated JWT authentication and authorization library for Elixir.
Stars: ✭ 73 (-89.6%)
Mutual labels:  phoenix, authentication
Guardian
Elixir Authentication
Stars: ✭ 3,150 (+348.72%)
Mutual labels:  phoenix, authentication
Social Core
Python Social Auth - Core
Stars: ✭ 618 (-11.97%)
Mutual labels:  authentication
Naperg
Fullstack Boilerplate GraphQL. Made with React & Prisma + authentication & roles
Stars: ✭ 661 (-5.84%)
Mutual labels:  authentication
Kaffy
Powerfully simple admin package for phoenix applications
Stars: ✭ 617 (-12.11%)
Mutual labels:  phoenix
Angular Oauth2
AngularJS OAuth2
Stars: ✭ 601 (-14.39%)
Mutual labels:  authentication
Acme bank
An example ☂ project
Stars: ✭ 700 (-0.28%)
Mutual labels:  phoenix
Git Credential Manager Core
Secure, cross-platform Git credential storage with authentication to GitHub, Azure Repos, and other popular Git hosting services.
Stars: ✭ 670 (-4.56%)
Mutual labels:  authentication
Django Graphql Jwt
JSON Web Token (JWT) authentication for Graphene Django
Stars: ✭ 649 (-7.55%)
Mutual labels:  authentication
Authelia
The Single Sign-On Multi-Factor portal for web apps
Stars: ✭ 11,094 (+1480.34%)
Mutual labels:  authentication
Fwknop
Single Packet Authorization > Port Knocking
Stars: ✭ 664 (-5.41%)
Mutual labels:  authentication
Google2fa Laravel
A One Time Password Authentication package, compatible with Google Authenticator for Laravel
Stars: ✭ 618 (-11.97%)
Mutual labels:  authentication
Faker
Faker is a pure Elixir library for generating fake data.
Stars: ✭ 673 (-4.13%)
Mutual labels:  phoenix
Ooth
User identity/authentication/accounts management microservice for node.js
Stars: ✭ 617 (-12.11%)
Mutual labels:  authentication
Next Auth
Authentication for Next.js
Stars: ✭ 8,362 (+1091.17%)
Mutual labels:  authentication
Auth0 React Samples
Auth0 Integration Samples for React Applications
Stars: ✭ 672 (-4.27%)
Mutual labels:  authentication
Torch
A rapid admin generator for Elixir & Phoenix
Stars: ✭ 640 (-8.83%)
Mutual labels:  phoenix

Phx.Gen.Auth

An authentication system generator for Phoenix 1.5+ applications.

Overview

The purpose of phx.gen.auth is to generate a pre-built authentication system into a Phoenix 1.5+ application that follows both security and elixir best practices. By generating code into the user's application instead of using a library, the user has complete freedom to modify the authentication system so it works best with their app. The following links have more information regarding the motivation and design of the code this generates.

Usage

Generating a Phoenix 1.5 app

phx.gen.auth must be installed into a Phoenix 1.5 application.

Once the installer is installed, a new project can be generated by running

$ mix phx.new my_app

Please note, the --no-ecto and --no-html options are not supported.

Installation

After running mix phx.new, cd into your application's directory (ex. my_app).

Basic installation

  1. Add phx_gen_auth to your list of dependencies in mix.exs

    def deps do
      [
        {:phx_gen_auth, "~> 0.6", only: [:dev], runtime: false},
        ...
      ]
    end
    
  2. Install and compile the dependencies

    $ mix do deps.get, deps.compile
    

Umbrella installation

  1. cd into your project's web app directory (ex. apps/my_app_web)

    $ cd apps/my_app_web
    
  2. Add phx_gen_auth to your list of dependencies in mix.exs

    def deps do
      [
        {:phx_gen_auth, "~> 0.6", only: [:dev], runtime: false},
        ...
      ]
    end
    
  3. Install and compile the dependencies

    $ mix do deps.get, deps.compile
    

Running the generator

From the root of your phoenix app (or apps/my_app_web in an umbrella app), you can install the authentication system with the following command

$ mix phx.gen.auth Accounts User users

This creates the templates,views, and controllers on the web namespace, and a new MyApp.Accounts context, in the application namespace.

Verify the database connection details for the development and test environments in config/ so the migrator and tests can run properly. Then run the following to create the database

$ mix ecto.create

Next, let's install the dependencies and migrate the database

$ mix deps.get
$ mix ecto.migrate

Let's run the tests and make sure our new authentication system works as expected.

$ mix test

Finally, let's start our phoenix server and try it out.

$ mix phx.server

Note on apps upgraded from Phoenix 1.4

If you've upgraded your app from Phoenix 1.4, you'll need to make the following update to test/support/conn_case.ex to get mix test to pass:

using do
  quote do
    # Import conveniences for testing with connections
    import Plug.Conn
    import Phoenix.ConnTest
+   import DemoWeb.ConnCase
    alias DemoWeb.Router.Helpers, as: Routes

    # The default endpoint for testing
    @endpoint DemoWeb.Endpoint
  end
end

Changing id types

By default, this generator uses the same type of id fields as the rest of the application. To override this configuration, the generator accepts --binary-id and --no-binary-id flags.

$ mix phx.gen.auth Accounts User users --binary-id

More information about these options are available in the documentation.

Learning more

To learn more about phx.gen.auth, run the following command.

$ mix help phx.gen.auth

You can also look up the mix task in hexdocs.

Upgrading

Since mix phx.gen.auth generates its code directly into your application, upgrading the version of this library will not upgrade your application's current authentication logic.

To see the changes that have been made to the generator output since the version that was used in your application, visit the CHANGELOG and click the [Diff] links for each version. These diffs will show you the changes to make to your application so it can be up to date with the current generator output.

License

Copyright 2020 Dashbit, Aaron Renner

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].