using System; using System.Collections.Generic; using System.Linq; using System.Net; using System.Net.Http; using System.Web.Http; using System.Web.Http.Results; using Kendo.Mvc.UI; using Kreta.BusinessLogic.Classes.ComboBox; using Kreta.BusinessLogic.Helpers; using Kreta.BusinessLogic.Logic; using Kreta.BusinessLogic.Security; using Kreta.Core; using Kreta.Core.Exceptions; using Kreta.Enums; using Kreta.Framework; using Kreta.Framework.Util; using Kreta.Resources; using Kreta.Web.Areas.OsztalyCsoport.Logic; using Kreta.Web.Areas.OsztalyCsoport.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.OsztalyCsoport.ApiControllers { [ApiRoleClaimsAuthorize(true)] [ApiRolePackageAuthorize(KretaClaimPackages.EGYMIModul.ClaimValue)] public class EGYMIOsztalyApiController : ApiController { public DataSourceResult GetOsztalyGrid(string data, DataSourceRequest request) { var (gridParameter, modelList) = GetGridData(data, request); return modelList.ToDataSourceResult(gridParameter); } [ApiRolePackageAuthorize(KretaClaimPackages.Adminisztrator.ClaimValue)] public HttpResponseMessage GetExport(string data, DataSourceRequest request) { try { var (gridParameter, modelList) = GetGridData(data, request); modelList = modelList.SortingAndPaging(gridParameter.OrderDictionary); var simpleExportColumnCos = SimpleExportLogic.GetSimpleExportColumnCos(OsztalyGridModel.OsztalyExportAttributeId); var memoryStream = SimpleExportLogic.GetExport(OsztalyCsoportResource.Osztalyok, simpleExportColumnCos, modelList, ClaimData.SelectedTanevID.Value); return HttpResponseExtensions.GetFileHttpResponse(memoryStream.ToArray(), $"{OsztalyCsoportResource.OsztalyokExportFileName}_{DateTime.Now:yyyy_MM_dd}.xlsx"); } catch (Exception ex) { throw new StatusError(HttpStatusCode.BadRequest, ErrorResource.HibaTortentAFajlExportalasaKozben) { UnHandledException = ex }; } } private (GridParameters gridParameter, List modelList) GetGridData(string data, DataSourceRequest request) { var model = JsonConvert.DeserializeObject(data); var gridParameter = Converter.GridParameter(request); var searchCo = model.ConvertToCo(OsztalyCsoportLogic.GetSearchDate()); searchCo.FeladatKategoriaId = (int)OktNevelesiKategoriaEnum.EGYMI; var coList = new OsztalyHelper(ConnectionTypeExtensions.GetSessionConnectionType()).GetOsztalyCoList(searchCo); var modelList = new List(); foreach (var co in coList) { var gridModel = new OsztalyGridModel(co); modelList.Add(gridModel); } return (gridParameter, modelList); } [HttpPost] [ApiValidateAjaxAntiForgeryToken] public HttpResponseMessage SaveOsztaly(AlapkepzesOsztalyModel model) { try { ModelState.AddRange(EGYMIOsztalyCsoportLogic.ValidateOsztaly(model)); if (model.NaplosorszamEsTorzslapszamBeallitasaiModelList?.Count > 0) { ModelState.AddRange(OsztalyCsoportLogic.ValidateNaplosorszamEsTorzslapszamBeallitasaiModelList(model.NaplosorszamEsTorzslapszamBeallitasaiModelList)); } if (ModelState.IsValid) { EGYMIOsztalyCsoportLogic.SaveOsztaly(model); if (model.NaplosorszamEsTorzslapszamBeallitasaiModelList?.Count > 0) { OsztalyCsoportLogic.SaveNaplosorszamEsTorzslapszamBeallitasai(model.NaplosorszamEsTorzslapszamBeallitasaiModelList); } return new HttpResponseMessage(HttpStatusCode.OK); } return Request.CreateErrorResponse(HttpStatusCode.BadRequest, ModelState); } catch (SDA.DataProvider.UniqueKeyViolationException) { throw new StatusError(HttpStatusCode.BadRequest, StringResourcesUtil.GetString(3684)); // Ebben a tanévben már létezik ilyen nevű osztály } catch (BlException e) { throw new StatusError(HttpStatusCode.BadRequest, e.Message); } } public HttpResponseMessage SaveModifiedOsztalyGroup(ModOsztalyModel model) { try { ModelState.AddRange(OsztalyCsoportLogic.ValidateOsztalyGroup(model)); if (ModelState.IsValid) { var errorMessage = OsztalyCsoportLogic.SaveOsztalyGroup(model); if (!string.IsNullOrWhiteSpace(errorMessage)) { errorMessage = $"{ErrorResource.AzAlabbiOsztalyCsoportokModositasaSikertelenVoltMertVanTanuloBesorolas}{errorMessage}"; return Request.CreateResponse(HttpStatusCode.OK, errorMessage); } } else { return Request.CreateErrorResponse(HttpStatusCode.BadRequest, ModelState); } } catch (BlException e) { throw new StatusError(HttpStatusCode.BadRequest, e.Message); } catch (Exception ex) { throw new StatusError(HttpStatusCode.BadRequest, ex.Message); } return new HttpResponseMessage(HttpStatusCode.OK); } public HttpResponseMessage SaveNaplosorszamListGroup(ModOsztalyModel model) { try { if (ModelState.IsValid) { OsztalyCsoportLogic.SaveNaplosorszamListGroup(model.OsztalyIdArray.Select(int.Parse).ToList()); } else { return Request.CreateErrorResponse(HttpStatusCode.BadRequest, ModelState); } } catch (BlException e) { throw new StatusError(HttpStatusCode.BadRequest, e.Message); } catch (Exception ex) { throw new StatusError(HttpStatusCode.BadRequest, ex.Message); } return new HttpResponseMessage(HttpStatusCode.OK); } public ModOsztalyModel GetOsztalyModProperties(int? osztalyID = null) { return OsztalyCsoportLogic.GetOsztalyModProperties(osztalyID); } public DataSourceResult GetOsztalyTanuloi(string osztalyId, [System.Web.Http.ModelBinding.ModelBinder(typeof(ModelBinder.DataSourceRequestModelBinder))] DataSourceRequest request) { return OsztalyCsoportLogic.GetOsztalyTanuloi(osztalyId, request); } //Osztályhoz tartozó összes csoport + osztálybontás csoportjai public DataSourceResult GetOsztalyBontasCsoportjai(string osztalyID, [System.Web.Http.ModelBinding.ModelBinder(typeof(ModelBinder.DataSourceRequestModelBinder))] DataSourceRequest request) { return OsztalyCsoportLogic.GetOsztalyBontasCsoportjai(osztalyID, request); } public DataSourceResult GetOsztalyFoglalkozasai(int osztalyID, [System.Web.Http.ModelBinding.ModelBinder(typeof(ModelBinder.DataSourceRequestModelBinder))] DataSourceRequest request) { return OsztalyCsoportLogic.GetOsztalyFoglalkozasai(osztalyID, request); } public DataSourceResult GetOsztalyOrarendiOrai(string osztalyID, [System.Web.Http.ModelBinding.ModelBinder(typeof(ModelBinder.DataSourceRequestModelBinder))] DataSourceRequest request) { return OsztalyCsoportLogic.GetOsztalyOrarendiOrai(osztalyID, request); } public DataSourceResult GetOsztalyTanmenetei(int osztalyID, [System.Web.Http.ModelBinding.ModelBinder(typeof(ModelBinder.DataSourceRequestModelBinder))] DataSourceRequest request) { return OsztalyCsoportLogic.GetOsztalyTanmenetei(osztalyID, request); } public DataSourceResult GetOsztalyErtekelesListGrid(string osztalyId, [System.Web.Http.ModelBinding.ModelBinder(typeof(ModelBinder.DataSourceRequestModelBinder))] DataSourceRequest request) { return OsztalyCsoportLogic.GetOsztalyErtekelesListGrid(osztalyId, request, (int)OktNevelesiKategoriaEnum.EGYMI); } public DataSourceResult GetOsztalyIgazolasai(int osztalyID, [System.Web.Http.ModelBinding.ModelBinder(typeof(ModelBinder.DataSourceRequestModelBinder))] DataSourceRequest request) { return OsztalyCsoportLogic.GetOsztalyIgazolasai(osztalyID, request); } [HttpPost] [ApiValidateAjaxAntiForgeryToken] public IHttpActionResult DeleteOsztalyok(DeleteOsztalyModel model) { var returnMsg = OsztalyCsoportLogic.DeleteOsztalyok(model.OsztalyIdLista, model.CsoportokTorlese, out bool deleteError); if (deleteError) { throw new StatusError(HttpStatusCode.BadRequest, returnMsg); } return Json(new { Message = returnMsg }); } public JsonResult> GetEvfolyamList(string cascadeFilter) { return Json(OsztalyCsoportLogic.GetEvfolyamListFilter(cascadeFilter)); } } }