Para agregar el usuario vamos a crear una función para que nos genere el salt.
En nuestra carpeta Core agregamos una nueva clase llamada Seguridad y agregamos una función GetSalt, esta función nos regresa una cadena aleatoria.
También agregamos la función GetHash el cual nos devolverá el hash de la cadena de texto que enviamos como parámetro.
Seguridad.cs
using System;
using System.Security.Cryptography;
namespace CaducaRest.Core
{
public class Seguridad
{
public Seguridad()
{
}
public string GetSalt()
{
byte[] bytes = new byte[128 / 8];
using (var keyGenerator = RandomNumberGenerator.Create())
{
keyGenerator.GetBytes(bytes);
return BitConverter.ToString(bytes).ToLower();
}
}
public string GetHash(string text)
{
using (var sha256 = SHA256.Create())
{
var hashedBytes = sha256
.ComputeHash(Encoding.UTF8.GetBytes(text));
return BitConverter
.ToString(hashedBytes).ToLower();
}
}
}
}
En nuestra carpeta DAO creamos nuestra clase UsuarioDAO, en la función agregarUsuario, agregamos las funciones que creamos para guardar el salt y el password con un hash
UsuarioDAO.cs
public class UsuarioDAO
{
private readonly CaducaContext contexto;
public CustomError customError;
public UsuarioDAO(CaducaContext context)
{
this.contexto = context;
}
public async Task<bool> AgregarAsync(Usuario usuario)
{
contexto.Usuario.Add(usuario);
Seguridad seguridad = new Seguridad();
usuario.Adicional1 = seguridad.GetSalt();
usuario.Password = seguridad.GetHash(usuario.Adicional1
+ usuario.Password );
await contexto.SaveChangesAsync();
return true;
}
}
En nuestro archivo CaducaContext, en la región de los inserts agregamos 3 usuarios uno por cada tipo de usuario.
Por seguridad tu primer usuario no debe ser el usuario administrador, ni llamarse admin, administrador, supervisor, superusuario, ni tampoco tener el nombre apellido del dueño o gerente, como por ejemplo chernandez ya que un hacker es lo primero que busca, intenta ver si el primer usuario es el administrador e intenta con esos nombres de usuarios.