# encoding: utf-8
module Github
class Search < API
include Github::Utils::Url
# Search issues
#
# Find issues by state and keyword.
#
# = Parameters
# :state - open or closed.
# :keyword - search term
#
# = Examples
# github = Github.new
# github.search.issues owner: 'owner', repo: 'repo-name', state: 'open', keyword: 'api'
#
def issues(*args)
params = args.extract_options!
normalize! params
required = ['owner', 'repo', 'state', 'keyword']
assert_required_keys required, params
options = required.inject({}) do |hash, key|
hash[key] = params.delete(key)
hash
end
get_request("/legacy/issues/search/#{options['owner']}/#{options['repo']}/#{options['state']}/#{escape(options['keyword'])}", params)
end
# Search repositories
#
# Find repositories by keyword.
#
# = Parameters
# :keyword - search term
#
# = Examples
# github = Github.new
# github.search.repos keyword: 'api'
#
def repos(*args)
params = args.extract_options!
normalize! params
assert_required_keys %w[ keyword ], params
get_request("/legacy/repos/search/#{escape(params.delete('keyword'))}", params)
end
alias :repositories :repos
# Search users
#
# Find users by keyword.
#
# = Parameters
# :keyword - search term
#
# = Examples
# github = Github.new
# github.search.users keyword: 'wycats'
#
def users(*args)
params = args.extract_options!
normalize! params
assert_required_keys %w[ keyword ], params
get_request("/legacy/user/search/#{escape(params.delete('keyword'))}", params)
end
# Search email
#
# This API call is added for compatibility reasons only. There’s no
# guarantee that full email searches will always be available.
#
# = Parameters
# :keyword - search term
#
# = Examples
# github = Github.new
# github.search.email email: 'wycats'
#
def email(*args)
params = args.extract_options!
normalize! params
assert_required_keys %w[ email ], params
get_request("/legacy/user/email/#{params.delete('email')}", params)
end
end # Search
end # Github