protected override void ProcessRecord() { base.ProcessRecord(); if (!ConfirmDelete("OCIComputeManagementTerminateClusterNetwork", "Invoke")) { return; } TerminateClusterNetworkRequest request; try { request = new TerminateClusterNetworkRequest { ClusterNetworkId = ClusterNetworkId, IfMatch = IfMatch }; HandleOutput(request); FinishProcessing(response); } catch (Exception ex) { TerminatingErrorDuringExecution(ex); } }
/// <summary> /// Terminates the specified cluster network. /// /// When you delete a cluster network, all of its resources are permanently deleted, including associated instances and instance pools. /// </summary> /// <param name="request"></param> /// <returns></returns> public async Task <TerminateClusterNetworkResponse> TerminateClusterNetwork(TerminateClusterNetworkRequest request) { var uri = new Uri($"{GetEndPoint(CoreServices.ClusterNetworks, this.Region)}/{request.ClusterNetworkId}"); using (var webResponse = await this.RestClientAsync.Delete(uri, new HttpRequestHeaderParam() { IfMatch = request.IfMatch })) using (var stream = webResponse.GetResponseStream()) using (var reader = new StreamReader(stream)) { var response = await reader.ReadToEndAsync(); return(new TerminateClusterNetworkResponse() { OpcRequestId = webResponse.Headers.Get("opc-request-id"), OpcWorkRequestId = webResponse.Headers.Get("opc-work-request-id") }); } }
private void HandleOutput(TerminateClusterNetworkRequest request) { var waiterConfig = new WaiterConfiguration { MaxAttempts = MaxWaitAttempts, GetNextDelayInSeconds = (_) => WaitIntervalSeconds }; switch (ParameterSetName) { case StatusParamSet: response = client.Waiters.ForTerminateClusterNetwork(request, waiterConfig, WaitForStatus).Execute(); break; case Default: response = client.TerminateClusterNetwork(request).GetAwaiter().GetResult(); break; } WriteOutput(response, CreateWorkRequestObject(response.OpcWorkRequestId)); }
/// <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 <TerminateClusterNetworkRequest, TerminateClusterNetworkResponse> ForTerminateClusterNetwork(TerminateClusterNetworkRequest request, WaiterConfiguration config, params WorkrequestsService.Models.WorkRequest.StatusEnum[] targetStates) { return(new Waiter <TerminateClusterNetworkRequest, TerminateClusterNetworkResponse>(() => { var response = client.TerminateClusterNetwork(request).Result; var getWorkRequestRequest = new Oci.WorkrequestsService.Requests.GetWorkRequestRequest { WorkRequestId = response.OpcWorkRequestId }; workRequestClient.Waiters.ForWorkRequest(getWorkRequestRequest, config, targetStates).Execute(); return response; })); }
/// <summary> /// Creates a waiter using default wait configuration. /// </summary> /// <param name="request">Request to send.</param> /// <param name="statuses">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 <TerminateClusterNetworkRequest, TerminateClusterNetworkResponse> ForTerminateClusterNetwork(TerminateClusterNetworkRequest request, params WorkrequestsService.Models.WorkRequest.StatusEnum[] targetStates) { return(this.ForTerminateClusterNetwork(request, WaiterConfiguration.DefaultWaiterConfiguration, targetStates)); }