piotrmurach/github

View on GitHub
lib/github_api/client/users.rb

Summary

Maintainability
A
0 mins
Test Coverage
# encoding: utf-8

require_relative '../api'

module Github
  class Client::Users < API
    # Load all the modules after initializing Repos to avoid superclass mismatch
    require_all 'github_api/client/users',
      'emails',
      'followers',
      'keys'

    VALID_USER_PARAMS_NAMES = %w[
      name
      email
      blog
      company
      location
      hireable
      bio
    ].freeze

    # Access to Users::Emails API
    namespace :emails

    # Access to Users::Followers API
    namespace :followers

    # Access to Users::Keys API
    namespace :keys

    # List all users.
    #
    # This provides a dump of every user, in the order that they signed up
    # for GitHub.
    #
    # @param [Hash] params
    # @option [Integer] :since
    #   The integer ID of the last User that you’ve seen.
    #
    # @example
    #  users = Github::Users.new
    #  users.list
    #
    # @api public
    def list(*args)
      arguments(args)

      response = get_request("/users", arguments.params)
      return response unless block_given?
      response.each { |el| yield el }
    end
    alias :all :list

    # Get a single unauthenticated user
    #
    # @example
    #  github = Github.new
    #  github.users.get user: 'user-name'
    #
    # Get the authenticated user
    #
    # @example
    #  github = Github.new oauth_token: '...'
    #  github.users.get
    #
    # @api public
    def get(*args)
      params = arguments(args).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
    #
    # @param [Hash] params
    # @option params [String] :name
    #   Optional string
    # @option params [String] :email
    #   Optional string - publically visible email address
    # @option params [String] :blog
    #   Optional string
    # @option params [String] :company
    #   Optional string
    # @option params [String] :location
    #   Optional string
    # @option params [String] :hireable
    #   Optional boolean
    # @option params [String] :bio
    #   Optional string
    #
    # @example
    #  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..."
    #
    # @api public
    def update(*args)
      arguments(args) do
        permit VALID_USER_PARAMS_NAMES
      end

      patch_request("/user", arguments.params)
    end
  end # Users
end # Github