# encoding: utf-8
module Github
class Orgs < API
extend AutoloadHelper
autoload_all 'github_api/orgs',
:Members => 'members',
:Teams => 'teams'
VALID_ORG_PARAM_NAMES = %w[
billing_email
company
email
location
name
].freeze
# Creates new Orgs API
def initialize(options = {})
super(options)
end
# Access to Orgs::Members API
def members
@members ||= ApiFactory.new 'Orgs::Members'
end
# Access to Orgs::Teams API
def teams
@teams ||= ApiFactory.new 'Orgs::Teams'
end
# List all public organizations for a user.
#
# = Examples
# github = Github.new :user => 'user-name'
# github.orgs.list
#
# List public and private organizations for the authenticated user.
#
# github = Github.new :oauth_token => '..'
# github.orgs.list 'github'
#
def list(user_name=nil, params={})
_update_user_repo_params(user_name)
_normalize_params_keys(params)
response = if user?
get_request("/users/#{user}/orgs", params)
else
get_request("/user/orgs", params)
end
return response unless block_given?
response.each { |el| yield el }
end
alias :all :list
# Get properties for a single organization
#
# = Examples
# github = Github.new
# github.orgs.get 'github'
#
def get(org_name, params={})
_validate_presence_of org_name
get_request("/orgs/#{org_name}", params)
end
alias :find :get
# Edit organization
#
# = Parameters
# :billing_email - Optional string - Billing email address. This address is not publicized.
# :company - Optional string
# :email - Optional string
# :location - Optional string
# :name - Optional string
#
# = Examples
# github = Github.new :oauth_token => '...'
# github.orgs.edit 'github',
# "billing_email" => "support@github.com",
# "blog" => "https://github.com/blog",
# "company" => "GitHub",
# "email" => "support@github.com",
# "location" => "San Francisco",
# "name" => "github"
#
def edit(org_name, params={})
_validate_presence_of org_name
_normalize_params_keys(params)
_filter_params_keys(VALID_ORG_PARAM_NAMES, params)
patch_request("/orgs/#{org_name}", params)
end
end # Orgs
end # Github