Reorganize and Add UserManager

This commit is contained in:
2021-01-23 10:52:10 +01:00
parent 6148956bc6
commit 5fe7edcb4c
12 changed files with 215 additions and 206 deletions

View File

@@ -88,16 +88,22 @@
<Reference Include="WaveshareUARTFingerprintSensor, Version=1.0.0.0, Culture=neutral, processorArchitecture=MSIL"> <Reference Include="WaveshareUARTFingerprintSensor, Version=1.0.0.0, Culture=neutral, processorArchitecture=MSIL">
<HintPath>packages\WaveshareUARTFingerprintSensor.1.0.0\lib\net472\WaveshareUARTFingerprintSensor.dll</HintPath> <HintPath>packages\WaveshareUARTFingerprintSensor.1.0.0\lib\net472\WaveshareUARTFingerprintSensor.dll</HintPath>
</Reference> </Reference>
<Reference Include="YamlDotNet, Version=9.0.0.0, Culture=neutral, PublicKeyToken=ec19458f3c15af5e, processorArchitecture=MSIL">
<HintPath>packages\YamlDotNet.9.1.4\lib\net45\YamlDotNet.dll</HintPath>
</Reference>
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<Compile Include="DataDisplay.cs" /> <Compile Include="Views\DataDisplay.cs" />
<Compile Include="EntryDialog.cs" /> <Compile Include="Views\EntryDialog.cs" />
<Compile Include="FingerprintDialog.cs" /> <Compile Include="Views\FingerprintDialog.cs" />
<Compile Include="Program.cs" /> <Compile Include="Program.cs" />
<Compile Include="Properties\AssemblyInfo.cs" /> <Compile Include="Properties\AssemblyInfo.cs" />
<Compile Include="SettingsDisplay.cs" /> <Compile Include="Views\SettingsDisplay.cs" />
<Compile Include="SleepDisplay.cs" /> <Compile Include="Views\SleepDisplay.cs" />
<Compile Include="TUIManager.cs" /> <Compile Include="Views\TUIManager.cs" />
<Compile Include="Users\User.cs" />
<Compile Include="Users\UsersManager.cs" />
<Compile Include="WaveshareUARTProvider.cs" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<None Include="App.config" /> <None Include="App.config" />

View File

@@ -1,4 +1,7 @@
using System; using Akari.Provider.WaveshareUART;
using Akari.Provider.WaveshareUART.Users;
using Akari.Provider.WaveshareUART.Views;
using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.IO.Ports; using System.IO.Ports;
using System.Linq; using System.Linq;
@@ -10,12 +13,15 @@ using Unosquare.RaspberryIO;
using Unosquare.RaspberryIO.Abstractions; using Unosquare.RaspberryIO.Abstractions;
using Unosquare.WiringPi; using Unosquare.WiringPi;
namespace WaveshareUARTFingerprintSensor.Sample namespace Akari.Provider.WaveshareUART
{ {
class Program class Program
{ {
static void Main(string[] args) static void Main(string[] args)
{ {
// TODO
args = new[] { "-c" };
if (args.Length > 0) if (args.Length > 0)
{ {
switch (args[0]) switch (args[0])
@@ -29,13 +35,7 @@ namespace WaveshareUARTFingerprintSensor.Sample
} }
} }
WaveshareUARTProvider.Instance.FingerprintLoop();
StartLoop();
}
private static void StartLoop()
{
} }
private static void StartConfig() private static void StartConfig()

27
Users/User.cs Normal file
View File

@@ -0,0 +1,27 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace Akari.Provider.WaveshareUART.Users
{
public class User
{
public string Name { get; private set; }
public string Token { get; private set; }
public ushort RangeStart { get; private set; }
public User()
{
}
public User(string name, string token, ushort rangeStart)
{
Name = name;
Token = token;
RangeStart = rangeStart;
}
}
}

88
Users/UsersManager.cs Normal file
View File

@@ -0,0 +1,88 @@
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Terminal.Gui;
using YamlDotNet.Serialization;
namespace Akari.Provider.WaveshareUART.Users
{
public class UsersManager
{
public const string UsersFilePath = "users.yaml";
private readonly List<User> _users;
private IDeserializer _deserializer;
private ISerializer _serializer;
public int Count => _users.Count;
public UsersManager()
{
_serializer = new SerializerBuilder().Build();
_deserializer = new DeserializerBuilder().Build();
try
{
if (!File.Exists(UsersFilePath))
{
_users = new List<User>();
}
else
{
_users = _deserializer.Deserialize<List<User>>(File.ReadAllText(UsersFilePath));
}
}
catch (Exception e)
{
Console.WriteLine($"Can't load users: {e.Message}");
Console.WriteLine(e.StackTrace);
}
}
public User this[string name] => _users.FirstOrDefault(u => u.Name.Equals(name, StringComparison.OrdinalIgnoreCase));
public void Add(User user)
{
_users.Add(user);
Save();
}
public IReadOnlyCollection<User> GetAll()
{
return _users.AsReadOnly();
}
public void Remove(User user)
{
_users.Remove(user);
Save();
}
public void Clear()
{
_users.Clear();
Save();
}
private void Save()
{
try
{
File.WriteAllText(UsersFilePath, _serializer.Serialize(_users));
}
catch (Exception e)
{
Console.WriteLine($"Can't save users: {e.Message}");
Console.WriteLine(e.StackTrace);
MessageBox.ErrorQuery("Users", $"Can't save users: {e.Message}");
}
}
}
}

View File

@@ -6,7 +6,7 @@ using System.Text;
using System.Threading.Tasks; using System.Threading.Tasks;
using Terminal.Gui; using Terminal.Gui;
namespace WaveshareUARTFingerprintSensor.Sample namespace Akari.Provider.WaveshareUART.Views
{ {
public class DataDisplay : Toplevel public class DataDisplay : Toplevel
{ {

View File

@@ -6,7 +6,7 @@ using System.Text;
using System.Threading.Tasks; using System.Threading.Tasks;
using Terminal.Gui; using Terminal.Gui;
namespace WaveshareUARTFingerprintSensor.Sample namespace Akari.Provider.WaveshareUART.Views
{ {
public class EntryDialog : Dialog public class EntryDialog : Dialog
{ {

View File

@@ -6,7 +6,7 @@ using System.Text;
using System.Threading.Tasks; using System.Threading.Tasks;
using Terminal.Gui; using Terminal.Gui;
namespace WaveshareUARTFingerprintSensor.Sample namespace Akari.Provider.WaveshareUART.Views
{ {
public class FingerprintDialog : Dialog public class FingerprintDialog : Dialog
{ {

View File

@@ -6,8 +6,9 @@ using System.Text;
using System.Threading; using System.Threading;
using System.Threading.Tasks; using System.Threading.Tasks;
using Terminal.Gui; using Terminal.Gui;
using WaveshareUARTFingerprintSensor;
namespace WaveshareUARTFingerprintSensor.Sample namespace Akari.Provider.WaveshareUART.Views
{ {
public class SettingsDisplay : Toplevel public class SettingsDisplay : Toplevel
{ {

View File

@@ -6,8 +6,9 @@ using System.Text;
using System.Threading; using System.Threading;
using System.Threading.Tasks; using System.Threading.Tasks;
using Terminal.Gui; using Terminal.Gui;
using WaveshareUARTFingerprintSensor;
namespace WaveshareUARTFingerprintSensor.Sample namespace Akari.Provider.WaveshareUART.Views
{ {
public class SleepDisplay : Toplevel public class SleepDisplay : Toplevel
{ {

View File

@@ -1,4 +1,6 @@
using NStack; using Akari.Provider.WaveshareUART;
using Akari.Provider.WaveshareUART.Users;
using NStack;
using System; using System;
using System.Collections.Generic; using System.Collections.Generic;
using System.IO; using System.IO;
@@ -6,21 +8,22 @@ using System.Linq;
using System.Text; using System.Text;
using System.Threading.Tasks; using System.Threading.Tasks;
using Terminal.Gui; using Terminal.Gui;
using WaveshareUARTFingerprintSensor;
namespace WaveshareUARTFingerprintSensor.Sample namespace Akari.Provider.WaveshareUART.Views
{ {
public class TUIManager : Toplevel public class TUIManager : Toplevel
{ {
public const string OutputFilePath = "out.txt";
public const string SettingsFilePath = "settings.txt"; public const string SettingsFilePath = "settings.txt";
private FingerprintSensor _fingerprintSensor; public WaveshareUARTProvider Provider => WaveshareUARTProvider.Instance;
public FingerprintSensor FingerprintSensor => Provider.FingerprintSensor;
public UsersManager UsersManager => Provider.UsersManager;
private Label _serialPortLabel; private Label _serialPortLabel;
private Label _comparisonLevelLabel; private Label _comparisonLevelLabel;
private Label _userCountLabel; private Label _userCountLabel;
private object _outputFileLock = new object();
public TUIManager() public TUIManager()
{ {
Init(); Init();
@@ -68,76 +71,34 @@ namespace WaveshareUARTFingerprintSensor.Sample
Y = Pos.Bottom(_serialPortLabel), Y = Pos.Bottom(_serialPortLabel),
Width = Dim.Fill() Width = Dim.Fill()
}; };
_userCountLabel = new Label("Users: 0") _userCountLabel = new Label($"Users: {UsersManager.Count}")
{ {
X = Pos.Left(_comparisonLevelLabel), X = Pos.Left(_comparisonLevelLabel),
Y = Pos.Bottom(_comparisonLevelLabel), Y = Pos.Bottom(_comparisonLevelLabel),
Width = Dim.Fill() Width = Dim.Fill()
}; };
var userCountButton = new Button("Query _User Count") var manageUsersButton = new Button("_Manage Users")
{ {
X = Pos.Center(), X = Pos.Center(),
Y = 7 Y = 7
}; };
userCountButton.Clicked += UserCountButton_Clicked; manageUsersButton.Clicked += ManageUsersButton_Clicked;
var readFingerprintButton = new Button("_Read Fingerprint") var addUserButton = new Button("_Add User")
{ {
X = Pos.Center(), X = Pos.Center(),
Y = Pos.Bottom(userCountButton) + 1 Y = Pos.Bottom(manageUsersButton) + 1
}; };
readFingerprintButton.Clicked += ReadFingerprintButton_Clicked; addUserButton.Clicked += AddUserButton_Clicked;
var readEigenvaluesButton = new Button("Read _Eigenvalues")
{
X = Pos.Center(),
Y = Pos.Bottom(readFingerprintButton)
};
readEigenvaluesButton.Clicked += ReadEigenvaluesButton_Clicked;
var readImageButton = new Button("Read _Image")
{
X = Pos.Center(),
Y = Pos.Bottom(readEigenvaluesButton)
};
readImageButton.Clicked += ReadImageButton_Clicked;
var addFingerprintButton = new Button("_Add Fingerprint")
{
X = Pos.Center(),
Y = Pos.Bottom(readImageButton) + 1
};
addFingerprintButton.Clicked += AddFingerprintButton_Clicked;
var deleteAFingerprint = new Button("_Delete a Fingerprint")
{
X = Pos.Center(),
Y = Pos.Bottom(addFingerprintButton)
};
deleteAFingerprint.Clicked += DeleteAFingerprint_Clicked;
var clearFingerprintsButton = new Button("_Clear Fingerprints")
{
X = Pos.Center(),
Y = Pos.Bottom(deleteAFingerprint)
};
clearFingerprintsButton.Clicked += ClearFingerprintsButton_Clicked;
var setComparisonLevelButton = new Button("Set Comparison _Level") var setComparisonLevelButton = new Button("Set Comparison _Level")
{ {
X = Pos.Center(), X = Pos.Center(),
Y = Pos.Bottom(clearFingerprintsButton) + 1 Y = Pos.Bottom(addUserButton) + 1
}; };
setComparisonLevelButton.Clicked += SetComparisonLevelButton_Clicked; setComparisonLevelButton.Clicked += SetComparisonLevelButton_Clicked;
var sleepButton = new Button("_Sleep Mode")
{
X = Pos.Center(),
Y = Pos.Bottom(setComparisonLevelButton) + 1
};
sleepButton.Clicked += SleepButton_Clicked;
var quitButton = new Button("_Quit") var quitButton = new Button("_Quit")
{ {
X = Pos.Center(), X = Pos.Center(),
@@ -149,15 +110,9 @@ namespace WaveshareUARTFingerprintSensor.Sample
_serialPortLabel, _serialPortLabel,
_comparisonLevelLabel, _comparisonLevelLabel,
_userCountLabel, _userCountLabel,
userCountButton, manageUsersButton,
readFingerprintButton, addUserButton,
readEigenvaluesButton,
readImageButton,
addFingerprintButton,
deleteAFingerprint,
clearFingerprintsButton,
setComparisonLevelButton, setComparisonLevelButton,
sleepButton,
quitButton quitButton
); );
@@ -167,7 +122,7 @@ namespace WaveshareUARTFingerprintSensor.Sample
Application.Run(new SettingsDisplay()); Application.Run(new SettingsDisplay());
} }
InitSensor(); Provider.InitSensor();
// Update gui // Update gui
UpdateSerialPort(); UpdateSerialPort();
@@ -177,97 +132,27 @@ namespace WaveshareUARTFingerprintSensor.Sample
private void UpdateSerialPort() private void UpdateSerialPort()
{ {
_serialPortLabel.Text = $"Serial Port: {_fingerprintSensor.PortName}"; _serialPortLabel.Text = $"Serial Port: {FingerprintSensor.PortName}";
}
private void InitSensor()
{
_fingerprintSensor = new FingerprintSensor(File.ReadAllText(SettingsFilePath));
_fingerprintSensor.Start();
} }
private void UpdateUserCount() private void UpdateUserCount()
{ {
if (_fingerprintSensor.TryGetUserCount(out ushort count)) _userCountLabel.Text = $"Users: {UsersManager.Count}";
{
_userCountLabel.Text = $"Users: {count}";
}
} }
private void UpdateComparisonLevel() private void UpdateComparisonLevel()
{ {
if (_fingerprintSensor.TryGetComparisonLevel(out byte comparisonLevel)) if (FingerprintSensor.TryGetComparisonLevel(out byte comparisonLevel))
{ {
_comparisonLevelLabel.Text = $"Comparison Level: {comparisonLevel}"; _comparisonLevelLabel.Text = $"Comparison Level: {comparisonLevel}";
} }
} }
private void ReadImageButton_Clicked()
{
var dialog = new FingerprintDialog("Acquire Image", "Can't acquire image, try to place your finger flat on the sensor");
byte[] image = null;
Task.Run(() =>
{
if (_fingerprintSensor.TryAcquireImage(out image))
{
dialog.Cancel();
}
else
{
dialog.CancelAndShowError();
}
});
dialog.Show();
if (image != null)
{
WriteOut($"Image:\n{Utils.ArrayDisplay(image)}\n\n\n");
var window = new DataDisplay("Image", image.ToArray());
Application.Run(window);
}
}
private void ReadEigenvaluesButton_Clicked()
{
var dialog = new FingerprintDialog("Acquire Eigenvalues", "Can't acquire eigenvalues, try to place your finger flat on the sensor");
byte[] eigenvalues = null;
Task.Run(() =>
{
if (_fingerprintSensor.TryAcquireEigenvalues(out var values))
{
eigenvalues = values.ToArray();
dialog.Cancel();
}
else
{
dialog.CancelAndShowError();
}
});
dialog.Show();
if (eigenvalues != null)
{
var window = new DataDisplay("Eigenvalues", eigenvalues);
WriteOut($"Eigenvalues:\n{Utils.ArrayDisplay(eigenvalues)}\n\n\n");
Application.Run(window);
}
}
private void SetComparisonLevelButton_Clicked() private void SetComparisonLevelButton_Clicked()
{ {
if (new EntryDialog("Comparison Level", i => int.TryParse(i.ToString(), out var n) && n > 0 && n < 10, "Need to be a valid number in 0-9 range").TryShow(out var input)) if (new EntryDialog("Comparison Level", i => int.TryParse(i.ToString(), out var n) && n > 0 && n < 10, "Need to be a valid number in 0-9 range").TryShow(out var input))
{ {
if (!_fingerprintSensor.TrySetComparisonLevel(byte.Parse(input.ToString()))) if (!FingerprintSensor.TrySetComparisonLevel(byte.Parse(input.ToString())))
{ {
MessageBox.ErrorQuery("Comparison Level", "Can't set comparison level", "Ok"); MessageBox.ErrorQuery("Comparison Level", "Can't set comparison level", "Ok");
} }
@@ -276,35 +161,7 @@ namespace WaveshareUARTFingerprintSensor.Sample
UpdateComparisonLevel(); UpdateComparisonLevel();
} }
private void DeleteAFingerprint_Clicked() private void AddUserButton_Clicked()
{
if (new EntryDialog("User id", i => int.TryParse(i.ToString(), out var n), "Need to be a valid user id").TryShow(out var input))
{
if (!_fingerprintSensor.DeleteUser(ushort.Parse(input.ToString())))
{
MessageBox.ErrorQuery("Delete User", "Can't delete user, check user id", "Ok");
}
}
UpdateUserCount();
}
private void SleepButton_Clicked()
{
var window = new SleepDisplay(_fingerprintSensor);
Application.Run(window);
}
private void ClearFingerprintsButton_Clicked()
{
if (!_fingerprintSensor.DeleteAllUsers())
{
MessageBox.ErrorQuery("Delete All Users", "Can't delete all user", "Ok");
}
}
private void AddFingerprintButton_Clicked()
{ {
if (new EntryDialog("User id", i => ushort.TryParse(i.ToString(), out var n), "Need to be a valid user id").TryShow(out var input)) if (new EntryDialog("User id", i => ushort.TryParse(i.ToString(), out var n), "Need to be a valid user id").TryShow(out var input))
{ {
@@ -312,7 +169,7 @@ namespace WaveshareUARTFingerprintSensor.Sample
Task.Run(() => Task.Run(() =>
{ {
switch (_fingerprintSensor.AddFingerprint(ushort.Parse(input.ToString()), UserPermission.Level1)) switch (FingerprintSensor.AddFingerprint(ushort.Parse(input.ToString()), UserPermission.Level1))
{ {
case ResponseType.Success: case ResponseType.Success:
dialog.Cancel(); dialog.Cancel();
@@ -356,7 +213,7 @@ namespace WaveshareUARTFingerprintSensor.Sample
} }
} }
private void ReadFingerprintButton_Clicked() private void ManageUsersButton_Clicked()
{ {
var dialog = new FingerprintDialog("Read Fingerprint", "Can't read fingerprint, try to place your finger flat on the sensor"); var dialog = new FingerprintDialog("Read Fingerprint", "Can't read fingerprint, try to place your finger flat on the sensor");
@@ -364,7 +221,7 @@ namespace WaveshareUARTFingerprintSensor.Sample
Task.Run(() => Task.Run(() =>
{ {
if (_fingerprintSensor.TryComparison1N(out userInfo)) if (FingerprintSensor.TryComparison1N(out userInfo))
{ {
dialog.Cancel(); dialog.Cancel();
} }
@@ -382,28 +239,13 @@ namespace WaveshareUARTFingerprintSensor.Sample
} }
} }
private void UserCountButton_Clicked()
{
UpdateUserCount();
}
private void WriteOut(string text)
{
Task.Run(() =>
{
lock (_outputFileLock)
{
File.AppendAllText(OutputFilePath, text);
}
});
}
private void ChangeConfig() private void ChangeConfig()
{ {
File.Delete(SettingsFilePath); File.Delete(SettingsFilePath);
Application.Run(new SettingsDisplay()); Application.Run(new SettingsDisplay());
InitSensor(); Provider.InitSensor();
UpdateSerialPort(); UpdateSerialPort();
} }

43
WaveshareUARTProvider.cs Normal file
View File

@@ -0,0 +1,43 @@
using Akari.Provider.WaveshareUART.Users;
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using WaveshareUARTFingerprintSensor;
namespace Akari.Provider.WaveshareUART
{
public class WaveshareUARTProvider
{
public const string SettingsFilePath = "settings.txt";
public static WaveshareUARTProvider Instance { get; }
static WaveshareUARTProvider()
{
Instance = new WaveshareUARTProvider();
}
public UsersManager UsersManager { get; }
public FingerprintSensor FingerprintSensor { get; private set; }
private WaveshareUARTProvider()
{
UsersManager = new UsersManager();
}
public void InitSensor()
{
FingerprintSensor = new FingerprintSensor(File.ReadAllText(SettingsFilePath));
FingerprintSensor.Start();
}
internal void FingerprintLoop()
{
}
}
}

View File

@@ -15,4 +15,5 @@
<package id="Unosquare.Swan.Lite" version="3.0.0" targetFramework="net472" /> <package id="Unosquare.Swan.Lite" version="3.0.0" targetFramework="net472" />
<package id="Unosquare.WiringPi" version="0.5.1" targetFramework="net472" /> <package id="Unosquare.WiringPi" version="0.5.1" targetFramework="net472" />
<package id="WaveshareUARTFingerprintSensor" version="1.0.0" targetFramework="net472" /> <package id="WaveshareUARTFingerprintSensor" version="1.0.0" targetFramework="net472" />
<package id="YamlDotNet" version="9.1.4" targetFramework="net472" />
</packages> </packages>