Ruby On Rails Quickstart

This quickstart guide outlines the essential steps to integrate Stytch’s B2B SaaS Authentication product within a Ruby on Rails application.

Overview

Stytch offers a Ruby SDK that can be integrated within Rails applications:

SDK

Development

Notes

Reference

Source Code

Ruby SDK

Server-side

For server-side code. Our Ruby SDK facilitates robust authentication and authorization mechanisms and can be integrated directly with Rails apps to handle backend logic.

SDK Reference

GitHub

In addition to our Ruby SDK, we recommend you consider using one of Stytch's frontend SDKs (headless or with pre-built UI) to build your client-side auth UI.

Learn more about different integration methods and their benefits by visiting our integration guides.

Getting Started

To begin, we'll set up Email Magic Links utilizing our Discovery flow.

1Install Stytch SDK and configure your API Keys

Create a Stytch B2B Project in your Stytch Dashboard if you haven't already.

Add the Stytch gem to your application's Gemfile and run bundle install:

gem 'stytch'

Configure your Stytch Project's API keys as environment variables:

STYTCH_PROJECT_ID="YOUR_STYTCH_PROJECT_ID"
STYTCH_SECRET="YOUR_STYTCH_PROJECT_SECRET"
# Use your Project's 'test' or 'live' credentials

2Set up your Rails app

Initialize the Stytch client and define routes and controller actions to handle authentication:

# config/routes.rb
Rails.application.routes.draw do
  post 'login', to: 'authentication#login'
  get 'authenticate', to: 'authentication#authenticate'
end
# app/controllers/authentication_controller.rb
class AuthenticationController < ApplicationController

  def stytch_client
    @stytch_client ||= StytchB2B::Client.new(
      project_id: ENV['STYTCH_PROJECT_ID'],
      secret: ENV['STYTCH_SECRET']
    )
  endf

  def login
    email = params[:email]
    response = stytch_client.magic_links.email.discovery.send(
      email_address: email
    )
    render json: response
  rescue => e
    render json: { error: e.message }, status: :internal_server_error
  end

  def authenticate
    token = params[:token]
    response = stytch_client.magic_links.discovery.authenticate(discovery_magic_links_token: token)
    render plain: "Hello, #{response.email_address}! Complete the Discovery flow by creating an Organization with your intermediate session token: #{response.intermediate_session_token}."
  rescue => e
    render plain: e.message, status: :unauthorized
  end
end

For Email Magic Links, you must specify a redirect URL in your Project's Dashboard to authenticate the token. By default, the redirect URL is set to http://localhost:3000/authenticate.

You can specify additional Redirect URLs in your Project's Dashboard, and override the default by passing in an explicit discovery_redirect_url argument.

You can read more about redirect URLs in this guide.

3Test your application

Run your Ruby on Rails application and send a POST request to the /login endpoint with an email address to test the Discovery auth flow. You will recieve an email in your inbox with an Email Magic Link, which redirects you to the /authenticate endpoint or the redirect URL you set in your [Dashboard].

4What's next

Check out our product-specific guides for how to handle full authentication flows for each product you'd like to support, like Email Magic Links and OAuth.