* Rename Umbraco.Core namespace to Umbraco.Cms.Core * Move extension methods in core project to Umbraco.Extensions * Move extension methods in core project to Umbraco.Extensions * Rename Umbraco.Examine namespace to Umbraco.Cms.Examine * Move examine extensions to Umbraco.Extensions namespace * Reflect changed namespaces in Builder and fix unit tests * Adjust namespace in Umbraco.ModelsBuilder.Embedded * Adjust namespace in Umbraco.Persistence.SqlCe * Adjust namespace in Umbraco.PublishedCache.NuCache * Align namespaces in Umbraco.Web.BackOffice * Align namespaces in Umbraco.Web.Common * Ensure that SqlCeSupport is still enabled after changing the namespace * Align namespaces in Umbraco.Web.Website * Align namespaces in Umbraco.Web.UI.NetCore * Align namespaces in Umbraco.Tests.Common * Align namespaces in Umbraco.Tests.UnitTests * Align namespaces in Umbraco.Tests.Integration * Fix errors caused by changed namespaces * Fix integration tests * Undo the Umbraco.Examine.Lucene namespace change This breaks integration tests on linux, since the namespace wont exists there because it's only used on windows. * Fix merge * Fix Merge
55 lines
2.2 KiB
C#
55 lines
2.2 KiB
C#
// Copyright (c) Umbraco.
|
|
// See LICENSE for more details.
|
|
|
|
using System;
|
|
using System.Linq;
|
|
using System.Threading.Tasks;
|
|
using Microsoft.AspNetCore.Authorization;
|
|
using Umbraco.Cms.Core.Security;
|
|
using Umbraco.Cms.Core.Services;
|
|
using Umbraco.Extensions;
|
|
|
|
namespace Umbraco.Cms.Web.BackOffice.Authorization
|
|
{
|
|
/// <summary>
|
|
/// Ensures that the current user has access to the section for which the specified tree(s) belongs
|
|
/// </summary>
|
|
/// <remarks>
|
|
/// This would allow a tree to be moved between sections.
|
|
/// The user only needs access to one of the trees specified, not all of the trees.
|
|
/// </remarks>
|
|
public class TreeHandler : MustSatisfyRequirementAuthorizationHandler<TreeRequirement>
|
|
{
|
|
private readonly ITreeService _treeService;
|
|
private readonly IBackOfficeSecurityAccessor _backOfficeSecurityAccessor;
|
|
|
|
/// <summary>
|
|
/// Initializes a new instance of the <see cref="TreeHandler"/> class.
|
|
/// </summary>
|
|
/// <param name="treeService">Service for section tree operations.</param>
|
|
/// <param name="backOfficeSecurityAccessor">Accessor for back-office security.</param>
|
|
public TreeHandler(ITreeService treeService, IBackOfficeSecurityAccessor backOfficeSecurityAccessor)
|
|
{
|
|
_treeService = treeService ?? throw new ArgumentNullException(nameof(treeService));
|
|
_backOfficeSecurityAccessor = backOfficeSecurityAccessor ?? throw new ArgumentNullException(nameof(backOfficeSecurityAccessor));
|
|
}
|
|
|
|
/// <inheritdoc/>
|
|
protected override Task<bool> IsAuthorized(AuthorizationHandlerContext context, TreeRequirement requirement)
|
|
{
|
|
var apps = requirement.TreeAliases
|
|
.Select(x => _treeService.GetByAlias(x))
|
|
.WhereNotNull()
|
|
.Select(x => x.SectionAlias)
|
|
.Distinct()
|
|
.ToArray();
|
|
|
|
var isAuth = _backOfficeSecurityAccessor.BackOfficeSecurity.CurrentUser != null &&
|
|
apps.Any(app => _backOfficeSecurityAccessor.BackOfficeSecurity.UserHasSectionAccess(
|
|
app, _backOfficeSecurityAccessor.BackOfficeSecurity.CurrentUser));
|
|
|
|
return Task.FromResult(isAuth);
|
|
}
|
|
}
|
|
}
|