When you're kicking off a new application, one of the first things you tackle is setting up the authentication system. For ages, Devise has been the go-to solution for handling just about anything related to authentication in a Rails application.
Now, Rails 8 comes with a built-in, basic authentication generator. If needed, you can expand on this foundation to include features like registration, two-factor authentication, account locking, invitations, and activity tracking. Naturally, different applications will have different requirements, and adding all these extra bells and whistles can take time, configuration, and integration work.
Honestly, one of the features a lot of Rails developers were excited about in Rails 8 is this new built-in authentication generator. It's super handy for those working on simple applications because it means you don't have to immediately reach for a third-party gem like Devise to get started.
Running the bin/rails generate authentication command in Rails 8 sets you up with a solid base for typical authentication needs. When you run this, here's what it usually scaffolds:
- User and Session Models. You get UserandSessionmodels, plus the necessary migrations to store user info (like email_address and password_digest) and session details (including a unique token, IP address, and user agent). TheUsermodel useshas_secure_passwordfor strong password hashing.
- Controllers. You'll see a SessionsControllerfor handling user login, logout, and session creation, and aPasswordsControllerto manage password reset requests.
- Views. You get basic views for login (sessions/new.html.erb) and password reset requests (passwords/new.html.erb,passwords/edit.html.erb).
- Authentication Concern. There’s a core Authenticationconcern included inApplicationController, giving you methods likerequire_authentication(abefore_actionto protect routes) andauthenticated?(a helper to check if a user is logged in). It also hasallow_unauthenticated_accessto let specific actions bypass authentication andstart_new_session_for(user)for session management.
- Password Mailer. A PasswordsMaileris set up to send password reset instructions.
This new authentication generator is quite straightforward and lightweight. If you're building a simple app that just needs basic authentication, this generator provides a streamlined, flexible, and easy-to-customize setup.
Since it's part of Rails itself, you reduce external dependencies, which can make upgrades and maintenance smoother down the line. Plus, the generator drops the code right into your application, so you've got more freedom, control, and can easily tweak things or add features when needed.
However, if you're dealing with more complex needs, this basic generator might not cut it unless you extend and modify it quite a bit. Features like registration, two-factor authentication (2FA), account lockout, invitations, social logins, and API authentication are pretty common requirements for apps with more intricate security and user management. Unfortunately, those aren't included in the basic generator just yet.
Then there's Authentication Zero, a gem that provides a robust framework and acts as a generator to scaffold a full-fledged, production-ready authentication system directly into your Rails app.
Here are some of the cool things Authentication Zero brings to the table:
- Registration. Unlike Rails 8's basic authentication, Authentication Zero gives you a registration component with the “Forgot Password” feature built right in.
- Two-Factor Authentication (2FA). A must-have for many apps, Authentication Zero's 2FA also includes recovery code functionality.
- Account Locking Mechanism. Helps prevent brute-force attacks and email bombing by locking accounts after too many failed login attempts, and you can configure how many attempts that is.
- Invitation System. Lets admins invite new users, often with a token-based signup process.
- Activity Log. Super useful for audit trails, this feature tracks user actions, including logins, IP addresses, and user agents.
Plus, you can get more advanced stuff like API authentication, Passwordless authentication, multi-session management, and social logins. You can add these in as you need them.
Authentication Zero packs a comprehensive set of features right out of the box, addressing a wide range of authentication and user management needs, which can save you a ton of development time.
It's built with security and Rails best practices in mind, which helps reduce the risk of common vulnerabilities. And unlike some gem-based solutions that can hide away a lot of the inner workings, Authentication Zero generates the code into your app, so you’re in full control and can customize, modify, and debug as needed.
One thing to be aware of with Authentication Zero, I did notice during development that if you wanted to add a new feature later on, like 2FA, it seemed you needed to add it during the initial build. If new database tables were involved, you had to drop, create, and run the migrations again.
To learn more about Authentication Zero, definitely check out their GitHub and see all the features it offers.