# encoding: utf-8
module Github
class Users < API
extend AutoloadHelper
# Load all the modules after initializing Repos to avoid superclass mismatch
autoload_all 'github_api/users',
:Emails => 'emails',
:Followers => 'followers',
:Keys => 'keys'
VALID_USER_PARAMS_NAMES = %w[
name
email
blog
company
location
hireable
bio
].freeze
# Creates new Repos API
def initialize(options = {})
super(options)
end
# Access to Users::Emails API
def emails
@emails ||= ApiFactory.new 'Users::Emails'
end
# Access to Users::Followers API
def followers
@followers ||= ApiFactory.new 'Users::Followers'
end
# Access to Users::Keys API
def keys
@keys ||= ApiFactory.new 'Users::Keys'
end
# Get a single unauthenticated user
#
# = Examples
# github = Github.new
# github.users.get user: 'user-name'
#
# Get the authenticated user
#
# = Examples
# github = Github.new oauth_token: '...'
# github.users.get
#
def get(*args)
params = args.extract_options!
normalize! params
if user_name = params.delete('user')
get_request("/users/#{user_name}", params)
else
get_request("/user", params)
end
end
alias :find :get
# Update the authenticated user
#
# = Inputs
# * :name - Optional string
# * :email - Optional string - publically visible email address
# * :blog - Optional string
# * :company - Optional string
# * :location - Optional string
# * :hireable - Optional boolean
# * :bio - Optional string
#
# = Examples
# github = Github.new :oauth_token => '..'
# github.users.update
# "name" => "monalisa octocat",
# "email" => "octocat@github.com",
# "blog" => "https://github.com/blog",
# "company" => "GitHub",
# "location" => "San Francisco",
# "hireable" => true,
# "bio" => "There once..."
#
def update(*args)
params = args.extract_options!
normalize! params
filter! VALID_USER_PARAMS_NAMES, params
patch_request("/user", params)
end
end # Users
end # Github