AWSDirectoryService

public struct AWSDirectoryService

Client object for interacting with AWS AWSDirectoryService service.

AWS Directory Service AWS Directory Service is a web service that makes it easy for you to setup and run directories in the AWS cloud, or connect your AWS resources with an existing on-premises Microsoft Active Directory. This guide provides detailed information about AWS Directory Service operations, data types, parameters, and errors. For information about AWS Directory Services features, see AWS Directory Service and the AWS Directory Service Administration Guide. AWS provides SDKs that consist of libraries and sample code for various programming languages and platforms (Java, Ruby, .Net, iOS, Android, etc.). The SDKs provide a convenient way to create programmatic access to AWS Directory Service and other AWS services. For more information about the AWS SDKs, including how to download and install them, see Tools for Amazon Web Services.

  • Initialize the AWSDirectoryService client

    Declaration

    Swift

    public init(accessKeyId: String? = nil, secretAccessKey: String? = nil, sessionToken: String? = nil, region: AWSSDKSwiftCore.Region? = nil, endpoint: String? = nil, middlewares: [AWSServiceMiddleware] = [], eventLoopGroupProvider: AWSClient.EventLoopGroupProvider = .useAWSClientShared)

    Parameters

    accessKeyId

    Public access key provided by AWS

    secretAccessKey

    Private access key provided by AWS

    sessionToken

    Token provided by STS.AssumeRole() which allows access to another AWS account

    region

    Region of server you want to communicate with

    endpoint

    Custom endpoint URL to use instead of standard AWS servers

    middlewares

    Array of middlewares to apply to requests and responses

    eventLoopGroupProvider

    EventLoopGroup to use. Use useAWSClientShared if the client shall manage its own EventLoopGroup.

  • Accepts a directory sharing request that was sent from the directory owner account.

    Declaration

    Swift

    public func acceptSharedDirectory(_ input: AcceptSharedDirectoryRequest) -> EventLoopFuture<AcceptSharedDirectoryResult>
  • If the DNS server for your on-premises domain uses a publicly addressable IP address, you must add a CIDR address block to correctly route traffic to and from your Microsoft AD on Amazon Web Services. AddIpRoutes adds this address block. You can also use AddIpRoutes to facilitate routing traffic that uses public IP ranges from your Microsoft AD on AWS to a peer VPC. Before you call AddIpRoutes, ensure that all of the required permissions have been explicitly granted through a policy. For details about what permissions are required to run the AddIpRoutes operation, see AWS Directory Service API Permissions: Actions, Resources, and Conditions Reference.

    Declaration

    Swift

    public func addIpRoutes(_ input: AddIpRoutesRequest) -> EventLoopFuture<AddIpRoutesResult>
  • Adds or overwrites one or more tags for the specified directory. Each directory can have a maximum of 50 tags. Each tag consists of a key and optional value. Tag keys must be unique to each resource.

    Declaration

    Swift

    public func addTagsToResource(_ input: AddTagsToResourceRequest) -> EventLoopFuture<AddTagsToResourceResult>
  • Cancels an in-progress schema extension to a Microsoft AD directory. Once a schema extension has started replicating to all domain controllers, the task can no longer be canceled. A schema extension can be canceled during any of the following states; Initializing, CreatingSnapshot, and UpdatingSchema.

    Declaration

    Swift

    public func cancelSchemaExtension(_ input: CancelSchemaExtensionRequest) -> EventLoopFuture<CancelSchemaExtensionResult>
  • Creates an AD Connector to connect to an on-premises directory. Before you call ConnectDirectory, ensure that all of the required permissions have been explicitly granted through a policy. For details about what permissions are required to run the ConnectDirectory operation, see AWS Directory Service API Permissions: Actions, Resources, and Conditions Reference.

    Declaration

    Swift

    public func connectDirectory(_ input: ConnectDirectoryRequest) -> EventLoopFuture<ConnectDirectoryResult>
  • Creates an alias for a directory and assigns the alias to the directory. The alias is used to construct the access URL for the directory, such as http://<alias>.awsapps.com. After an alias has been created, it cannot be deleted or reused, so this operation should only be used when absolutely necessary.

    Declaration

    Swift

    public func createAlias(_ input: CreateAliasRequest) -> EventLoopFuture<CreateAliasResult>
  • Creates a computer account in the specified directory, and joins the computer to the directory.

    Declaration

    Swift

    public func createComputer(_ input: CreateComputerRequest) -> EventLoopFuture<CreateComputerResult>
  • Creates a conditional forwarder associated with your AWS directory. Conditional forwarders are required in order to set up a trust relationship with another domain. The conditional forwarder points to the trusted domain.

    Declaration

    Swift

    public func createConditionalForwarder(_ input: CreateConditionalForwarderRequest) -> EventLoopFuture<CreateConditionalForwarderResult>
  • Creates a Simple AD directory. For more information, see Simple Active Directory in the AWS Directory Service Admin Guide. Before you call CreateDirectory, ensure that all of the required permissions have been explicitly granted through a policy. For details about what permissions are required to run the CreateDirectory operation, see AWS Directory Service API Permissions: Actions, Resources, and Conditions Reference.

    Declaration

    Swift

    public func createDirectory(_ input: CreateDirectoryRequest) -> EventLoopFuture<CreateDirectoryResult>
  • Creates a subscription to forward real-time Directory Service domain controller security logs to the specified Amazon CloudWatch log group in your AWS account.

    Declaration

    Swift

    public func createLogSubscription(_ input: CreateLogSubscriptionRequest) -> EventLoopFuture<CreateLogSubscriptionResult>
  • Creates a Microsoft AD directory in the AWS Cloud. For more information, see AWS Managed Microsoft AD in the AWS Directory Service Admin Guide. Before you call CreateMicrosoftAD, ensure that all of the required permissions have been explicitly granted through a policy. For details about what permissions are required to run the CreateMicrosoftAD operation, see AWS Directory Service API Permissions: Actions, Resources, and Conditions Reference.

    Declaration

    Swift

    public func createMicrosoftAD(_ input: CreateMicrosoftADRequest) -> EventLoopFuture<CreateMicrosoftADResult>
  • Creates a snapshot of a Simple AD or Microsoft AD directory in the AWS cloud. You cannot take snapshots of AD Connector directories.

    Declaration

    Swift

    public func createSnapshot(_ input: CreateSnapshotRequest) -> EventLoopFuture<CreateSnapshotResult>
  • AWS Directory Service for Microsoft Active Directory allows you to configure trust relationships. For example, you can establish a trust between your AWS Managed Microsoft AD directory, and your existing on-premises Microsoft Active Directory. This would allow you to provide users and groups access to resources in either domain, with a single set of credentials. This action initiates the creation of the AWS side of a trust relationship between an AWS Managed Microsoft AD directory and an external domain. You can create either a forest trust or an external trust.

    Declaration

    Swift

    public func createTrust(_ input: CreateTrustRequest) -> EventLoopFuture<CreateTrustResult>
  • Deletes a conditional forwarder that has been set up for your AWS directory.

    Declaration

    Swift

    public func deleteConditionalForwarder(_ input: DeleteConditionalForwarderRequest) -> EventLoopFuture<DeleteConditionalForwarderResult>
  • Deletes an AWS Directory Service directory. Before you call DeleteDirectory, ensure that all of the required permissions have been explicitly granted through a policy. For details about what permissions are required to run the DeleteDirectory operation, see AWS Directory Service API Permissions: Actions, Resources, and Conditions Reference.

    Declaration

    Swift

    public func deleteDirectory(_ input: DeleteDirectoryRequest) -> EventLoopFuture<DeleteDirectoryResult>
  • Deletes the specified log subscription.

    Declaration

    Swift

    public func deleteLogSubscription(_ input: DeleteLogSubscriptionRequest) -> EventLoopFuture<DeleteLogSubscriptionResult>
  • Deletes a directory snapshot.

    Declaration

    Swift

    public func deleteSnapshot(_ input: DeleteSnapshotRequest) -> EventLoopFuture<DeleteSnapshotResult>
  • Deletes an existing trust relationship between your AWS Managed Microsoft AD directory and an external domain.

    Declaration

    Swift

    public func deleteTrust(_ input: DeleteTrustRequest) -> EventLoopFuture<DeleteTrustResult>
  • Deletes from the system the certificate that was registered for a secured LDAP connection.

    Declaration

    Swift

    public func deregisterCertificate(_ input: DeregisterCertificateRequest) -> EventLoopFuture<DeregisterCertificateResult>
  • Removes the specified directory as a publisher to the specified SNS topic.

    Declaration

    Swift

    public func deregisterEventTopic(_ input: DeregisterEventTopicRequest) -> EventLoopFuture<DeregisterEventTopicResult>
  • Displays information about the certificate registered for a secured LDAP connection.

    Declaration

    Swift

    public func describeCertificate(_ input: DescribeCertificateRequest) -> EventLoopFuture<DescribeCertificateResult>
  • Obtains information about the conditional forwarders for this account. If no input parameters are provided for RemoteDomainNames, this request describes all conditional forwarders for the specified directory ID.

    Declaration

    Swift

    public func describeConditionalForwarders(_ input: DescribeConditionalForwardersRequest) -> EventLoopFuture<DescribeConditionalForwardersResult>
  • Obtains information about the directories that belong to this account. You can retrieve information about specific directories by passing the directory identifiers in the DirectoryIds parameter. Otherwise, all directories that belong to the current account are returned. This operation supports pagination with the use of the NextToken request and response parameters. If more results are available, the DescribeDirectoriesResult.NextToken member contains a token that you pass in the next call to DescribeDirectories to retrieve the next set of items. You can also specify a maximum number of return results with the Limit parameter.

    Declaration

    Swift

    public func describeDirectories(_ input: DescribeDirectoriesRequest) -> EventLoopFuture<DescribeDirectoriesResult>
  • Provides information about any domain controllers in your directory.

    Declaration

    Swift

    public func describeDomainControllers(_ input: DescribeDomainControllersRequest) -> EventLoopFuture<DescribeDomainControllersResult>
  • Obtains information about which SNS topics receive status messages from the specified directory. If no input parameters are provided, such as DirectoryId or TopicName, this request describes all of the associations in the account.

    Declaration

    Swift

    public func describeEventTopics(_ input: DescribeEventTopicsRequest) -> EventLoopFuture<DescribeEventTopicsResult>
  • Describes the status of LDAP security for the specified directory.

    Declaration

    Swift

    public func describeLDAPSSettings(_ input: DescribeLDAPSSettingsRequest) -> EventLoopFuture<DescribeLDAPSSettingsResult>
  • Returns the shared directories in your account.

    Declaration

    Swift

    public func describeSharedDirectories(_ input: DescribeSharedDirectoriesRequest) -> EventLoopFuture<DescribeSharedDirectoriesResult>
  • Obtains information about the directory snapshots that belong to this account. This operation supports pagination with the use of the NextToken request and response parameters. If more results are available, the DescribeSnapshots.NextToken member contains a token that you pass in the next call to DescribeSnapshots to retrieve the next set of items. You can also specify a maximum number of return results with the Limit parameter.

    Declaration

    Swift

    public func describeSnapshots(_ input: DescribeSnapshotsRequest) -> EventLoopFuture<DescribeSnapshotsResult>
  • Obtains information about the trust relationships for this account. If no input parameters are provided, such as DirectoryId or TrustIds, this request describes all the trust relationships belonging to the account.

    Declaration

    Swift

    public func describeTrusts(_ input: DescribeTrustsRequest) -> EventLoopFuture<DescribeTrustsResult>
  • Deactivates LDAP secure calls for the specified directory.

    Declaration

    Swift

    public func disableLDAPS(_ input: DisableLDAPSRequest) -> EventLoopFuture<DisableLDAPSResult>
  • Disables multi-factor authentication (MFA) with the Remote Authentication Dial In User Service (RADIUS) server for an AD Connector or Microsoft AD directory.

    Declaration

    Swift

    public func disableRadius(_ input: DisableRadiusRequest) -> EventLoopFuture<DisableRadiusResult>
  • Disables single-sign on for a directory.

    Declaration

    Swift

    public func disableSso(_ input: DisableSsoRequest) -> EventLoopFuture<DisableSsoResult>
  • Activates the switch for the specific directory to always use LDAP secure calls.

    Declaration

    Swift

    public func enableLDAPS(_ input: EnableLDAPSRequest) -> EventLoopFuture<EnableLDAPSResult>
  • Enables multi-factor authentication (MFA) with the Remote Authentication Dial In User Service (RADIUS) server for an AD Connector or Microsoft AD directory.

    Declaration

    Swift

    public func enableRadius(_ input: EnableRadiusRequest) -> EventLoopFuture<EnableRadiusResult>
  • Enables single sign-on for a directory. Single sign-on allows users in your directory to access certain AWS services from a computer joined to the directory without having to enter their credentials separately.

    Declaration

    Swift

    public func enableSso(_ input: EnableSsoRequest) -> EventLoopFuture<EnableSsoResult>
  • Obtains directory limit information for the current Region.

    Declaration

    Swift

    public func getDirectoryLimits(_ input: GetDirectoryLimitsRequest) -> EventLoopFuture<GetDirectoryLimitsResult>
  • Obtains the manual snapshot limits for a directory.

    Declaration

    Swift

    public func getSnapshotLimits(_ input: GetSnapshotLimitsRequest) -> EventLoopFuture<GetSnapshotLimitsResult>
  • For the specified directory, lists all the certificates registered for a secured LDAP connection.

    Declaration

    Swift

    public func listCertificates(_ input: ListCertificatesRequest) -> EventLoopFuture<ListCertificatesResult>
  • Lists the address blocks that you have added to a directory.

    Declaration

    Swift

    public func listIpRoutes(_ input: ListIpRoutesRequest) -> EventLoopFuture<ListIpRoutesResult>
  • Lists the active log subscriptions for the AWS account.

    Declaration

    Swift

    public func listLogSubscriptions(_ input: ListLogSubscriptionsRequest) -> EventLoopFuture<ListLogSubscriptionsResult>
  • Lists all schema extensions applied to a Microsoft AD Directory.

    Declaration

    Swift

    public func listSchemaExtensions(_ input: ListSchemaExtensionsRequest) -> EventLoopFuture<ListSchemaExtensionsResult>
  • Lists all tags on a directory.

    Declaration

    Swift

    public func listTagsForResource(_ input: ListTagsForResourceRequest) -> EventLoopFuture<ListTagsForResourceResult>
  • Registers a certificate for secured LDAP connection.

    Declaration

    Swift

    public func registerCertificate(_ input: RegisterCertificateRequest) -> EventLoopFuture<RegisterCertificateResult>
  • Associates a directory with an SNS topic. This establishes the directory as a publisher to the specified SNS topic. You can then receive email or text (SMS) messages when the status of your directory changes. You get notified if your directory goes from an Active status to an Impaired or Inoperable status. You also receive a notification when the directory returns to an Active status.

    Declaration

    Swift

    public func registerEventTopic(_ input: RegisterEventTopicRequest) -> EventLoopFuture<RegisterEventTopicResult>
  • Rejects a directory sharing request that was sent from the directory owner account.

    Declaration

    Swift

    public func rejectSharedDirectory(_ input: RejectSharedDirectoryRequest) -> EventLoopFuture<RejectSharedDirectoryResult>
  • Removes IP address blocks from a directory.

    Declaration

    Swift

    public func removeIpRoutes(_ input: RemoveIpRoutesRequest) -> EventLoopFuture<RemoveIpRoutesResult>
  • Removes tags from a directory.

    Declaration

    Swift

    public func removeTagsFromResource(_ input: RemoveTagsFromResourceRequest) -> EventLoopFuture<RemoveTagsFromResourceResult>
  • Resets the password for any user in your AWS Managed Microsoft AD or Simple AD directory. You can reset the password for any user in your directory with the following exceptions: For Simple AD, you cannot reset the password for any user that is a member of either the Domain Admins or Enterprise Admins group except for the administrator user. For AWS Managed Microsoft AD, you can only reset the password for a user that is in an OU based off of the NetBIOS name that you typed when you created your directory. For example, you cannot reset the password for a user in the AWS Reserved OU. For more information about the OU structure for an AWS Managed Microsoft AD directory, see What Gets Created in the AWS Directory Service Administration Guide.

    Declaration

    Swift

    public func resetUserPassword(_ input: ResetUserPasswordRequest) -> EventLoopFuture<ResetUserPasswordResult>
  • Restores a directory using an existing directory snapshot. When you restore a directory from a snapshot, any changes made to the directory after the snapshot date are overwritten. This action returns as soon as the restore operation is initiated. You can monitor the progress of the restore operation by calling the DescribeDirectories operation with the directory identifier. When the DirectoryDescription.Stage value changes to Active, the restore operation is complete.

    Declaration

    Swift

    public func restoreFromSnapshot(_ input: RestoreFromSnapshotRequest) -> EventLoopFuture<RestoreFromSnapshotResult>
  • Shares a specified directory (DirectoryId) in your AWS account (directory owner) with another AWS account (directory consumer). With this operation you can use your directory from any AWS account and from any Amazon VPC within an AWS Region. When you share your AWS Managed Microsoft AD directory, AWS Directory Service creates a shared directory in the directory consumer account. This shared directory contains the metadata to provide access to the directory within the directory owner account. The shared directory is visible in all VPCs in the directory consumer account. The ShareMethod parameter determines whether the specified directory can be shared between AWS accounts inside the same AWS organization (ORGANIZATIONS). It also determines whether you can share the directory with any other AWS account either inside or outside of the organization (HANDSHAKE). The ShareNotes parameter is only used when HANDSHAKE is called, which sends a directory sharing request to the directory consumer.

    Declaration

    Swift

    public func shareDirectory(_ input: ShareDirectoryRequest) -> EventLoopFuture<ShareDirectoryResult>
  • Applies a schema extension to a Microsoft AD directory.

    Declaration

    Swift

    public func startSchemaExtension(_ input: StartSchemaExtensionRequest) -> EventLoopFuture<StartSchemaExtensionResult>
  • Stops the directory sharing between the directory owner and consumer accounts.

    Declaration

    Swift

    public func unshareDirectory(_ input: UnshareDirectoryRequest) -> EventLoopFuture<UnshareDirectoryResult>
  • Updates a conditional forwarder that has been set up for your AWS directory.

    Declaration

    Swift

    public func updateConditionalForwarder(_ input: UpdateConditionalForwarderRequest) -> EventLoopFuture<UpdateConditionalForwarderResult>
  • Adds or removes domain controllers to or from the directory. Based on the difference between current value and new value (provided through this API call), domain controllers will be added or removed. It may take up to 45 minutes for any new domain controllers to become fully active once the requested number of domain controllers is updated. During this time, you cannot make another update request.

    Declaration

    Swift

    public func updateNumberOfDomainControllers(_ input: UpdateNumberOfDomainControllersRequest) -> EventLoopFuture<UpdateNumberOfDomainControllersResult>
  • Updates the Remote Authentication Dial In User Service (RADIUS) server information for an AD Connector or Microsoft AD directory.

    Declaration

    Swift

    public func updateRadius(_ input: UpdateRadiusRequest) -> EventLoopFuture<UpdateRadiusResult>
  • Updates the trust that has been set up between your AWS Managed Microsoft AD directory and an on-premises Active Directory.

    Declaration

    Swift

    public func updateTrust(_ input: UpdateTrustRequest) -> EventLoopFuture<UpdateTrustResult>
  • AWS Directory Service for Microsoft Active Directory allows you to configure and verify trust relationships. This action verifies a trust relationship between your AWS Managed Microsoft AD directory and an external domain.

    Declaration

    Swift

    public func verifyTrust(_ input: VerifyTrustRequest) -> EventLoopFuture<VerifyTrustResult>
  • Undocumented

    See more

    Declaration

    Swift

    public enum CertificateState : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum DirectoryEdition : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum DirectorySize : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum DirectoryStage : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum DirectoryType : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum DomainControllerStatus : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum IpRouteStatusMsg : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum LDAPSStatus : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum LDAPSType : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum RadiusAuthenticationProtocol : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum RadiusStatus : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum ReplicationScope : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum SchemaExtensionStatus : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum SelectiveAuth : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum ShareMethod : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum ShareStatus : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum SnapshotStatus : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum SnapshotType : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum TargetType : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum TopicStatus : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum TrustDirection : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum TrustState : String, CustomStringConvertible, Codable
  • Undocumented

    See more

    Declaration

    Swift

    public enum TrustType : String, CustomStringConvertible, Codable