/** * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. * SPDX-License-Identifier: Apache-2.0. */ #pragma once #include #include #include #include #include #include #include namespace Aws { namespace Http { class URI; } //namespace Http namespace CodeArtifact { namespace Model { /** */ class AWS_CODEARTIFACT_API DeletePackageVersionsRequest : public CodeArtifactRequest { public: DeletePackageVersionsRequest(); // Service request name is the Operation name which will send this request out, // each operation should has unique request name, so that we can get operation's name from this request. // Note: this is not true for response, multiple operations may have the same response name, // so we can not get operation's name from response. inline virtual const char* GetServiceRequestName() const override { return "DeletePackageVersions"; } Aws::String SerializePayload() const override; void AddQueryStringParameters(Aws::Http::URI& uri) const override; /** *

The name of the domain that contains the package to delete.

*/ inline const Aws::String& GetDomain() const{ return m_domain; } /** *

The name of the domain that contains the package to delete.

*/ inline bool DomainHasBeenSet() const { return m_domainHasBeenSet; } /** *

The name of the domain that contains the package to delete.

*/ inline void SetDomain(const Aws::String& value) { m_domainHasBeenSet = true; m_domain = value; } /** *

The name of the domain that contains the package to delete.

*/ inline void SetDomain(Aws::String&& value) { m_domainHasBeenSet = true; m_domain = std::move(value); } /** *

The name of the domain that contains the package to delete.

*/ inline void SetDomain(const char* value) { m_domainHasBeenSet = true; m_domain.assign(value); } /** *

The name of the domain that contains the package to delete.

*/ inline DeletePackageVersionsRequest& WithDomain(const Aws::String& value) { SetDomain(value); return *this;} /** *

The name of the domain that contains the package to delete.

*/ inline DeletePackageVersionsRequest& WithDomain(Aws::String&& value) { SetDomain(std::move(value)); return *this;} /** *

The name of the domain that contains the package to delete.

*/ inline DeletePackageVersionsRequest& WithDomain(const char* value) { SetDomain(value); return *this;} /** *

The 12-digit account number of the AWS account that owns the domain. It does * not include dashes or spaces.

*/ inline const Aws::String& GetDomainOwner() const{ return m_domainOwner; } /** *

The 12-digit account number of the AWS account that owns the domain. It does * not include dashes or spaces.

*/ inline bool DomainOwnerHasBeenSet() const { return m_domainOwnerHasBeenSet; } /** *

The 12-digit account number of the AWS account that owns the domain. It does * not include dashes or spaces.

*/ inline void SetDomainOwner(const Aws::String& value) { m_domainOwnerHasBeenSet = true; m_domainOwner = value; } /** *

The 12-digit account number of the AWS account that owns the domain. It does * not include dashes or spaces.

*/ inline void SetDomainOwner(Aws::String&& value) { m_domainOwnerHasBeenSet = true; m_domainOwner = std::move(value); } /** *

The 12-digit account number of the AWS account that owns the domain. It does * not include dashes or spaces.

*/ inline void SetDomainOwner(const char* value) { m_domainOwnerHasBeenSet = true; m_domainOwner.assign(value); } /** *

The 12-digit account number of the AWS account that owns the domain. It does * not include dashes or spaces.

*/ inline DeletePackageVersionsRequest& WithDomainOwner(const Aws::String& value) { SetDomainOwner(value); return *this;} /** *

The 12-digit account number of the AWS account that owns the domain. It does * not include dashes or spaces.

*/ inline DeletePackageVersionsRequest& WithDomainOwner(Aws::String&& value) { SetDomainOwner(std::move(value)); return *this;} /** *

The 12-digit account number of the AWS account that owns the domain. It does * not include dashes or spaces.

*/ inline DeletePackageVersionsRequest& WithDomainOwner(const char* value) { SetDomainOwner(value); return *this;} /** *

The name of the repository that contains the package versions to delete. *

*/ inline const Aws::String& GetRepository() const{ return m_repository; } /** *

The name of the repository that contains the package versions to delete. *

*/ inline bool RepositoryHasBeenSet() const { return m_repositoryHasBeenSet; } /** *

The name of the repository that contains the package versions to delete. *

*/ inline void SetRepository(const Aws::String& value) { m_repositoryHasBeenSet = true; m_repository = value; } /** *

The name of the repository that contains the package versions to delete. *

*/ inline void SetRepository(Aws::String&& value) { m_repositoryHasBeenSet = true; m_repository = std::move(value); } /** *

The name of the repository that contains the package versions to delete. *

*/ inline void SetRepository(const char* value) { m_repositoryHasBeenSet = true; m_repository.assign(value); } /** *

The name of the repository that contains the package versions to delete. *

*/ inline DeletePackageVersionsRequest& WithRepository(const Aws::String& value) { SetRepository(value); return *this;} /** *

The name of the repository that contains the package versions to delete. *

*/ inline DeletePackageVersionsRequest& WithRepository(Aws::String&& value) { SetRepository(std::move(value)); return *this;} /** *

The name of the repository that contains the package versions to delete. *

*/ inline DeletePackageVersionsRequest& WithRepository(const char* value) { SetRepository(value); return *this;} /** *

The format of the package versions to delete. The valid values are:

*
  • npm

  • pypi

  • *
  • maven

*/ inline const PackageFormat& GetFormat() const{ return m_format; } /** *

The format of the package versions to delete. The valid values are:

*
  • npm

  • pypi

  • *
  • maven

*/ inline bool FormatHasBeenSet() const { return m_formatHasBeenSet; } /** *

The format of the package versions to delete. The valid values are:

*
  • npm

  • pypi

  • *
  • maven

*/ inline void SetFormat(const PackageFormat& value) { m_formatHasBeenSet = true; m_format = value; } /** *

The format of the package versions to delete. The valid values are:

*
  • npm

  • pypi

  • *
  • maven

*/ inline void SetFormat(PackageFormat&& value) { m_formatHasBeenSet = true; m_format = std::move(value); } /** *

The format of the package versions to delete. The valid values are:

*
  • npm

  • pypi

  • *
  • maven

*/ inline DeletePackageVersionsRequest& WithFormat(const PackageFormat& value) { SetFormat(value); return *this;} /** *

The format of the package versions to delete. The valid values are:

*
  • npm

  • pypi

  • *
  • maven

*/ inline DeletePackageVersionsRequest& WithFormat(PackageFormat&& value) { SetFormat(std::move(value)); return *this;} /** *

The namespace of the package. The package component that specifies its * namespace depends on its type. For example:

  • The namespace of * a Maven package is its groupId.

  • The namespace * of an npm package is its scope.

  • A Python * package does not contain a corresponding component, so Python packages do not * have a namespace.

*/ inline const Aws::String& GetNamespace() const{ return m_namespace; } /** *

The namespace of the package. The package component that specifies its * namespace depends on its type. For example:

  • The namespace of * a Maven package is its groupId.

  • The namespace * of an npm package is its scope.

  • A Python * package does not contain a corresponding component, so Python packages do not * have a namespace.

*/ inline bool NamespaceHasBeenSet() const { return m_namespaceHasBeenSet; } /** *

The namespace of the package. The package component that specifies its * namespace depends on its type. For example:

  • The namespace of * a Maven package is its groupId.

  • The namespace * of an npm package is its scope.

  • A Python * package does not contain a corresponding component, so Python packages do not * have a namespace.

*/ inline void SetNamespace(const Aws::String& value) { m_namespaceHasBeenSet = true; m_namespace = value; } /** *

The namespace of the package. The package component that specifies its * namespace depends on its type. For example:

  • The namespace of * a Maven package is its groupId.

  • The namespace * of an npm package is its scope.

  • A Python * package does not contain a corresponding component, so Python packages do not * have a namespace.

*/ inline void SetNamespace(Aws::String&& value) { m_namespaceHasBeenSet = true; m_namespace = std::move(value); } /** *

The namespace of the package. The package component that specifies its * namespace depends on its type. For example:

  • The namespace of * a Maven package is its groupId.

  • The namespace * of an npm package is its scope.

  • A Python * package does not contain a corresponding component, so Python packages do not * have a namespace.

*/ inline void SetNamespace(const char* value) { m_namespaceHasBeenSet = true; m_namespace.assign(value); } /** *

The namespace of the package. The package component that specifies its * namespace depends on its type. For example:

  • The namespace of * a Maven package is its groupId.

  • The namespace * of an npm package is its scope.

  • A Python * package does not contain a corresponding component, so Python packages do not * have a namespace.

*/ inline DeletePackageVersionsRequest& WithNamespace(const Aws::String& value) { SetNamespace(value); return *this;} /** *

The namespace of the package. The package component that specifies its * namespace depends on its type. For example:

  • The namespace of * a Maven package is its groupId.

  • The namespace * of an npm package is its scope.

  • A Python * package does not contain a corresponding component, so Python packages do not * have a namespace.

*/ inline DeletePackageVersionsRequest& WithNamespace(Aws::String&& value) { SetNamespace(std::move(value)); return *this;} /** *

The namespace of the package. The package component that specifies its * namespace depends on its type. For example:

  • The namespace of * a Maven package is its groupId.

  • The namespace * of an npm package is its scope.

  • A Python * package does not contain a corresponding component, so Python packages do not * have a namespace.

*/ inline DeletePackageVersionsRequest& WithNamespace(const char* value) { SetNamespace(value); return *this;} /** *

The name of the package with the versions to delete.

*/ inline const Aws::String& GetPackage() const{ return m_package; } /** *

The name of the package with the versions to delete.

*/ inline bool PackageHasBeenSet() const { return m_packageHasBeenSet; } /** *

The name of the package with the versions to delete.

*/ inline void SetPackage(const Aws::String& value) { m_packageHasBeenSet = true; m_package = value; } /** *

The name of the package with the versions to delete.

*/ inline void SetPackage(Aws::String&& value) { m_packageHasBeenSet = true; m_package = std::move(value); } /** *

The name of the package with the versions to delete.

*/ inline void SetPackage(const char* value) { m_packageHasBeenSet = true; m_package.assign(value); } /** *

The name of the package with the versions to delete.

*/ inline DeletePackageVersionsRequest& WithPackage(const Aws::String& value) { SetPackage(value); return *this;} /** *

The name of the package with the versions to delete.

*/ inline DeletePackageVersionsRequest& WithPackage(Aws::String&& value) { SetPackage(std::move(value)); return *this;} /** *

The name of the package with the versions to delete.

*/ inline DeletePackageVersionsRequest& WithPackage(const char* value) { SetPackage(value); return *this;} /** *

An array of strings that specify the versions of the package to delete.

*/ inline const Aws::Vector& GetVersions() const{ return m_versions; } /** *

An array of strings that specify the versions of the package to delete.

*/ inline bool VersionsHasBeenSet() const { return m_versionsHasBeenSet; } /** *

An array of strings that specify the versions of the package to delete.

*/ inline void SetVersions(const Aws::Vector& value) { m_versionsHasBeenSet = true; m_versions = value; } /** *

An array of strings that specify the versions of the package to delete.

*/ inline void SetVersions(Aws::Vector&& value) { m_versionsHasBeenSet = true; m_versions = std::move(value); } /** *

An array of strings that specify the versions of the package to delete.

*/ inline DeletePackageVersionsRequest& WithVersions(const Aws::Vector& value) { SetVersions(value); return *this;} /** *

An array of strings that specify the versions of the package to delete.

*/ inline DeletePackageVersionsRequest& WithVersions(Aws::Vector&& value) { SetVersions(std::move(value)); return *this;} /** *

An array of strings that specify the versions of the package to delete.

*/ inline DeletePackageVersionsRequest& AddVersions(const Aws::String& value) { m_versionsHasBeenSet = true; m_versions.push_back(value); return *this; } /** *

An array of strings that specify the versions of the package to delete.

*/ inline DeletePackageVersionsRequest& AddVersions(Aws::String&& value) { m_versionsHasBeenSet = true; m_versions.push_back(std::move(value)); return *this; } /** *

An array of strings that specify the versions of the package to delete.

*/ inline DeletePackageVersionsRequest& AddVersions(const char* value) { m_versionsHasBeenSet = true; m_versions.push_back(value); return *this; } /** *

The expected status of the package version to delete. Valid values are:

*
  • Published

  • Unfinished *

  • Unlisted

  • * Archived

  • Disposed

*/ inline const PackageVersionStatus& GetExpectedStatus() const{ return m_expectedStatus; } /** *

The expected status of the package version to delete. Valid values are:

*
  • Published

  • Unfinished *

  • Unlisted

  • * Archived

  • Disposed

*/ inline bool ExpectedStatusHasBeenSet() const { return m_expectedStatusHasBeenSet; } /** *

The expected status of the package version to delete. Valid values are:

*
  • Published

  • Unfinished *

  • Unlisted

  • * Archived

  • Disposed

*/ inline void SetExpectedStatus(const PackageVersionStatus& value) { m_expectedStatusHasBeenSet = true; m_expectedStatus = value; } /** *

The expected status of the package version to delete. Valid values are:

*
  • Published

  • Unfinished *

  • Unlisted

  • * Archived

  • Disposed

*/ inline void SetExpectedStatus(PackageVersionStatus&& value) { m_expectedStatusHasBeenSet = true; m_expectedStatus = std::move(value); } /** *

The expected status of the package version to delete. Valid values are:

*
  • Published

  • Unfinished *

  • Unlisted

  • * Archived

  • Disposed

*/ inline DeletePackageVersionsRequest& WithExpectedStatus(const PackageVersionStatus& value) { SetExpectedStatus(value); return *this;} /** *

The expected status of the package version to delete. Valid values are:

*
  • Published

  • Unfinished *

  • Unlisted

  • * Archived

  • Disposed

*/ inline DeletePackageVersionsRequest& WithExpectedStatus(PackageVersionStatus&& value) { SetExpectedStatus(std::move(value)); return *this;} private: Aws::String m_domain; bool m_domainHasBeenSet; Aws::String m_domainOwner; bool m_domainOwnerHasBeenSet; Aws::String m_repository; bool m_repositoryHasBeenSet; PackageFormat m_format; bool m_formatHasBeenSet; Aws::String m_namespace; bool m_namespaceHasBeenSet; Aws::String m_package; bool m_packageHasBeenSet; Aws::Vector m_versions; bool m_versionsHasBeenSet; PackageVersionStatus m_expectedStatus; bool m_expectedStatusHasBeenSet; }; } // namespace Model } // namespace CodeArtifact } // namespace Aws