-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathAutoSave.cs
More file actions
95 lines (77 loc) · 3.15 KB
/
AutoSave.cs
File metadata and controls
95 lines (77 loc) · 3.15 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
using Upsilon.Apps.PassKey.Core.Internal.Utils;
namespace Upsilon.Apps.PassKey.Core.Internal.Models
{
internal sealed class AutoSave
{
private Database? _database;
internal Database Database
{
get => _database ?? throw new NullReferenceException(nameof(Database));
set => _database = value;
}
public Queue<Change> Changes { get; set; } = new();
internal T UpdateValue<T>(string itemId, string itemName, string fieldName, bool needsReview, T value, string readableValue) where T : notnull
{
_addChange(itemId, itemName, string.Empty, fieldName, Database.SerializationCenter.Serialize(value), readableValue, needsReview, Change.Type.Update);
return value;
}
internal T AddValue<T>(string itemId, string itemName, string containerName, bool needsReview, T value) where T : notnull
{
_addChange(itemId, itemName, containerName, string.Empty, Database.SerializationCenter.Serialize(value), string.Empty, needsReview, Change.Type.Add);
return value;
}
internal T DeleteValue<T>(string itemId, string itemName, string containerName, bool needsReview, T value) where T : notnull
{
_addChange(itemId, itemName, containerName, string.Empty, Database.SerializationCenter.Serialize(value), string.Empty, needsReview, Change.Type.Delete);
return value;
}
private void _addChange(string itemId, string itemName, string containerName, string fieldName, string value, string readableValue, bool needsReview, Change.Type action)
{
Changes.Enqueue(new Change
{
ActionType = action,
ItemId = itemId,
FieldName = fieldName,
Value = value,
});
if (Database.AutoSaveFileLocker == null)
{
Database.AutoSaveFileLocker = new(Database.CryptographyCenter, Database.SerializationCenter, Database.AutoSaveFile, FileMode.OpenOrCreate);
}
Database.AutoSaveFileLocker.Save(this, Database.Passkeys);
string logMessage;
switch (action)
{
case Change.Type.Add:
logMessage = $"{itemName} has been added to {containerName}";
break;
case Change.Type.Delete:
logMessage = $"{itemName} has been removed from {containerName}";
break;
case Change.Type.Update:
default:
logMessage = $"{itemName}'s {fieldName.ToSentenceCase().ToLower()} has been {(string.IsNullOrWhiteSpace(readableValue) ? $"updated" : $"set to {readableValue}")}";
break;
}
Database.Logs.AddLog(logMessage, needsReview);
}
internal void MergeChange()
{
while (Changes.Count != 0)
{
Database.User?.Apply(Changes.Dequeue());
}
Clear();
}
internal void Clear()
{
Changes.Clear();
Database.AutoSaveFileLocker?.Dispose();
Database.AutoSaveFileLocker = null;
if (File.Exists(Database.AutoSaveFile))
{
File.Delete(Database.AutoSaveFile);
}
}
}
}