/// <summary> /// Gets information about the specified cluster network. /// </summary> /// <param name="request"></param> /// <returns></returns> public async Task <GetClusterNetworkResponse> GetClusterNetwork(GetClusterNetworkRequest request) { var uri = new Uri($"{GetEndPoint(CoreServices.ClusterNetworks, this.Region)}/{request.ClusterNetworkId}"); using (var webResponse = await this.RestClientAsync.Get(uri)) using (var stream = webResponse.GetResponseStream()) using (var reader = new StreamReader(stream)) { var response = await reader.ReadToEndAsync(); return(new GetClusterNetworkResponse() { ClusterNetwork = JsonSerializer.Deserialize <ClusterNetwork>(response), ETag = webResponse.Headers.Get("ETag"), OpcRequestId = webResponse.Headers.Get("opc-request-id") }); } }
private void HandleOutput(GetClusterNetworkRequest request) { var waiterConfig = new WaiterConfiguration { MaxAttempts = MaxWaitAttempts, GetNextDelayInSeconds = (_) => WaitIntervalSeconds }; switch (ParameterSetName) { case LifecycleStateParamSet: response = client.Waiters.ForClusterNetwork(request, waiterConfig, WaitForLifecycleState).Execute(); break; case Default: response = client.GetClusterNetwork(request).GetAwaiter().GetResult(); break; } WriteOutput(response, response.ClusterNetwork); }
protected override void ProcessRecord() { base.ProcessRecord(); GetClusterNetworkRequest request; try { request = new GetClusterNetworkRequest { ClusterNetworkId = ClusterNetworkId }; 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 <GetClusterNetworkRequest, GetClusterNetworkResponse> ForClusterNetwork(GetClusterNetworkRequest request, WaiterConfiguration config, params ClusterNetwork.LifecycleStateEnum[] targetStates) { var agent = new WaiterAgent <GetClusterNetworkRequest, GetClusterNetworkResponse>( request, request => client.GetClusterNetwork(request), response => targetStates.Contains(response.ClusterNetwork.LifecycleState.Value), targetStates.Contains(ClusterNetwork.LifecycleStateEnum.Terminated) ); return(new Waiter <GetClusterNetworkRequest, GetClusterNetworkResponse>(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 <GetClusterNetworkRequest, GetClusterNetworkResponse> ForClusterNetwork(GetClusterNetworkRequest request, params ClusterNetwork.LifecycleStateEnum[] targetStates) { return(this.ForClusterNetwork(request, WaiterConfiguration.DefaultWaiterConfiguration, targetStates)); }