sharee.bike-App/TINKLib/Model/User/User.cs

149 lines
4.9 KiB
C#
Raw Permalink Normal View History

2021-05-13 20:03:07 +02:00
using System;
using System.Collections.Generic;
2021-06-26 20:57:55 +02:00
using System.Threading.Tasks;
2021-05-13 20:03:07 +02:00
using TINK.Model.User.Account;
namespace TINK.Model.User
{
public delegate void LoginStateChangedDelegate(object p_oSender, EventArgs p_oEventArgs);
/// <summary>
/// Manages user of the app.
/// </summary>
public class User : IUser
{
2021-11-08 23:11:56 +01:00
/// <summary> Holds account data. </summary>
private AccountMutable Account { get; }
2021-05-13 20:03:07 +02:00
/// <summary>
/// Provides storing functionality.
/// </summary>
2021-11-08 23:11:56 +01:00
private IStore Store { get; }
2021-05-13 20:03:07 +02:00
/// <summary> Holds the id of the device. </summary>
public string DeviceId { get; }
/// Loads user name and passwort from account store.
/// </summary>
/// <param name="p_oAccountStore"> Object to use for loading and saving user data.</param>
public User(
2021-06-26 20:57:55 +02:00
IStore accountStore,
IAccount account,
string deviceId)
2021-05-13 20:03:07 +02:00
{
2021-11-08 23:11:56 +01:00
Store = accountStore
2021-05-13 20:03:07 +02:00
?? throw new ArgumentException("Can not instantiate user- object. No store functionality available.");
2021-06-26 20:57:55 +02:00
DeviceId = deviceId;
2021-11-08 23:11:56 +01:00
Account = new AccountMutable(account);
2021-05-13 20:03:07 +02:00
}
/// <summary> Is fired wheneverlogin state changes. </summary>
public event LoginStateChangedDelegate StateChanged;
/// <summary>
/// Holds a value indicating whether user is logged in or not.
/// </summary>
2021-11-08 23:11:56 +01:00
public bool IsLoggedIn => Account.GetIsLoggedIn();
2021-05-13 20:03:07 +02:00
/// <summary>
/// Holds the mail address.
/// </summary>
public string Mail
{
2021-11-08 23:11:56 +01:00
get { return Account.Mail; }
2021-05-13 20:03:07 +02:00
}
/// <summary>
/// Gets the sessiong cookie.
/// </summary>
public string SessionCookie
{
2021-11-08 23:11:56 +01:00
get { return Account.SessionCookie; }
2021-05-13 20:03:07 +02:00
}
/// <summary>
/// Holds the password.
/// </summary>
public string Password
{
2021-11-08 23:11:56 +01:00
get { return Account.Pwd; }
2021-05-13 20:03:07 +02:00
}
/// <summary>Holds the debug level.</summary>
public Permissions DebugLevel
{
2021-11-08 23:11:56 +01:00
get { return Account.DebugLevel; }
2021-05-13 20:03:07 +02:00
}
/// <summary> Holds the group of the bike (TINK, Konrad, ...).</summary>
2021-11-08 23:11:56 +01:00
public IEnumerable<string> Group { get { return Account.Group; } }
2021-05-13 20:03:07 +02:00
/// <summary> Logs in user. </summary>
/// <param name="p_oAccount">Account to use for login.</param>
/// <param name="p_str_DeviceId">Holds the Id to identify the device.</param>
/// <param name="isConnected">True if connector has access to copri server, false if cached values are used.</param>
public void CheckIsPasswordValid(string mail, string password)
{
if (IsLoggedIn)
{
2021-11-08 23:11:56 +01:00
throw new Exception($"Can not log in user {mail} because user {Account} is already logged in.");
2021-05-13 20:03:07 +02:00
}
// Check if password might be valid before connecting to copri.
var l_oResult = Validator.ValidateMailAndPasswordDelegate(mail, password);
if (!l_oResult.IsValid)
{
// Password is not valid.
throw new ArgumentException(l_oResult.Description[Elements.Account]);
}
}
/// <summary> Logs in user. </summary>
/// <param name="p_oAccount">Account to use for login.</param>
/// <param name="p_str_DeviceId">Holds the Id to identify the device.</param>
/// <param name="isConnected">True if connector has access to copri server, false if cached values are used.</param>
2021-06-26 20:57:55 +02:00
public async Task Login(IAccount account)
2021-05-13 20:03:07 +02:00
{
// Update account instance from copri data.
2021-11-08 23:11:56 +01:00
Account.Copy(account);
2021-05-13 20:03:07 +02:00
// Save data to store.
2021-11-08 23:11:56 +01:00
await Store.Save(Account);
2021-05-13 20:03:07 +02:00
// Nothing to do because state did not change.
StateChanged?.Invoke(this, new EventArgs());
}
/// <summary> Logs in user</summary>
/// <returns></returns>
public void Logout()
{
var l_oPreviousState = IsLoggedIn;
2021-11-08 23:11:56 +01:00
Account.Copy(Store.Delete(Account));
2021-05-13 20:03:07 +02:00
if (IsLoggedIn == l_oPreviousState)
{
// Nothing to do because state did not change.
return;
}
StateChanged?.Invoke(this, new EventArgs());
}
/// <summary>
/// Filters bike groups depending on whether user has access to all groups of bikes.
/// Some user may be "TINK"- user only, some "Konrad" and some may be "TINK" and "Konrad" users.
/// </summary>
/// <param name="p_oAccount">Account to filter with.</param>
2021-11-08 23:11:56 +01:00
/// <param name="source">Groups to filter..</param>
2021-05-13 20:03:07 +02:00
/// <returns>Filtered bike groups.</returns>
2021-11-08 23:11:56 +01:00
public IEnumerable<string> DoFilter(IEnumerable<string> source = null)
2021-05-13 20:03:07 +02:00
{
2021-11-08 23:11:56 +01:00
return Account.DoFilter(source);
2021-05-13 20:03:07 +02:00
}
}
}