FSharp.HotChocolate
0.1.0
See the version list below for details.
dotnet add package FSharp.HotChocolate --version 0.1.0
NuGet\Install-Package FSharp.HotChocolate -Version 0.1.0
<PackageReference Include="FSharp.HotChocolate" Version="0.1.0" />
paket add FSharp.HotChocolate --version 0.1.0
#r "nuget: FSharp.HotChocolate, 0.1.0"
// Install FSharp.HotChocolate as a Cake Addin #addin nuget:?package=FSharp.HotChocolate&version=0.1.0 // Install FSharp.HotChocolate as a Cake Tool #tool nuget:?package=FSharp.HotChocolate&version=0.1.0
FSharp.HotChocolate
Support for F# types and nullability in HotChocolate.
Quick start
- Remove any existing calls to
AddFSharpTypeConverters
orAddTypeConverter<OptionTypeConverter>
. - Call
AddFSharpSupport
:.AddGraphQLServer().AddFSharpSupport()
Features
Idiomatic F# nullability through Option<_>
All fields defined in F# (including HotChocolate type extensions for types not defined in F#) will have idiomatic F#
nullability applied. This means that everything except Option
-wrapped values will be non-nullable (!
) in the GraphQL
schema. Any usages of [<GraphQLNonNullType>]
, or NonNullType<_>
in [<GraphQLType>]
, will be ignored.
Opting out of F# nullability
Due to limitations (see below) or other reasons, you may want to opt out of F# nullability for a certain scope. You can
apply the SkipFSharpNullability
attribute to parameters, members, types (including HotChocolate type extensions), or
whole assemblies to disable F# nullability processing for that scope.
Limitations in F# nullability
- When using global object identification,
Option
-wrapped node resolvers are not supported (#5). - When using global object identification,
Option
-wrappedID
values inside lists are not supported (#6). - Support for
ValueOption<_>
is not yet added (#10).
Async<_>
fields
Fields can now be Async<_>
.
The computations are automatically wired up to the RequestAborted
cancellation token. If you do not want that, please
convert the Async<_>
to Task<_>
yourself as you see fit.
Limitations in Async<_>
fields
- When using some built-in middleware such as
[<UsePaging>]
,Async<_>
is not supported for that field. (#8). - When using global object identification,
Async<_>
is not supported for node resolvers (#9).
Acknowledgements
Many thanks to @Stock44 for creating this gist that sparked this project. Without that, I'd have no idea where to even begin.
Deployment checklist
For maintainers.
- Make necessary changes to the code
- Update the changelog
- Update the version and release notes in the fsproj files
- Commit and tag the commit in the format
v/x.y.z
(this is what triggers deployment) - Push the changes and the tag to the repo. If the build succeeds, the package is automatically published to NuGet.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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 was computed. 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. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.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 was computed. |
.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 (>= 8.0.100)
- HotChocolate.AspNetCore (>= 14.0.0-rc.2)
- HotChocolate.Types.CursorPagination (>= 14.0.0-rc.2)
- HotChocolate.Types.FSharp (>= 14.0.0-rc.2)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
0.1.13 | 8,119 | 11/22/2024 |
0.1.13-hc15-001 | 46 | 11/22/2024 |
0.1.10 | 202 | 11/18/2024 |
0.1.10-hc15-001 | 40 | 11/18/2024 |
0.1.9 | 717 | 10/19/2024 |
0.1.9-hc15-001 | 76 | 10/19/2024 |
0.1.8 | 267 | 9/25/2024 |
0.1.7 | 88 | 9/25/2024 |
0.1.6 | 61 | 9/25/2024 |
0.1.5 | 57 | 9/25/2024 |
0.1.4 | 62 | 9/24/2024 |
0.1.3 | 72 | 9/23/2024 |
0.1.2 | 67 | 9/23/2024 |
0.1.1 | 64 | 9/23/2024 |
0.1.0 | 67 | 9/23/2024 |