/*
 * 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 ecr-2015-09-21.normal.json service model.
 */
using System;
using System.Collections.Generic;
using System.Globalization;
using System.IO;
using System.Net;
using System.Text;
using System.Xml.Serialization;

using Amazon.ECR.Model;
using Amazon.Runtime;
using Amazon.Runtime.Internal;
using Amazon.Runtime.Internal.Transform;
using Amazon.Runtime.Internal.Util;
using ThirdParty.Json.LitJson;

namespace Amazon.ECR.Model.Internal.MarshallTransformations
{
    /// <summary>
    /// Response Unmarshaller for PackageVulnerabilityDetails Object
    /// </summary>  
    public class PackageVulnerabilityDetailsUnmarshaller : IUnmarshaller<PackageVulnerabilityDetails, XmlUnmarshallerContext>, IUnmarshaller<PackageVulnerabilityDetails, JsonUnmarshallerContext>
    {
        /// <summary>
        /// Unmarshaller the response from the service to the response class.
        /// </summary>  
        /// <param name="context"></param>
        /// <returns></returns>
        PackageVulnerabilityDetails IUnmarshaller<PackageVulnerabilityDetails, XmlUnmarshallerContext>.Unmarshall(XmlUnmarshallerContext context)
        {
            throw new NotImplementedException();
        }

        /// <summary>
        /// Unmarshaller the response from the service to the response class.
        /// </summary>  
        /// <param name="context"></param>
        /// <returns></returns>
        public PackageVulnerabilityDetails Unmarshall(JsonUnmarshallerContext context)
        {
            context.Read();
            if (context.CurrentTokenType == JsonToken.Null) 
                return null;

            PackageVulnerabilityDetails unmarshalledObject = new PackageVulnerabilityDetails();
        
            int targetDepth = context.CurrentDepth;
            while (context.ReadAtDepth(targetDepth))
            {
                if (context.TestExpression("cvss", targetDepth))
                {
                    var unmarshaller = new ListUnmarshaller<CvssScore, CvssScoreUnmarshaller>(CvssScoreUnmarshaller.Instance);
                    unmarshalledObject.Cvss = unmarshaller.Unmarshall(context);
                    continue;
                }
                if (context.TestExpression("referenceUrls", targetDepth))
                {
                    var unmarshaller = new ListUnmarshaller<string, StringUnmarshaller>(StringUnmarshaller.Instance);
                    unmarshalledObject.ReferenceUrls = unmarshaller.Unmarshall(context);
                    continue;
                }
                if (context.TestExpression("relatedVulnerabilities", targetDepth))
                {
                    var unmarshaller = new ListUnmarshaller<string, StringUnmarshaller>(StringUnmarshaller.Instance);
                    unmarshalledObject.RelatedVulnerabilities = unmarshaller.Unmarshall(context);
                    continue;
                }
                if (context.TestExpression("source", targetDepth))
                {
                    var unmarshaller = StringUnmarshaller.Instance;
                    unmarshalledObject.Source = unmarshaller.Unmarshall(context);
                    continue;
                }
                if (context.TestExpression("sourceUrl", targetDepth))
                {
                    var unmarshaller = StringUnmarshaller.Instance;
                    unmarshalledObject.SourceUrl = unmarshaller.Unmarshall(context);
                    continue;
                }
                if (context.TestExpression("vendorCreatedAt", targetDepth))
                {
                    var unmarshaller = DateTimeUnmarshaller.Instance;
                    unmarshalledObject.VendorCreatedAt = unmarshaller.Unmarshall(context);
                    continue;
                }
                if (context.TestExpression("vendorSeverity", targetDepth))
                {
                    var unmarshaller = StringUnmarshaller.Instance;
                    unmarshalledObject.VendorSeverity = unmarshaller.Unmarshall(context);
                    continue;
                }
                if (context.TestExpression("vendorUpdatedAt", targetDepth))
                {
                    var unmarshaller = DateTimeUnmarshaller.Instance;
                    unmarshalledObject.VendorUpdatedAt = unmarshaller.Unmarshall(context);
                    continue;
                }
                if (context.TestExpression("vulnerabilityId", targetDepth))
                {
                    var unmarshaller = StringUnmarshaller.Instance;
                    unmarshalledObject.VulnerabilityId = unmarshaller.Unmarshall(context);
                    continue;
                }
                if (context.TestExpression("vulnerablePackages", targetDepth))
                {
                    var unmarshaller = new ListUnmarshaller<VulnerablePackage, VulnerablePackageUnmarshaller>(VulnerablePackageUnmarshaller.Instance);
                    unmarshalledObject.VulnerablePackages = unmarshaller.Unmarshall(context);
                    continue;
                }
            }
          
            return unmarshalledObject;
        }


        private static PackageVulnerabilityDetailsUnmarshaller _instance = new PackageVulnerabilityDetailsUnmarshaller();        

        /// <summary>
        /// Gets the singleton.
        /// </summary>  
        public static PackageVulnerabilityDetailsUnmarshaller Instance
        {
            get
            {
                return _instance;
            }
        }
    }
}