lib/roda/plugins/hash_matcher.rb



# frozen-string-literal: true

#
class Roda
  module RodaPlugins
    # The hash_matcher plugin adds the hash_matcher class method, which
    # allows for easily defining hash matchers:
    #
    #   class App < Roda
    #     hash_matcher(:foo) do |v|
    #       self['foo'] == v
    #     end
    #
    #     route do
    #       r.on :foo=>'bar' do
    #         # matches when param foo has value bar
    #       end
    #     end
    #   end
    module HashMatcher
      module ClassMethods
        # Create a match_#{key} method in the request class using the given
        # block, so that using a hash key in a request match method will
        # call the block.  The block should return nil or false to not
        # match, and anything else to match.  See the HashMatcher module
        # documentation for an example.
        def hash_matcher(key, &block)
          self::RodaRequest.send(:define_method, :"match_#{key}", &block)
        end
      end
    end

    register_plugin(:hash_matcher, HashMatcher)
  end
end