public object Execute(ExecutorContext context) { var cmdletContext = context as CmdletContext; // create request var request = new Amazon.DirectConnect.Model.CreateInterconnectRequest(); if (cmdletContext.Bandwidth != null) { request.Bandwidth = cmdletContext.Bandwidth; } if (cmdletContext.InterconnectName != null) { request.InterconnectName = cmdletContext.InterconnectName; } if (cmdletContext.LagId != null) { request.LagId = cmdletContext.LagId; } if (cmdletContext.Location != null) { request.Location = cmdletContext.Location; } if (cmdletContext.ProviderName != null) { request.ProviderName = cmdletContext.ProviderName; } if (cmdletContext.Tag != null) { request.Tags = cmdletContext.Tag; } 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.DirectConnect.Model.CreateInterconnectResponse CallAWSServiceOperation(IAmazonDirectConnect client, Amazon.DirectConnect.Model.CreateInterconnectRequest request) { Utils.Common.WriteVerboseEndpointMessage(this, client.Config, "AWS Direct Connect", "CreateInterconnect"); try { #if DESKTOP return(client.CreateInterconnect(request)); #elif CORECLR return(client.CreateInterconnectAsync(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> /// Initiates the asynchronous execution of the CreateInterconnect operation. /// </summary> /// /// <param name="request">Container for the necessary parameters to execute the CreateInterconnect operation on AmazonDirectConnectClient.</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 EndCreateInterconnect /// operation.</returns> public IAsyncResult BeginCreateInterconnect(CreateInterconnectRequest request, AsyncCallback callback, object state) { var marshaller = new CreateInterconnectRequestMarshaller(); var unmarshaller = CreateInterconnectResponseUnmarshaller.Instance; return BeginInvoke<CreateInterconnectRequest>(request, marshaller, unmarshaller, callback, state); }
/// <summary> /// Initiates the asynchronous execution of the CreateInterconnect operation. /// <seealso cref="Amazon.DirectConnect.IAmazonDirectConnect.CreateInterconnect"/> /// </summary> /// /// <param name="request">Container for the necessary parameters to execute the CreateInterconnect 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<CreateInterconnectResponse> CreateInterconnectAsync(CreateInterconnectRequest request, CancellationToken cancellationToken = default(CancellationToken)) { var marshaller = new CreateInterconnectRequestMarshaller(); var unmarshaller = CreateInterconnectResponseUnmarshaller.GetInstance(); return Invoke<IRequest, CreateInterconnectRequest, CreateInterconnectResponse>(request, marshaller, unmarshaller, signer, cancellationToken); }
/// <summary> /// Creates a new interconnect between a AWS Direct Connect partner's network and a specific /// AWS Direct Connect location. /// /// /// <para> /// An interconnect is a connection which is capable of hosting other connections. The /// AWS Direct Connect partner can use an interconnect to provide sub-1Gbps AWS Direct /// Connect service to tier 2 customers who do not have their own connections. Like a /// standard connection, an interconnect links the AWS Direct Connect partner's network /// to an AWS Direct Connect location over a standard 1 Gbps or 10 Gbps Ethernet fiber-optic /// cable. One end is connected to the partner's router, the other to an AWS Direct Connect /// router. /// </para> /// /// <para> /// For each end customer, the AWS Direct Connect partner provisions a connection on their /// interconnect by calling AllocateConnectionOnInterconnect. The end customer can then /// connect to AWS resources by creating a virtual interface on their connection, using /// the VLAN assigned to them by the AWS Direct Connect partner. /// </para> /// </summary> /// <param name="request">Container for the necessary parameters to execute the CreateInterconnect service method.</param> /// /// <returns>The response from the CreateInterconnect service method, as returned by DirectConnect.</returns> /// <exception cref="Amazon.DirectConnect.Model.DirectConnectClientException"> /// The API was called with invalid parameters. The error message will contain additional /// details about the cause. /// </exception> /// <exception cref="Amazon.DirectConnect.Model.DirectConnectServerException"> /// A server-side error occurred during the API call. The error message will contain additional /// details about the cause. /// </exception> public CreateInterconnectResponse CreateInterconnect(CreateInterconnectRequest request) { var marshaller = new CreateInterconnectRequestMarshaller(); var unmarshaller = CreateInterconnectResponseUnmarshaller.Instance; return Invoke<CreateInterconnectRequest,CreateInterconnectResponse>(request, marshaller, unmarshaller); }
/// <summary> /// <para>Creates a new interconnect between a Direct Connect partner's network and a specific AWS Direct Connect location.</para> <para>An /// interconnect is a connection which is capable of hosting other connections. The AWS Direct Connect partner can use an interconnect to /// provide sub-1Gbps Direct Connect service to tier 2 customers who do not have their own connections. Like a standard connection, an /// interconnect links the Direct Connect partner's network to an AWS Direct Connect location over a standard 1 Gbps or 10 Gbps Ethernet /// fiber-optic cable. One end is connected to the partner's router, the other to an AWS Direct Connect router.</para> <para>For each end /// customer, the Direct Connect partner provisions a connection on their interconnect by calling AllocateConnectionOnInterconnect. The end /// customer can then connect to AWS resources by creating a virtual interface on their connection, using the VLAN assigned to them by the /// Direct Connect partner.</para> /// </summary> /// /// <param name="request">Container for the necessary parameters to execute the CreateInterconnect service method on /// AmazonDirectConnect.</param> /// /// <returns>The response from the CreateInterconnect service method, as returned by AmazonDirectConnect.</returns> /// /// <exception cref="T:Amazon.DirectConnect.Model.DirectConnectServerException" /> /// <exception cref="T:Amazon.DirectConnect.Model.DirectConnectClientException" /> public CreateInterconnectResponse CreateInterconnect(CreateInterconnectRequest request) { var task = CreateInterconnectAsync(request); try { return task.Result; } catch(AggregateException e) { throw e.InnerException; } }
/// <summary> /// <para>Creates a new interconnect between a Direct Connect partner's network and a specific AWS Direct Connect location.</para> <para>An /// interconnect is a connection which is capable of hosting other connections. The AWS Direct Connect partner can use an interconnect to /// provide sub-1Gbps Direct Connect service to tier 2 customers who do not have their own connections. Like a standard connection, an /// interconnect links the Direct Connect partner's network to an AWS Direct Connect location over a standard 1 Gbps or 10 Gbps Ethernet /// fiber-optic cable. One end is connected to the partner's router, the other to an AWS Direct Connect router.</para> <para>For each end /// customer, the Direct Connect partner provisions a connection on their interconnect by calling AllocateConnectionOnInterconnect. The end /// customer can then connect to AWS resources by creating a virtual interface on their connection, using the VLAN assigned to them by the /// Direct Connect partner.</para> /// </summary> /// /// <param name="request">Container for the necessary parameters to execute the CreateInterconnect service method on /// AmazonDirectConnect.</param> /// /// <returns>The response from the CreateInterconnect service method, as returned by AmazonDirectConnect.</returns> /// /// <exception cref="T:Amazon.DirectConnect.Model.DirectConnectServerException" /> /// <exception cref="T:Amazon.DirectConnect.Model.DirectConnectClientException" /> public CreateInterconnectResponse CreateInterconnect(CreateInterconnectRequest request) { var task = CreateInterconnectAsync(request); try { return task.Result; } catch(AggregateException e) { ExceptionDispatchInfo.Capture(e.InnerException).Throw(); return null; } }
/// <summary> /// Initiates the asynchronous execution of the CreateInterconnect operation. /// <seealso cref="Amazon.DirectConnect.IAmazonDirectConnect"/> /// </summary> /// /// <param name="request">Container for the necessary parameters to execute the CreateInterconnect 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<CreateInterconnectResponse> CreateInterconnectAsync(CreateInterconnectRequest request, System.Threading.CancellationToken cancellationToken = default(CancellationToken)) { var marshaller = new CreateInterconnectRequestMarshaller(); var unmarshaller = CreateInterconnectResponseUnmarshaller.Instance; return InvokeAsync<CreateInterconnectRequest,CreateInterconnectResponse>(request, marshaller, unmarshaller, cancellationToken); }
/// <summary> /// Initiates the asynchronous execution of the CreateInterconnect operation. /// <seealso cref="Amazon.DirectConnect.IAmazonDirectConnect.CreateInterconnect"/> /// </summary> /// /// <param name="request">Container for the necessary parameters to execute the CreateInterconnect 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 async Task<CreateInterconnectResponse> CreateInterconnectAsync(CreateInterconnectRequest request, CancellationToken cancellationToken = default(CancellationToken)) { var marshaller = new CreateInterconnectRequestMarshaller(); var unmarshaller = CreateInterconnectResponseUnmarshaller.GetInstance(); var response = await Invoke<IRequest, CreateInterconnectRequest, CreateInterconnectResponse>(request, marshaller, unmarshaller, signer, cancellationToken) .ConfigureAwait(continueOnCapturedContext: false); return response; }
IAsyncResult invokeCreateInterconnect(CreateInterconnectRequest createInterconnectRequest, AsyncCallback callback, object state, bool synchronized) { IRequest irequest = new CreateInterconnectRequestMarshaller().Marshall(createInterconnectRequest); var unmarshaller = CreateInterconnectResponseUnmarshaller.GetInstance(); AsyncResult result = new AsyncResult(irequest, callback, state, synchronized, signer, unmarshaller); Invoke(result); return result; }
/// <summary> /// Initiates the asynchronous execution of the CreateInterconnect operation. /// <seealso cref="Amazon.DirectConnect.IAmazonDirectConnect.CreateInterconnect"/> /// </summary> /// /// <param name="createInterconnectRequest">Container for the necessary parameters to execute the CreateInterconnect operation on /// AmazonDirectConnect.</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 /// EndCreateInterconnect operation.</returns> public IAsyncResult BeginCreateInterconnect(CreateInterconnectRequest createInterconnectRequest, AsyncCallback callback, object state) { return invokeCreateInterconnect(createInterconnectRequest, callback, state, false); }
/// <summary> /// <para>Creates a new interconnect between a Direct Connect partner's network and a specific AWS Direct Connect location.</para> <para>An /// interconnect is a connection which is capable of hosting other connections. The AWS Direct Connect partner can use an interconnect to /// provide sub-1Gbps Direct Connect service to tier 2 customers who do not have their own connections. Like a standard connection, an /// interconnect links the Direct Connect partner's network to an AWS Direct Connect location over a standard 1 Gbps or 10 Gbps Ethernet /// fiber-optic cable. One end is connected to the partner's router, the other to an AWS Direct Connect router.</para> <para>For each end /// customer, the Direct Connect partner provisions a connection on their interconnect by calling AllocateConnectionOnInterconnect. The end /// customer can then connect to AWS resources by creating a virtual interface on their connection, using the VLAN assigned to them by the /// Direct Connect partner.</para> /// </summary> /// /// <param name="createInterconnectRequest">Container for the necessary parameters to execute the CreateInterconnect service method on /// AmazonDirectConnect.</param> /// /// <returns>The response from the CreateInterconnect service method, as returned by AmazonDirectConnect.</returns> /// /// <exception cref="DirectConnectServerException"/> /// <exception cref="DirectConnectClientException"/> public CreateInterconnectResponse CreateInterconnect(CreateInterconnectRequest createInterconnectRequest) { IAsyncResult asyncResult = invokeCreateInterconnect(createInterconnectRequest, null, null, true); return EndCreateInterconnect(asyncResult); }