Esempio n. 1
0
        private AdjudicatedRating GetAdjudicatedRating(AdjudicatedRating request)
        {
            var id = request?.Id;
            AdjudicatedRating ret = null;
            var query             = DocQuery.ActiveQuery ?? Execute;

            DocPermissionFactory.SetSelect <AdjudicatedRating>(currentUser, "AdjudicatedRating", request.Select);

            DocEntityAdjudicatedRating entity = null;

            if (id.HasValue)
            {
                entity = DocEntityAdjudicatedRating.Get(id.Value);
            }
            if (null == entity)
            {
                throw new HttpError(HttpStatusCode.NotFound, $"No AdjudicatedRating found for Id {id.Value}");
            }

            if (!DocPermissionFactory.HasPermission(entity, currentUser, DocConstantPermission.VIEW))
            {
                throw new HttpError(HttpStatusCode.Forbidden, "You do not have VIEW permission for this route.");
            }

            ret = entity?.ToDto();
            return(ret);
        }
Esempio n. 2
0
        public AdjudicatedRating Post(AdjudicatedRating request)
        {
            if (request == null)
            {
                throw new HttpError(HttpStatusCode.NotFound, "Request cannot be null.");
            }

            request.Select = request.Select ?? new List <string>();

            AdjudicatedRating ret = null;

            using (Execute)
            {
                Execute.Run(ssn =>
                {
                    if (!DocPermissionFactory.HasPermissionTryAdd(currentUser, "AdjudicatedRating"))
                    {
                        throw new HttpError(HttpStatusCode.Forbidden, "You do not have ADD permission for this route.");
                    }

                    ret = _AssignValues(request, DocConstantPermission.ADD, ssn);
                });
            }
            return(ret);
        }
Esempio n. 3
0
        public void Delete(AdjudicatedRating request)
        {
            using (Execute)
            {
                Execute.Run(ssn =>
                {
                    if (!(request?.Id > 0))
                    {
                        throw new HttpError(HttpStatusCode.NotFound, $"No Id provided for delete.");
                    }

                    var en = DocEntityAdjudicatedRating.Get(request?.Id);
                    if (null == en)
                    {
                        throw new HttpError(HttpStatusCode.NotFound, $"No AdjudicatedRating could be found for Id {request?.Id}.");
                    }
                    if (en.IsRemoved)
                    {
                        return;
                    }

                    if (!DocPermissionFactory.HasPermission(en, currentUser, DocConstantPermission.DELETE))
                    {
                        throw new HttpError(HttpStatusCode.Forbidden, "You do not have DELETE permission for this route.");
                    }

                    en.Remove();

                    DocCacheClient.RemoveSearch(DocConstantModelName.ADJUDICATEDRATING);
                    DocCacheClient.RemoveById(request.Id);
                });
            }
        }
Esempio n. 4
0
        public AdjudicatedRating Post(AdjudicatedRatingCopy request)
        {
            AdjudicatedRating ret = null;

            using (Execute)
            {
                Execute.Run(ssn =>
                {
                    var entity = DocEntityAdjudicatedRating.Get(request?.Id);
                    if (null == entity)
                    {
                        throw new HttpError(HttpStatusCode.NoContent, "The COPY request did not succeed.");
                    }
                    if (!DocPermissionFactory.HasPermission(entity, currentUser, DocConstantPermission.ADD))
                    {
                        throw new HttpError(HttpStatusCode.Forbidden, "You do not have ADD permission for this route.");
                    }

                    var pAssignee    = entity.Assignee;
                    var pData        = entity.Data;
                    var pDescription = entity.Description;
                    if (!DocTools.IsNullOrEmpty(pDescription))
                    {
                        pDescription += " (Copy)";
                    }
                    var pDocument       = entity.Document;
                    var pDueDate        = entity.DueDate;
                    var pRating         = entity.Rating;
                    var pReasonRejected = entity.ReasonRejected;
                    var pReporter       = entity.Reporter;
                    var pType           = entity.Type;
                    var pWorkflow       = entity.Workflow;
                    var copy            = new DocEntityAdjudicatedRating(ssn)
                    {
                        Hash             = Guid.NewGuid()
                        , Assignee       = pAssignee
                        , Data           = pData
                        , Description    = pDescription
                        , Document       = pDocument
                        , DueDate        = pDueDate
                        , Rating         = pRating
                        , ReasonRejected = pReasonRejected
                        , Reporter       = pReporter
                        , Type           = pType
                        , Workflow       = pWorkflow
                    };

                    copy.SaveChanges(DocConstantPermission.ADD);
                    ret = copy.ToDto();
                });
            }
            return(ret);
        }
Esempio n. 5
0
        public AdjudicatedRating Patch(AdjudicatedRating request)
        {
            if (true != (request?.Id > 0))
            {
                throw new HttpError(HttpStatusCode.NotFound, "Please specify a valid Id of the AdjudicatedRating to patch.");
            }

            request.Select = request.Select ?? new List <string>();

            AdjudicatedRating ret = null;

            using (Execute)
            {
                Execute.Run(ssn =>
                {
                    ret = _AssignValues(request, DocConstantPermission.EDIT, ssn);
                });
            }
            return(ret);
        }
Esempio n. 6
0
 public AdjudicatedRating Put(AdjudicatedRating request)
 {
     return(Patch(request));
 }
Esempio n. 7
0
        private AdjudicatedRating _AssignValues(AdjudicatedRating request, DocConstantPermission permission, Session session)
        {
            if (permission != DocConstantPermission.ADD && (request == null || request.Id <= 0))
            {
                throw new HttpError(HttpStatusCode.NotFound, $"No record");
            }

            if (permission == DocConstantPermission.ADD && !DocPermissionFactory.HasPermissionTryAdd(currentUser, "AdjudicatedRating"))
            {
                throw new HttpError(HttpStatusCode.Forbidden, "You do not have ADD permission for this route.");
            }

            request.Select = request.Select ?? new List <string>();

            AdjudicatedRating ret = null;

            request = _InitAssignValues <AdjudicatedRating>(request, permission, session);
            //In case init assign handles create for us, return it
            if (permission == DocConstantPermission.ADD && request.Id > 0)
            {
                return(request);
            }

            var cacheKey = GetApiCacheKey <AdjudicatedRating>(DocConstantModelName.ADJUDICATEDRATING, nameof(AdjudicatedRating), request);

            //First, assign all the variables, do database lookups and conversions
            var pAssignee       = DocEntityUser.Get(request.Assignee?.Id, true, Execute) ?? DocEntityUser.Get(request.AssigneeId, true, Execute);
            var pData           = request.Data;
            var pDescription    = request.Description;
            var pDocument       = DocEntityDocument.Get(request.Document?.Id, true, Execute) ?? DocEntityDocument.Get(request.DocumentId, true, Execute);
            var pDueDate        = request.DueDate;
            var pRating         = request.Rating;
            var pReasonRejected = request.ReasonRejected;
            var pReporter       = DocEntityUser.Get(request.Reporter?.Id, true, Execute) ?? DocEntityUser.Get(request.ReporterId, true, Execute);
            var pType           = request.Type;
            var pWorkflow       = DocEntityWorkflow.Get(request.Workflow?.Id, true, Execute) ?? DocEntityWorkflow.Get(request.WorkflowId, true, Execute);
            var pArchived       = true == request.Archived;
            var pLocked         = request.Locked;

            var entity = InitEntity <DocEntityAdjudicatedRating, AdjudicatedRating>(request, permission, session);

            if (AllowPatchValue <AdjudicatedRating, bool>(request, DocConstantModelName.ADJUDICATEDRATING, pArchived, permission, nameof(request.Archived), pArchived != entity.Archived))
            {
                entity.Archived = pArchived;
            }
            if (AllowPatchValue <AdjudicatedRating, DocEntityUser>(request, DocConstantModelName.ADJUDICATEDRATING, pAssignee, permission, nameof(request.Assignee), pAssignee != entity.Assignee))
            {
                entity.Assignee = pAssignee;
            }
            if (AllowPatchValue <AdjudicatedRating, string>(request, DocConstantModelName.ADJUDICATEDRATING, pData, permission, nameof(request.Data), pData != entity.Data))
            {
                entity.Data = pData;
            }
            if (AllowPatchValue <AdjudicatedRating, string>(request, DocConstantModelName.ADJUDICATEDRATING, pDescription, permission, nameof(request.Description), pDescription != entity.Description))
            {
                entity.Description = pDescription;
            }
            if (AllowPatchValue <AdjudicatedRating, DocEntityDocument>(request, DocConstantModelName.ADJUDICATEDRATING, pDocument, permission, nameof(request.Document), pDocument != entity.Document))
            {
                entity.Document = pDocument;
            }
            if (AllowPatchValue <AdjudicatedRating, DateTime?>(request, DocConstantModelName.ADJUDICATEDRATING, pDueDate, permission, nameof(request.DueDate), pDueDate != entity.DueDate))
            {
                entity.DueDate = pDueDate;
            }
            if (AllowPatchValue <AdjudicatedRating, RatingEnm?>(request, DocConstantModelName.ADJUDICATEDRATING, pRating, permission, nameof(request.Rating), pRating != entity.Rating))
            {
                if (null != pRating)
                {
                    entity.Rating = pRating.Value;
                }
            }
            if (AllowPatchValue <AdjudicatedRating, ReasonRejectedEnm?>(request, DocConstantModelName.ADJUDICATEDRATING, pReasonRejected, permission, nameof(request.ReasonRejected), pReasonRejected != entity.ReasonRejected))
            {
                entity.ReasonRejected = pReasonRejected;
            }
            if (AllowPatchValue <AdjudicatedRating, DocEntityUser>(request, DocConstantModelName.ADJUDICATEDRATING, pReporter, permission, nameof(request.Reporter), pReporter != entity.Reporter))
            {
                entity.Reporter = pReporter;
            }
            if (AllowPatchValue <AdjudicatedRating, TaskTypeEnm?>(request, DocConstantModelName.ADJUDICATEDRATING, pType, permission, nameof(request.Type), pType != entity.Type))
            {
                if (null != pType)
                {
                    entity.Type = pType.Value;
                }
            }
            if (AllowPatchValue <AdjudicatedRating, DocEntityWorkflow>(request, DocConstantModelName.ADJUDICATEDRATING, pWorkflow, permission, nameof(request.Workflow), pWorkflow != entity.Workflow))
            {
                entity.Workflow = pWorkflow;
            }
            if (request.Locked && AllowPatchValue <AdjudicatedRating, bool>(request, DocConstantModelName.ADJUDICATEDRATING, pArchived, permission, nameof(request.Locked), pLocked != entity.Locked))
            {
                entity.Archived = pArchived;
            }
            entity.SaveChanges(permission);

            var idsToInvalidate = new List <int>();

            if (idsToInvalidate.Any())
            {
                idsToInvalidate.Add(entity.Id);
                DocCacheClient.RemoveByEntityIds(idsToInvalidate);
                DocCacheClient.RemoveSearch(DocConstantModelName.ADJUDICATEDRATING);
            }

            entity.SaveChanges(permission);
            DocPermissionFactory.SetSelect <AdjudicatedRating>(currentUser, nameof(AdjudicatedRating), request.Select);
            ret = entity.ToDto();

            var cacheExpires = DocResources.Metadata.GetCacheExpiration(DocConstantModelName.ADJUDICATEDRATING);

            DocCacheClient.Set(key: cacheKey, value: ret, entityId: request.Id, entityType: DocConstantModelName.ADJUDICATEDRATING, cacheExpires);

            return(ret);
        }
Esempio n. 8
0
 public object Get(AdjudicatedRating request) => GetEntityWithCache <AdjudicatedRating>(DocConstantModelName.ADJUDICATEDRATING, request, GetAdjudicatedRating);