This commit is contained in:
mmrbnjd
2025-01-19 17:44:20 +03:30
parent be0616ac97
commit d14c474c6b
20 changed files with 570 additions and 74 deletions

View File

@@ -4,6 +4,7 @@ using Microsoft.AspNetCore.Http;
using Microsoft.AspNetCore.Mvc;
using Shared.DTOs.Warehouse;
using Shared.Enums;
using Back.Validations.Warehouse.Remittance;
namespace Back.Controllers.Warehouse
{
@@ -13,6 +14,20 @@ namespace Back.Controllers.Warehouse
{
private readonly RemittanceService _treanceService;
private readonly servUser _servUser;
private readonly ADDValidation _addvalidation;
private readonly UpdateValidation _updatevalidation;
private readonly DeleteValidation _deletevalidation;
public RemittanceController(RemittanceService treanceService, servUser servUser, ADDValidation addvalidation, UpdateValidation updatevalidation, DeleteValidation deletevalidation)
{
_treanceService = treanceService;
_servUser = servUser;
_addvalidation = addvalidation;
_updatevalidation = updatevalidation;
_deletevalidation = deletevalidation;
}
[HttpGet("{ItemID}")]
public async Task<IActionResult> Get(int ItemID)
{
@@ -34,7 +49,17 @@ namespace Back.Controllers.Warehouse
[HttpPost("ADD")]
public async Task<IActionResult> Add(RemittanceDto item)
{
// validate ADD
var claim = HttpContext.User.Claims.First(c => c.Type == "UserID");
var UserID = claim.Value;
var user = await _servUser.GetUserByUserID(Convert.ToInt32(UserID));
var CompanyID = user.RolUsers.First().CompanyID;
//-----Validaton
var resultValidationmodel = await _addvalidation.ValidateAsync(Tuple.Create(item, CompanyID));
if (!resultValidationmodel.IsValid)
return BadRequest(resultValidationmodel.Errors.Select(s => s.ErrorMessage).ToList());
var newmodel = await _treanceService.ADD(item);
if (newmodel != null) return Ok(newmodel);
else return BadRequest(new List<string> { "خطا در صدور" });
@@ -43,7 +68,16 @@ namespace Back.Controllers.Warehouse
[HttpPut("Update")]
public async Task<IActionResult> Update(RemittanceDto item)
{
// validate Update
var claim = HttpContext.User.Claims.First(c => c.Type == "UserID");
var UserID = claim.Value;
var user = await _servUser.GetUserByUserID(Convert.ToInt32(UserID));
var CompanyID = user.RolUsers.First().CompanyID;
//-----Validaton
var resultValidationmodel = await _updatevalidation.ValidateAsync(Tuple.Create(item, CompanyID));
if (!resultValidationmodel.IsValid)
return BadRequest(resultValidationmodel.Errors.Select(s => s.ErrorMessage).ToList());
var Updatemodel = await _treanceService.Update(item);
if (Updatemodel != null) return Ok(Updatemodel);
else return BadRequest(new List<string> { "خطا در ویرایش" });
@@ -57,6 +91,11 @@ namespace Back.Controllers.Warehouse
var user = await _servUser.GetUserByUserID(Convert.ToInt32(UserID));
var CompanyID = user.RolUsers.First().CompanyID;
//-----Validaton
var resultValidationmodel = await _deletevalidation.ValidateAsync(Tuple.Create(ItemID, CompanyID));
if (!resultValidationmodel.IsValid)
return BadRequest(resultValidationmodel.Errors.Select(s => s.ErrorMessage).ToList());
var Deletemodel = await _treanceService.Delete(ItemID, CompanyID);
if (Deletemodel) return Ok();
else return BadRequest(new List<string> { "خطا در حذف" });