Files
cms_thermo_active/Step.Database/Controllers/UsersController.cs
T
Lucio Maranta 5b40cf6fb0 * Fix Web api exception manager
* Added language support api
* Added canRead canWrite to functions Access api
2017-12-28 16:36:48 +01:00

74 lines
2.1 KiB
C#

using System;
using System.Globalization;
using System.Linq;
using System.Web.Helpers;
using Step.Model.DatabaseModels;
namespace Step.Database.Controllers
{
public class UsersController : IDisposable
{
private DatabaseContext dbCtx;
public UsersController()
{
// Initialize database context
dbCtx = new DatabaseContext();
}
public void Dispose()
{
// Clear database context
dbCtx.Dispose();
}
public void Create(string username, string password, string firstName, string lastName, int roleId, CultureInfo language)
{
// Create a new user model with params
UserModel user = new UserModel()
{
Username = username,
Password = Crypto.HashPassword(password),
FirstName = firstName,
LastName = lastName,
RoleId = roleId,
SecurityStamp = Guid.NewGuid().ToString(),
Language = language
};
// Add to database
dbCtx.Users.Add(user);
// Commit changes
dbCtx.SaveChanges();
}
public UserModel Find(int id)
{
// Find user by Id with Role object included
return dbCtx.Users.Include("Role").Where(u => u.UserId == id).FirstOrDefault();
}
public UserModel Find(string username)
{
// Find user by Id with Role object included
return dbCtx.Users.Include("Role").Where(u => u.Username == username).FirstOrDefault();
}
public UserModel Find(string username, string password)
{
// Find if username exists
UserModel user = Find(username);
if (user != null)
{
// Check if the passwords match
if (Crypto.VerifyHashedPassword(user.Password, password) != true)
{
return null;
}
}
return user;
}
}
}