kreta/KretaWeb/Areas/Tanulo/ApiControllers/HetesekApiController.cs
2024-03-13 00:33:46 +01:00

124 lines
4.7 KiB
C#

using System.Collections.Generic;
using System.Data;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Text;
using System.Web.Http;
using System.Web.Http.ModelBinding;
using Kendo.Mvc.UI;
using Kreta.BusinessLogic.Helpers;
using Kreta.BusinessLogic.Security;
using Kreta.Resources;
using Kreta.Web.Areas.Tanulo.Models;
using Kreta.Web.Helpers;
using Kreta.Web.Helpers.Error;
using Kreta.Web.Helpers.Grid;
using Kreta.Web.Security;
using Newtonsoft.Json;
namespace Kreta.Web.Areas.Tanulo.ApiControllers
{
[ApiRoleClaimsAuthorize(true)]
[ApiRolePackageAuthorize(KretaClaimPackages.Osztalyfonok.ClaimValue, KretaClaimPackages.SzuperOsztalyfonok.ClaimValue, KretaClaimPackages.Evfolyamfelelos.ClaimValue)]
public class HetesekApiController : ApiController
{
public DataSourceResult GetHetesekGrid(string data, [ModelBinder(typeof(ModelBinder.DataSourceRequestModelBinder))] DataSourceRequest request)
{
var model = JsonConvert.DeserializeObject<OsztalyTanuloiSearchModel>(data);
if (!model.OsztalyCsoport.HasValue)
{
return new DataSourceResult();
}
var authorization = (IKretaAuthorization)Request.GetDependencyScope().GetService(typeof(IKretaAuthorization));
if (!authorization.IsValidOsztaly(model.OsztalyCsoport.Value))
{
throw new StatusError(HttpStatusCode.Forbidden, ErrorResource.AFelhasznalonakNincsMegfeleloJogosultsagaAFunkcioHasznalatahoz);
}
var helper = new HetesekHelper(ConnectionTypeExtensions.GetSessionConnectionType())
{
GridParameters = Converter.GridParameter(request)
};
var ds = helper.GetHetesek(model.OsztalyCsoport.Value);
return ds.ToDataSourceResult();
}
[HttpPost]
[ApiValidateAjaxAntiForgeryToken]
public HttpResponseMessage ValidateHetesek(List<HetesekModel> list)
{
ValidateHetesekModel(list);
return Request.CreateResponse(HttpStatusCode.OK, list, Configuration.Formatters.JsonFormatter);
}
[HttpPost]
[ApiValidateAjaxAntiForgeryToken]
public HttpResponseMessage DeleteFutureHetesInOsztalyCsoport(int id)
{
new HetesekHelper(ConnectionTypeExtensions.GetSessionConnectionType()).DeleteFutureHetesInOsztalyCsoport(id);
return Request.CreateResponse(HttpStatusCode.OK);
}
[HttpPost]
[ApiValidateAjaxAntiForgeryToken]
public HttpResponseMessage SaveHetesek(List<HetesekModel> list)
{
var helper = new HetesekHelper(ConnectionTypeExtensions.GetSessionConnectionType());
var osztalyCsoportId = list.FirstOrDefault().OsztalyCsoportId;
var hetesekCoList = list.ConvertAll(x => x.ToCo());
helper.SaveOrDeleteHetesekFeljegyzessel(hetesekCoList, osztalyCsoportId, ClaimData.FelhasznaloId);
return Request.CreateResponse(HttpStatusCode.OK);
}
private void ValidateHetesekModel(List<HetesekModel> list)
{
var helper = new HetesekHelper(ConnectionTypeExtensions.GetSessionConnectionType());
foreach (var model in list)
{
var errorMessage = new StringBuilder();
if (!string.IsNullOrWhiteSpace(model.Tanulok))
{
var tanuloIds = model.Tanulok.Split(',').Select(x => int.Parse(x)).ToList();
if (tanuloIds.Count > Constants.General.HetesekMaximalisSzama)
{
errorMessage.AppendFormat(ErrorResource.MaximumXHetesLehetAzYsorszamuHetnel, Constants.General.HetesekMaximalisSzama.ToString(), model.HetSorszam.ToString());
}
else
{
var tanulok = helper.GetHetSorszamokTanulokkal(model.OsztalyCsoportId, model.HetSorszam).Tables[0].AsEnumerable()
.Select(x => x.Field<int>("TanuloId")).ToList();
foreach (var tanuloId in tanuloIds)
{
if (!tanulok.Contains(tanuloId))
{
errorMessage.AppendFormat(ErrorResource.ATanuloNemTagjaAzOsztalynakASorszamuHeten, model.HetSorszam.ToString());
break;
}
}
}
}
if (errorMessage.Length > 0)
{
throw new StatusError(HttpStatusCode.BadRequest, errorMessage.ToString());
}
}
}
}
}