815216fd73
Add or Override User Flag assignments in bulk.
199 lines
8.1 KiB
C#
199 lines
8.1 KiB
C#
using Disco.Data.Repository;
|
|
using Disco.Models.Repository;
|
|
using Disco.Services.Extensions;
|
|
using Disco.Services.Tasks;
|
|
using System;
|
|
using System.Collections;
|
|
using System.Collections.Generic;
|
|
using System.Collections.ObjectModel;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Threading.Tasks;
|
|
|
|
namespace Disco.Services.Users.UserFlags
|
|
{
|
|
public static class UserFlagService
|
|
{
|
|
private static Cache _cache;
|
|
|
|
public static void Initialize(DiscoDataContext Database)
|
|
{
|
|
_cache = new Cache(Database);
|
|
}
|
|
|
|
public static List<UserFlag> GetUserFlags() { return _cache.GetUserFlags(); }
|
|
public static UserFlag GetUserFlag(int UserFlagId) { return _cache.GetUserFlag(UserFlagId); }
|
|
|
|
#region User Flag Maintenance
|
|
public static UserFlag CreateUserFlag(DiscoDataContext Database, UserFlag UserFlag)
|
|
{
|
|
// Verify
|
|
if (string.IsNullOrWhiteSpace(UserFlag.Name))
|
|
throw new ArgumentException("The User Flag Name is required");
|
|
|
|
// Name Unique
|
|
if (_cache.GetUserFlags().Any(f => f.Name == UserFlag.Name))
|
|
throw new ArgumentException("Another User Flag already exists with that name", "UserFlag");
|
|
|
|
// Clone to break reference
|
|
var flag = new UserFlag()
|
|
{
|
|
Name = UserFlag.Name,
|
|
Description = UserFlag.Description,
|
|
Icon = UserFlag.Icon,
|
|
IconColour = UserFlag.IconColour
|
|
};
|
|
|
|
Database.UserFlags.Add(flag);
|
|
Database.SaveChanges();
|
|
|
|
return _cache.Update(flag);
|
|
}
|
|
public static UserFlag Update(DiscoDataContext Database, UserFlag UserFlag)
|
|
{
|
|
// Verify
|
|
if (string.IsNullOrWhiteSpace(UserFlag.Name))
|
|
throw new ArgumentException("The User Flag Name is required");
|
|
|
|
// Name Unique
|
|
if (_cache.GetUserFlags().Any(f => f.Id != UserFlag.Id && f.Name == UserFlag.Name))
|
|
throw new ArgumentException("Another User Flag already exists with that name", "UserFlag");
|
|
|
|
Database.SaveChanges();
|
|
|
|
return _cache.Update(UserFlag);
|
|
}
|
|
public static void DeleteUserFlag(DiscoDataContext Database, int UserFlagId, IScheduledTaskStatus Status)
|
|
{
|
|
UserFlag flag = Database.UserFlags.Find(UserFlagId);
|
|
|
|
// Delete Assignments
|
|
Status.UpdateStatus(0, string.Format("Removing '{0}' [{1}] User Flag", flag.Name, flag.Id), "Starting");
|
|
List<UserFlagAssignment> flagAssignments = Database.UserFlagAssignments.Where(fa => fa.UserFlagId == flag.Id).ToList();
|
|
if (flagAssignments.Count > 0)
|
|
{
|
|
Status.UpdateStatus(20, "Removing flag from users");
|
|
flagAssignments.ForEach(flagAssignment => Database.UserFlagAssignments.Remove(flagAssignment));
|
|
Database.SaveChanges();
|
|
}
|
|
|
|
// Delete Flag
|
|
Status.UpdateStatus(90, "Deleting User Flag");
|
|
Database.UserFlags.Remove(flag);
|
|
Database.SaveChanges();
|
|
|
|
// Remove from Cache
|
|
_cache.Remove(UserFlagId);
|
|
|
|
Status.Finished(string.Format("Successfully Deleted User Flag: '{0}' [{1}]", flag.Name, flag.Id));
|
|
}
|
|
#endregion
|
|
|
|
#region Bulk Assignment
|
|
public static IEnumerable<UserFlagAssignment> BulkAssignAddUsers(DiscoDataContext Database, UserFlag UserFlag, User Technician, string Comments, List<User> Users, IScheduledTaskStatus Status)
|
|
{
|
|
if (Users.Count > 0)
|
|
{
|
|
|
|
double progressInterval;
|
|
string comments = string.IsNullOrWhiteSpace(Comments) ? null : Comments.Trim();
|
|
|
|
var addUsers = Users.Where(u => !u.UserFlagAssignments.Any(a => a.UserFlagId == UserFlag.Id && !a.RemovedDate.HasValue)).ToList();
|
|
|
|
progressInterval = (double)100 / addUsers.Count;
|
|
|
|
var addedUserAssignments = addUsers.Select((user, index) =>
|
|
{
|
|
Status.UpdateStatus(index * progressInterval, string.Format("Assigning Flag: {0}", user.ToString()));
|
|
|
|
var fa = new UserFlagAssignment()
|
|
{
|
|
UserFlagId = UserFlag.Id,
|
|
UserId = user.UserId,
|
|
AddedDate = DateTime.Now,
|
|
AddedUserId = Technician.UserId,
|
|
Comments = comments
|
|
};
|
|
|
|
Database.UserFlagAssignments.Add(fa);
|
|
Database.SaveChanges();
|
|
return fa;
|
|
}).Where(fa => fa != null).ToList();
|
|
|
|
Status.SetFinishedMessage(string.Format("{0} Users/s Added; {1} User/s Skipped", addUsers.Count, (Users.Count - addUsers.Count)));
|
|
|
|
return addedUserAssignments;
|
|
}
|
|
else
|
|
{
|
|
Status.SetFinishedMessage("No changes found");
|
|
return Enumerable.Empty<UserFlagAssignment>();
|
|
}
|
|
}
|
|
|
|
public static IEnumerable<UserFlagAssignment> BulkAssignOverrideUsers(DiscoDataContext Database, UserFlag UserFlag, User Technician, string Comments, List<User> Users, IScheduledTaskStatus Status)
|
|
{
|
|
double progressInterval;
|
|
string comments = string.IsNullOrWhiteSpace(Comments) ? null : Comments.Trim();
|
|
|
|
Status.UpdateStatus(0, "Calculating assignment changes");
|
|
|
|
var currentAssignments = Database.UserFlagAssignments.Include("User").Where(a => a.UserFlagId == UserFlag.Id && !a.RemovedDate.HasValue).ToList();
|
|
var removeAssignments = currentAssignments.Where(ca => !Users.Any(u => u.UserId.Equals(ca.UserId, StringComparison.OrdinalIgnoreCase))).ToList();
|
|
var addUsers = Users.Where(u => !currentAssignments.Any(ca => ca.UserId.Equals(u.UserId, StringComparison.OrdinalIgnoreCase))).ToList();
|
|
|
|
if (removeAssignments.Count > 0 || addUsers.Count > 0)
|
|
{
|
|
progressInterval = (double)100 / (removeAssignments.Count + addUsers.Count);
|
|
var removedDateTime = DateTime.Now;
|
|
|
|
removeAssignments.Select((flagAssignment, index) =>
|
|
{
|
|
Status.UpdateStatus(index * progressInterval, string.Format("Removing Flag: {0}", flagAssignment.User.ToString()));
|
|
flagAssignment.RemovedDate = removedDateTime;
|
|
flagAssignment.RemovedUserId = Technician.UserId;
|
|
Database.SaveChanges();
|
|
return flagAssignment;
|
|
}).ToList();
|
|
|
|
var addedUserAssignments = addUsers.Select((user, index) =>
|
|
{
|
|
Status.UpdateStatus((removeAssignments.Count + index) * progressInterval, string.Format("Assigning Flag: {0}", user.ToString()));
|
|
|
|
var fa = new UserFlagAssignment()
|
|
{
|
|
UserFlagId = UserFlag.Id,
|
|
UserId = user.UserId,
|
|
AddedDate = DateTime.Now,
|
|
AddedUserId = Technician.UserId,
|
|
Comments = comments
|
|
};
|
|
|
|
Database.UserFlagAssignments.Add(fa);
|
|
Database.SaveChanges();
|
|
return fa;
|
|
}).ToList();
|
|
|
|
Status.SetFinishedMessage(string.Format("{0} Users/s Added; {1} User/s Removed; {2} User/s Skipped", addUsers.Count, removeAssignments.Count, (Users.Count - addUsers.Count)));
|
|
|
|
return addedUserAssignments;
|
|
}
|
|
else
|
|
{
|
|
Status.SetFinishedMessage("No changes found");
|
|
return Enumerable.Empty<UserFlagAssignment>();
|
|
}
|
|
}
|
|
#endregion
|
|
|
|
public static string RandomUnusedIcon()
|
|
{
|
|
return UIHelpers.RandomIcon(_cache.GetUserFlags().Select(f => f.Icon));
|
|
}
|
|
public static string RandomUnusedThemeColour()
|
|
{
|
|
return UIHelpers.RandomThemeColour(_cache.GetUserFlags().Select(f => f.IconColour));
|
|
}
|
|
}
|
|
}
|