2024-05-06 21:25:10 +02:00
|
|
|
|
using FirmTracker_Server.nHibernate.Products;
|
2024-05-05 22:08:27 +02:00
|
|
|
|
using NHibernate;
|
|
|
|
|
using NHibernate.Linq;
|
2024-05-06 21:25:10 +02:00
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.Linq;
|
2024-05-16 00:42:06 +02:00
|
|
|
|
using System.Transactions;
|
2024-05-05 22:08:27 +02:00
|
|
|
|
|
|
|
|
|
namespace FirmTracker_Server.nHibernate.Transactions
|
|
|
|
|
{
|
|
|
|
|
public class TransactionCRUD
|
|
|
|
|
{
|
|
|
|
|
public void AddTransaction(Transaction transaction)
|
|
|
|
|
{
|
|
|
|
|
using (var session = SessionFactory.OpenSession())
|
|
|
|
|
using (var sessionTransaction = session.BeginTransaction())
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
2024-05-06 21:25:10 +02:00
|
|
|
|
foreach (var transactionProduct in transaction.TransactionProducts)
|
|
|
|
|
{
|
2024-05-16 00:42:06 +02:00
|
|
|
|
|
2024-05-06 21:25:10 +02:00
|
|
|
|
transactionProduct.TransactionId = transaction.Id;
|
|
|
|
|
session.Save(transactionProduct);
|
|
|
|
|
}
|
2024-05-05 22:08:27 +02:00
|
|
|
|
session.Save(transaction);
|
2024-05-06 21:25:10 +02:00
|
|
|
|
|
|
|
|
|
// Decrease product quantities based on transaction
|
|
|
|
|
foreach (var transactionProduct in transaction.TransactionProducts)
|
|
|
|
|
{
|
2024-05-16 00:42:06 +02:00
|
|
|
|
|
|
|
|
|
var product = session.Get<Product>(transactionProduct.ProductID);
|
2024-05-06 21:25:10 +02:00
|
|
|
|
if (product.Type != 0)
|
|
|
|
|
{
|
|
|
|
|
product.Availability -= transactionProduct.Quantity;
|
|
|
|
|
session.Update(product);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-05-05 22:08:27 +02:00
|
|
|
|
sessionTransaction.Commit();
|
|
|
|
|
}
|
|
|
|
|
catch
|
|
|
|
|
{
|
|
|
|
|
sessionTransaction.Rollback();
|
|
|
|
|
throw;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-05-06 21:25:10 +02:00
|
|
|
|
//usage of HQL
|
2024-05-16 00:42:06 +02:00
|
|
|
|
public Transaction2 GetTransaction(int transactionId)
|
2024-05-05 22:08:27 +02:00
|
|
|
|
{
|
|
|
|
|
using (var session = SessionFactory.OpenSession())
|
|
|
|
|
{
|
2024-05-06 21:25:10 +02:00
|
|
|
|
var query = session.CreateQuery(@"
|
2024-05-16 00:42:06 +02:00
|
|
|
|
SELECT t
|
|
|
|
|
FROM Transaction2 t
|
|
|
|
|
LEFT JOIN FETCH t.TransactionProducts tp
|
|
|
|
|
LEFT JOIN FETCH tp.Product
|
2024-05-06 21:25:10 +02:00
|
|
|
|
WHERE t.Id = :transactionId
|
|
|
|
|
");
|
|
|
|
|
query.SetParameter("transactionId", transactionId);
|
2024-05-16 00:42:06 +02:00
|
|
|
|
|
|
|
|
|
var transaction = query.UniqueResult<Transaction2>();
|
2024-05-05 22:08:27 +02:00
|
|
|
|
return transaction;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-05-06 21:25:10 +02:00
|
|
|
|
|
2024-05-16 00:42:06 +02:00
|
|
|
|
|
|
|
|
|
|
2024-05-05 22:08:27 +02:00
|
|
|
|
public void UpdateTransaction(Transaction transaction)
|
|
|
|
|
{
|
|
|
|
|
using (var session = SessionFactory.OpenSession())
|
2024-05-16 00:42:06 +02:00
|
|
|
|
using (var sessionTransaction = session.BeginTransaction())
|
2024-05-05 22:08:27 +02:00
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
2024-05-16 00:42:06 +02:00
|
|
|
|
foreach (var transactionProduct in transaction.TransactionProducts)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
transactionProduct.TransactionId = transaction.Id;
|
|
|
|
|
session.Update(transactionProduct);
|
|
|
|
|
}
|
2024-05-05 22:08:27 +02:00
|
|
|
|
session.Update(transaction);
|
2024-05-16 00:42:06 +02:00
|
|
|
|
|
|
|
|
|
// Decrease product quantities based on transaction
|
|
|
|
|
foreach (var transactionProduct in transaction.TransactionProducts)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
var product = session.Get<Product>(transactionProduct.ProductID);
|
|
|
|
|
if (product.Type != 0)
|
|
|
|
|
{
|
|
|
|
|
product.Availability -= transactionProduct.Quantity;
|
|
|
|
|
session.Update(product);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
sessionTransaction.Commit();
|
|
|
|
|
}
|
|
|
|
|
catch
|
|
|
|
|
{
|
|
|
|
|
sessionTransaction.Rollback();
|
|
|
|
|
throw;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
public void UpdateTransactionProduct(TransactionProduct transactionProduct)
|
|
|
|
|
{
|
|
|
|
|
using (var session = SessionFactory.OpenSession())
|
|
|
|
|
using (var t = session.BeginTransaction())
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
session.Update(transactionProduct);
|
2024-05-05 22:08:27 +02:00
|
|
|
|
t.Commit();
|
|
|
|
|
}
|
|
|
|
|
catch
|
|
|
|
|
{
|
|
|
|
|
t.Rollback();
|
|
|
|
|
throw;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void DeleteTransaction(int transactionId)
|
|
|
|
|
{
|
|
|
|
|
using (var session = SessionFactory.OpenSession())
|
|
|
|
|
using (var t = session.BeginTransaction())
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
2024-05-06 21:25:10 +02:00
|
|
|
|
var transaction = session.Get<Transaction>(transactionId);
|
2024-05-05 22:08:27 +02:00
|
|
|
|
if (transaction != null)
|
|
|
|
|
{
|
|
|
|
|
session.Delete(transaction);
|
|
|
|
|
t.Commit();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
catch
|
|
|
|
|
{
|
|
|
|
|
t.Rollback();
|
|
|
|
|
throw;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-05-06 21:25:10 +02:00
|
|
|
|
public void AddTransactionProductToTransaction(int transactionId, TransactionProduct transactionProduct)
|
|
|
|
|
{
|
|
|
|
|
using (var session = SessionFactory.OpenSession())
|
|
|
|
|
using (var transaction = session.BeginTransaction())
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
var transactionToUpdate = session.Get<Transaction>(transactionId);
|
|
|
|
|
if (transactionToUpdate != null)
|
|
|
|
|
{
|
2024-05-16 00:42:06 +02:00
|
|
|
|
transactionProduct.TransactionId= transactionToUpdate.Id;
|
2024-05-06 21:25:10 +02:00
|
|
|
|
session.Save(transactionProduct);
|
|
|
|
|
transaction.Commit();
|
2024-05-16 00:42:06 +02:00
|
|
|
|
|
|
|
|
|
var product = session.Get<Product>(transactionProduct.ProductID);
|
|
|
|
|
if (product.Type != 0)
|
|
|
|
|
{
|
|
|
|
|
product.Availability -= transactionProduct.Quantity;
|
|
|
|
|
session.Update(product);
|
|
|
|
|
}
|
|
|
|
|
|
2024-05-06 21:25:10 +02:00
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
throw new Exception("Transaction not found.");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
transaction.Rollback();
|
|
|
|
|
throw ex;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-05-05 22:08:27 +02:00
|
|
|
|
|
2024-05-16 00:42:06 +02:00
|
|
|
|
public IList<Transaction2> GetAllTransactions()
|
2024-05-05 22:08:27 +02:00
|
|
|
|
{
|
|
|
|
|
using (var session = SessionFactory.OpenSession())
|
|
|
|
|
{
|
2024-05-16 00:42:06 +02:00
|
|
|
|
var transactions = session.Query<Transaction2>()
|
|
|
|
|
.FetchMany(t => t.TransactionProducts)
|
|
|
|
|
.ThenFetch(tp => tp.Product)
|
2024-05-05 22:08:27 +02:00
|
|
|
|
.ToList();
|
2024-05-06 21:25:10 +02:00
|
|
|
|
|
2024-05-05 22:08:27 +02:00
|
|
|
|
return transactions;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-05-06 21:25:10 +02:00
|
|
|
|
}
|
2024-05-05 22:08:27 +02:00
|
|
|
|
}
|