/*
 * Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved.
 * 
 * Licensed under the Apache License, Version 2.0 (the "License").
 * You may not use this file except in compliance with the License.
 * A copy of the License is located at
 * 
 *  http://aws.amazon.com/apache2.0
 * 
 * or in the "license" file accompanying this file. This file is distributed
 * on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
 * express or implied. See the License for the specific language governing
 * permissions and limitations under the License.
 */
/*
 * Do not modify this file. This file is generated from the transfer-2018-11-05.normal.json service model.
 */
using System;
using System.Collections.Generic;
using System.Xml.Serialization;
using System.Text;
using System.IO;
using System.Net;
using Amazon.Runtime;
using Amazon.Runtime.Internal;
namespace Amazon.Transfer.Model
{
    /// 
    /// This is the response object from the TestConnection operation.
    /// 
    public partial class TestConnectionResponse : AmazonWebServiceResponse
    {
        private string _connectorId;
        private string _status;
        private string _statusMessage;
        /// 
        /// Gets and sets the property ConnectorId. 
        /// 
        /// Returns the identifier of the connector object that you are testing.
        /// 
        /// 
        [AWSProperty(Min=19, Max=19)]
        public string ConnectorId
        {
            get { return this._connectorId; }
            set { this._connectorId = value; }
        }
        // Check to see if ConnectorId property is set
        internal bool IsSetConnectorId()
        {
            return this._connectorId != null;
        }
        /// 
        /// Gets and sets the property Status. 
        /// 
        /// Returns OK for successful test, or ERROR if the test fails.
        /// 
        /// 
        public string Status
        {
            get { return this._status; }
            set { this._status = value; }
        }
        // Check to see if Status property is set
        internal bool IsSetStatus()
        {
            return this._status != null;
        }
        /// 
        /// Gets and sets the property StatusMessage. 
        /// 
        /// Returns Connection succeeded if the test is successful. Or, returns a
        /// descriptive error message if the test fails. The following list provides the details
        /// for some error messages and troubleshooting steps for each.
        /// 
        ///   -  
        /// 
        ///  Unable to access secrets manager: Verify that your secret name aligns with
        /// the one in Transfer Role permissions.
        /// 
        ///  
  -  
        /// 
        ///  Unknown Host/Connection failed: Verify the server URL in the connector configuration
        /// , and verify that the login credentials work successfully outside of the connector.
        /// 
        ///  
  -  
        /// 
        ///  Private key not found: Verify that the secret exists and is formatted correctly.
        /// 
        ///  
  -  
        /// 
        ///  Invalid trusted host keys: Verify that the trusted host key in the connector
        /// configuration matches the 
ssh-keyscan output.
        /// 
        ///    
        /// 
        public string StatusMessage
        {
            get { return this._statusMessage; }
            set { this._statusMessage = value; }
        }
        // Check to see if StatusMessage property is set
        internal bool IsSetStatusMessage()
        {
            return this._statusMessage != null;
        }
    }
}