Files
Lars Zweifel bdc16944ae feat: added Missing APIOption overload for PackagesClient.GetAll* #2923 (#2934)
feat: added Missing APIOption overload for PackagesClient.GetAll* #2923

added missing APIOption overload for PackagesClient and ObservablePackagesClient
added overload for optional parameter packageVisibility to be a nonbreaking change
extended PackagesClientTests.cs to be conform with RepositoriesClientTests.cs to take ApiOptions into account
2024-06-21 12:17:55 -07:00

425 lines
21 KiB
C#

using System.Collections.Generic;
using System.Threading.Tasks;
namespace Octokit
{
/// <summary>
/// A client for GitHub's Packages API.
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages">Packages API documentation</a> for more details.
/// </remarks>
public class PackagesClient : ApiClient, IPackagesClient
{
public PackagesClient(IApiConnection apiConnection) : base(apiConnection)
{
PackageVersions = new PackageVersionsClient(apiConnection);
}
public IPackageVersionsClient PackageVersions { get; private set; }
#region Organization
/// <summary>
/// List all packages for an organisations, readable by the current user
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#list-packages-for-an-organization">API documentation</a> for more details
/// </remarks>
/// <param name="org">Required: Organisation Name</param>
/// <param name="packageType">Required: The type of package</param>
[ManualRoute("GET", "/orgs/{org}/packages")]
public Task<IReadOnlyList<Package>> GetAllForOrg(string org, PackageType packageType)
{
Ensure.ArgumentNotNullOrEmptyString(org, nameof(org));
Ensure.ArgumentNotNull(packageType, nameof(packageType));
return GetAllForOrg(org, packageType, ApiOptions.None);
}
/// <summary>
/// List all packages for an organisations, readable by the current user
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#list-packages-for-an-organization">API documentation</a> for more details
/// </remarks>
/// <param name="org">Required: Organisation Name</param>
/// <param name="packageType">Required: The type of package</param>
/// <param name="options">Options for changing the API response</param>
[ManualRoute("GET", "/orgs/{org}/packages")]
public Task<IReadOnlyList<Package>> GetAllForOrg(string org, PackageType packageType, ApiOptions options)
{
Ensure.ArgumentNotNullOrEmptyString(org, nameof(org));
Ensure.ArgumentNotNull(packageType, nameof(packageType));
Ensure.ArgumentNotNull(options, nameof(options));
return GetAllForOrg(org, packageType, null, options);
}
/// <summary>
/// List all packages for an organisations, readable by the current user
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#list-packages-for-an-organization">API documentation</a> for more details
/// </remarks>
/// <param name="org">Required: Organisation Name</param>
/// <param name="packageType">Required: The type of package</param>
/// <param name="packageVisibility">Optional: The visibility of the package</param>
[ManualRoute("GET", "/orgs/{org}/packages")]
public Task<IReadOnlyList<Package>> GetAllForOrg(string org, PackageType packageType, PackageVisibility? packageVisibility)
{
Ensure.ArgumentNotNullOrEmptyString(org, nameof(org));
Ensure.ArgumentNotNull(packageType, nameof(packageType));
return GetAllForOrg(org, packageType, packageVisibility, ApiOptions.None);
}
/// <summary>
/// List all packages for an organisations, readable by the current user
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#list-packages-for-an-organization">API documentation</a> for more details
/// </remarks>
/// <param name="org">Required: Organisation Name</param>
/// <param name="packageType">Required: The type of package</param>
/// <param name="packageVisibility">Optional: The visibility of the package</param>
/// <param name="options">Options for changing the API response</param>
[ManualRoute("GET", "/orgs/{org}/packages")]
public Task<IReadOnlyList<Package>> GetAllForOrg(string org, PackageType packageType, PackageVisibility? packageVisibility, ApiOptions options)
{
Ensure.ArgumentNotNullOrEmptyString(org, nameof(org));
Ensure.ArgumentNotNull(packageType, nameof(packageType));
Ensure.ArgumentNotNull(options, nameof(options));
var route = ApiUrls.PackagesOrg(org);
var parameters = ParameterBuilder.AddParameter("package_type", packageType).AddOptionalParameter("visibility", packageVisibility);
return ApiConnection.GetAll<Package>(route, parameters, options);
}
/// <summary>
/// Get a specific package for an Organization.
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#get-a-package-for-an-organization">API documentation</a> for more details
/// </remarks>
/// <param name="org">Required: Organisation Name</param>
/// <param name="packageType">Required: The type of package</param>
/// <param name="packageName">Required: The name of the package</param>
[ManualRoute("GET", "/orgs/{org}/packages/{package_type}/{package_name}")]
public Task<Package> GetForOrg(string org, PackageType packageType, string packageName)
{
Ensure.ArgumentNotNullOrEmptyString(org, nameof(org));
Ensure.ArgumentNotNullOrEmptyString(packageName, nameof(packageName));
var route = ApiUrls.PackageOrg(org, packageType, packageName);
return ApiConnection.Get<Package>(route);
}
/// <summary>
/// Delete a specific package for an Organization.
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#delete-a-package-for-an-organization">API documentation</a> for more details
/// </remarks>
/// <param name="org">Required: Organisation Name</param>
/// <param name="packageType">Required: The type of package</param>
/// <param name="packageName">Required: The name of the package</param>
[ManualRoute("DELETE", "/orgs/{org}/packages/{package_type}/{package_name}")]
public Task DeleteForOrg(string org, PackageType packageType, string packageName)
{
Ensure.ArgumentNotNullOrEmptyString(org, nameof(org));
Ensure.ArgumentNotNullOrEmptyString(packageName, nameof(packageName));
Ensure.ArgumentNotNull(packageType, nameof(packageType));
var route = ApiUrls.PackageOrg(org, packageType, packageName);
return ApiConnection.Delete(route);
}
/// <summary>
/// Restore a specific package for an Organization.
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#restore-a-package-for-an-organization">API documentation</a> for more details
/// </remarks>
/// <param name="org">Required: Organisation Name</param>
/// <param name="packageType">Required: The type of package</param>
/// <param name="packageName">Required: The name of the package</param>
[ManualRoute("POST", "/orgs/{org}/packages/{package_type}/{package_name}/restore")]
public Task RestoreForOrg(string org, PackageType packageType, string packageName)
{
Ensure.ArgumentNotNullOrEmptyString(org, nameof(org));
Ensure.ArgumentNotNullOrEmptyString(packageName, nameof(packageName));
var route = ApiUrls.PackageRestoreOrg(org, packageType, packageName);
return ApiConnection.Post(route);
}
#endregion
#region Active User
/// <summary>
/// Lists packages owned by the authenticated user within the user's namespace
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#list-packages-for-the-authenticated-users-namespace">API documentation</a> for more details
/// </remarks>
/// <param name="packageType">Required: The type of package</param>
[ManualRoute("GET", "/user/packages")]
public Task<IReadOnlyList<Package>> GetAllForActiveUser(PackageType packageType)
{
Ensure.ArgumentNotNull(packageType, nameof(packageType));
return GetAllForActiveUser(packageType, (PackageVisibility?)null);
}
/// <summary>
/// Lists packages owned by the authenticated user within the user's namespace
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#list-packages-for-the-authenticated-users-namespace">API documentation</a> for more details
/// </remarks>
/// <param name="packageType">Required: The type of package</param>
/// <param name="options">Options for changing the API response</param>
[ManualRoute("GET", "/user/packages")]
public Task<IReadOnlyList<Package>> GetAllForActiveUser(PackageType packageType, ApiOptions options)
{
Ensure.ArgumentNotNull(packageType, nameof(packageType));
Ensure.ArgumentNotNull(options, nameof(options));
return GetAllForActiveUser(packageType, null, options);
}
/// <summary>
/// Lists packages owned by the authenticated user within the user's namespace
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#list-packages-for-the-authenticated-users-namespace">API documentation</a> for more details
/// </remarks>
/// <param name="packageType">Required: The type of package</param>
/// <param name="packageVisibility">Optional: The visibility of the package</param>
[ManualRoute("GET", "/user/packages")]
public Task<IReadOnlyList<Package>> GetAllForActiveUser(PackageType packageType, PackageVisibility? packageVisibility)
{
Ensure.ArgumentNotNull(packageType, nameof(packageType));
return GetAllForActiveUser(packageType, packageVisibility, ApiOptions.None);
}
/// <summary>
/// Lists packages owned by the authenticated user within the user's namespace
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#list-packages-for-the-authenticated-users-namespace">API documentation</a> for more details
/// </remarks>
/// <param name="packageType">Required: The type of package</param>
/// <param name="packageVisibility">Optional: The visibility of the package</param>
/// <param name="options">Options for changing the API response</param>
[ManualRoute("GET", "/user/packages")]
public Task<IReadOnlyList<Package>> GetAllForActiveUser(PackageType packageType, PackageVisibility? packageVisibility, ApiOptions options)
{
Ensure.ArgumentNotNull(packageType, nameof(packageType));
Ensure.ArgumentNotNull(options, nameof(options));
var route = ApiUrls.PackagesActiveUser();
var parameters = ParameterBuilder.AddParameter("package_type", packageType).AddOptionalParameter("visibility", packageVisibility);
return ApiConnection.GetAll<Package>(route, parameters, options);
}
/// <summary>
/// Gets a specific package for a package owned by the authenticated user.
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#get-a-package-for-the-authenticated-user">API documentation</a> for more details
/// </remarks>
/// <param name="packageType">Required: The type of package</param>
/// <param name="packageName">Required: The name of the package</param>
[ManualRoute("GET", "/user/packages/{package_type}/{package_name}")]
public Task<Package> GetForActiveUser(PackageType packageType, string packageName)
{
Ensure.ArgumentNotNullOrEmptyString(packageName, nameof(packageName));
var route = ApiUrls.PackageActiveUser(packageType, packageName);
return ApiConnection.Get<Package>(route);
}
/// <summary>
/// Deletes a package owned by the authenticated user.
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#delete-a-package-for-the-authenticated-user">API documentation</a> for more details
/// </remarks>
/// <param name="packageType">Required: The type of package</param>
/// <param name="packageName">Required: The name of the package</param>
[ManualRoute("DELETE", "/user/packages/{package_type}/{package_name}")]
public Task DeleteForActiveUser(PackageType packageType, string packageName)
{
Ensure.ArgumentNotNullOrEmptyString(packageName, nameof(packageName));
var route = ApiUrls.PackageActiveUser(packageType, packageName);
return ApiConnection.Delete(route);
}
/// <summary>
/// Restores a package owned by the authenticated user.
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#restore-a-package-for-the-authenticated-user">API documentation</a> for more details
/// </remarks>
/// <param name="packageType">Required: The type of package</param>
/// <param name="packageName">Required: The name of the package</param>
[ManualRoute("POST", "/user/packages/{package_type}/{package_name}/restore")]
public Task RestoreForActiveUser(PackageType packageType, string packageName)
{
Ensure.ArgumentNotNullOrEmptyString(packageName, nameof(packageName));
var route = ApiUrls.PackageRestoreActiveUser(packageType, packageName);
return ApiConnection.Post(route);
}
#endregion
#region Specific User
/// <summary>
/// Lists packages owned by the authenticated user within the user's namespace
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#list-packages-for-the-authenticated-users-namespace">API documentation</a> for more details
/// </remarks>
/// <param name="username">Required: Username</param>
/// <param name="packageType">Required: The type of package</param>
[ManualRoute("GET", "/users/{username}/packages")]
public Task<IReadOnlyList<Package>> GetAllForUser(string username, PackageType packageType)
{
Ensure.ArgumentNotNullOrEmptyString(username, nameof(username));
Ensure.ArgumentNotNull(packageType, nameof(packageType));
return GetAllForUser(username, packageType, ApiOptions.None);
}
/// <summary>
/// Lists packages owned by the authenticated user within the user's namespace
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#list-packages-for-the-authenticated-users-namespace">API documentation</a> for more details
/// </remarks>
/// <param name="username">Required: Username</param>
/// <param name="packageType">Required: The type of package</param>
/// <param name="options">Options for changing the API response</param>
[ManualRoute("GET", "/users/{username}/packages")]
public Task<IReadOnlyList<Package>> GetAllForUser(string username, PackageType packageType, ApiOptions options)
{
Ensure.ArgumentNotNull(packageType, nameof(packageType));
Ensure.ArgumentNotNull(options, nameof(options));
return GetAllForUser(username, packageType, null, options);
}
/// <summary>
/// Lists packages owned by the authenticated user within the user's namespace
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#list-packages-for-the-authenticated-users-namespace">API documentation</a> for more details
/// </remarks>
/// <param name="username">Required: Username</param>
/// <param name="packageType">Required: The type of package</param>
/// <param name="packageVisibility">Optional: The visibility of the package</param>
[ManualRoute("GET", "/users/{username}/packages")]
public Task<IReadOnlyList<Package>> GetAllForUser(string username, PackageType packageType, PackageVisibility? packageVisibility)
{
Ensure.ArgumentNotNullOrEmptyString(username, nameof(username));
Ensure.ArgumentNotNull(packageType, nameof(packageType));
return GetAllForUser(username, packageType, packageVisibility, ApiOptions.None);
}
/// <summary>
/// Lists packages owned by the authenticated user within the user's namespace
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#list-packages-for-the-authenticated-users-namespace">API documentation</a> for more details
/// </remarks>
/// <param name="username">Required: Username</param>
/// <param name="packageType">Required: The type of package</param>
/// <param name="packageVisibility">Optional: The visibility of the package</param>
/// <param name="options">Options for changing the API response</param>
[ManualRoute("GET", "/users/{username}/packages")]
public Task<IReadOnlyList<Package>> GetAllForUser(string username, PackageType packageType, PackageVisibility? packageVisibility, ApiOptions options)
{
Ensure.ArgumentNotNullOrEmptyString(username, nameof(username));
Ensure.ArgumentNotNull(packageType, nameof(packageType));
Ensure.ArgumentNotNull(options, nameof(options));
var route = ApiUrls.PackagesUser(username);
var parameters = ParameterBuilder.AddParameter("package_type", packageType).AddOptionalParameter("visibility", packageVisibility);
return ApiConnection.GetAll<Package>(route, parameters, options);
}
/// <summary>
/// Gets a specific package metadata for a public package owned by a user.
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#get-a-package-for-a-user">API documentation</a> for more details
/// </remarks>
/// <param name="username">Required: Username</param>
/// <param name="packageType">Required: The type of package</param>
/// <param name="packageName">Required: The name of the package</param>
[ManualRoute("GET", "/users/{username}/packages/{package_type}/{package_name}")]
public Task<Package> GetForUser(string username, PackageType packageType, string packageName)
{
Ensure.ArgumentNotNullOrEmptyString(username, nameof(username));
Ensure.ArgumentNotNullOrEmptyString(packageName, nameof(packageName));
var route = ApiUrls.PackageUser(username, packageType, packageName);
return ApiConnection.Get<Package>(route);
}
/// <summary>
/// Deletes an entire package for a user.
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#delete-a-package-for-a-user">API documentation</a> for more details
/// </remarks>
/// <param name="username">Required: Username</param>
/// <param name="packageType">Required: The type of package</param>
/// <param name="packageName">Required: The name of the package</param>
[ManualRoute("DELETE", "/users/{username}/packages/{package_type}/{package_name}")]
public Task DeleteForUser(string username, PackageType packageType, string packageName)
{
Ensure.ArgumentNotNullOrEmptyString(username, nameof(username));
Ensure.ArgumentNotNullOrEmptyString(packageName, nameof(packageName));
var route = ApiUrls.PackageUser(username, packageType, packageName);
return ApiConnection.Delete(route);
}
/// <summary>
/// Restores an entire package for a user.
/// </summary>
/// <remarks>
/// See the <a href="https://docs.github.com/rest/packages#restore-a-package-for-a-user">API documentation</a> for more details
/// </remarks>
/// <param name="username">Required: Username</param>
/// <param name="packageType">Required: The type of package</param>
/// <param name="packageName">Required: The name of the package</param>
[ManualRoute("POST", "/users/{username}/packages/{package_type}/{package_name}/restore")]
public Task RestoreForUser(string username, PackageType packageType, string packageName)
{
Ensure.ArgumentNotNullOrEmptyString(username, nameof(username));
Ensure.ArgumentNotNullOrEmptyString(packageName, nameof(packageName));
var route = ApiUrls.PackageRestoreUser(username, packageType, packageName);
return ApiConnection.Post(route);
}
#endregion
}
}