OmniAuth PayPal OAuth2 Strategy
Strategy to authenticate with PayPal via OmniAuth.
Get your API key at: https://developer.paypal.com/developer/applications/ in the section RESTApps. Note the Client ID and the Client Secret.
Note: You generate separate keys for development (sandbox) and production (live) with each application you register.
Use the config Gem to organize your keys and keep them safe.
For more details, read the PayPal docs: https://developer.paypal.com/docs/integration/direct/identity/
Table of Contents
Installation
Add to your Gemfile
:
gem 'omniauth-paypal-oauth2'
And then execute:
$ bundle
Or install it yourself as:
$ gem install omniauth-paypal-oauth2
If you always want to be up to date fetch the latest from GitHub in your Gemfile
:
gem 'omniauth-paypal-oauth2', github: 'jonhue/omniauth-paypal-oauth2'
Usage
PayPal API Setup
- Go to 'https://developer.paypal.com/developer/applications/'
- Select your project.
- Scroll down to 'APP SETTINGS' for each 'SANDBOX' and 'LIVE'.
- Set
<YOURDOMAIN>/users/auth/paypal_oauth2/callback
as Return URL. - Make sure "Log In with PayPal" is enabled and Save.
- Go to Credentials, then select the "OAuth consent screen" tab on top, and provide an 'EMAIL ADDRESS' and a 'PRODUCT NAME'
- Wait 10 minutes for changes to take effect.
Rails middleware
Here's an example for adding the middleware to a Rails app in config/initializers/omniauth.rb
:
Rails.application.config.middleware.use OmniAuth::Builder do
provider :paypal_oauth2, ENV['PAYPAL_CLIENT_ID'], ENV['PAYPAL_CLIENT_SECRET']
end
You can now access the OmniAuth PayPal OAuth2 URL: /auth/paypal_oauth2
Note: While developing your application, if you change the scope in the initializer you will need to restart your app server. Remember that either the 'email' or 'profile' scope is required!
Devise
First define your application id and secret in config/initializers/devise.rb
. Do not use the snippet mentioned in the Usage section.
require 'omniauth-paypal-oauth2'
config.omniauth :paypal_oauth2, 'PAYPAL_CLIENT_ID', 'PAYPAL_CLIENT_SECRET'
Then add the following to 'config/routes.rb' so the callback routes are defined.
devise_for :users, controllers: { omniauth_callbacks: 'users/omniauth_callbacks' }
Make sure your model is omniauthable. Generally this is '/app/models/user.rb'
devise :omniauthable, omniauth_providers: [:paypal_oauth2]
Then make sure your callbacks controller is setup.
class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController
def paypal_oauth2
@user = User.from_omniauth(request.env['omniauth.auth'])
if @user.persisted?
flash[:notice] = I18n.t('devise.omniauth_callbacks.success', kind: 'PayPal')
sign_in_and_redirect(@user, event: :authentication)
else
session['devise.paypal_data'] = request.env['omniauth.auth']
redirect_to new_user_registration_url
end
end
end
and bind to or create the user
def self.from_omniauth(access_token)
data = access_token.info
user = User.where(email: data['email']).first
user
end
For your views you can login using:
<%= link_to 'Sign in with PayPal', user_paypal_oauth2_omniauth_authorize_path %>
<%# Devise prior 4.1.0: %>
<%= link_to 'Sign in with PayPal', user_omniauth_authorize_path(:paypal_oauth2) %>
An overview is available at https://github.com/plataformatec/devise/wiki/OmniAuth:-Overview
Configuration
If you click from your Applications Dashboard in your Application on "Advanced Options" in the "APP SETTINGS" section and "Log In with PayPal" subsection, you can configure several options:
Auth Hash
Here's an example of an authentication hash available in the callback by accessing request.env['omniauth.auth']
:
{
provider: 'paypal',
uid: 'bathjJwvdhKjgfgh8Jd745J7dh5Qkgflbnczd65dfnw',
info: {
name: 'John Smith',
email: 'example@example.com',
location: 'Moscow'
},
credentials: {
token: 'token',
refresh_token: 'refresh_token',
expires_at: 1355082790,
expires: true
},
extra: {
account_creation_date: '2008-04-21',
account_type: 'PERSONAL',
user_id: 'https://www.paypal.com/webapps/auth/identity/user/bathjJwvdhKjgfgh8Jd745J7dh5Qkgflbnczd65dfnw',
address: {
country: 'US',
locality: 'San Jose',
postal_code: '95131',
region: 'CA',
street_address: '1 Main St'
},
language: 'en_US',
locale: 'en_US',
verified_account: true,
zoneinfo: 'America/Los_Angeles'
}
}
For more details see the PayPal List Of Attributes.
Testing
-
Fork this repository
-
Clone your forked git locally
-
Install dependencies
$ bundle install
-
Run specs
$ bundle exec rspec
-
Run RuboCop
$ bundle exec rubocop
Release
- Review breaking changes and deprecations in
CHANGELOG.md
- Change the gem version in
lib/omniauth/paypal_oauth2/version.rb
- Reset
CHANGELOG.md
- Create a pull request to merge the changes into
master
- After the pull request was merged, create a new release listing the breaking changes and commits on
master
since the last release. - The release workflow will publish the gems to RubyGems and the GitHub Package Registry
To Do
We use GitHub projects to coordinate the work on this project.
To propose your ideas, initiate the discussion by adding a new issue.
Contributing
We hope that you will consider contributing to OmniAuth PayPal OAuth2 Strategy. Please read this short overview for some information about how to get started:
Learn more about contributing to this repository, Code of Conduct
Semantic Versioning
omniauth-paypal-oauth2 follows Semantic Versioning 2.0 as defined at http://semver.org.