mirror of
https://github.com/zoriya/octokit.net.git
synced 2025-12-06 07:16:09 +00:00
108 lines
4.0 KiB
C#
108 lines
4.0 KiB
C#
using System;
|
|
using System.Threading.Tasks;
|
|
|
|
namespace Octokit
|
|
{
|
|
/// <summary>
|
|
/// A client for GitHub's Users API.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// See the <a href="http://developer.github.com/v3/users/">Users API documentation</a> for more information.
|
|
/// </remarks>
|
|
public class UsersClient : ApiClient, IUsersClient
|
|
{
|
|
static readonly Uri _userEndpoint = new Uri("user", UriKind.Relative);
|
|
|
|
/// <summary>
|
|
/// Instantiates a new GitHub Users API client.
|
|
/// </summary>
|
|
/// <param name="apiConnection">An API connection</param>
|
|
public UsersClient(IApiConnection apiConnection) : base(apiConnection)
|
|
{
|
|
Email = new UserEmailsClient(apiConnection);
|
|
Followers = new FollowersClient(apiConnection);
|
|
GitSshKey = new UserKeysClient(apiConnection);
|
|
GpgKey = new UserGpgKeysClient(apiConnection);
|
|
|
|
Administration = new UserAdministrationClient(apiConnection);
|
|
}
|
|
|
|
/// <summary>
|
|
/// A client for GitHub's User Emails API
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// See the <a href="http://developer.github.com/v3/users/emails/">Emails API documentation</a> for more information.
|
|
///</remarks>
|
|
public IUserEmailsClient Email { get; private set; }
|
|
|
|
/// <summary>
|
|
/// A client for GitHub's User Keys API
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// See the <a href="http://developer.github.com/v3/users/keys/">Keys API documentation</a> for more information.
|
|
///</remarks>
|
|
public IUserKeysClient GitSshKey { get; private set; }
|
|
|
|
/// <summary>
|
|
/// A client for GitHub's UserUser GPG Keys API.
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// See the <a href="https://developer.github.com/v3/users/gpg_keys/">User GPG Keys documentation</a> for more information.
|
|
/// </remarks>
|
|
public IUserGpgKeysClient GpgKey { get; private set; }
|
|
|
|
/// <summary>
|
|
/// Returns the user specified by the login.
|
|
/// </summary>
|
|
/// <param name="login">The login name for the user</param>
|
|
[ManualRoute("GET", "/users/{username}")]
|
|
public Task<User> Get(string login)
|
|
{
|
|
Ensure.ArgumentNotNullOrEmptyString(login, nameof(login));
|
|
|
|
return ApiConnection.Get<User>(ApiUrls.User(login));
|
|
}
|
|
|
|
/// <summary>
|
|
/// Returns a <see cref="User"/> for the current authenticated user.
|
|
/// </summary>
|
|
/// <exception cref="AuthorizationException">Thrown if the client is not authenticated.</exception>
|
|
/// <returns>A <see cref="User"/></returns>
|
|
[ManualRoute("GET", "/user")]
|
|
public Task<User> Current()
|
|
{
|
|
return ApiConnection.Get<User>(_userEndpoint);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Update the specified <see cref="UserUpdate"/>.
|
|
/// </summary>
|
|
/// <param name="user">The login for the user</param>
|
|
/// <exception cref="AuthorizationException">Thrown if the client is not authenticated.</exception>
|
|
/// <returns>A <see cref="User"/></returns>
|
|
[ManualRoute("PATCH", "/user")]
|
|
public Task<User> Update(UserUpdate user)
|
|
{
|
|
Ensure.ArgumentNotNull(user, nameof(user));
|
|
|
|
return ApiConnection.Patch<User>(_userEndpoint, user);
|
|
}
|
|
|
|
/// <summary>
|
|
/// A client for GitHub's User Followers API
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// See the <a href="http://developer.github.com/v3/users/followers/">Followers API documentation</a> for more information.
|
|
///</remarks>
|
|
public IFollowersClient Followers { get; private set; }
|
|
|
|
/// <summary>
|
|
/// A client for GitHub's User Administration API
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// See the <a href="https://developer.github.com/v3/users/administration/">User Administration API documentation</a> for more information.
|
|
///</remarks>
|
|
public IUserAdministrationClient Administration { get; private set; }
|
|
}
|
|
}
|