diff --git a/src/VirtoCommerce.OrdersModule.Web/Controllers/Api/OrderModuleController.cs b/src/VirtoCommerce.OrdersModule.Web/Controllers/Api/OrderModuleController.cs index 75a2ae84..4e5dbe22 100644 --- a/src/VirtoCommerce.OrdersModule.Web/Controllers/Api/OrderModuleController.cs +++ b/src/VirtoCommerce.OrdersModule.Web/Controllers/Api/OrderModuleController.cs @@ -621,6 +621,12 @@ public async Task GetInvoicePdf(string orderNumber) throw new InvalidOperationException($"Cannot find order with number {orderNumber}"); } + var authorizationResult = await _authorizationService.AuthorizeAsync(User, order, new OrderAuthorizationRequirement(ModuleConstants.Security.Permissions.Read)); + if (!authorizationResult.Succeeded) + { + return Forbid(); + } + var notification = await _notificationSearchService.GetNotificationAsync(new TenantIdentity(order.StoreId, nameof(Store))); notification.CustomerOrder = order; notification.LanguageCode = order.LanguageCode; @@ -718,6 +724,12 @@ public ActionResult GetOrderFullTextSearchEnabled() [Route("indexed/search")] public async Task> SearchCustomerOrderIndexed([FromBody] CustomerOrderSearchCriteria criteria) { + var authorizationResult = await _authorizationService.AuthorizeAsync(User, criteria, new OrderAuthorizationRequirement(ModuleConstants.Security.Permissions.Read)); + if (!authorizationResult.Succeeded) + { + return Forbid(); + } + var result = await _indexedSearchService.SearchCustomerOrdersAsync(criteria); return Content(JsonConvert.SerializeObject(result, _outputJsonSerializerSettings), "application/json"); }