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

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

            DocEntityTermCategory entity = null;

            if (id.HasValue)
            {
                entity = DocEntityTermCategory.Get(id.Value);
            }
            if (null == entity)
            {
                throw new HttpError(HttpStatusCode.NotFound, $"No TermCategory 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 void Delete(TermCategory request)
        {
            using (Execute)
            {
                Execute.Run(ssn =>
                {
                    if (!(request?.Id > 0))
                    {
                        throw new HttpError(HttpStatusCode.NotFound, $"No Id provided for delete.");
                    }

                    var en = DocEntityTermCategory.Get(request?.Id);
                    if (null == en)
                    {
                        throw new HttpError(HttpStatusCode.NotFound, $"No TermCategory 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.TERMCATEGORY);
                    DocCacheClient.RemoveById(request.Id);
                });
            }
        }
Esempio n. 3
0
        public TermCategory Post(TermCategoryCopy request)
        {
            TermCategory ret = null;

            using (Execute)
            {
                Execute.Run(ssn =>
                {
                    var entity = DocEntityTermCategory.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 pName           = entity.Name;
                    var pParentCategory = entity.ParentCategory;
                    var pScope          = entity.Scope;
                    var pTerms          = entity.Terms.ToList();
                    var copy            = new DocEntityTermCategory(ssn)
                    {
                        Hash             = Guid.NewGuid()
                        , Name           = pName
                        , ParentCategory = pParentCategory
                        , Scope          = pScope
                    };
                    foreach (var item in pTerms)
                    {
                        entity.Terms.Add(item);
                    }

                    copy.SaveChanges(DocConstantPermission.ADD);
                    ret = copy.ToDto();
                });
            }
            return(ret);
        }
Esempio n. 4
0
        private TermCategory _AssignValues(TermCategory 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, "TermCategory"))
            {
                throw new HttpError(HttpStatusCode.Forbidden, "You do not have ADD permission for this route.");
            }

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

            TermCategory ret = null;

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

            //First, assign all the variables, do database lookups and conversions
            DocEntityLookupTable pName = GetLookup(DocConstantLookupTable.TERMCATEGORY, request.Name?.Name, request.Name?.Id);
            var pParentCategory        = DocEntityTermCategory.Get(request.ParentCategory?.Id, true, Execute) ?? DocEntityTermCategory.Get(request.ParentCategoryId, true, Execute);
            var pScope    = DocEntityScope.Get(request.Scope?.Id, true, Execute) ?? DocEntityScope.Get(request.ScopeId, true, Execute);
            var pTerms    = GetVariable <Reference>(request, nameof(request.Terms), request.Terms?.ToList(), request.TermsIds?.ToList());
            var pArchived = true == request.Archived;
            var pLocked   = request.Locked;

            var entity = InitEntity <DocEntityTermCategory, TermCategory>(request, permission, session);

            if (AllowPatchValue <TermCategory, bool>(request, DocConstantModelName.TERMCATEGORY, pArchived, permission, nameof(request.Archived), pArchived != entity.Archived))
            {
                entity.Archived = pArchived;
            }
            if (AllowPatchValue <TermCategory, DocEntityLookupTable>(request, DocConstantModelName.TERMCATEGORY, pName, permission, nameof(request.Name), pName != entity.Name))
            {
                entity.Name = pName;
            }
            if (AllowPatchValue <TermCategory, DocEntityTermCategory>(request, DocConstantModelName.TERMCATEGORY, pParentCategory, permission, nameof(request.ParentCategory), pParentCategory != entity.ParentCategory))
            {
                entity.ParentCategory = pParentCategory;
            }
            if (AllowPatchValue <TermCategory, DocEntityScope>(request, DocConstantModelName.TERMCATEGORY, pScope, permission, nameof(request.Scope), pScope != entity.Scope))
            {
                entity.Scope = pScope;
            }
            if (request.Locked && AllowPatchValue <TermCategory, bool>(request, DocConstantModelName.TERMCATEGORY, pArchived, permission, nameof(request.Locked), pLocked != entity.Locked))
            {
                entity.Archived = pArchived;
            }
            entity.SaveChanges(permission);

            var idsToInvalidate = new List <int>();

            idsToInvalidate.AddRange(PatchCollection <TermCategory, DocEntityTermCategory, Reference, DocEntityTermMaster>(request, entity, pTerms, permission, nameof(request.Terms)));
            if (idsToInvalidate.Any())
            {
                idsToInvalidate.Add(entity.Id);
                DocCacheClient.RemoveByEntityIds(idsToInvalidate);
                DocCacheClient.RemoveSearch(DocConstantModelName.TERMCATEGORY);
            }

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

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

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

            return(ret);
        }