public IHttpActionResult Get(int id)
        {
            // authentication
            Module.Framework.BLL fwBll = new Module.Framework.BLL();
            if (!fwBll.CanPerformAction(ControllerContext.GetAuthUserId(), moduleCode, Library.DTO.ModuleAction.CanRead))
            {
                return(InternalServerError(new Exception(Properties.Resources.NOT_AUTHORIZED)));
            }

            BLL.WarehouseCIMng               bll = new BLL.WarehouseCIMng();
            Library.DTO.Notification         notification;
            DTO.WarehouseCIMng.DataContainer WarehouseCI = bll.GetDataContainer(id, ControllerContext.GetAuthUserId(), out notification);
            if (notification.Type == Library.DTO.NotificationType.Error)
            {
                return(InternalServerError(new Exception(notification.Message)));
            }
            return(Ok(new Library.DTO.ReturnData <DTO.WarehouseCIMng.DataContainer>()
            {
                Data = WarehouseCI, Message = notification
            }));
        }
        public IHttpActionResult Update(int id, DTO.WarehouseCIMng.WarehouseCI dtoItem)
        {
            Library.DTO.Notification notification;

            // authentication
            Module.Framework.BLL fwBll = new Module.Framework.BLL();
            if (id > 0 && !fwBll.CanPerformAction(ControllerContext.GetAuthUserId(), moduleCode, Library.DTO.ModuleAction.CanUpdate))
            {
                // edit case
                return(InternalServerError(new Exception(Properties.Resources.NOT_AUTHORIZED)));
            }
            else if (id == 0 && !fwBll.CanPerformAction(ControllerContext.GetAuthUserId(), moduleCode, Library.DTO.ModuleAction.CanCreate))
            {
                // create new case
                return(InternalServerError(new Exception(Properties.Resources.NOT_AUTHORIZED)));
            }

            // validation
            if (!Helper.CommonHelper.ValidateDTO <DTO.WarehouseCIMng.WarehouseCI>(dtoItem, out notification))
            {
                return(Ok(new Library.DTO.ReturnData <DTO.WarehouseCIMng.WarehouseCI>()
                {
                    Data = dtoItem, Message = notification
                }));
            }

            // continue processing
            BLL.WarehouseCIMng bll = new BLL.WarehouseCIMng();
            bll.UpdateData(id, ref dtoItem, ControllerContext.GetAuthUserId(), out notification);

            if (notification.Type == Library.DTO.NotificationType.Error)
            {
                return(InternalServerError(new Exception(notification.Message)));
            }
            return(Ok(new Library.DTO.ReturnData <DTO.WarehouseCIMng.WarehouseCI>()
            {
                Data = dtoItem, Message = notification
            }));
        }
        public IHttpActionResult Gets(DTO.Search searchInput)
        {
            // authentication
            Module.Framework.BLL fwBll = new Module.Framework.BLL();
            if (!fwBll.CanPerformAction(ControllerContext.GetAuthUserId(), moduleCode, Library.DTO.ModuleAction.CanRead))
            {
                return(InternalServerError(new Exception(Properties.Resources.NOT_AUTHORIZED)));
            }

            BLL.WarehouseCIMng       bll = new BLL.WarehouseCIMng();
            Library.DTO.Notification notification;
            int totalRows = 0;
            IEnumerable <DTO.WarehouseCIMng.WarehouseCISearch> searchResult = bll.GetDataWithFilter(ControllerContext.GetAuthUserId(), searchInput.Filters, searchInput.PageSize, searchInput.PageIndex, searchInput.SortedBy, searchInput.SortedDirection, out totalRows, out notification);

            if (notification.Type == Library.DTO.NotificationType.Error)
            {
                return(InternalServerError(new Exception(notification.Message)));
            }
            return(Ok(new Library.DTO.ReturnData <IEnumerable <DTO.WarehouseCIMng.WarehouseCISearch> >()
            {
                Data = searchResult, Message = notification, TotalRows = totalRows
            }));
        }