diff --git a/src/Umbraco.Examine/MediaValueSetBuilder.cs b/src/Umbraco.Examine/MediaValueSetBuilder.cs
index 3839d008b3..e6e7d620d9 100644
--- a/src/Umbraco.Examine/MediaValueSetBuilder.cs
+++ b/src/Umbraco.Examine/MediaValueSetBuilder.cs
@@ -1,9 +1,12 @@
-using Examine;
+using System;
+using Examine;
using System.Collections.Generic;
using System.Linq;
+using Newtonsoft.Json;
using Umbraco.Core;
using Umbraco.Core.Models;
using Umbraco.Core.PropertyEditors;
+using Umbraco.Core.PropertyEditors.ValueConverters;
using Umbraco.Core.Services;
using Umbraco.Core.Strings;
@@ -13,14 +16,16 @@ namespace Umbraco.Examine
{
private readonly UrlSegmentProviderCollection _urlSegmentProviders;
private readonly IUserService _userService;
+ private readonly IRuntimeState _runtimeState;
public MediaValueSetBuilder(PropertyEditorCollection propertyEditors,
UrlSegmentProviderCollection urlSegmentProviders,
- IUserService userService)
+ IUserService userService, IRuntimeState runtimeState)
: base(propertyEditors, false)
{
_urlSegmentProviders = urlSegmentProviders;
_userService = userService;
+ _runtimeState = runtimeState;
}
///
@@ -29,6 +34,28 @@ namespace Umbraco.Examine
foreach (var m in media)
{
var urlValue = m.GetUrlSegment(_urlSegmentProviders);
+
+ var umbracoFilePath = string.Empty;
+ var umbracoFile = string.Empty;
+
+ var umbracoFileSource = m.GetValue(Constants.Conventions.Media.File);
+
+ if (umbracoFileSource.DetectIsJson())
+ {
+ var cropper = JsonConvert.DeserializeObject(m.GetValue(Constants.Conventions.Media.File));
+ if (cropper != null)
+ {
+ umbracoFilePath = cropper.Src;
+ }
+ }
+ else
+ {
+ umbracoFilePath = umbracoFileSource;
+ }
+
+ var uri = new Uri(_runtimeState.ApplicationUrl.GetLeftPart(UriPartial.Authority) + umbracoFilePath);
+ umbracoFile = uri.Segments.Last();
+
var values = new Dictionary>
{
{"icon", m.ContentType.Icon?.Yield() ?? Enumerable.Empty()},
@@ -44,7 +71,8 @@ namespace Umbraco.Examine
{"urlName", urlValue?.Yield() ?? Enumerable.Empty()},
{"path", m.Path?.Yield() ?? Enumerable.Empty()},
{"nodeType", m.ContentType.Id.ToString().Yield() },
- {"creatorName", (m.GetCreatorProfile(_userService)?.Name ?? "??").Yield()}
+ {"creatorName", (m.GetCreatorProfile(_userService)?.Name ?? "??").Yield()},
+ {"__umbracoFile", new object[] {umbracoFile}}
};
foreach (var property in m.Properties)
diff --git a/src/Umbraco.Tests/UmbracoExamine/IndexInitializer.cs b/src/Umbraco.Tests/UmbracoExamine/IndexInitializer.cs
index f7b1799d63..8ac9bc59ea 100644
--- a/src/Umbraco.Tests/UmbracoExamine/IndexInitializer.cs
+++ b/src/Umbraco.Tests/UmbracoExamine/IndexInitializer.cs
@@ -7,6 +7,7 @@ using Lucene.Net.Analysis;
using Lucene.Net.Analysis.Standard;
using Lucene.Net.Store;
using Moq;
+using Umbraco.Core;
using Umbraco.Core.Logging;
using Umbraco.Core.Models;
using Umbraco.Core.Models.Membership;
@@ -44,11 +45,19 @@ namespace Umbraco.Tests.UmbracoExamine
public static MediaIndexPopulator GetMediaIndexRebuilder(PropertyEditorCollection propertyEditors, IMediaService mediaService)
{
- var mediaValueSetBuilder = new MediaValueSetBuilder(propertyEditors, new UrlSegmentProviderCollection(new[] { new DefaultUrlSegmentProvider() }), GetMockUserService());
+ var mediaValueSetBuilder = new MediaValueSetBuilder(propertyEditors, new UrlSegmentProviderCollection(new[] { new DefaultUrlSegmentProvider() }), GetMockUserService(), MockRuntimeState(RuntimeLevel.Run));
var mediaIndexDataSource = new MediaIndexPopulator(null, mediaService, mediaValueSetBuilder);
return mediaIndexDataSource;
}
+ public static IRuntimeState MockRuntimeState(RuntimeLevel level)
+ {
+ var runtimeState = Mock.Of();
+ Mock.Get(runtimeState).Setup(x => x.Level).Returns(level);
+ return runtimeState;
+ }
+
+
public static IContentService GetMockContentService()
{
long longTotalRecs;
diff --git a/src/Umbraco.Web/Models/Mapping/EntityMapDefinition.cs b/src/Umbraco.Web/Models/Mapping/EntityMapDefinition.cs
index eb474e4cbe..7e88590552 100644
--- a/src/Umbraco.Web/Models/Mapping/EntityMapDefinition.cs
+++ b/src/Umbraco.Web/Models/Mapping/EntityMapDefinition.cs
@@ -180,6 +180,15 @@ namespace Umbraco.Web.Models.Mapping
target.Name = source.Values.ContainsKey("nodeName") ? source.Values["nodeName"] : "[no name]";
+ if (source.Values.ContainsKey("__umbracoFile"))
+ {
+ var umbracoFile = source.Values["__umbracoFile"];
+ if (umbracoFile != null)
+ {
+ target.Name = $"{target.Name} ({umbracoFile})";
+ }
+ }
+
if (source.Values.ContainsKey(UmbracoExamineIndex.NodeKeyFieldName))
{
if (Guid.TryParse(source.Values[UmbracoExamineIndex.NodeKeyFieldName], out var key))
diff --git a/src/Umbraco.Web/Search/UmbracoTreeSearcher.cs b/src/Umbraco.Web/Search/UmbracoTreeSearcher.cs
index c3c3dc75ce..23f13c2f33 100644
--- a/src/Umbraco.Web/Search/UmbracoTreeSearcher.cs
+++ b/src/Umbraco.Web/Search/UmbracoTreeSearcher.cs
@@ -85,6 +85,7 @@ namespace Umbraco.Web.Search
break;
case UmbracoEntityTypes.Media:
type = "media";
+ fields = new[] { "__umbracoFile" };
var allMediaStartNodes = _umbracoContext.Security.CurrentUser.CalculateMediaStartNodeIds(_entityService);
AppendPath(sb, UmbracoObjectTypes.Media, allMediaStartNodes, searchFrom, ignoreUserStartNodes, _entityService);
break;