/// <summary> /// Describes a transfer appliance in detail /// </summary> /// <param name="request">The request object containing the details to send. Required.</param> /// <param name="retryConfiguration">The retry configuration that will be used by to send this request. Optional.</param> /// <param name="cancellationToken">The cancellation token to cancel this operation. Optional.</param> /// <returns>A response object containing details about the completed operation</returns> /// <example>Click <a href="https://docs.cloud.oracle.com/en-us/iaas/tools/dot-net-examples/latest/dts/GetTransferAppliance.cs.html">here</a> to see an example of how to use GetTransferAppliance API.</example> public async Task <GetTransferApplianceResponse> GetTransferAppliance(GetTransferApplianceRequest request, RetryConfiguration retryConfiguration = null, CancellationToken cancellationToken = default) { logger.Trace("Called getTransferAppliance"); Uri uri = new Uri(this.restClient.GetEndpoint(), System.IO.Path.Combine(basePathWithoutHost, "/transferJobs/{id}/transferAppliances/{transferApplianceLabel}".Trim('/'))); HttpMethod method = new HttpMethod("GET"); HttpRequestMessage requestMessage = Converter.ToHttpRequestMessage(uri, method, request); requestMessage.Headers.Add("Accept", "application/json"); GenericRetrier retryingClient = Retrier.GetPreferredRetrier(retryConfiguration, this.retryConfiguration); HttpResponseMessage responseMessage; try { if (retryingClient != null) { responseMessage = await retryingClient.MakeRetryingCall(this.restClient.HttpSend, requestMessage, cancellationToken).ConfigureAwait(false); } else { responseMessage = await this.restClient.HttpSend(requestMessage).ConfigureAwait(false); } this.restClient.CheckHttpResponseMessage(requestMessage, responseMessage); return(Converter.FromHttpResponseMessage <GetTransferApplianceResponse>(responseMessage)); } catch (Exception e) { logger.Error($"GetTransferAppliance failed with error: {e.Message}"); throw; } }
private void HandleOutput(GetTransferApplianceRequest request) { var waiterConfig = new WaiterConfiguration { MaxAttempts = MaxWaitAttempts, GetNextDelayInSeconds = (_) => WaitIntervalSeconds }; switch (ParameterSetName) { case LifecycleStateParamSet: response = client.Waiters.ForTransferAppliance(request, waiterConfig, WaitForLifecycleState).Execute(); break; case Default: response = client.GetTransferAppliance(request).GetAwaiter().GetResult(); break; } WriteOutput(response, response.TransferAppliance); }
protected override void ProcessRecord() { base.ProcessRecord(); GetTransferApplianceRequest request; try { request = new GetTransferApplianceRequest { Id = Id, TransferApplianceLabel = TransferApplianceLabel }; HandleOutput(request); FinishProcessing(response); } catch (Exception ex) { TerminatingErrorDuringExecution(ex); } }
/// <summary> /// Creates a waiter using the provided configuration. /// </summary> /// <param name="request">Request to send.</param> /// <param name="config">Wait Configuration</param> /// <param name="targetStates">Desired resource states. If multiple states are provided then the waiter will return once the resource reaches any of the provided states</param> /// <returns>a new Oci.common.Waiter instance</returns> public Waiter <GetTransferApplianceRequest, GetTransferApplianceResponse> ForTransferAppliance(GetTransferApplianceRequest request, WaiterConfiguration config, params TransferAppliance.LifecycleStateEnum[] targetStates) { var agent = new WaiterAgent <GetTransferApplianceRequest, GetTransferApplianceResponse>( request, request => client.GetTransferAppliance(request), response => targetStates.Contains(response.TransferAppliance.LifecycleState.Value), targetStates.Contains(TransferAppliance.LifecycleStateEnum.Deleted) ); return(new Waiter <GetTransferApplianceRequest, GetTransferApplianceResponse>(config, agent)); }
/// <summary> /// Creates a waiter using default wait configuration. /// </summary> /// <param name="request">Request to send.</param> /// <param name="targetStates">Desired resource states. If multiple states are provided then the waiter will return once the resource reaches any of the provided states</param> /// <returns>a new Oci.common.Waiter instance</returns> public Waiter <GetTransferApplianceRequest, GetTransferApplianceResponse> ForTransferAppliance(GetTransferApplianceRequest request, params TransferAppliance.LifecycleStateEnum[] targetStates) { return(this.ForTransferAppliance(request, WaiterConfiguration.DefaultWaiterConfiguration, targetStates)); }