Build auth API
This commit is contained in:
commit
dafe603a06
43 changed files with 1153 additions and 0 deletions
11
src/Robware.Data/DatabaseUser.cs
Normal file
11
src/Robware.Data/DatabaseUser.cs
Normal file
|
@ -0,0 +1,11 @@
|
|||
using Robware.Auth;
|
||||
using Robware.Data.States;
|
||||
|
||||
namespace Robware.Data {
|
||||
public class DatabaseUser : User {
|
||||
public DatabaseUser(UserState state) {
|
||||
Username = state.User_Email;
|
||||
Password = state.User_Password;
|
||||
}
|
||||
}
|
||||
}
|
7
src/Robware.Data/IDatabaseProvider.cs
Normal file
7
src/Robware.Data/IDatabaseProvider.cs
Normal file
|
@ -0,0 +1,7 @@
|
|||
using System.Data;
|
||||
|
||||
namespace Robware.Data {
|
||||
public interface IDatabaseProvider {
|
||||
IDbConnection NewConnection();
|
||||
}
|
||||
}
|
12
src/Robware.Data/MySQLDatabaseProvider.cs
Normal file
12
src/Robware.Data/MySQLDatabaseProvider.cs
Normal file
|
@ -0,0 +1,12 @@
|
|||
using System.Data;
|
||||
using MySql.Data.MySqlClient;
|
||||
|
||||
namespace Robware.Data {
|
||||
public class MySQLDatabaseProvider : IDatabaseProvider {
|
||||
private readonly string _connectionString;
|
||||
|
||||
public MySQLDatabaseProvider(string connectionString) => _connectionString = connectionString;
|
||||
|
||||
public IDbConnection NewConnection() => new MySqlConnection(_connectionString);
|
||||
}
|
||||
}
|
16
src/Robware.Data/Robware.Data.csproj
Normal file
16
src/Robware.Data/Robware.Data.csproj
Normal file
|
@ -0,0 +1,16 @@
|
|||
<Project Sdk="Microsoft.NET.Sdk">
|
||||
|
||||
<PropertyGroup>
|
||||
<TargetFramework>netcoreapp3.1</TargetFramework>
|
||||
</PropertyGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<PackageReference Include="Dapper" Version="2.0.35" />
|
||||
<PackageReference Include="MySqlConnector" Version="0.63.2" />
|
||||
</ItemGroup>
|
||||
|
||||
<ItemGroup>
|
||||
<ProjectReference Include="..\Robware.Auth\Robware.Auth.csproj" />
|
||||
</ItemGroup>
|
||||
|
||||
</Project>
|
10
src/Robware.Data/States/UserState.cs
Normal file
10
src/Robware.Data/States/UserState.cs
Normal file
|
@ -0,0 +1,10 @@
|
|||
namespace Robware.Data.States {
|
||||
public class UserState {
|
||||
public string User_Id { get; set; }
|
||||
public string User_Email { get; set; }
|
||||
public string User_Password { get; set; }
|
||||
public string User_Created { get; set; }
|
||||
public string User_Deleted { get; set; }
|
||||
public string Group_Id { get; set; }
|
||||
}
|
||||
}
|
29
src/Robware.Data/UserRepository.cs
Normal file
29
src/Robware.Data/UserRepository.cs
Normal file
|
@ -0,0 +1,29 @@
|
|||
using System.Linq;
|
||||
using System.Threading.Tasks;
|
||||
using Dapper;
|
||||
using Robware.Auth;
|
||||
using Robware.Data.States;
|
||||
|
||||
namespace Robware.Data {
|
||||
public class UserRepository : IUsers {
|
||||
private readonly IDatabaseProvider _dbProvider;
|
||||
|
||||
public UserRepository(IDatabaseProvider dbProvider) {
|
||||
_dbProvider = dbProvider;
|
||||
}
|
||||
|
||||
public async Task<User> GetByEmail(string email) {
|
||||
const string query = "SELECT * FROM users WHERE user_email=@email";
|
||||
|
||||
using (var connection = _dbProvider.NewConnection()) {
|
||||
connection.Open();
|
||||
var result = await connection.QueryAsync<UserState>(query, new { email });
|
||||
|
||||
if (!result.Any())
|
||||
throw new UserNotFoundException(email);
|
||||
|
||||
return new DatabaseUser(result.Single());
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue