private void HandleOutput(FailoverAutonomousContainerDatabaseDataguardAssociationRequest request)
        {
            var waiterConfig = new WaiterConfiguration
            {
                MaxAttempts           = MaxWaitAttempts,
                GetNextDelayInSeconds = (_) => WaitIntervalSeconds
            };

            switch (ParameterSetName)
            {
            case StatusParamSet:
                response = client.Waiters.ForFailoverAutonomousContainerDatabaseDataguardAssociation(request, waiterConfig, WaitForStatus).Execute();
                break;

            case Default:
                response = client.FailoverAutonomousContainerDatabaseDataguardAssociation(request).GetAwaiter().GetResult();
                break;
            }
            WriteOutput(response, response.AutonomousContainerDatabaseDataguardAssociation);
        }
        protected override void ProcessRecord()
        {
            base.ProcessRecord();
            FailoverAutonomousContainerDatabaseDataguardAssociationRequest request;

            try
            {
                request = new FailoverAutonomousContainerDatabaseDataguardAssociationRequest
                {
                    AutonomousContainerDatabaseId = AutonomousContainerDatabaseId,
                    AutonomousContainerDatabaseDataguardAssociationId = AutonomousContainerDatabaseDataguardAssociationId,
                    IfMatch = IfMatch
                };

                HandleOutput(request);
                FinishProcessing(response);
            }
            catch (Exception ex)
            {
                TerminatingErrorDuringExecution(ex);
            }
        }