Provide mechanism to validate API keys. Re-organise structure to reflect new responsibility

This commit is contained in:
Robert Marshall 2020-04-19 18:16:42 +01:00
parent 87ae65316f
commit 9519bc623b
27 changed files with 245 additions and 36 deletions

View file

@ -0,0 +1,43 @@
using System;
using System.Threading.Tasks;
using System.Linq;
using Dapper;
using Robware.Auth.API;
using Robware.Data.Users;
namespace Robware.Data.API {
public class ApiKeyRepository : IApiKeys {
private readonly IDatabaseProvider _dbProvider;
public ApiKeyRepository(IDatabaseProvider dbProvider) {
_dbProvider = dbProvider;
}
public async Task<ApiKey> Get(string key) {
const string query = "SELECT * FROM api_keys WHERE api_key=@key";
using (var connection = _dbProvider.NewConnection()) {
connection.Open();
var result = await connection.QueryAsync<ApiKeyState>(query, new {key});
if (!result.Any())
throw new ApiKeyNotFoundException(key);
var dbKey = result.Single();
return new ApiKey {
Key = dbKey.Api_Key,
Enabled = dbKey.Enabled,
IssueTimestamp = dbKey.IssueTimestamp,
Name = dbKey.Name
};
}
}
}
public class ApiKeyState {
public string Name { get; set; }
public DateTime IssueTimestamp { get; set; }
public string Api_Key { get; set; }
public bool Enabled { get; set; }
}
}

View file

@ -1,7 +1,7 @@
using Robware.Auth;
using Robware.Data.States;
using Robware.Auth.Users;
using Robware.Data.Users.States;
namespace Robware.Data {
namespace Robware.Data.Users {
public class DatabaseUser : User {
public DatabaseUser(UserState state) {
Username = state.User_Email;

View file

@ -1,6 +1,6 @@
using System.Data;
namespace Robware.Data {
namespace Robware.Data.Users {
public interface IDatabaseProvider {
IDbConnection NewConnection();
}

View file

@ -1,7 +1,7 @@
using System.Data;
using MySql.Data.MySqlClient;
namespace Robware.Data {
namespace Robware.Data.Users {
public class MySQLDatabaseProvider : IDatabaseProvider {
private readonly string _connectionString;

View file

@ -1,4 +1,4 @@
namespace Robware.Data.States {
namespace Robware.Data.Users.States {
public class UserState {
public string User_Id { get; set; }
public string User_Email { get; set; }

View file

@ -1,10 +1,10 @@
using System.Linq;
using System.Threading.Tasks;
using Dapper;
using Robware.Auth;
using Robware.Data.States;
using Robware.Auth.Users;
using Robware.Data.Users.States;
namespace Robware.Data {
namespace Robware.Data.Users {
public class UserRepository : IUsers {
private readonly IDatabaseProvider _dbProvider;