FsHttp 12.0.0
See the version list below for details.
dotnet add package FsHttp --version 12.0.0
NuGet\Install-Package FsHttp -Version 12.0.0
<PackageReference Include="FsHttp" Version="12.0.0" />
paket add FsHttp --version 12.0.0
#r "nuget: FsHttp, 12.0.0"
// Install FsHttp as a Cake Addin #addin nuget:?package=FsHttp&version=12.0.0 // Install FsHttp as a Cake Tool #tool nuget:?package=FsHttp&version=12.0.0
<p align="center"> <img src='./docs/img/logo_big.png' alt='logo' width='300' /> </p>
FsHttp is a .Net HTTP client library for C# and F#. It aims for describing and executing HTTP requests in convenient ways that can be used in production and interactive environments.
The design principle behind FsHttp is:
Specify common HTTP requests in a most convenient and readable way, while still being able to access the underlying .Net Http representations for covering unusual cases.
FsHttp is developed and maintained by @ronaldschlenker and @dawedawe. Feel free to leave us a message.
Sponsoring
Want to help keep FsHttp alive? Then help keep F# and its ecosystem alive by supporting one of the following developers:
- @edgarfgp. Why? E.g. for "Amplifying F#", for bringing people together, for his support and his work in the F# community.
- @TheAngryByrd. Why? E.g. for maintaining Ionidem and many, many more.
- @AngelMunoz. Why? E.g. for his work in Fable (The F# to JS compiler), his passion and support.
- @dawedawe and @nojaf. Why? E.g. for Fantomas and their support in the F# community.
- @PawelStadnicki. Why? E.g. for his attempt to push F# forward in data science.
For sure, there are many more. If you think someone should appear on that list, leave us a message!
A Simple Example
An example in F#:
#r "nuget: FsHttp"
open FsHttp
http {
POST "https://reqres.in/api/users"
CacheControl "no-cache"
body
jsonSerialize
{|
name = "morpheus"
job = "leader"
|}
}
|> Request.send
An example in C#:
#r "nuget: FsHttp"
using FsHttp.CSharp;
await "https://reqres.in/api/users".Post()
.CacheControl("no-cache")
.Body()
.JsonSerialize(new
{
name = "morpheus",
job = "leader"
}
)
.SendAsync();
Documentation
- ๐ Please see FsHttp Documentation site for a detailed documentation.
- ๐งช In addition, have a look at the Integration Tests that show various library details.
Release Notes / Migrating to new versions
- See https://www.nuget.org/packages/FsHttp#release-body-tab
- For different upgrade paths, please read the Migrations section in the docu.
GitHub
Please see FsHttp on GitHub.
Building
.Net SDK:
You need to have the latest .Net SDK installed, which is specified in ./global.json
.
Build Tasks
There is a F# build script (./build.fsx
) that can be used to perform several build tasks from command line.
For common tasks, there are powershell files located in the repo root:
./test.ps1
: Runs all tests (sources in./src/Tests
).- You can pass args to this task. E.g. for executing only some tests:
./test.ps1 --filter Name~'Response Decompression'
- You can pass args to this task. E.g. for executing only some tests:
./docu.ps1
: Rebuilds the FsHttp documentation site (sources in./src/docs
; output goes to./docs
)../docu-watch.ps1
: Run it if you are working on the documentation sources, and want to see the result in a browser../publish.ps1
: Publishes all packages (FsHttp and it's integration packages for Newtonsoft and FSharp.Data) to NuGet.- Always have a look at
./src/Directory.Build.props
and keep the file up-to-date.
- Always have a look at
Credits
- Parts of the code is taken from the HTTP utilities of FSharp.Data.
- Credits to all critics, supporters, contributors, promoters, users, and friends.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 is compatible. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- FSharp.Core (>= 5.0.0)
- System.Text.Json (>= 5.0.0)
-
.NETStandard 2.1
- FSharp.Core (>= 5.0.0)
- System.Text.Json (>= 5.0.0)
-
net6.0
- FSharp.Core (>= 5.0.0)
-
net7.0
- FSharp.Core (>= 5.0.0)
NuGet packages (13)
Showing the top 5 NuGet packages that depend on FsHttp:
Package | Downloads |
---|---|
Functional.SplinterBots.API
Package Description |
|
FsHttp.FSharpData
FSharp.Data (JSON) integration package for FsHttp |
|
FsHttp.NewtonsoftJson
JSON.Net (Newtonsoft.Json) integration package for FsHttp |
|
Swate.Api
Dotnet library for easy access to Swate API. |
|
AVPRIndex
Type system and utils for the indexing backend of avpr.nfdi4plants.org |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
15.0.1 | 2,257 | 12/3/2024 |
14.5.2 | 122 | 12/3/2024 |
14.5.1 | 106,425 | 8/9/2024 |
14.5.0 | 157,070 | 3/5/2024 |
14.4.2 | 312 | 3/5/2024 |
14.4.1 | 73,146 | 2/5/2024 |
14.4.0 | 79,186 | 1/7/2024 |
14.2.0 | 837 | 1/5/2024 |
14.1.0 | 792 | 1/3/2024 |
14.0.0 | 633 | 1/2/2024 |
13.3.0 | 13,020 | 12/28/2023 |
13.2.0 | 617 | 12/28/2023 |
12.2.0-preview01 | 654 | 12/24/2023 |
12.1.0 | 2,870 | 11/27/2023 |
12.0.0 | 51,688 | 10/31/2023 |
11.0.0 | 49,769 | 8/5/2023 |
11.0.0-preview01 | 1,284 | 3/25/2023 |
10.0.0 | 196,481 | 11/25/2022 |
10.0.0-preview3 | 905 | 11/23/2022 |
10.0.0-preview2 | 1,121 | 11/12/2022 |
10.0.0-preview1 | 935 | 11/12/2022 |
9.1.2 | 32,354 | 6/5/2022 |
9.1.1 | 3,584 | 4/24/2022 |
9.1.0 | 1,740 | 4/19/2022 |
9.0.6 | 1,782 | 4/19/2022 |
9.0.5 | 1,787 | 4/14/2022 |
9.0.4 | 1,539 | 4/8/2022 |
9.0.3 | 1,422 | 4/8/2022 |
9.0.2 | 3,873 | 4/6/2022 |
9.0.1 | 1,342 | 4/5/2022 |
9.0.0 | 13,858 | 4/5/2022 |
8.0.1 | 8,426 | 3/6/2022 |
8.0.0 | 1,189 | 3/2/2022 |
7.0.0 | 41,975 | 12/13/2021 |
6.0.1 | 2,371 | 11/23/2021 |
6.0.0 | 1,019 | 11/22/2021 |
0.9.0 | 1,951 | 7/14/2019 |
v12.0.0
- 137: Change the type for FsHttpUrl.additionalQueryParams from obj to string
- Removed (auto opened) Async.await and Task.map/await
- Moved (auto opened) Async.map to FsHttp.Helper.Async.map
v11.1.0
- 130: Add method for user-supplied cancellation token
v11.0.0
- #121 (Breaking change): Turning off debug logs in FSI (breaking change in signature / namespace)
- #124: Support Repeating Query Parameters (thanks @DaveJohnson8080)
- #106 (Breaking change): Allow filename metadata with other "parts" (thanks @dawedawe)
- Breaking change: ContentTypeForPart custom operations should come after part definition
- #104 (Breaking change): Automatic GZip response decompression per Default
- Other breaking changes:
- Removed `ContentTypeWithEncoding` and used optional `charset` parameter in `ContentType` overloads.
- Renamed `byteArray` to `binary` in Dsl, DslCE and CSharp.
- Caution (!!): Renamed `stringPart` to `textPart` and changed argument order for `name` and `value` in Dsl and DslCE.
- Restructured types in Domain
- `Helper` is a module instead of a namespace, and some things were moved.
- All transformers in config are a list of transformers instead of a single item.
- Removed `setHttpClient`. Please use `setHttpClientFactory` instead.
- `setHttpClientFactory` takes a `Config` as input argument.
-----------------------------
-- Old release notes below --
-----------------------------
v7.0.0
- #92: `expect` and `assert` pass through the original response instead of unit.
v8.0.0
- #93 (thanks @drhumlen): Changed content type 'text/json' to 'application/json'.
- Http modules are always AutoOpen in both Dsl and DslCE.
- No extra modules for builder methods.
v8.0.1
- #89: No more blocking requests using net5 with FSI.
v9.0.0 / v9.0.1
- Redefined builders (see README.md).
- Many breaking changes (see "Migrations" sections in the docu).
v9.0.2
- Added JSON toArray functions
- Fixed #99: Response.saveFile should create the directory if not present.
v9.0.3
- Supporting netstandard2.1 again.
v9.0.4
- Referenced lowest possible FSharp.Core and other referenced packages version.
v9.0.5
- Support for netstandard2.0.
- New 'FsHttp.NewtonsoftJson' integration package.
- More JSON functions and defaults config.
v9.0.6
- #100 - Removed FSI print messages.
v9.1.0
- Fixed naming inconsistency for 'Response.deserialize...' functions.
- More C# JSON functions.
v9.1.1
- Fix: Using GlobalConfig.Json.defaultJsonSerializerOptions as default for jsonSerialize.
v9.1.2
- Fixed #103: FSI response printing and initialization doesn't work out of the box anymore.
v10.0.0
- .Net 7 support (thank you @Samuel-Dufour)
- Breaking change: Corrected typo "guessMineTypeFromPath" -> "guessMimeTypeFromPath"
- Breaking change: Module 'Helper', 'HelperInternal' and 'HelperAutos' refactored
- #115: Remove print messages when downloading streams
- Printing: Separate print functions for response and request via Request.print and Response.print
- Printing: Default request (IToRequest) printing in FSI
- Removed net5.0 targets in all projects
- PrintHint.printDebugMessages: Moved to FsHttp.Helper.Fsi.logDebugMessages as a global switch
- #113 - Config.timeoutInSeconds bug
v10.1.0
- #117: Escape string for query params values (by @maciej-izak - thank you)
(!!) This can be seen as breaking change.
- #112: Allow to add (multiple) headers (by @Samuel-Dufour - thank you)