Example #1
0
        public async Task <IActionResult> GetItems(string key)
        {
            try
            {
                var  userKey = _contextAccessor.UserKeyFromContext();
                bool userCanAccessCollection = await UserCanAccessCollection(userKey, key, _hiarcDatabase, AccessLevelGroup.ReadOnlyOrHigher);

                if (userCanAccessCollection)
                {
                    var theItems = await _hiarcDatabase.GetItemsForCollection(key);

                    return(Ok(theItems));
                }
                else
                {
                    return(StatusCode(StatusCodes.Status403Forbidden));
                }
            }
            catch (InvalidOperationException ex)
            {
                _logger.LogError(ex.Message);
                return(StatusCode(StatusCodes.Status403Forbidden));
            }
            catch (Exception ex)
            {
                return(BuildErrorResponse(ex, _logger));
            }
        }