2021-05-13 20:03:07 +02:00
|
|
|
|
using Serilog;
|
|
|
|
|
using System;
|
|
|
|
|
using System.Threading.Tasks;
|
2021-06-26 20:57:55 +02:00
|
|
|
|
using TINK.Repository;
|
|
|
|
|
using TINK.Repository.Request;
|
|
|
|
|
using TINK.Repository.Response;
|
2021-05-13 20:03:07 +02:00
|
|
|
|
using TINK.Model.User.Account;
|
2021-06-26 20:57:55 +02:00
|
|
|
|
using TINK.Model.Device;
|
2021-05-13 20:03:07 +02:00
|
|
|
|
|
|
|
|
|
namespace TINK.Model.Connector
|
|
|
|
|
{
|
|
|
|
|
public class Command : Base, ICommand
|
|
|
|
|
{
|
|
|
|
|
/// <summary> True if connector has access to copri server, false if cached values are used. </summary>
|
|
|
|
|
public bool IsConnected => CopriServer.IsConnected;
|
|
|
|
|
|
|
|
|
|
/// <summary> No user is logged in.</summary>
|
|
|
|
|
public string SessionCookie => null;
|
|
|
|
|
|
|
|
|
|
/// <summary> Is raised whenever login state has changed.</summary>
|
|
|
|
|
public event LoginStateChangedEventHandler LoginStateChanged;
|
|
|
|
|
|
|
|
|
|
/// <summary>Constructs a copri query object.</summary>
|
|
|
|
|
/// <param name="p_oCopriServer">Server which implements communication.</param>
|
|
|
|
|
public Command(
|
|
|
|
|
ICopriServerBase p_oCopriServer) : base(p_oCopriServer)
|
|
|
|
|
{
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Logs user in.
|
|
|
|
|
/// If log in succeeds either and session might be updated if it was no more valid (logged in by an different device).
|
|
|
|
|
/// If log in fails (password modified) session cookie is set to empty.
|
|
|
|
|
/// If communication fails an exception is thrown.
|
|
|
|
|
/// </summary>
|
|
|
|
|
public async Task<IAccount> DoLogin(
|
|
|
|
|
string p_strMail,
|
|
|
|
|
string p_strPassword,
|
|
|
|
|
string p_strDeviceId)
|
|
|
|
|
{
|
|
|
|
|
if (string.IsNullOrEmpty(p_strMail))
|
|
|
|
|
{
|
|
|
|
|
throw new ArgumentNullException("Can not loging user. Mail address must not be null or empty.");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (string.IsNullOrEmpty(p_strPassword))
|
|
|
|
|
{
|
|
|
|
|
throw new ArgumentNullException("Can not loging user. Password must not be null or empty.");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (string.IsNullOrEmpty(p_strDeviceId))
|
|
|
|
|
{
|
|
|
|
|
throw new ArgumentNullException("Can not loging user. Device not be null or empty.");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
AuthorizationResponse l_oResponse;
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
l_oResponse = (await CopriServer.DoAuthorizationAsync(p_strMail, p_strPassword, p_strDeviceId)).GetIsResponseOk(p_strMail);
|
|
|
|
|
}
|
|
|
|
|
catch (System.Exception)
|
|
|
|
|
{
|
|
|
|
|
throw;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var l_oAccount = l_oResponse.GetAccount(MerchantId, p_strMail, p_strPassword);
|
|
|
|
|
|
|
|
|
|
// Log in state changes. Notify parent object to update.
|
|
|
|
|
LoginStateChanged?.Invoke(this, new LoginStateChangedEventArgs(l_oAccount.SessionCookie, l_oAccount.Mail));
|
|
|
|
|
|
|
|
|
|
return l_oAccount;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary> Logs user out. </summary>
|
|
|
|
|
public async Task DoLogout()
|
|
|
|
|
{
|
|
|
|
|
Log.ForContext<Command>().Error("Unexpected log out request detected. No user logged in.");
|
|
|
|
|
await Task.CompletedTask;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Request to reserve a bike.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="p_oBike">Bike to book.</param>
|
|
|
|
|
public async Task DoReserve(
|
|
|
|
|
Bikes.Bike.BC.IBikeInfoMutable p_oBike)
|
|
|
|
|
{
|
|
|
|
|
Log.ForContext<Command>().Error("Unexpected booking request detected. No user logged in.");
|
|
|
|
|
await Task.CompletedTask;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary> Request to cancel a reservation.</summary>
|
|
|
|
|
/// <param name="p_oBike">Bike to book.</param>
|
|
|
|
|
public async Task DoCancelReservation(Bikes.Bike.BC.IBikeInfoMutable bike)
|
|
|
|
|
{
|
|
|
|
|
Log.ForContext<Command>().Error("Unexpected cancel reservation request detected. No user logged in.");
|
|
|
|
|
await Task.CompletedTask;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary> Get authentication keys.</summary>
|
|
|
|
|
/// <param name="bike">Bike to book.</param>
|
|
|
|
|
public async Task CalculateAuthKeys(Bikes.Bike.BluetoothLock.IBikeInfoMutable bike)
|
|
|
|
|
{
|
|
|
|
|
Log.ForContext<Command>().Error("Unexpected request to get authenticatin keys detected. No user logged in.");
|
|
|
|
|
await Task.CompletedTask;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary> Updates COPRI lock state for a booked bike. </summary>
|
|
|
|
|
/// <param name="bike">Bike to update locking state for.</param>
|
|
|
|
|
/// <param name="location">Location where lock was opened/ changed.</param>
|
|
|
|
|
/// <returns>Response on updating locking state.</returns>
|
|
|
|
|
public async Task UpdateLockingStateAsync(Bikes.Bike.BluetoothLock.IBikeInfoMutable bike, LocationDto location)
|
|
|
|
|
{
|
|
|
|
|
Log.ForContext<Command>().Error("Unexpected request to update locking state detected. No user logged in.");
|
|
|
|
|
await Task.CompletedTask;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task DoBook(Bikes.Bike.BluetoothLock.IBikeInfoMutable bike)
|
|
|
|
|
{
|
|
|
|
|
Log.ForContext<Command>().Error("Unexpected booking request detected. No user logged in.");
|
|
|
|
|
await Task.CompletedTask;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public async Task DoReturn(
|
|
|
|
|
Bikes.Bike.BluetoothLock.IBikeInfoMutable bike,
|
2021-06-26 20:57:55 +02:00
|
|
|
|
LocationDto location,
|
|
|
|
|
ISmartDevice smartDevice)
|
2021-05-13 20:03:07 +02:00
|
|
|
|
{
|
|
|
|
|
Log.ForContext<Command>().Error("Unexpected returning request detected. No user logged in.");
|
|
|
|
|
await Task.CompletedTask;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
/// Submits feedback to copri server.
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="userFeedback">Feedback to submit.</param>
|
2021-06-26 20:57:55 +02:00
|
|
|
|
#if USCSHARP9
|
2021-05-13 20:03:07 +02:00
|
|
|
|
public async Task DoSubmitFeedback(ICommand.IUserFeedback userFeedback, Uri opertorUri)
|
2021-06-26 20:57:55 +02:00
|
|
|
|
#else
|
|
|
|
|
public async Task DoSubmitFeedback(IUserFeedback userFeedback, Uri opertorUri)
|
|
|
|
|
#endif
|
2021-05-13 20:03:07 +02:00
|
|
|
|
{
|
|
|
|
|
Log.ForContext<Command>().Error("Unexpected submit feedback request detected. No user logged in.");
|
|
|
|
|
await Task.CompletedTask;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|