Provide mechanism to validate API keys. Re-organise structure to reflect new responsibility
This commit is contained in:
parent
87ae65316f
commit
9519bc623b
27 changed files with 245 additions and 36 deletions
43
src/Robware.Data/API/ApiKeyRepository.cs
Normal file
43
src/Robware.Data/API/ApiKeyRepository.cs
Normal 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; }
|
||||
}
|
||||
}
|
|
@ -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;
|
|
@ -1,6 +1,6 @@
|
|||
using System.Data;
|
||||
|
||||
namespace Robware.Data {
|
||||
namespace Robware.Data.Users {
|
||||
public interface IDatabaseProvider {
|
||||
IDbConnection NewConnection();
|
||||
}
|
|
@ -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;
|
||||
|
|
@ -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; }
|
|
@ -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;
|
||||
|
Loading…
Add table
Add a link
Reference in a new issue