/*
 * 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 databrew-2017-07-25.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.GlueDataBrew.Model
{
    /// 
    /// Represents one or more dates and times when a job is to run.
    /// 
    public partial class Schedule
    {
        private string _accountId;
        private DateTime? _createDate;
        private string _createdBy;
        private string _cronExpression;
        private List _jobNames = new List();
        private string _lastModifiedBy;
        private DateTime? _lastModifiedDate;
        private string _name;
        private string _resourceArn;
        private Dictionary _tags = new Dictionary();
        /// 
        /// Gets and sets the property AccountId. 
        /// 
        /// The ID of the Amazon Web Services account that owns the schedule.
        /// 
        /// 
        [AWSProperty(Max=255)]
        public string AccountId
        {
            get { return this._accountId; }
            set { this._accountId = value; }
        }
        // Check to see if AccountId property is set
        internal bool IsSetAccountId()
        {
            return this._accountId != null;
        }
        /// 
        /// Gets and sets the property CreateDate. 
        /// 
        /// The date and time that the schedule was created.
        /// 
        /// 
        public DateTime CreateDate
        {
            get { return this._createDate.GetValueOrDefault(); }
            set { this._createDate = value; }
        }
        // Check to see if CreateDate property is set
        internal bool IsSetCreateDate()
        {
            return this._createDate.HasValue; 
        }
        /// 
        /// Gets and sets the property CreatedBy. 
        /// 
        /// The Amazon Resource Name (ARN) of the user who created the schedule.
        /// 
        /// 
        public string CreatedBy
        {
            get { return this._createdBy; }
            set { this._createdBy = value; }
        }
        // Check to see if CreatedBy property is set
        internal bool IsSetCreatedBy()
        {
            return this._createdBy != null;
        }
        /// 
        /// Gets and sets the property CronExpression. 
        /// 
        /// The dates and times when the job is to run. For more information, see Cron
        /// expressions in the Glue DataBrew Developer Guide.
        /// 
        /// 
        [AWSProperty(Min=1, Max=512)]
        public string CronExpression
        {
            get { return this._cronExpression; }
            set { this._cronExpression = value; }
        }
        // Check to see if CronExpression property is set
        internal bool IsSetCronExpression()
        {
            return this._cronExpression != null;
        }
        /// 
        /// Gets and sets the property JobNames. 
        /// 
        /// A list of jobs to be run, according to the schedule.
        /// 
        /// 
        [AWSProperty(Max=50)]
        public List JobNames
        {
            get { return this._jobNames; }
            set { this._jobNames = value; }
        }
        // Check to see if JobNames property is set
        internal bool IsSetJobNames()
        {
            return this._jobNames != null && this._jobNames.Count > 0; 
        }
        /// 
        /// Gets and sets the property LastModifiedBy. 
        /// 
        /// The Amazon Resource Name (ARN) of the user who last modified the schedule.
        /// 
        /// 
        public string LastModifiedBy
        {
            get { return this._lastModifiedBy; }
            set { this._lastModifiedBy = value; }
        }
        // Check to see if LastModifiedBy property is set
        internal bool IsSetLastModifiedBy()
        {
            return this._lastModifiedBy != null;
        }
        /// 
        /// Gets and sets the property LastModifiedDate. 
        /// 
        /// The date and time when the schedule was last modified.
        /// 
        /// 
        public DateTime LastModifiedDate
        {
            get { return this._lastModifiedDate.GetValueOrDefault(); }
            set { this._lastModifiedDate = value; }
        }
        // Check to see if LastModifiedDate property is set
        internal bool IsSetLastModifiedDate()
        {
            return this._lastModifiedDate.HasValue; 
        }
        /// 
        /// Gets and sets the property Name. 
        /// 
        /// The name of the schedule.
        /// 
        /// 
        [AWSProperty(Required=true, Min=1, Max=255)]
        public string Name
        {
            get { return this._name; }
            set { this._name = value; }
        }
        // Check to see if Name property is set
        internal bool IsSetName()
        {
            return this._name != null;
        }
        /// 
        /// Gets and sets the property ResourceArn. 
        /// 
        /// The Amazon Resource Name (ARN) of the schedule.
        /// 
        /// 
        [AWSProperty(Min=20, Max=2048)]
        public string ResourceArn
        {
            get { return this._resourceArn; }
            set { this._resourceArn = value; }
        }
        // Check to see if ResourceArn property is set
        internal bool IsSetResourceArn()
        {
            return this._resourceArn != null;
        }
        /// 
        /// Gets and sets the property Tags. 
        /// 
        /// Metadata tags that have been applied to the schedule.
        /// 
        /// 
        [AWSProperty(Min=1, Max=200)]
        public Dictionary Tags
        {
            get { return this._tags; }
            set { this._tags = value; }
        }
        // Check to see if Tags property is set
        internal bool IsSetTags()
        {
            return this._tags != null && this._tags.Count > 0; 
        }
    }
}