using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Net; using System.Net.Http; using System.Web.Http; using Kendo.Mvc.UI; using Kreta.BusinessLogic.Helpers; using Kreta.BusinessLogic.Interfaces; using Kreta.BusinessLogic.Logic; using Kreta.BusinessLogic.Security; using Kreta.Core; using Kreta.Framework; using Kreta.Framework.Util; using Kreta.Resources; using Kreta.Web.Areas.Intezmeny.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.Intezmeny.ApiControllers { [ApiRoleClaimsAuthorize(true)] [MvcRolePackageDenyAuthorize(KretaClaimPackages.IsOnlyAlkalmozott.ClaimValue)] [ApiRolePackageAuthorize(KretaClaimPackages.Adminisztrator.ClaimValue, KretaClaimPackages.IsSzakkepzoIntezmeny.ClaimValue)] public class OktatottSzakmakApiController : ApiController { private readonly IFileServiceHelper _fileServiceHelper; public OktatottSzakmakApiController(IFileServiceHelper fileServiceHelper) { _fileServiceHelper = fileServiceHelper ?? throw new ArgumentNullException(nameof(fileServiceHelper)); } public DataSourceResult GetOktatottSzakmakGrid(string data, DataSourceRequest request) { var (gridParameter, modelList) = GetGridData(data, request); return modelList.ToDataSourceResult(gridParameter); } public HttpResponseMessage GetExport(string data, DataSourceRequest request) { try { var (gridParameter, modelList) = GetGridData(data, request); modelList = modelList.SortingAndPaging(gridParameter.OrderDictionary); var simpleExportColumnCos = SimpleExportLogic.GetSimpleExportColumnCos(OktatottSzakmakGridModel.OktatottSzakmakExportAttributeId); var memoryStream = SimpleExportLogic.GetExport(UjSzktSzakmajegyzekOsszerendelesResource.ExportDefaultSheetname, simpleExportColumnCos, modelList, ClaimData.SelectedTanevID.Value); var today = DateTime.Today; return HttpResponseExtensions.GetFileHttpResponse(memoryStream.ToArray(), string.Format(UjSzktSzakmajegyzekOsszerendelesResource.ExportFileName, $"{today.Year}_{today.Month:00}_{today.Day:00}")); } catch (Exception ex) { throw new StatusError(HttpStatusCode.BadRequest, ErrorResource.HibaTortentAFajlExportalasaKozben) { UnHandledException = ex }; } } [HttpPost] [ApiValidateAjaxAntiForgeryToken] public HttpResponseMessage OktatottSzakmaMultipleModify(OktatottSzakmaMultipleModifyModel model) { if (ModelState.IsValid) { try { new UjSzktSzakmajegyzekOsszerendelesHelper(ConnectionTypeExtensions.GetSessionConnectionType()).SaveUjSzktSzakmajegyzekOsszerendelesCoList(model.ToCoList(), false); } catch (KretaError ke) { SDAServer.Instance.Logger.ExceptionThrown(ke); ModelState.AddModelError("Error", ke.Message); } if (ModelState.IsValid) { return new HttpResponseMessage(HttpStatusCode.OK); } } return Request.CreateErrorResponse(HttpStatusCode.BadRequest, ModelState); } [HttpPost] [ApiValidateAjaxAntiForgeryToken] public HttpResponseMessage OktatottSzakmaModify(OktatottSzakmaModifyModel model) { if (model.File != null) { var maxAllowedFileSizeInBytes = model.MaxAllowedFileSizeInBytes; if (model.File.Size > maxAllowedFileSizeInBytes) { ModelState.AddModelError("Error", string.Format(CommonResource.TulNagyFajl, Math.Round((decimal)maxAllowedFileSizeInBytes / 1024 / 1024))); } var allowedFileExtensions = model.AllowedFileExtensions; if (!allowedFileExtensions.ContainsValue(model.File.Type)) { ModelState.AddModelError("Error", string.Format(CommonResource.NemMegfeleloFajlKiterjesztes, string.Join(", ", allowedFileExtensions.Select(x => x.Key)))); } } if (ModelState.IsValid) { try { new UjSzktSzakmajegyzekOsszerendelesHelper(ConnectionTypeExtensions.GetSessionConnectionType(), _fileServiceHelper).SaveUjSzktSzakmajegyzekOsszerendelesCo(model.ToCo(), isFileModify: true); } catch (KretaError ke) { SDAServer.Instance.Logger.ExceptionThrown(ke); ModelState.AddModelError("Error", ke.Message); } if (ModelState.IsValid) { return new HttpResponseMessage(HttpStatusCode.OK); } } return Request.CreateErrorResponse(HttpStatusCode.BadRequest, ModelState); } public DataSourceResult GetOktatottSzakmaTanuloGrid(string id, DataSourceRequest request) { var gridParameter = Converter.GridParameter(request); var helper = new UjSzktSzakmajegyzekOsszerendelesHelper(ConnectionTypeExtensions.GetSessionConnectionType()) { GridParameters = gridParameter }; var searchCo = helper.GetUjSzktSzakmajegyzekOsszerendelesCo(int.Parse(id)); var coList = helper.GetOktatottSzakmaTanuloCoList(searchCo); var modelList = new List(); foreach (var co in coList) { var gridModel = new OktatottSzakmaTanulokGridModel(co); modelList.Add(gridModel); } return modelList.ToDataSourceResult(gridParameter); } private (GridParameters gridParameter, List modelList) GetGridData(string data, DataSourceRequest request) { var searchModel = JsonConvert.DeserializeObject(data); var gridParameter = Converter.GridParameter(request); var helper = new UjSzktSzakmajegyzekOsszerendelesHelper(ConnectionTypeExtensions.GetSessionConnectionType()) { GridParameters = gridParameter }; var coList = helper.GetUjSzktSzakmajegyzekOsszerendelesCoList(searchModel.ToCo()); var modelList = new List(); foreach (var co in coList) { var gridModel = new OktatottSzakmakGridModel(co); modelList.Add(gridModel); } return (gridParameter, modelList); } } }