| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301 | using MediaBrowser.Common.Configuration;using MediaBrowser.Controller.Library;using MediaBrowser.Controller.Providers;using MediaBrowser.Model.Configuration;using MediaBrowser.Model.Connect;using MediaBrowser.Model.Serialization;using System;using System.IO;using System.Linq;using System.Runtime.Serialization;using System.Threading;using System.Threading.Tasks;namespace MediaBrowser.Controller.Entities{    /// <summary>    /// Class User    /// </summary>    public class User : BaseItem    {        public static IUserManager UserManager { get; set; }        public static IXmlSerializer XmlSerializer { get; set; }        /// <summary>        /// From now on all user paths will be Id-based.         /// This is for backwards compatibility.        /// </summary>        public bool UsesIdForConfigurationPath { get; set; }        /// <summary>        /// Gets or sets the password.        /// </summary>        /// <value>The password.</value>        public string Password { get; set; }        public string LocalPassword { get; set; }        public string ConnectUserName { get; set; }        public string ConnectUserId { get; set; }        public UserLinkType? ConnectLinkType { get; set; }        public string ConnectAccessKey { get; set; }        /// <summary>        /// Gets or sets the path.        /// </summary>        /// <value>The path.</value>        [IgnoreDataMember]        public override string Path        {            get            {                // Return this so that metadata providers will look in here                return ConfigurationDirectoryPath;            }            set            {                base.Path = value;            }        }        /// <summary>        /// Returns the folder containing the item.        /// If the item is a folder, it returns the folder itself        /// </summary>        /// <value>The containing folder path.</value>        public override string ContainingFolderPath        {            get            {                return Path;            }        }        /// <summary>        /// Gets a value indicating whether this instance is owned item.        /// </summary>        /// <value><c>true</c> if this instance is owned item; otherwise, <c>false</c>.</value>        public override bool IsOwnedItem        {            get            {                return false;            }        }        /// <summary>        /// Gets the root folder.        /// </summary>        /// <value>The root folder.</value>        [IgnoreDataMember]        public Folder RootFolder        {            get            {                return LibraryManager.GetUserRootFolder();            }        }        /// <summary>        /// Gets or sets the last login date.        /// </summary>        /// <value>The last login date.</value>        public DateTime? LastLoginDate { get; set; }        /// <summary>        /// Gets or sets the last activity date.        /// </summary>        /// <value>The last activity date.</value>        public DateTime? LastActivityDate { get; set; }        /// <summary>        /// The _configuration        /// </summary>        private UserConfiguration _configuration;        /// <summary>        /// The _configuration initialized        /// </summary>        private bool _configurationInitialized;        /// <summary>        /// The _configuration sync lock        /// </summary>        private object _configurationSyncLock = new object();        /// <summary>        /// Gets the user's configuration        /// </summary>        /// <value>The configuration.</value>        [IgnoreDataMember]        public UserConfiguration Configuration        {            get            {                // Lazy load                LazyInitializer.EnsureInitialized(ref _configuration, ref _configurationInitialized, ref _configurationSyncLock, () => (UserConfiguration)ConfigurationHelper.GetXmlConfiguration(typeof(UserConfiguration), ConfigurationFilePath, XmlSerializer));                return _configuration;            }            private set            {                _configuration = value;                _configurationInitialized = value != null;            }        }        /// <summary>        /// Renames the user.        /// </summary>        /// <param name="newName">The new name.</param>        /// <returns>Task.</returns>        /// <exception cref="System.ArgumentNullException"></exception>        public Task Rename(string newName)        {            if (string.IsNullOrEmpty(newName))            {                throw new ArgumentNullException("newName");            }            // If only the casing is changing, leave the file system alone            if (!UsesIdForConfigurationPath && !newName.Equals(Name, StringComparison.OrdinalIgnoreCase))            {                UsesIdForConfigurationPath = true;                // Move configuration                var newConfigDirectory = GetConfigurationDirectoryPath(newName);                var oldConfigurationDirectory = ConfigurationDirectoryPath;                // Exceptions will be thrown if these paths already exist                if (Directory.Exists(newConfigDirectory))                {                    Directory.Delete(newConfigDirectory, true);                }                if (Directory.Exists(oldConfigurationDirectory))                {                    Directory.Move(oldConfigurationDirectory, newConfigDirectory);                }                else                {                    Directory.CreateDirectory(newConfigDirectory);                }            }            Name = newName;            return RefreshMetadata(new MetadataRefreshOptions            {                ReplaceAllMetadata = true,                ImageRefreshMode = ImageRefreshMode.FullRefresh,                MetadataRefreshMode = MetadataRefreshMode.FullRefresh,                ForceSave = true            }, CancellationToken.None);        }        public override Task UpdateToRepository(ItemUpdateType updateReason, CancellationToken cancellationToken)        {            return UserManager.UpdateUser(this);        }        /// <summary>        /// Gets the path to the user's configuration directory        /// </summary>        /// <value>The configuration directory path.</value>        [IgnoreDataMember]        private string ConfigurationDirectoryPath        {            get            {                return GetConfigurationDirectoryPath(Name);            }        }        /// <summary>        /// Gets the configuration directory path.        /// </summary>        /// <param name="username">The username.</param>        /// <returns>System.String.</returns>        private string GetConfigurationDirectoryPath(string username)        {            if (string.IsNullOrEmpty(username))            {                throw new ArgumentNullException("username");            }            var parentPath = ConfigurationManager.ApplicationPaths.UserConfigurationDirectoryPath;            // Legacy            if (!UsesIdForConfigurationPath)            {                var safeFolderName = FileSystem.GetValidFilename(username);                return System.IO.Path.Combine(ConfigurationManager.ApplicationPaths.UserConfigurationDirectoryPath, safeFolderName);            }            return System.IO.Path.Combine(parentPath, Id.ToString("N"));        }        /// <summary>        /// Gets the path to the user's configuration file        /// </summary>        /// <value>The configuration file path.</value>        [IgnoreDataMember]        public string ConfigurationFilePath        {            get            {                return System.IO.Path.Combine(ConfigurationDirectoryPath, "config.xml");            }        }        /// <summary>        /// Updates the configuration.        /// </summary>        /// <param name="config">The config.</param>        /// <exception cref="System.ArgumentNullException">config</exception>        public void UpdateConfiguration(UserConfiguration config)        {            if (config == null)            {                throw new ArgumentNullException("config");            }            Configuration = config;            UserManager.UpdateConfiguration(this, Configuration);        }        public bool IsParentalScheduleAllowed()        {            return IsParentalScheduleAllowed(DateTime.UtcNow);        }        public bool IsParentalScheduleAllowed(DateTime date)        {            var schedules = Configuration.AccessSchedules;            if (schedules.Length == 0)            {                return true;            }            return schedules.Any(i => IsParentalScheduleAllowed(i, date));        }        private bool IsParentalScheduleAllowed(AccessSchedule schedule, DateTime date)        {            if (date.Kind != DateTimeKind.Utc)            {                throw new ArgumentException("Utc date expected");            }            var localTime = date.ToLocalTime();            return DayOfWeekHelper.GetDaysOfWeek(schedule.DayOfWeek).Contains(localTime.DayOfWeek) &&                 IsWithinTime(schedule, localTime);        }        private bool IsWithinTime(AccessSchedule schedule, DateTime localTime)        {            var hour = localTime.TimeOfDay.TotalHours;            return hour >= schedule.StartHour && hour <= schedule.EndHour;        }    }}
 |