lib/doorkeeper/config.rb
require 'doorkeeper/config/scopes' require 'doorkeeper/config/scope' require 'doorkeeper/config/scopes_builder' module Doorkeeper def self.configure(&block) @config = Config::Builder.new(&block).build end def self.configuration @config end class Config def default_scope_string @scopes.try(:default_scope_string) || "" end class Builder def initialize(&block) @config = Config.new instance_eval(&block) end def build @config end def use_refresh_token @config.instance_variable_set("@refresh_token_enabled", true) end end module Option # Defines configuration option # # When you call option, it defines two methods. One method will take place # in the +Config+ class and the other method will take place in the # +Builder+ class. # # The +name+ parameter will set both builder method and config attribute. # If the +:as+ option is defined, the builder method will be the specified # option while the config attribute will be the +name+ parameter. # # If you want to introduce another level of config DSL you can # define +builder_class+ parameter. # Builder should take a block as the initializer parameter and respond to function +build+ # that returns the value of the config attribute. # # ==== Options # # * [:+as+] Set the builder method that goes inside +configure+ block # * [+:default+] The default value in case no option was set # # ==== Examples # # option :name # option :name, :as => :set_name # option :name, :default => "My Name" # option :scopes :builder_class => ScopesBuilder # def option(name, options = {}) attribute = options[:as] || name attribute_builder = options[:builder_class] Builder.instance_eval do define_method name do |*args, &block| value = unless attribute_builder block ? block : args.first else attribute_builder.new(&block).build end @config.instance_variable_set(:"@#{attribute}", value) end end define_method attribute do |*args| instance_variable_get(:"@#{attribute}") || options[:default] end public attribute end def extended(base) base.send(:private, :option) end end extend Option option :resource_owner_authenticator, :as => :authenticate_resource_owner option :admin_authenticator, :as => :authenticate_admin option :access_token_expires_in, :default => 7200 option :authorization_scopes, :as => :scopes, :builder_class => ScopesBuilder, :default => Scopes.new def refresh_token_enabled? !!@refresh_token_enabled end end end