# frozen_string_literal: true module BitBucket class User < API DEFAULT_USER_OPTIONS = { 'first_name' => '', 'last_name' => '', 'avatar' => '' # TODO: can this filed be modified? # "resource_uri" => "" }.freeze # Creates new User API def initialize(options = {}) super(options) end # Gets the basic information associated with an account and # a list of all of the repositories owned by the user. # See https://confluence.atlassian.com/display/BITBUCKET/user+Endpoint#userEndpoint-GETauserprofile # # = Examples # bitbucket = BitBucket.new # bitbucket.user_api.profile # def profile get_request('/1.0/user') end # Update a user # = Parameters # * :first_name Optional string # * :last_name Optional string # * :avatar Optional string # * :resource_uri Optional string # # = Examples # # bitbucket = BitBucket.new # bitbucket.user_api.update :first_name => 'first-name', :last_name => 'last-name' # def update(params = {}) normalize! params filter! DEFAULT_USER_OPTIONS, params put_request('/1.0/user', DEFAULT_USER_OPTIONS.merge(params)) end # GET a list of user privileges def privileges get_request('/1.0/user/privileges') end # GET a list of repositories an account follows # Gets the details of the repositories that the individual or team account follows. # This call returns the full data about the repositories including # if the repository is a fork of another repository. # An account always "follows" its own repositories. def follows get_request('/1.0/user/follows') end # GET a list of repositories visible to an account # Gets the details of the repositories that the user owns # or has at least read access to. # Use this if you're looking for a full list of all of the repositories associated with a user. def repositories get_request('/1.0/user/repositories') end alias repos repositories # GET a list of repositories the account is following # Gets a list of the repositories the account follows. # This is the same list that appears on the Following tab on your account dashboard. def overview get_request('/1.0/user/repositories/overview') end # GET the list of repositories on the dashboard # Gets the repositories list from the account's dashboard. def dashboard get_request('/1.0/user/repositories/dashboard') end end # User end # BitBucket