| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308 | using MediaBrowser.Controller.Library;using MediaBrowser.Controller.Providers;using MediaBrowser.Model.Configuration;using MediaBrowser.Model.Connect;using MediaBrowser.Model.Serialization;using MediaBrowser.Model.Users;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 EasyPassword { 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>        [IgnoreDataMember]        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>        [IgnoreDataMember]        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; }        private UserConfiguration _config;        private readonly object _configSyncLock = new object();        [IgnoreDataMember]        public UserConfiguration Configuration        {            get            {                if (_config == null)                {                    lock (_configSyncLock)                    {                        if (_config == null)                        {                            _config = UserManager.GetUserConfiguration(this);                        }                    }                }                return _config;            }            set { _config = value; }        }        private UserPolicy _policy;        private readonly object _policySyncLock = new object();        [IgnoreDataMember]        public UserPolicy Policy        {            get            {                if (_policy == null)                {                    lock (_policySyncLock)                    {                        if (_policy == null)                        {                            _policy = UserManager.GetUserPolicy(this);                        }                    }                }                                return _policy;            }            set { _policy = value; }        }        /// <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 && !string.Equals(newName, Name, StringComparison.OrdinalIgnoreCase))            {                UsesIdForConfigurationPath = true;                // Move configuration                var newConfigDirectory = GetConfigurationDirectoryPath(newName);                var oldConfigurationDirectory = ConfigurationDirectoryPath;                // Exceptions will be thrown if these paths already exist				if (FileSystem.DirectoryExists(newConfigDirectory))                {                    FileSystem.DeleteDirectory(newConfigDirectory, true);                }				if (FileSystem.DirectoryExists(oldConfigurationDirectory))                {					FileSystem.MoveDirectory(oldConfigurationDirectory, newConfigDirectory);                }                else                {					FileSystem.CreateDirectory(newConfigDirectory);                }            }            Name = newName;			return RefreshMetadata(new MetadataRefreshOptions(new DirectoryService(FileSystem))            {                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]        public 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)        {            var parentPath = ConfigurationManager.ApplicationPaths.UserConfigurationDirectoryPath;            // Legacy            if (!UsesIdForConfigurationPath)            {                if (string.IsNullOrEmpty(username))                {                    throw new ArgumentNullException("username");                }                var safeFolderName = FileSystem.GetValidFilename(username);                return System.IO.Path.Combine(ConfigurationManager.ApplicationPaths.UserConfigurationDirectoryPath, safeFolderName);            }            return System.IO.Path.Combine(parentPath, Id.ToString("N"));        }        public bool IsParentalScheduleAllowed()        {            return IsParentalScheduleAllowed(DateTime.UtcNow);        }        public bool IsParentalScheduleAllowed(DateTime date)        {            var schedules = Policy.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;        }        public bool IsFolderGrouped(Guid id)        {            var config = Configuration;            if (config.ExcludeFoldersFromGrouping != null)            {                return !config.ExcludeFoldersFromGrouping.Select(i => new Guid(i)).Contains(id);            }            return config.GroupedFolders.Select(i => new Guid(i)).Contains(id);        }        [IgnoreDataMember]        public override bool SupportsPeople        {            get            {                return false;            }        }    }}
 |