|
|
@ -63,6 +63,7 @@ namespace Ombi.Controllers
|
|
|
|
IRepository<RequestSubscription> subscriptionRepository,
|
|
|
|
IRepository<RequestSubscription> subscriptionRepository,
|
|
|
|
ISettingsService<UserManagementSettings> umSettings,
|
|
|
|
ISettingsService<UserManagementSettings> umSettings,
|
|
|
|
IRepository<UserNotificationPreferences> notificationPreferences,
|
|
|
|
IRepository<UserNotificationPreferences> notificationPreferences,
|
|
|
|
|
|
|
|
IRepository<UserQualityProfiles> userProfiles,
|
|
|
|
IMusicRequestRepository musicRepo,
|
|
|
|
IMusicRequestRepository musicRepo,
|
|
|
|
IMovieRequestEngine movieRequestEngine,
|
|
|
|
IMovieRequestEngine movieRequestEngine,
|
|
|
|
ITvRequestEngine tvRequestEngine)
|
|
|
|
ITvRequestEngine tvRequestEngine)
|
|
|
@ -90,6 +91,7 @@ namespace Ombi.Controllers
|
|
|
|
TvRequestEngine = tvRequestEngine;
|
|
|
|
TvRequestEngine = tvRequestEngine;
|
|
|
|
MovieRequestEngine = movieRequestEngine;
|
|
|
|
MovieRequestEngine = movieRequestEngine;
|
|
|
|
_userNotificationPreferences = notificationPreferences;
|
|
|
|
_userNotificationPreferences = notificationPreferences;
|
|
|
|
|
|
|
|
_userQualityProfiles = userProfiles;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private OmbiUserManager UserManager { get; }
|
|
|
|
private OmbiUserManager UserManager { get; }
|
|
|
@ -115,6 +117,7 @@ namespace Ombi.Controllers
|
|
|
|
private readonly IRepository<NotificationUserId> _notificationRepository;
|
|
|
|
private readonly IRepository<NotificationUserId> _notificationRepository;
|
|
|
|
private readonly IRepository<RequestSubscription> _requestSubscriptionRepository;
|
|
|
|
private readonly IRepository<RequestSubscription> _requestSubscriptionRepository;
|
|
|
|
private readonly IRepository<UserNotificationPreferences> _userNotificationPreferences;
|
|
|
|
private readonly IRepository<UserNotificationPreferences> _userNotificationPreferences;
|
|
|
|
|
|
|
|
private readonly IRepository<UserQualityProfiles> _userQualityProfiles;
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// <summary>
|
|
|
|
/// This is what the Wizard will call when creating the user for the very first time.
|
|
|
|
/// This is what the Wizard will call when creating the user for the very first time.
|
|
|
@ -329,16 +332,26 @@ namespace Ombi.Controllers
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (vm.EpisodeRequestLimit > 0)
|
|
|
|
if (vm.EpisodeRequestLimit > 0)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
vm.EpisodeRequestQuota = await TvRequestEngine.GetRemainingRequests(user);
|
|
|
|
vm.EpisodeRequestQuota = await TvRequestEngine.GetRemainingRequests(user);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (vm.MovieRequestLimit > 0)
|
|
|
|
if (vm.MovieRequestLimit > 0)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
vm.MovieRequestQuota = await MovieRequestEngine.GetRemainingRequests(user);
|
|
|
|
vm.MovieRequestQuota = await MovieRequestEngine.GetRemainingRequests(user);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Get the quality profiles
|
|
|
|
|
|
|
|
vm.UserQualityProfiles = await _userQualityProfiles.GetAll().FirstOrDefaultAsync(x => x.UserId == user.Id);
|
|
|
|
|
|
|
|
if (vm.UserQualityProfiles == null)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
vm.UserQualityProfiles = new UserQualityProfiles
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
UserId = user.Id
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return vm;
|
|
|
|
return vm;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -397,6 +410,20 @@ namespace Ombi.Controllers
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Add the quality profiles
|
|
|
|
|
|
|
|
if (user.UserQualityProfiles != null)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
user.UserQualityProfiles.UserId = ombiUser.Id;
|
|
|
|
|
|
|
|
await _userQualityProfiles.Add(user.UserQualityProfiles);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
user.UserQualityProfiles = new UserQualityProfiles
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
UserId = ombiUser.Id
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return new OmbiIdentityResult
|
|
|
|
return new OmbiIdentityResult
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Successful = true
|
|
|
|
Successful = true
|
|
|
@ -552,8 +579,24 @@ namespace Ombi.Controllers
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Errors = messages
|
|
|
|
Errors = messages
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
// Add the quality profiles
|
|
|
|
|
|
|
|
if (ui.UserQualityProfiles != null)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
var currentQualityProfiles = await
|
|
|
|
|
|
|
|
_userQualityProfiles.GetAll().FirstOrDefaultAsync(x => x.UserId == user.Id);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
currentQualityProfiles.RadarrQualityProfile = ui.UserQualityProfiles.RadarrQualityProfile;
|
|
|
|
|
|
|
|
currentQualityProfiles.RadarrRootPath = ui.UserQualityProfiles.RadarrRootPath;
|
|
|
|
|
|
|
|
currentQualityProfiles.SonarrQualityProfile = ui.UserQualityProfiles.SonarrQualityProfile;
|
|
|
|
|
|
|
|
currentQualityProfiles.SonarrQualityProfileAnime = ui.UserQualityProfiles.SonarrQualityProfileAnime;
|
|
|
|
|
|
|
|
currentQualityProfiles.SonarrRootPath = ui.UserQualityProfiles.SonarrRootPath;
|
|
|
|
|
|
|
|
currentQualityProfiles.SonarrRootPathAnime = ui.UserQualityProfiles.SonarrRootPathAnime;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
await _userQualityProfiles.SaveChangesAsync();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return new OmbiIdentityResult
|
|
|
|
return new OmbiIdentityResult
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Successful = true
|
|
|
|
Successful = true
|
|
|
@ -585,6 +628,8 @@ namespace Ombi.Controllers
|
|
|
|
var moviesUserRequested = MovieRepo.GetAll().Where(x => x.RequestedUserId == userId);
|
|
|
|
var moviesUserRequested = MovieRepo.GetAll().Where(x => x.RequestedUserId == userId);
|
|
|
|
var tvUserRequested = TvRepo.GetChild().Where(x => x.RequestedUserId == userId);
|
|
|
|
var tvUserRequested = TvRepo.GetChild().Where(x => x.RequestedUserId == userId);
|
|
|
|
var musicRequested = MusicRepo.GetAll().Where(x => x.RequestedUserId == userId);
|
|
|
|
var musicRequested = MusicRepo.GetAll().Where(x => x.RequestedUserId == userId);
|
|
|
|
|
|
|
|
var notificationPreferences = _userNotificationPreferences.GetAll().Where(x => x.UserId == userId);
|
|
|
|
|
|
|
|
var userQuality = await _userQualityProfiles.GetAll().FirstOrDefaultAsync(x => x.UserId == userId);
|
|
|
|
|
|
|
|
|
|
|
|
if (moviesUserRequested.Any())
|
|
|
|
if (moviesUserRequested.Any())
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -594,11 +639,18 @@ namespace Ombi.Controllers
|
|
|
|
{
|
|
|
|
{
|
|
|
|
await TvRepo.DeleteChildRange(tvUserRequested);
|
|
|
|
await TvRepo.DeleteChildRange(tvUserRequested);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (musicRequested.Any())
|
|
|
|
if (musicRequested.Any())
|
|
|
|
{
|
|
|
|
{
|
|
|
|
await MusicRepo.DeleteRange(musicRequested);
|
|
|
|
await MusicRepo.DeleteRange(musicRequested);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (notificationPreferences.Any())
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
await _userNotificationPreferences.DeleteRange(notificationPreferences);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if (userQuality != null)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
await _userQualityProfiles.Delete(userQuality);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Delete any issues and request logs
|
|
|
|
// Delete any issues and request logs
|
|
|
|
var issues = _issuesRepository.GetAll().Where(x => x.UserReportedId == userId);
|
|
|
|
var issues = _issuesRepository.GetAll().Where(x => x.UserReportedId == userId);
|
|
|
@ -903,7 +955,7 @@ namespace Ombi.Controllers
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return Json(true);
|
|
|
|
return Json(true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private async Task<List<IdentityResult>> AddRoles(IEnumerable<ClaimCheckboxes> roles, OmbiUser ombiUser)
|
|
|
|
private async Task<List<IdentityResult>> AddRoles(IEnumerable<ClaimCheckboxes> roles, OmbiUser ombiUser)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var roleResult = new List<IdentityResult>();
|
|
|
|
var roleResult = new List<IdentityResult>();
|
|
|
|