Skip to content

Commit 1c9caba

Browse files
Use encoded filename for FileNameStar (#2117) (#2123)
* Use encoded filename for FileNameStar (#2117) * Remove the "fix" and add a test that shows it working * Update the docs * Fix the CsvHelper new version
1 parent 6197f31 commit 1c9caba

File tree

13 files changed

+85
-57
lines changed

13 files changed

+85
-57
lines changed

benchmarks/RestSharp.Benchmarks/RestSharp.Benchmarks.csproj

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -9,7 +9,7 @@
99

1010
<ItemGroup>
1111
<PackageReference Include="AutoFixture" Version="4.18.0" />
12-
<PackageReference Include="BenchmarkDotNet" Version="0.13.5" />
12+
<PackageReference Include="BenchmarkDotNet" Version="0.13.7" />
1313
<PackageReference Include="Microsoft.CodeAnalysis.CSharp" Version="4.6.0" />
1414
</ItemGroup>
1515
<ItemGroup>

docs/usage.md

Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -561,6 +561,22 @@ AddFile(parameterName, getFile, fileName, contentType);
561561

562562
Remember that `AddFile` will set all the necessary headers, so please don't try to set content headers manually.
563563

564+
You can also provide file upload options to the `AddFile` call. The options are:
565+
- `DisableFilenameEncoding` (default `false`): if set to `true`, RestSharp will not encode the file name in the `Content-Disposition` header
566+
- `DisableFilenameStar` (default `true`): if set to `true`, RestSharp will not add the `filename*` parameter to the `Content-Disposition` header
567+
568+
Example of using the options:
569+
570+
```csharp
571+
var options = new FileParameterOptions {
572+
DisableFilenameEncoding = true,
573+
DisableFilenameStar = false
574+
};
575+
request.AddFile("file", filePath, options: options);
576+
```
577+
578+
The options specified in the snippet above usually help when you upload files with non-ASCII characters in their names.
579+
564580
### Downloading binary data
565581

566582
There are two functions that allow you to download binary data from the remote API.

props/Common.props

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,4 +7,7 @@
77
<ImplicitUsings>enable</ImplicitUsings>
88
<Nullable>enable</Nullable>
99
</PropertyGroup>
10+
<ItemGroup>
11+
<Using Include="System.Net.Http"/>
12+
</ItemGroup>
1013
</Project>

src/Directory.Build.props

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -21,7 +21,7 @@
2121
<ItemGroup>
2222
<PackageReference Include="Microsoft.SourceLink.GitHub" Version="1.1.1" PrivateAssets="All"/>
2323
<PackageReference Include="MinVer" Version="4.3.0" PrivateAssets="All"/>
24-
<PackageReference Include="JetBrains.Annotations" Version="2022.3.1" PrivateAssets="All"/>
24+
<PackageReference Include="JetBrains.Annotations" Version="2023.2.0" PrivateAssets="All"/>
2525
</ItemGroup>
2626
<ItemGroup>
2727
<None Include="$(RepoRoot)\restsharp.png" Pack="true" PackagePath="\"/>

src/RestSharp.Serializers.CsvHelper/CsvHelperSerializer.cs

Lines changed: 1 addition & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -84,19 +84,7 @@ public class CsvHelperSerializer : IDeserializer, IRestSerializer, ISerializer {
8484
using var csvWriter = new CsvWriter(stringWriter, _configuration);
8585

8686
if (obj is IEnumerable records) {
87-
// ReSharper disable once PossibleMultipleEnumeration
88-
var enumerator = records.GetEnumerator();
89-
90-
if (enumerator.MoveNext() && enumerator.Current != null) {
91-
csvWriter.WriteHeader(enumerator.Current.GetType());
92-
csvWriter.NextRecord();
93-
// ReSharper disable once PossibleMultipleEnumeration
94-
csvWriter.WriteRecords(records);
95-
}
96-
97-
if (enumerator is IDisposable disposable) {
98-
disposable.Dispose();
99-
}
87+
csvWriter.WriteRecords(records);
10088
}
10189
else {
10290
csvWriter.WriteHeader(obj.GetType());

src/RestSharp.Serializers.CsvHelper/RestSharp.Serializers.CsvHelper.csproj

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,6 @@
11
<Project Sdk="Microsoft.NET.Sdk">
22
<ItemGroup>
3-
<PackageReference Include="CsvHelper" Version="28.0.1"/>
3+
<PackageReference Include="CsvHelper" Version="30.0.1" />
44
</ItemGroup>
55
<ItemGroup>
66
<ProjectReference Include="..\RestSharp\RestSharp.csproj"/>

src/RestSharp/Parameters/FileParameter.cs

Lines changed: 6 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -113,6 +113,11 @@ public static FileParameter FromFile(
113113

114114
[PublicAPI]
115115
public class FileParameterOptions {
116-
public bool DisableFileNameStar { get; set; } = true;
116+
[Obsolete("Use DisableFilenameStar instead")]
117+
public bool DisableFileNameStar {
118+
get => DisableFilenameStar;
119+
set => DisableFilenameStar = value;
120+
}
121+
public bool DisableFilenameStar { get; set; } = true;
117122
public bool DisableFilenameEncoding { get; set; }
118123
}

test/Directory.Build.props

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -9,14 +9,14 @@
99
</PropertyGroup>
1010

1111
<ItemGroup Condition="$(IsTestProject) == 'true'">
12-
<PackageReference Include="Microsoft.NET.Test.Sdk" Version="17.6.3"/>
13-
<PackageReference Include="xunit.runner.visualstudio" Version="2.4.5" PrivateAssets="All"/>
12+
<PackageReference Include="Microsoft.NET.Test.Sdk" Version="17.7.0"/>
13+
<PackageReference Include="xunit.runner.visualstudio" Version="2.5.0" PrivateAssets="All"/>
1414
<PackageReference Include="coverlet.collector" Version="6.0.0"/>
1515
</ItemGroup>
1616
<ItemGroup>
17-
<PackageReference Include="xunit" Version="2.4.2"/>
17+
<PackageReference Include="xunit" Version="2.5.0"/>
1818
<PackageReference Include="AutoFixture" Version="4.18.0"/>
19-
<PackageReference Include="FluentAssertions" Version="6.10.0"/>
19+
<PackageReference Include="FluentAssertions" Version="6.11.0"/>
2020
</ItemGroup>
2121
<ItemGroup Condition="$(TargetFramework) == 'net472'">
2222
<PackageReference Include="Microsoft.NETFramework.ReferenceAssemblies.net472" Version="1.0.3" PrivateAssets="All"/>

test/RestSharp.Tests.Integrated/RestSharp.Tests.Integrated.csproj

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -16,7 +16,7 @@
1616
</ItemGroup>
1717
<ItemGroup>
1818
<PackageReference Include="HttpTracer" Version="2.1.1" />
19-
<PackageReference Include="Microsoft.AspNetCore.TestHost" Version="6.0.19" />
19+
<PackageReference Include="Microsoft.AspNetCore.TestHost" Version="6.0.21" />
2020
<PackageReference Include="Polly" Version="7.2.4" />
2121
<PackageReference Include="Xunit.Extensions.Logging" Version="1.1.0" />
2222
</ItemGroup>

test/RestSharp.Tests.Integrated/Server/Handlers/FileHandlers.cs

Lines changed: 15 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -10,17 +10,27 @@ public class UploadController : ControllerBase {
1010
[HttpPost]
1111
[Route("upload")]
1212
[SuppressMessage("Performance", "CA1822:Mark members as static")]
13-
public async Task<UploadResponse> Upload([FromForm] FormFile formFile) {
13+
public async Task<IActionResult> Upload([FromForm] FormFile formFile, [FromQuery] bool checkFile = true) {
14+
var file = formFile.File;
15+
16+
if (!checkFile) {
17+
return Ok(new UploadResponse(file.FileName, file.Length, true));
18+
}
19+
1420
var assetPath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "Assets");
15-
var file = formFile.File;
1621

1722
await using var stream = file.OpenReadStream();
1823

1924
var received = await stream.ReadAsBytes(default);
20-
var expected = await System.IO.File.ReadAllBytesAsync(Path.Combine(assetPath, file.FileName));
2125

22-
var response = new UploadResponse(file.FileName, file.Length, received.SequenceEqual(expected));
23-
return response;
26+
try {
27+
var expected = await System.IO.File.ReadAllBytesAsync(Path.Combine(assetPath, file.FileName));
28+
var response = new UploadResponse(file.FileName, file.Length, received.SequenceEqual(expected));
29+
return Ok(response);
30+
}
31+
catch (Exception e) {
32+
return BadRequest(new { Message = e.Message, Filename = file.FileName });
33+
}
2434
}
2535
}
2636

0 commit comments

Comments
 (0)