Sha256: 327e46852953411f98a6ba2160d0cb6b1dbac93d84e5c1fac3a0f0c5668e9a32

Contents?: true

Size: 1.32 KB

Versions: 1

Compression:

Stored size: 1.32 KB

Contents

require 'omniauth-oauth2'

module OmniAuth
  module Strategies
    class Discord < OmniAuth::Strategies::OAuth2
      DEFAULT_SCOPE = 'identify'

      option :name, 'discord'

      option :client_options, {
        :site          => 'https://discordapp.com/api',
        :authorize_url => 'oauth2/authorize',
        :token_url     => 'oauth2/token'
      }

      option :authorize_options, [:scope]

      uid { raw_info['id'] }

      info do
        {
          :name  => raw_info['username'],
          :email => raw_info['email'],
          :image => "https://cdn.discordapp.com/avatars/#{raw_info['id']}/#{raw_info['avatar']}"
        }
      end

      extra do
        {
          'raw_info' => raw_info
        }
      end

      def raw_info
        @raw_info ||= access_token.get('users/@me').parsed
      end

      def callback_url
        # Discord does not support query parameters
        full_host + script_name + callback_path
      end

      def authorize_params
        super.tap do |params|
          options[:authorize_options].each do |option|
            params[option] = request.params[option.to_s] if request.params[option.to_s]
          end

          params[:redirect_uri] = options[:redirect_uri] unless options[:redirect_uri].nil?
          params[:scope] ||= DEFAULT_SCOPE
        end
      end
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
omniauth-discord-0.1.5 lib/omniauth/strategies/discord.rb