/** * 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 #include #include namespace Aws { template class AmazonWebServiceResult; namespace Utils { namespace Xml { class XmlDocument; } // namespace Xml } // namespace Utils namespace IAM { namespace Model { class GetOrganizationsAccessReportResult { public: AWS_IAM_API GetOrganizationsAccessReportResult(); AWS_IAM_API GetOrganizationsAccessReportResult(const Aws::AmazonWebServiceResult& result); AWS_IAM_API GetOrganizationsAccessReportResult& operator=(const Aws::AmazonWebServiceResult& result); /** *

The status of the job.

*/ inline const JobStatusType& GetJobStatus() const{ return m_jobStatus; } /** *

The status of the job.

*/ inline void SetJobStatus(const JobStatusType& value) { m_jobStatus = value; } /** *

The status of the job.

*/ inline void SetJobStatus(JobStatusType&& value) { m_jobStatus = std::move(value); } /** *

The status of the job.

*/ inline GetOrganizationsAccessReportResult& WithJobStatus(const JobStatusType& value) { SetJobStatus(value); return *this;} /** *

The status of the job.

*/ inline GetOrganizationsAccessReportResult& WithJobStatus(JobStatusType&& value) { SetJobStatus(std::move(value)); return *this;} /** *

The date and time, in ISO 8601 * date-time format, when the report job was created.

*/ inline const Aws::Utils::DateTime& GetJobCreationDate() const{ return m_jobCreationDate; } /** *

The date and time, in ISO 8601 * date-time format, when the report job was created.

*/ inline void SetJobCreationDate(const Aws::Utils::DateTime& value) { m_jobCreationDate = value; } /** *

The date and time, in ISO 8601 * date-time format, when the report job was created.

*/ inline void SetJobCreationDate(Aws::Utils::DateTime&& value) { m_jobCreationDate = std::move(value); } /** *

The date and time, in ISO 8601 * date-time format, when the report job was created.

*/ inline GetOrganizationsAccessReportResult& WithJobCreationDate(const Aws::Utils::DateTime& value) { SetJobCreationDate(value); return *this;} /** *

The date and time, in ISO 8601 * date-time format, when the report job was created.

*/ inline GetOrganizationsAccessReportResult& WithJobCreationDate(Aws::Utils::DateTime&& value) { SetJobCreationDate(std::move(value)); return *this;} /** *

The date and time, in ISO 8601 * date-time format, when the generated report job was completed or failed.

*

This field is null if the job is still in progress, as indicated by a job * status value of IN_PROGRESS.

*/ inline const Aws::Utils::DateTime& GetJobCompletionDate() const{ return m_jobCompletionDate; } /** *

The date and time, in ISO 8601 * date-time format, when the generated report job was completed or failed.

*

This field is null if the job is still in progress, as indicated by a job * status value of IN_PROGRESS.

*/ inline void SetJobCompletionDate(const Aws::Utils::DateTime& value) { m_jobCompletionDate = value; } /** *

The date and time, in ISO 8601 * date-time format, when the generated report job was completed or failed.

*

This field is null if the job is still in progress, as indicated by a job * status value of IN_PROGRESS.

*/ inline void SetJobCompletionDate(Aws::Utils::DateTime&& value) { m_jobCompletionDate = std::move(value); } /** *

The date and time, in ISO 8601 * date-time format, when the generated report job was completed or failed.

*

This field is null if the job is still in progress, as indicated by a job * status value of IN_PROGRESS.

*/ inline GetOrganizationsAccessReportResult& WithJobCompletionDate(const Aws::Utils::DateTime& value) { SetJobCompletionDate(value); return *this;} /** *

The date and time, in ISO 8601 * date-time format, when the generated report job was completed or failed.

*

This field is null if the job is still in progress, as indicated by a job * status value of IN_PROGRESS.

*/ inline GetOrganizationsAccessReportResult& WithJobCompletionDate(Aws::Utils::DateTime&& value) { SetJobCompletionDate(std::move(value)); return *this;} /** *

The number of services that the applicable SCPs allow account principals to * access.

*/ inline int GetNumberOfServicesAccessible() const{ return m_numberOfServicesAccessible; } /** *

The number of services that the applicable SCPs allow account principals to * access.

*/ inline void SetNumberOfServicesAccessible(int value) { m_numberOfServicesAccessible = value; } /** *

The number of services that the applicable SCPs allow account principals to * access.

*/ inline GetOrganizationsAccessReportResult& WithNumberOfServicesAccessible(int value) { SetNumberOfServicesAccessible(value); return *this;} /** *

The number of services that account principals are allowed but did not * attempt to access.

*/ inline int GetNumberOfServicesNotAccessed() const{ return m_numberOfServicesNotAccessed; } /** *

The number of services that account principals are allowed but did not * attempt to access.

*/ inline void SetNumberOfServicesNotAccessed(int value) { m_numberOfServicesNotAccessed = value; } /** *

The number of services that account principals are allowed but did not * attempt to access.

*/ inline GetOrganizationsAccessReportResult& WithNumberOfServicesNotAccessed(int value) { SetNumberOfServicesNotAccessed(value); return *this;} /** *

An object that contains details about the most recent attempt to access the * service.

*/ inline const Aws::Vector& GetAccessDetails() const{ return m_accessDetails; } /** *

An object that contains details about the most recent attempt to access the * service.

*/ inline void SetAccessDetails(const Aws::Vector& value) { m_accessDetails = value; } /** *

An object that contains details about the most recent attempt to access the * service.

*/ inline void SetAccessDetails(Aws::Vector&& value) { m_accessDetails = std::move(value); } /** *

An object that contains details about the most recent attempt to access the * service.

*/ inline GetOrganizationsAccessReportResult& WithAccessDetails(const Aws::Vector& value) { SetAccessDetails(value); return *this;} /** *

An object that contains details about the most recent attempt to access the * service.

*/ inline GetOrganizationsAccessReportResult& WithAccessDetails(Aws::Vector&& value) { SetAccessDetails(std::move(value)); return *this;} /** *

An object that contains details about the most recent attempt to access the * service.

*/ inline GetOrganizationsAccessReportResult& AddAccessDetails(const AccessDetail& value) { m_accessDetails.push_back(value); return *this; } /** *

An object that contains details about the most recent attempt to access the * service.

*/ inline GetOrganizationsAccessReportResult& AddAccessDetails(AccessDetail&& value) { m_accessDetails.push_back(std::move(value)); return *this; } /** *

A flag that indicates whether there are more items to return. If your results * were truncated, you can make a subsequent pagination request using the * Marker request parameter to retrieve more items. Note that IAM * might return fewer than the MaxItems number of results even when * there are more results available. We recommend that you check * IsTruncated after every call to ensure that you receive all your * results.

*/ inline bool GetIsTruncated() const{ return m_isTruncated; } /** *

A flag that indicates whether there are more items to return. If your results * were truncated, you can make a subsequent pagination request using the * Marker request parameter to retrieve more items. Note that IAM * might return fewer than the MaxItems number of results even when * there are more results available. We recommend that you check * IsTruncated after every call to ensure that you receive all your * results.

*/ inline void SetIsTruncated(bool value) { m_isTruncated = value; } /** *

A flag that indicates whether there are more items to return. If your results * were truncated, you can make a subsequent pagination request using the * Marker request parameter to retrieve more items. Note that IAM * might return fewer than the MaxItems number of results even when * there are more results available. We recommend that you check * IsTruncated after every call to ensure that you receive all your * results.

*/ inline GetOrganizationsAccessReportResult& WithIsTruncated(bool value) { SetIsTruncated(value); return *this;} /** *

When IsTruncated is true, this element is present * and contains the value to use for the Marker parameter in a * subsequent pagination request.

*/ inline const Aws::String& GetMarker() const{ return m_marker; } /** *

When IsTruncated is true, this element is present * and contains the value to use for the Marker parameter in a * subsequent pagination request.

*/ inline void SetMarker(const Aws::String& value) { m_marker = value; } /** *

When IsTruncated is true, this element is present * and contains the value to use for the Marker parameter in a * subsequent pagination request.

*/ inline void SetMarker(Aws::String&& value) { m_marker = std::move(value); } /** *

When IsTruncated is true, this element is present * and contains the value to use for the Marker parameter in a * subsequent pagination request.

*/ inline void SetMarker(const char* value) { m_marker.assign(value); } /** *

When IsTruncated is true, this element is present * and contains the value to use for the Marker parameter in a * subsequent pagination request.

*/ inline GetOrganizationsAccessReportResult& WithMarker(const Aws::String& value) { SetMarker(value); return *this;} /** *

When IsTruncated is true, this element is present * and contains the value to use for the Marker parameter in a * subsequent pagination request.

*/ inline GetOrganizationsAccessReportResult& WithMarker(Aws::String&& value) { SetMarker(std::move(value)); return *this;} /** *

When IsTruncated is true, this element is present * and contains the value to use for the Marker parameter in a * subsequent pagination request.

*/ inline GetOrganizationsAccessReportResult& WithMarker(const char* value) { SetMarker(value); return *this;} inline const ErrorDetails& GetErrorDetails() const{ return m_errorDetails; } inline void SetErrorDetails(const ErrorDetails& value) { m_errorDetails = value; } inline void SetErrorDetails(ErrorDetails&& value) { m_errorDetails = std::move(value); } inline GetOrganizationsAccessReportResult& WithErrorDetails(const ErrorDetails& value) { SetErrorDetails(value); return *this;} inline GetOrganizationsAccessReportResult& WithErrorDetails(ErrorDetails&& value) { SetErrorDetails(std::move(value)); return *this;} inline const ResponseMetadata& GetResponseMetadata() const{ return m_responseMetadata; } inline void SetResponseMetadata(const ResponseMetadata& value) { m_responseMetadata = value; } inline void SetResponseMetadata(ResponseMetadata&& value) { m_responseMetadata = std::move(value); } inline GetOrganizationsAccessReportResult& WithResponseMetadata(const ResponseMetadata& value) { SetResponseMetadata(value); return *this;} inline GetOrganizationsAccessReportResult& WithResponseMetadata(ResponseMetadata&& value) { SetResponseMetadata(std::move(value)); return *this;} private: JobStatusType m_jobStatus; Aws::Utils::DateTime m_jobCreationDate; Aws::Utils::DateTime m_jobCompletionDate; int m_numberOfServicesAccessible; int m_numberOfServicesNotAccessed; Aws::Vector m_accessDetails; bool m_isTruncated; Aws::String m_marker; ErrorDetails m_errorDetails; ResponseMetadata m_responseMetadata; }; } // namespace Model } // namespace IAM } // namespace Aws