public object Execute(ExecutorContext context) { var cmdletContext = context as CmdletContext; // create request var request = new Amazon.DirectoryService.Model.AddIpRoutesRequest(); if (cmdletContext.DirectoryId != null) { request.DirectoryId = cmdletContext.DirectoryId; } if (cmdletContext.IpRoute != null) { request.IpRoutes = cmdletContext.IpRoute; } if (cmdletContext.UpdateSecurityGroupForDirectoryController != null) { request.UpdateSecurityGroupForDirectoryControllers = cmdletContext.UpdateSecurityGroupForDirectoryController.Value; } CmdletOutput output; // issue call var client = Client ?? CreateClient(_CurrentCredentials, _RegionEndpoint); try { var response = CallAWSServiceOperation(client, request); object pipelineOutput = null; pipelineOutput = cmdletContext.Select(response, this); output = new CmdletOutput { PipelineOutput = pipelineOutput, ServiceResponse = response }; } catch (Exception e) { output = new CmdletOutput { ErrorResponse = e }; } return(output); }
private Amazon.DirectoryService.Model.AddIpRoutesResponse CallAWSServiceOperation(IAmazonDirectoryService client, Amazon.DirectoryService.Model.AddIpRoutesRequest request) { Utils.Common.WriteVerboseEndpointMessage(this, client.Config, "AWS Directory Service", "AddIpRoutes"); try { #if DESKTOP return(client.AddIpRoutes(request)); #elif CORECLR return(client.AddIpRoutesAsync(request).GetAwaiter().GetResult()); #else #error "Unknown build edition" #endif } catch (AmazonServiceException exc) { var webException = exc.InnerException as System.Net.WebException; if (webException != null) { throw new Exception(Utils.Common.FormatNameResolutionFailureMessage(client.Config, webException.Message), webException); } throw; } }
/// <summary> /// 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. <i>AddIpRoutes</i> adds this address block. You can also /// use <i>AddIpRoutes</i> to facilitate routing traffic that uses public IP ranges from /// your Microsoft AD on AWS to a peer VPC. /// /// /// <para> /// Before you call <i>AddIpRoutes</i>, ensure that all of the required permissions have /// been explicitly granted through a policy. For details about what permissions are required /// to run the <i>AddIpRoutes</i> operation, see <a href="http://docs.aws.amazon.com/directoryservice/latest/admin-guide/UsingWithDS_IAM_ResourcePermissions.html">AWS /// Directory Service API Permissions: Actions, Resources, and Conditions Reference</a>. /// </para> /// </summary> /// <param name="request">Container for the necessary parameters to execute the AddIpRoutes service method.</param> /// /// <returns>The response from the AddIpRoutes service method, as returned by DirectoryService.</returns> /// <exception cref="Amazon.DirectoryService.Model.ClientException"> /// A client exception has occurred. /// </exception> /// <exception cref="Amazon.DirectoryService.Model.DirectoryUnavailableException"> /// The specified directory is unavailable or could not be found. /// </exception> /// <exception cref="Amazon.DirectoryService.Model.EntityAlreadyExistsException"> /// The specified entity already exists. /// </exception> /// <exception cref="Amazon.DirectoryService.Model.EntityDoesNotExistException"> /// The specified entity could not be found. /// </exception> /// <exception cref="Amazon.DirectoryService.Model.InvalidParameterException"> /// One or more parameters are not valid. /// </exception> /// <exception cref="Amazon.DirectoryService.Model.IpRouteLimitExceededException"> /// The maximum allowed number of IP addresses was exceeded. The default limit is 100 /// IP address blocks. /// </exception> /// <exception cref="Amazon.DirectoryService.Model.ServiceException"> /// An exception has occurred in AWS Directory Service. /// </exception> public AddIpRoutesResponse AddIpRoutes(AddIpRoutesRequest request) { var marshaller = new AddIpRoutesRequestMarshaller(); var unmarshaller = AddIpRoutesResponseUnmarshaller.Instance; return Invoke<AddIpRoutesRequest,AddIpRoutesResponse>(request, marshaller, unmarshaller); }
/// <summary> /// Initiates the asynchronous execution of the AddIpRoutes operation. /// </summary> /// /// <param name="request">Container for the necessary parameters to execute the AddIpRoutes operation on AmazonDirectoryServiceClient.</param> /// <param name="callback">An AsyncCallback delegate that is invoked when the operation completes.</param> /// <param name="state">A user-defined state object that is passed to the callback procedure. Retrieve this object from within the callback /// procedure using the AsyncState property.</param> /// /// <returns>An IAsyncResult that can be used to poll or wait for results, or both; this value is also needed when invoking EndAddIpRoutes /// operation.</returns> public IAsyncResult BeginAddIpRoutes(AddIpRoutesRequest request, AsyncCallback callback, object state) { var marshaller = new AddIpRoutesRequestMarshaller(); var unmarshaller = AddIpRoutesResponseUnmarshaller.Instance; return BeginInvoke<AddIpRoutesRequest>(request, marshaller, unmarshaller, callback, state); }
/// <summary> /// Initiates the asynchronous execution of the AddIpRoutes operation. /// </summary> /// /// <param name="request">Container for the necessary parameters to execute the AddIpRoutes operation.</param> /// <param name="cancellationToken"> /// A cancellation token that can be used by other objects or threads to receive notice of cancellation. /// </param> /// <returns>The task object representing the asynchronous operation.</returns> public Task<AddIpRoutesResponse> AddIpRoutesAsync(AddIpRoutesRequest request, System.Threading.CancellationToken cancellationToken = default(CancellationToken)) { var marshaller = new AddIpRoutesRequestMarshaller(); var unmarshaller = AddIpRoutesResponseUnmarshaller.Instance; return InvokeAsync<AddIpRoutesRequest,AddIpRoutesResponse>(request, marshaller, unmarshaller, cancellationToken); }