/*
 * 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 location-2020-11-19.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.LocationService.Model
{
    /// 
    /// Container for the parameters to the UpdateTracker operation.
    /// Updates the specified properties of a given tracker resource.
    /// 
    public partial class UpdateTrackerRequest : AmazonLocationServiceRequest
    {
        private string _description;
        private bool? _eventBridgeEnabled;
        private PositionFiltering _positionFiltering;
        private PricingPlan _pricingPlan;
        private string _pricingPlanDataSource;
        private string _trackerName;
        /// 
        /// Gets and sets the property Description. 
        /// 
        /// Updates the description for the tracker resource.
        /// 
        /// 
        [AWSProperty(Min=0, Max=1000)]
        public string Description
        {
            get { return this._description; }
            set { this._description = value; }
        }
        // Check to see if Description property is set
        internal bool IsSetDescription()
        {
            return this._description != null;
        }
        /// 
        /// Gets and sets the property EventBridgeEnabled. 
        /// 
        /// Whether to enable position UPDATE events from this tracker to be sent
        /// to EventBridge.
        /// 
        ///   
        /// 
        /// You do not need enable this feature to get ENTER and EXIT
        /// events for geofences with this tracker. Those events are always sent to EventBridge.
        /// 
        ///  
        /// 
        public bool EventBridgeEnabled
        {
            get { return this._eventBridgeEnabled.GetValueOrDefault(); }
            set { this._eventBridgeEnabled = value; }
        }
        // Check to see if EventBridgeEnabled property is set
        internal bool IsSetEventBridgeEnabled()
        {
            return this._eventBridgeEnabled.HasValue; 
        }
        /// 
        /// Gets and sets the property PositionFiltering. 
        /// 
        /// Updates the position filtering for the tracker resource.
        /// 
        ///  
        /// 
        /// Valid values:
        /// 
        ///   -  
        /// 
        ///  TimeBased- Location updates are evaluated against linked geofence collections,
        /// but not every location update is stored. If your update frequency is more often than
        /// 30 seconds, only one update per 30 seconds is stored for each unique device ID. 
        /// 
        ///
-  
        /// 
        ///  DistanceBased- If the device has moved less than 30 m (98.4 ft), location
        /// updates are ignored. Location updates within this distance are neither evaluated against
        /// linked geofence collections, nor stored. This helps control costs by reducing the
        /// number of geofence evaluations and historical device positions to paginate through.
        /// Distance-based filtering can also reduce the effects of GPS noise when displaying
        /// device trajectories on a map. 
        /// 
        ///
-  
        /// 
        ///  AccuracyBased- If the device has moved less than the measured accuracy,
        /// location updates are ignored. For example, if two consecutive updates from a device
        /// have a horizontal accuracy of 5 m and 10 m, the second update is ignored if the device
        /// has moved less than 15 m. Ignored location updates are neither evaluated against linked
        /// geofence collections, nor stored. This helps educe the effects of GPS noise when displaying
        /// device trajectories on a map, and can help control costs by reducing the number of
        /// geofence evaluations. 
        /// 
        ///
/// 
        public PositionFiltering PositionFiltering
        {
            get { return this._positionFiltering; }
            set { this._positionFiltering = value; }
        }
        // Check to see if PositionFiltering property is set
        internal bool IsSetPositionFiltering()
        {
            return this._positionFiltering != null;
        }
        /// 
        /// Gets and sets the property PricingPlan. 
        /// 
        /// No longer used. If included, the only allowed value isRequestBasedUsage.
        /// 
        /// 
        [Obsolete("Deprecated. If included, the only allowed value is RequestBasedUsage.")]
        public PricingPlan PricingPlan
        {
            get { return this._pricingPlan; }
            set { this._pricingPlan = value; }
        }
        // Check to see if PricingPlan property is set
        internal bool IsSetPricingPlan()
        {
            return this._pricingPlan != null;
        }
        /// 
        /// Gets and sets the property PricingPlanDataSource. 
        /// 
        /// This parameter is no longer used.
        /// 
        /// 
        [Obsolete("Deprecated. No longer allowed.")]
        public string PricingPlanDataSource
        {
            get { return this._pricingPlanDataSource; }
            set { this._pricingPlanDataSource = value; }
        }
        // Check to see if PricingPlanDataSource property is set
        internal bool IsSetPricingPlanDataSource()
        {
            return this._pricingPlanDataSource != null;
        }
        /// 
        /// Gets and sets the property TrackerName. 
        /// 
        /// The name of the tracker resource to update.
        /// 
        /// 
        [AWSProperty(Required=true, Min=1, Max=100)]
        public string TrackerName
        {
            get { return this._trackerName; }
            set { this._trackerName = value; }
        }
        // Check to see if TrackerName property is set
        internal bool IsSetTrackerName()
        {
            return this._trackerName != null;
        }
    }
}