Example #1
0
        private TermSynonym GetTermSynonym(TermSynonym request)
        {
            var         id    = request?.Id;
            TermSynonym ret   = null;
            var         query = DocQuery.ActiveQuery ?? Execute;

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

            DocEntityTermSynonym entity = null;

            if (id.HasValue)
            {
                entity = DocEntityTermSynonym.Get(id.Value);
            }
            if (null == entity)
            {
                throw new HttpError(HttpStatusCode.NotFound, $"No TermSynonym 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);
        }
Example #2
0
        public TermSynonym Post(TermSynonym request)
        {
            if (request == null)
            {
                throw new HttpError(HttpStatusCode.NotFound, "Request cannot be null.");
            }

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

            TermSynonym ret = null;

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

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

                    var en = DocEntityTermSynonym.Get(request?.Id);
                    if (null == en)
                    {
                        throw new HttpError(HttpStatusCode.NotFound, $"No TermSynonym 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.TERMSYNONYM);
                    DocCacheClient.RemoveById(request.Id);
                });
            }
        }
Example #4
0
        public TermSynonym Post(TermSynonymCopy request)
        {
            TermSynonym ret = null;

            using (Execute)
            {
                Execute.Run(ssn =>
                {
                    var entity = DocEntityTermSynonym.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 pApproved  = entity.Approved;
                    var pBindings  = entity.Bindings.ToList();
                    var pMaster    = entity.Master;
                    var pPreferred = entity.Preferred;
                    var pScope     = entity.Scope;
                    var pSynonym   = entity.Synonym;
                    if (!DocTools.IsNullOrEmpty(pSynonym))
                    {
                        pSynonym += " (Copy)";
                    }
                    var copy = new DocEntityTermSynonym(ssn)
                    {
                        Hash        = Guid.NewGuid()
                        , Approved  = pApproved
                        , Master    = pMaster
                        , Preferred = pPreferred
                        , Scope     = pScope
                        , Synonym   = pSynonym
                    };
                    foreach (var item in pBindings)
                    {
                        entity.Bindings.Add(item);
                    }

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

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

            TermSynonym ret = null;

            using (Execute)
            {
                Execute.Run(ssn =>
                {
                    ret = _AssignValues(request, DocConstantPermission.EDIT, ssn);
                });
            }
            return(ret);
        }
Example #6
0
 public TermSynonym Put(TermSynonym request)
 {
     return(Patch(request));
 }
Example #7
0
        private TermSynonym _AssignValues(TermSynonym 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, "TermSynonym"))
            {
                throw new HttpError(HttpStatusCode.Forbidden, "You do not have ADD permission for this route.");
            }

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

            TermSynonym ret = null;

            request = _InitAssignValues <TermSynonym>(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 <TermSynonym>(DocConstantModelName.TERMSYNONYM, nameof(TermSynonym), request);

            //First, assign all the variables, do database lookups and conversions
            var pApproved  = request.Approved;
            var pBindings  = GetVariable <Reference>(request, nameof(request.Bindings), request.Bindings?.ToList(), request.BindingsIds?.ToList());
            var pMaster    = DocEntityTermMaster.Get(request.Master?.Id, true, Execute) ?? DocEntityTermMaster.Get(request.MasterId, true, Execute);
            var pPreferred = request.Preferred;
            var pScope     = DocEntityScope.Get(request.Scope?.Id, true, Execute) ?? DocEntityScope.Get(request.ScopeId, true, Execute);
            var pSynonym   = request.Synonym;
            var pArchived  = true == request.Archived;
            var pLocked    = request.Locked;

            var entity = InitEntity <DocEntityTermSynonym, TermSynonym>(request, permission, session);

            if (AllowPatchValue <TermSynonym, bool>(request, DocConstantModelName.TERMSYNONYM, pArchived, permission, nameof(request.Archived), pArchived != entity.Archived))
            {
                entity.Archived = pArchived;
            }
            if (AllowPatchValue <TermSynonym, bool>(request, DocConstantModelName.TERMSYNONYM, pApproved, permission, nameof(request.Approved), pApproved != entity.Approved))
            {
                entity.Approved = pApproved;
            }
            if (AllowPatchValue <TermSynonym, DocEntityTermMaster>(request, DocConstantModelName.TERMSYNONYM, pMaster, permission, nameof(request.Master), pMaster != entity.Master))
            {
                entity.Master = pMaster;
            }
            if (AllowPatchValue <TermSynonym, bool>(request, DocConstantModelName.TERMSYNONYM, pPreferred, permission, nameof(request.Preferred), pPreferred != entity.Preferred))
            {
                entity.Preferred = pPreferred;
            }
            if (AllowPatchValue <TermSynonym, DocEntityScope>(request, DocConstantModelName.TERMSYNONYM, pScope, permission, nameof(request.Scope), pScope != entity.Scope))
            {
                entity.Scope = pScope;
            }
            if (AllowPatchValue <TermSynonym, string>(request, DocConstantModelName.TERMSYNONYM, pSynonym, permission, nameof(request.Synonym), pSynonym != entity.Synonym))
            {
                entity.Synonym = pSynonym;
            }
            if (request.Locked && AllowPatchValue <TermSynonym, bool>(request, DocConstantModelName.TERMSYNONYM, pArchived, permission, nameof(request.Locked), pLocked != entity.Locked))
            {
                entity.Archived = pArchived;
            }
            entity.SaveChanges(permission);

            var idsToInvalidate = new List <int>();

            idsToInvalidate.AddRange(PatchCollection <TermSynonym, DocEntityTermSynonym, Reference, DocEntityLookupTableBinding>(request, entity, pBindings, permission, nameof(request.Bindings)));
            if (idsToInvalidate.Any())
            {
                idsToInvalidate.Add(entity.Id);
                DocCacheClient.RemoveByEntityIds(idsToInvalidate);
                DocCacheClient.RemoveSearch(DocConstantModelName.TERMSYNONYM);
            }

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

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

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

            return(ret);
        }
Example #8
0
 public object Get(TermSynonym request) => GetEntityWithCache <TermSynonym>(DocConstantModelName.TERMSYNONYM, request, GetTermSynonym);