using Asp.Versioning; using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Http; using Microsoft.AspNetCore.Mvc; using Umbraco.Cms.Api.Management.Factories; using Umbraco.Cms.Api.Management.Security.Authorization.Content; using Umbraco.Cms.Api.Management.ViewModels.PublicAccess; using Umbraco.Cms.Core; using Umbraco.Cms.Core.Actions; using Umbraco.Cms.Core.Models; using Umbraco.Cms.Core.Services; using Umbraco.Cms.Core.Services.OperationStatus; using Umbraco.Cms.Web.Common.Authorization; using Umbraco.Extensions; namespace Umbraco.Cms.Api.Management.Controllers.Document; [ApiVersion("1.0")] public class UpdatePublicAccessDocumentController : DocumentControllerBase { private readonly IAuthorizationService _authorizationService; private readonly IPublicAccessPresentationFactory _publicAccessPresentationFactory; private readonly IPublicAccessService _publicAccessService; public UpdatePublicAccessDocumentController( IAuthorizationService authorizationService, IPublicAccessPresentationFactory publicAccessPresentationFactory, IPublicAccessService publicAccessService) { _authorizationService = authorizationService; _publicAccessPresentationFactory = publicAccessPresentationFactory; _publicAccessService = publicAccessService; } [HttpPut("{id:guid}/public-access")] [MapToApiVersion("1.0")] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(typeof(ProblemDetails), StatusCodes.Status404NotFound)] public async Task Update(Guid id, PublicAccessRequestModel requestModel) { AuthorizationResult authorizationResult = await _authorizationService.AuthorizeResourceAsync( User, ContentPermissionResource.WithKeys(ActionProtect.ActionLetter, id), AuthorizationPolicies.ContentPermissionByResource); if (!authorizationResult.Succeeded) { return Forbidden(); } PublicAccessEntrySlim publicAccessEntrySlim = _publicAccessPresentationFactory.CreatePublicAccessEntrySlim(requestModel, id); Attempt updateAttempt = await _publicAccessService.UpdateAsync(publicAccessEntrySlim); return updateAttempt.Success ? Ok() : PublicAccessOperationStatusResult(updateAttempt.Status); } }