* 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
112 lines
3.9 KiB
C#
112 lines
3.9 KiB
C#
using System.IO;
|
|
using System.Net;
|
|
using System.Text;
|
|
using System.Threading.Tasks;
|
|
using Microsoft.AspNetCore.Http;
|
|
using Microsoft.Extensions.DependencyInjection;
|
|
using Umbraco.Cms.Core.Routing;
|
|
|
|
namespace Umbraco.Extensions
|
|
{
|
|
/// <summary>
|
|
/// Extension methods for <see cref="HttpRequest"/>
|
|
/// </summary>
|
|
public static class HttpRequestExtensions
|
|
{
|
|
/// <summary>
|
|
/// Check if a preview cookie exist
|
|
/// </summary>
|
|
public static bool HasPreviewCookie(this HttpRequest request)
|
|
=> request.Cookies.TryGetValue(Cms.Core.Constants.Web.PreviewCookieName, out var cookieVal) && !cookieVal.IsNullOrWhiteSpace();
|
|
|
|
/// <summary>
|
|
/// Returns true if the request is a back office request
|
|
/// </summary>
|
|
public static bool IsBackOfficeRequest(this HttpRequest request)
|
|
{
|
|
PathString absPath = request.Path;
|
|
UmbracoRequestPaths umbReqPaths = request.HttpContext.RequestServices.GetService<UmbracoRequestPaths>();
|
|
return umbReqPaths.IsBackOfficeRequest(absPath);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Returns true if the request is for a client side extension
|
|
/// </summary>
|
|
public static bool IsClientSideRequest(this HttpRequest request)
|
|
{
|
|
PathString absPath = request.Path;
|
|
UmbracoRequestPaths umbReqPaths = request.HttpContext.RequestServices.GetService<UmbracoRequestPaths>();
|
|
return umbReqPaths.IsClientSideRequest(absPath);
|
|
}
|
|
|
|
public static string ClientCulture(this HttpRequest request)
|
|
=> request.Headers.TryGetValue("X-UMB-CULTURE", out var values) ? values[0] : null;
|
|
|
|
/// <summary>
|
|
/// Determines if a request is local.
|
|
/// </summary>
|
|
/// <returns>True if request is local</returns>
|
|
/// <remarks>
|
|
/// Hat-tip: https://stackoverflow.com/a/41242493/489433
|
|
/// </remarks>
|
|
public static bool IsLocal(this HttpRequest request)
|
|
{
|
|
var connection = request.HttpContext.Connection;
|
|
if (connection.RemoteIpAddress.IsSet())
|
|
{
|
|
// We have a remote address set up
|
|
return connection.LocalIpAddress.IsSet()
|
|
// Is local is same as remote, then we are local
|
|
? connection.RemoteIpAddress.Equals(connection.LocalIpAddress)
|
|
// else we are remote if the remote IP address is not a loopback address
|
|
: IPAddress.IsLoopback(connection.RemoteIpAddress);
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
private static bool IsSet(this IPAddress address)
|
|
{
|
|
const string NullIpAddress = "::1";
|
|
return address != null && address.ToString() != NullIpAddress;
|
|
}
|
|
|
|
public static string GetRawBodyString(this HttpRequest request, Encoding encoding = null)
|
|
{
|
|
if (request.Body.CanSeek)
|
|
{
|
|
request.Body.Seek(0, SeekOrigin.Begin);
|
|
}
|
|
|
|
using (var reader = new StreamReader(request.Body, encoding ?? Encoding.UTF8, leaveOpen: true))
|
|
{
|
|
var result = reader.ReadToEnd();
|
|
if (request.Body.CanSeek)
|
|
{
|
|
request.Body.Seek(0, SeekOrigin.Begin);
|
|
}
|
|
|
|
return result;
|
|
}
|
|
}
|
|
|
|
public static async Task<string> GetRawBodyStringAsync(this HttpRequest request, Encoding encoding = null)
|
|
{
|
|
if (!request.Body.CanSeek)
|
|
{
|
|
request.EnableBuffering();
|
|
}
|
|
|
|
request.Body.Seek(0, SeekOrigin.Begin);
|
|
|
|
using (var reader = new StreamReader(request.Body, encoding ?? Encoding.UTF8, leaveOpen: true))
|
|
{
|
|
var result = await reader.ReadToEndAsync();
|
|
request.Body.Seek(0, SeekOrigin.Begin);
|
|
|
|
return result;
|
|
}
|
|
}
|
|
}
|
|
}
|