Example #1
0
        /// <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));
 }