Skip to content

Commit 6f9fb9d

Browse files
Merge branch 'support/1.1.x'
2 parents 25662ea + d05a4e0 commit 6f9fb9d

File tree

1 file changed

+11
-4
lines changed

1 file changed

+11
-4
lines changed

src/Umbraco.StorageProviders/CdnMediaUrlProvider.cs

Lines changed: 11 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -5,6 +5,7 @@
55
using Umbraco.Cms.Core.Models.PublishedContent;
66
using Umbraco.Cms.Core.PropertyEditors;
77
using Umbraco.Cms.Core.Routing;
8+
using Umbraco.Extensions;
89

910
namespace Umbraco.StorageProviders
1011
{
@@ -38,7 +39,7 @@ public CdnMediaUrlProvider(IOptionsMonitor<CdnMediaUrlProviderOptions> options,
3839

3940
_cdnUrl = options.CurrentValue.Url;
4041
_removeMediaFromPath = options.CurrentValue.RemoveMediaFromPath;
41-
_mediaPath = hostingEnvironment.ToAbsolute(globalSettings.CurrentValue.UmbracoMediaPath).TrimEnd('/');
42+
_mediaPath = hostingEnvironment.ToAbsolute(globalSettings.CurrentValue.UmbracoMediaPath).EnsureEndsWith('/');
4243

4344
options.OnChange((options, name) =>
4445
{
@@ -53,7 +54,7 @@ public CdnMediaUrlProvider(IOptionsMonitor<CdnMediaUrlProviderOptions> options,
5354
{
5455
if (name == Options.DefaultName)
5556
{
56-
_mediaPath = hostingEnvironment.ToAbsolute(options.UmbracoMediaPath).TrimEnd('/');
57+
_mediaPath = hostingEnvironment.ToAbsolute(options.UmbracoMediaPath).EnsureEndsWith('/');
5758
}
5859
});
5960
}
@@ -65,12 +66,18 @@ public CdnMediaUrlProvider(IOptionsMonitor<CdnMediaUrlProviderOptions> options,
6566
if (mediaUrl?.IsUrl == true)
6667
{
6768
string url = mediaUrl.Text;
69+
70+
int startIndex = 0;
6871
if (_removeMediaFromPath && url.StartsWith(_mediaPath, StringComparison.OrdinalIgnoreCase))
6972
{
70-
url = url[_mediaPath.Length..];
73+
startIndex = _mediaPath.Length;
74+
}
75+
else if (url.StartsWith('/'))
76+
{
77+
startIndex = 1;
7178
}
7279

73-
return UrlInfo.Url(_cdnUrl + url, culture);
80+
return UrlInfo.Url(_cdnUrl + url[startIndex..], culture);
7481
}
7582

7683
return mediaUrl;

0 commit comments

Comments
 (0)