mirror of
https://github.com/wiremock/WireMock.Net.git
synced 2026-01-16 00:23:35 +01:00
* Create WireMock.Net.MimePart project * . * REFACTOR * ILRepack * -- * ... * x * x * . * fix * public class MimePartMatcher * shared * min * . * <!--<DelaySign>true</DelaySign>--> * Update README.md Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
76 lines
3.4 KiB
C#
76 lines
3.4 KiB
C#
// Copyright © WireMock.Net
|
|
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Net;
|
|
using System.Net.Http;
|
|
using System.Threading.Tasks;
|
|
using WireMock.Util;
|
|
|
|
namespace WireMock.Http;
|
|
|
|
internal static class HttpResponseMessageHelper
|
|
{
|
|
public static async Task<ResponseMessage> CreateAsync(
|
|
HttpResponseMessage httpResponseMessage,
|
|
Uri requiredUri,
|
|
Uri originalUri,
|
|
bool deserializeJson,
|
|
bool decompressGzipAndDeflate,
|
|
bool deserializeFormUrlEncoded)
|
|
{
|
|
var responseMessage = new ResponseMessage { StatusCode = (int)httpResponseMessage.StatusCode };
|
|
|
|
// Set both content and response headers, replacing URLs in values
|
|
var headers = (httpResponseMessage.Content?.Headers.Union(httpResponseMessage.Headers) ?? Enumerable.Empty<KeyValuePair<string, IEnumerable<string>>>()).ToArray();
|
|
if (httpResponseMessage.Content != null)
|
|
{
|
|
var stream = await httpResponseMessage.Content.ReadAsStreamAsync().ConfigureAwait(false);
|
|
IEnumerable<string>? contentTypeHeader = null;
|
|
if (headers.Any(header => string.Equals(header.Key, HttpKnownHeaderNames.ContentType, StringComparison.OrdinalIgnoreCase)))
|
|
{
|
|
contentTypeHeader = headers.First(header => string.Equals(header.Key, HttpKnownHeaderNames.ContentType, StringComparison.OrdinalIgnoreCase)).Value;
|
|
}
|
|
|
|
IEnumerable<string>? contentEncodingHeader = null;
|
|
if (headers.Any(header => string.Equals(header.Key, HttpKnownHeaderNames.ContentEncoding, StringComparison.OrdinalIgnoreCase)))
|
|
{
|
|
contentEncodingHeader = headers.First(header => string.Equals(header.Key, HttpKnownHeaderNames.ContentEncoding, StringComparison.OrdinalIgnoreCase)).Value;
|
|
}
|
|
|
|
if (httpResponseMessage.StatusCode != HttpStatusCode.NoContent) // A body is not allowed for 204.
|
|
{
|
|
var bodyParserSettings = new BodyParserSettings
|
|
{
|
|
Stream = stream,
|
|
ContentType = contentTypeHeader?.FirstOrDefault(),
|
|
DeserializeJson = deserializeJson,
|
|
ContentEncoding = contentEncodingHeader?.FirstOrDefault(),
|
|
DecompressGZipAndDeflate = decompressGzipAndDeflate,
|
|
DeserializeFormUrlEncoded = deserializeFormUrlEncoded
|
|
};
|
|
responseMessage.BodyData = await BodyParser.ParseAsync(bodyParserSettings).ConfigureAwait(false);
|
|
}
|
|
}
|
|
|
|
foreach (var header in headers)
|
|
{
|
|
// If Location header contains absolute redirect URL, and base URL is one that we proxy to,
|
|
// we need to replace it to original one.
|
|
if (string.Equals(header.Key, HttpKnownHeaderNames.Location, StringComparison.OrdinalIgnoreCase)
|
|
&& Uri.TryCreate(header.Value.First(), UriKind.Absolute, out var absoluteLocationUri)
|
|
&& string.Equals(absoluteLocationUri.Host, requiredUri.Host, StringComparison.OrdinalIgnoreCase))
|
|
{
|
|
var replacedLocationUri = new Uri(originalUri, absoluteLocationUri.PathAndQuery);
|
|
responseMessage.AddHeader(header.Key, replacedLocationUri.ToString());
|
|
}
|
|
else
|
|
{
|
|
responseMessage.AddHeader(header.Key, header.Value.ToArray());
|
|
}
|
|
}
|
|
|
|
return responseMessage;
|
|
}
|
|
} |