Код: Выделить всё
public class NHibernateSessionAttribute : ActionFilterAttribute
{
public override void OnActionExecuting(HttpActionContext actionContext)
{
var session = NHibernateSessionManager.SessionFactory.OpenSession();
session.BeginTransaction();
CurrentSessionContext.Bind(session);
}
public override void OnActionExecuted(HttpActionExecutedContext actionExecutedContext)
{
var session = CurrentSessionContext.Unbind(NHibernateSessionManager.SessionFactory)
if (session != null)
{
if (session.Transaction.IsActive)
{
try
{
session.Transaction.Commit();
}
catch
{
session.Transaction.Rollback();
}
}
session.Close();
}
}
}
Код: Выделить всё
AccountController.cs
public async Task ChangePassword(ChangePasswordBindingModel model)
{
if (!ModelState.IsValid)
{
return BadRequest(ModelState);
}
IdentityResult result = await UserManager.ChangePasswordAsync(User.Identity.GetUserId(), model.OldPassword,
model.NewPassword);
if (!result.Succeeded)
{
return GetErrorResult(result);
}
return Ok();
}
В коде первая попытка сохранения выполняется без сбоев, а вторая - нет. Дублированный код предназначен только для иллюстрации ситуации.
Код: Выделить всё
UserStore.cs
public System.Threading.Tasks.Task UpdateAsync(UserModel user)
{
if (user == null)
{
throw new ArgumentNullException("user");
}
//Here the Session is found
DataProviderI prov = new DataProviderImplGeneric();
prov.Save(user);
return Task.Factory.StartNew(() =>
{
//Here the Session is NOT found
DataProviderI prov2 = new DataProviderImplGeneric();
prov.Save(user);
});
}
Насколько мне известно, NHibernate не поддерживает асинхронные вызовы, и я мог бы реорганизовать методы с возвратом типа Task.FromResult(0) в случаях void или Task.FromResult(T), где T является объектом, но я хотел бы знать, если есть еще одно решение, позволяющее воспользоваться преимуществами параллелизма
Подробнее здесь: https://stackoverflow.com/questions/332 ... ks-threads
Мобильная версия