Merge pull request #776 from tidusjar/dev

Final bug fixed and code changes.
This commit is contained in:
Jamie 2016-12-14 15:45:51 +00:00 committed by GitHub
commit cbb5f3ff73
4 changed files with 219 additions and 154 deletions

View file

@ -51,7 +51,7 @@ namespace PlexRequests.Core.Migration
} }
catch (Exception e) catch (Exception e)
{ {
_log.Fatal("Error when migrating"); _log.Fatal("Error when migrating version : {0}", v.Value.Version);
_log.Fatal(e); _log.Fatal(e);
} }

View file

@ -1,4 +1,5 @@
#region Copyright #region Copyright
// /************************************************************************ // /************************************************************************
// Copyright (c) 2016 Jamie Rees // Copyright (c) 2016 Jamie Rees
// File: Version1100.cs // File: Version1100.cs
@ -23,16 +24,15 @@
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
// ************************************************************************/ // ************************************************************************/
#endregion #endregion
using System; using System;
using System.Collections.Generic;
using System.Data; using System.Data;
using NLog; using NLog;
using System.Linq; using System.Linq;
using PlexRequests.Api.Interfaces; using PlexRequests.Api.Interfaces;
using PlexRequests.Core.SettingModels; using PlexRequests.Core.SettingModels;
using PlexRequests.Core.Users;
using PlexRequests.Helpers; using PlexRequests.Helpers;
using PlexRequests.Helpers.Permissions; using PlexRequests.Helpers.Permissions;
using PlexRequests.Store; using PlexRequests.Store;
@ -44,8 +44,10 @@ namespace PlexRequests.Core.Migration.Migrations
[Migration(11000, "v1.10.0.0")] [Migration(11000, "v1.10.0.0")]
public class Version1100 : BaseMigration, IMigration public class Version1100 : BaseMigration, IMigration
{ {
public Version1100(IUserRepository userRepo, IRequestService requestService, ISettingsService<LogSettings> log, IPlexApi plexApi, ISettingsService<PlexSettings> plexService, public Version1100(IUserRepository userRepo, IRequestService requestService, ISettingsService<LogSettings> log,
IPlexUserRepository plexusers, ISettingsService<PlexRequestSettings> prSettings, ISettingsService<UserManagementSettings> umSettings, IPlexApi plexApi, ISettingsService<PlexSettings> plexService,
IPlexUserRepository plexusers, ISettingsService<PlexRequestSettings> prSettings,
ISettingsService<UserManagementSettings> umSettings,
ISettingsService<ScheduledJobsSettings> sjs, IRepository<UsersToNotify> usersToNotify) ISettingsService<ScheduledJobsSettings> sjs, IRepository<UsersToNotify> usersToNotify)
{ {
UserRepo = userRepo; UserRepo = userRepo;
@ -59,7 +61,9 @@ namespace PlexRequests.Core.Migration.Migrations
ScheduledJobSettings = sjs; ScheduledJobSettings = sjs;
UserNotifyRepo = usersToNotify; UserNotifyRepo = usersToNotify;
} }
public int Version => 11000; public int Version => 11000;
private IUserRepository UserRepo { get; } private IUserRepository UserRepo { get; }
private IRequestService RequestService { get; } private IRequestService RequestService { get; }
private ISettingsService<LogSettings> Log { get; } private ISettingsService<LogSettings> Log { get; }
@ -71,6 +75,9 @@ namespace PlexRequests.Core.Migration.Migrations
private ISettingsService<ScheduledJobsSettings> ScheduledJobSettings { get; } private ISettingsService<ScheduledJobsSettings> ScheduledJobSettings { get; }
private IRepository<UsersToNotify> UserNotifyRepo { get; } private IRepository<UsersToNotify> UserNotifyRepo { get; }
private static Logger Logger = LogManager.GetCurrentClassLogger();
public void Start(IDbConnection con) public void Start(IDbConnection con)
{ {
UpdateDb(con); UpdateDb(con);
@ -88,6 +95,8 @@ namespace PlexRequests.Core.Migration.Migrations
} }
private void MigrateUserNotifications() private void MigrateUserNotifications()
{
try
{ {
var usersToNotify = UserNotifyRepo.GetAll(); var usersToNotify = UserNotifyRepo.GetAll();
var plexUsers = PlexUsers.GetAll().ToList(); var plexUsers = PlexUsers.GetAll().ToList();
@ -100,7 +109,9 @@ namespace PlexRequests.Core.Migration.Migrations
foreach (var u in usersToNotify) foreach (var u in usersToNotify)
{ {
var selectedPlexUser = plexUsers.FirstOrDefault(x => x.Username.Equals(u.Username, StringComparison.CurrentCultureIgnoreCase)); var selectedPlexUser =
plexUsers.FirstOrDefault(
x => x.Username.Equals(u.Username, StringComparison.CurrentCultureIgnoreCase));
if (selectedPlexUser != null) if (selectedPlexUser != null)
{ {
selectedPlexUser.Features += (int)Features.RequestAddedNotification; selectedPlexUser.Features += (int)Features.RequestAddedNotification;
@ -114,11 +125,18 @@ namespace PlexRequests.Core.Migration.Migrations
selectedLocalUser.Features += (int)Features.RequestAddedNotification; selectedLocalUser.Features += (int)Features.RequestAddedNotification;
UserRepo.Update(selectedLocalUser); UserRepo.Update(selectedLocalUser);
} }
}
}
catch (Exception e)
{
Logger.Fatal("Exception when migrating Version 1.10.0 (UpdateScheduledJobs)");
Logger.Fatal(e);
} }
} }
private void UpdateScheduledJobs() private void UpdateScheduledJobs()
{
try
{ {
var settings = ScheduledJobSettings.GetSettings(); var settings = ScheduledJobSettings.GetSettings();
@ -127,8 +145,16 @@ namespace PlexRequests.Core.Migration.Migrations
ScheduledJobSettings.SaveSettings(settings); ScheduledJobSettings.SaveSettings(settings);
} }
catch (Exception e)
{
Logger.Fatal("Exception when migrating Version 1.10.0 (UpdateScheduledJobs)");
Logger.Fatal(e);
}
}
private void PopulateDefaultUserManagementSettings() private void PopulateDefaultUserManagementSettings()
{
try
{ {
var plexRequestSettings = PlexRequestSettings.GetSettings(); var plexRequestSettings = PlexRequestSettings.GetSettings();
@ -142,8 +168,16 @@ namespace PlexRequests.Core.Migration.Migrations
AutoApproveTvShows = !plexRequestSettings.RequireTvShowApproval AutoApproveTvShows = !plexRequestSettings.RequireTvShowApproval
}); });
} }
catch (Exception e)
{
Logger.Fatal("Exception when migrating Version 1.10.0 (PopulateDefaultUserMngmentSettings)");
Logger.Fatal(e);
}
}
private void UpdatePlexUsers() private void UpdatePlexUsers()
{
try
{ {
var settings = PlexSettings.GetSettings(); var settings = PlexSettings.GetSettings();
if (string.IsNullOrEmpty(settings.PlexAuthToken)) if (string.IsNullOrEmpty(settings.PlexAuthToken))
@ -210,10 +244,17 @@ namespace PlexRequests.Core.Migration.Migrations
PlexUsers.Insert(m); PlexUsers.Insert(m);
} }
}
catch (Exception e)
{
Logger.Fatal("Exception when migrating Version 1.10.0 (UpdatePlexUsers)");
Logger.Fatal(e);
}
} }
private void ResetLogLevel() private void ResetLogLevel()
{
try
{ {
var logSettings = Log.GetSettings(); var logSettings = Log.GetSettings();
logSettings.Level = LogLevel.Error.Ordinal; logSettings.Level = LogLevel.Error.Ordinal;
@ -221,8 +262,16 @@ namespace PlexRequests.Core.Migration.Migrations
LoggingHelper.ReconfigureLogLevel(LogLevel.FromOrdinal(logSettings.Level)); LoggingHelper.ReconfigureLogLevel(LogLevel.FromOrdinal(logSettings.Level));
} }
catch (Exception e)
{
Logger.Fatal("Exception when migrating Version 1.10.0 (ResetLogLvl)");
Logger.Fatal(e);
}
}
private void UpdateDb(IDbConnection con) private void UpdateDb(IDbConnection con)
{
try
{ {
// Create the two new columns // Create the two new columns
con.AlterTable("Users", "ADD", "Permissions", true, "INTEGER"); con.AlterTable("Users", "ADD", "Permissions", true, "INTEGER");
@ -258,8 +307,16 @@ namespace PlexRequests.Core.Migration.Migrations
} }
RequestService.BatchUpdate(requestedModels); RequestService.BatchUpdate(requestedModels);
} }
catch (Exception e)
{
Logger.Fatal("Exception when migrating Version 1.10.0 (UpdateDb)");
Logger.Fatal(e);
}
}
private void UpdateAdmin() private void UpdateAdmin()
{
try
{ {
var users = UserRepo.GetAll().ToList(); var users = UserRepo.GetAll().ToList();
@ -278,5 +335,11 @@ namespace PlexRequests.Core.Migration.Migrations
UserRepo.UpdateAll(users); UserRepo.UpdateAll(users);
} }
catch (Exception e)
{
Logger.Fatal("Exception when migrating Version 1.10.0 (UpdateAdmin)");
Logger.Fatal(e);
}
}
} }
} }

View file

@ -41,7 +41,7 @@
<button id="clearLogs" type="submit" class="btn btn-danger-outline ">Clear Logs</button> <button id="clearLogs" type="submit" class="btn btn-danger-outline ">Clear Logs</button>
</form> </form>
<table id="example" class="table table-striped table-hover table-responsive"> <table id="logDatatable" class="table table-striped table-hover table-responsive">
<thead> <thead>
<tr> <tr>
<th>Message</th> <th>Message</th>
@ -63,7 +63,7 @@
var logsUrl = "/admin/loadlogs"; var logsUrl = "/admin/loadlogs";
var url = createBaseUrl(baseUrl, logsUrl); var url = createBaseUrl(baseUrl, logsUrl);
$('#example').DataTable({ $('#logDatatable').DataTable({
"ajax": url, "ajax": url,
"columns": [ "columns": [
{ "data": "message" }, { "data": "message" },
@ -147,5 +147,8 @@
}); });
$('body .dropdown-toggle').dropdown();
}); });
</script> </script>

View file

@ -57,7 +57,6 @@
<div class="form-group"> <div class="form-group">
<label for="ApiKey" class="control-label">Api Key</label> <label for="ApiKey" class="control-label">Api Key</label>
<div class="input-group"> <div class="input-group">
<input type="text" hidden="hidden" name="ApiKey" value="@Model.ApiKey"/>
<input type="text" readonly="readonly" class="form-control form-control-custom" id="ApiKey" name="ApiKey" value="@Model.ApiKey"> <input type="text" readonly="readonly" class="form-control form-control-custom" id="ApiKey" name="ApiKey" value="@Model.ApiKey">
<div class="input-group-addon"> <div class="input-group-addon">