mirror of
https://github.com/Prowlarr/Prowlarr
synced 2026-01-20 14:42:07 +01:00
Fixed: Form data encoding for non-UTF8 indexers
This commit is contained in:
parent
0884ac92ff
commit
878818e950
7 changed files with 78 additions and 1 deletions
|
|
@ -1,4 +1,5 @@
|
|||
using System;
|
||||
using System.Text;
|
||||
using FluentAssertions;
|
||||
using NUnit.Framework;
|
||||
using NzbDrone.Common.Http;
|
||||
|
|
@ -9,6 +10,12 @@ namespace NzbDrone.Common.Test.Http
|
|||
[TestFixture]
|
||||
public class HttpRequestBuilderFixture : TestBase
|
||||
{
|
||||
[OneTimeSetUp]
|
||||
public void RegisterEncodingProvider()
|
||||
{
|
||||
Encoding.RegisterProvider(CodePagesEncodingProvider.Instance);
|
||||
}
|
||||
|
||||
[TestCase("http://host/{seg}/some", "http://host/dir/some")]
|
||||
[TestCase("http://host/some/{seg}", "http://host/some/dir")]
|
||||
public void should_add_single_segment_url_segments(string url, string result)
|
||||
|
|
@ -36,5 +43,70 @@ public void should_remove_duplicated_slashes()
|
|||
|
||||
request.Url.FullUri.Should().Be("http://domain/v1/");
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void should_encode_form_parameters_with_utf8_by_default()
|
||||
{
|
||||
var builder = new HttpRequestBuilder("http://domain/login")
|
||||
.Post()
|
||||
.AddFormParameter("username", "Привет");
|
||||
|
||||
var request = builder.Build();
|
||||
var body = Encoding.UTF8.GetString(request.ContentData);
|
||||
|
||||
// UTF-8 encoding: Привет = %D0%9F%D1%80%D0%B8%D0%B2%D0%B5%D1%82
|
||||
body.Should().Contain("username=%D0%9F%D1%80%D0%B8%D0%B2%D0%B5%D1%82");
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void should_encode_form_parameters_with_windows_1251_for_cyrillic()
|
||||
{
|
||||
var windows1251 = Encoding.GetEncoding("windows-1251");
|
||||
|
||||
var builder = new HttpRequestBuilder("http://domain/login")
|
||||
.Post()
|
||||
.SetEncoding(windows1251)
|
||||
.AddFormParameter("username", "Привет");
|
||||
|
||||
var request = builder.Build();
|
||||
var body = windows1251.GetString(request.ContentData);
|
||||
|
||||
// Windows-1251 encoding: Привет = %CF%F0%E8%E2%E5%F2
|
||||
body.Should().Contain("username=%CF%F0%E8%E2%E5%F2");
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void should_encode_form_parameters_with_iso_8859_1_for_extended_latin()
|
||||
{
|
||||
var iso88591 = Encoding.GetEncoding("iso-8859-1");
|
||||
|
||||
var builder = new HttpRequestBuilder("http://domain/login")
|
||||
.Post()
|
||||
.SetEncoding(iso88591)
|
||||
.AddFormParameter("username", "café");
|
||||
|
||||
var request = builder.Build();
|
||||
var body = iso88591.GetString(request.ContentData);
|
||||
|
||||
// ISO-8859-1 encoding: é = %E9
|
||||
body.Should().Contain("username=caf%E9");
|
||||
}
|
||||
|
||||
[Test]
|
||||
public void should_encode_form_parameters_ascii_same_regardless_of_encoding()
|
||||
{
|
||||
var windows1251 = Encoding.GetEncoding("windows-1251");
|
||||
|
||||
var builder = new HttpRequestBuilder("http://domain/login")
|
||||
.Post()
|
||||
.SetEncoding(windows1251)
|
||||
.AddFormParameter("username", "testuser")
|
||||
.AddFormParameter("password", "pass123");
|
||||
|
||||
var request = builder.Build();
|
||||
var body = windows1251.GetString(request.ContentData);
|
||||
|
||||
body.Should().Be("username=testuser&password=pass123");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
|||
|
|
@ -231,7 +231,7 @@ protected virtual void ApplyFormData(HttpRequest request)
|
|||
}
|
||||
else
|
||||
{
|
||||
var parameters = FormData.Select(v => string.Format("{0}={1}", v.Name, Uri.EscapeDataString(Encoding.GetString(v.ContentData))));
|
||||
var parameters = FormData.Select(v => string.Format("{0}={1}", v.Name, Encoding.GetString(v.ContentData).UrlEncode(Encoding)));
|
||||
var urlencoded = string.Join("&", parameters);
|
||||
var body = Encoding.GetBytes(urlencoded);
|
||||
|
||||
|
|
|
|||
|
|
@ -58,6 +58,7 @@ protected override async Task DoLogin()
|
|||
};
|
||||
|
||||
var authLoginRequest = requestBuilder
|
||||
.SetEncoding(Encoding)
|
||||
.AddFormParameter("username", Settings.Username)
|
||||
.AddFormParameter("password", Settings.Password)
|
||||
.AddFormParameter("returnto", "")
|
||||
|
|
|
|||
|
|
@ -57,6 +57,7 @@ protected override async Task DoLogin()
|
|||
};
|
||||
|
||||
var authLoginRequest = requestBuilder
|
||||
.SetEncoding(Encoding)
|
||||
.AddFormParameter("login_username", Settings.Username)
|
||||
.AddFormParameter("login_password", Settings.Password)
|
||||
.AddFormParameter("login", "Login")
|
||||
|
|
|
|||
|
|
@ -66,6 +66,7 @@ protected override async Task DoLogin()
|
|||
};
|
||||
|
||||
var authLoginRequest = requestBuilder
|
||||
.SetEncoding(Encoding)
|
||||
.SetCookies(loginPage.GetCookies())
|
||||
.AddFormParameter("username", Settings.Username)
|
||||
.AddFormParameter("password", Settings.Password)
|
||||
|
|
|
|||
|
|
@ -91,6 +91,7 @@ protected override async Task DoLogin()
|
|||
Cookies = null;
|
||||
|
||||
var authLoginRequest = requestBuilder.Post()
|
||||
.SetEncoding(Encoding)
|
||||
.AddFormParameter("login_username", Settings.Username)
|
||||
.AddFormParameter("login_password", Settings.Password)
|
||||
.AddFormParameter("login", "Login")
|
||||
|
|
|
|||
|
|
@ -58,6 +58,7 @@ protected override async Task DoLogin()
|
|||
Cookies = null;
|
||||
|
||||
var authLoginRequest = requestBuilder
|
||||
.SetEncoding(Encoding)
|
||||
.AddFormParameter("username", Settings.Username)
|
||||
.AddFormParameter("password", Settings.Password)
|
||||
.AddFormParameter("returnto", "/")
|
||||
|
|
|
|||
Loading…
Reference in a new issue