EdjCase.ICP.ClientGenerator
3.0.1
There is a newer version of this package available.
See the version list below for details.
See the version list below for details.
dotnet tool install --global EdjCase.ICP.ClientGenerator --version 3.0.1
This package contains a .NET tool you can call from the shell/command line.
dotnet new tool-manifest # if you are setting up this repo dotnet tool install --local EdjCase.ICP.ClientGenerator --version 3.0.1
This package contains a .NET tool you can call from the shell/command line.
#tool dotnet:?package=EdjCase.ICP.ClientGenerator&version=3.0.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
nuke :add-package EdjCase.ICP.ClientGenerator --version 3.0.1
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
Client Generator
- Library of generating C# client code from *.did files
- Nuget:
EdjCase.ICP.ClientGenerator
Usage (dotnet tool)
Install with dotnet tools
dotnet tool install -g EdjCase.ICP.ClientGenerator
Run tool
(First run only) Initialize config file and update generated file
candid-client-generator init ./
Creates candid-client.toml
file to update in specified directory
Example:
namespace = "My.Namespace" # Base namespace used for generated files
output-directory = "./Clients" # Directory to put clients. Each client will get its own sub folder based on its name. If not specified, will use current directory
no-folders = false # If true, will put all the files in a single directory
[[clients]]
name = "Dex" # Used for the name of the folder and client class
type = "file" # Create client based on service definition file
file-path = "./ServiceDefinitionFiles/Dex.did" # Service definition file path
output-directory = "./Clients/D" # Override base output directory, but this specifies the subfolder
no-folders = false # If true, will put all the files in a single directory
# Can specify multiple clients by defining another
[[clients]]
name = "Governance"
type = "canister" # Create client based on canister
canister-id = "rrkah-fqaaa-aaaaa-aaaaq-cai" # Canister to create client for
Generate clients
candid-client-generator ./
or
candid-client-generator gen ./
Config file options
Top Level:
namespace
- (Text) REQUIRED. The base namespace used in all C# files generated. Files generated in a sub-folder will have a more specific namespace to match. This namespace can be overidden per client.output-directory
- (Text) OPTIONAL. Directory to put all generated files. Each client will have a sub-folder within the output directory that will match the client name. If not specified, the working directory will be usedno-folders
- (Bool) OPTIONAL. If true, no sub-folders will be generated for the clients or the models within the clients. All generated files will be in a flat structure. Defaults to falseurl
- (Text) OPTIONAL. Sets the boundry node url to use for making calls to canisters on the IC. Can be set to a local developer instance/localhost. Defaults to 'https://ic0.app/'. This setting is only useful for clients of generation typecanister
feature-nullable
- (Bool) Optional. Sets whether to use the C# nullable feature when generating the client (likeobject?
). Defaults to truekeep-candid-case
- (Bool) Optional. If true, the names of properties and methods will keep the raw candid name. Otherwise they will be converted to something prettier. Defaults to false
Client Level:
name
- (Text) REQUIRED. The name of the sub-folder put the client files and the prefix to the client class name.type
- (Text) REQUIRED. An enum value to indicate what type of client generation method to use. Each enum value also has associated configuration settings. Options:file
- Will create a client based on a service definition file (*.did
)file-path
- (Text) REQUIRED. The file path to the*.did
file to generate from
canister
- Creates a client based on a canister idcansiter-id
- (Text) REQUIRED. The principal id of the canister to generate a client for
output-directory
- (Text) OPTIONAL. Directory to put all generated client files. Overrides the top leveloutput-directory
. NOTE: this does not create a sub-folder based on the client name like the top leveloutput-directory
doesno-folders
- (Bool) OPTIONAL. If true, no sub-folders will be generated for the client. All generated files will be in a flat structure. Defaults to false. Overrides the top levelno-folders
feature-nullable
- (Bool) Optional. Sets whether to use the C# nullable feature when generating the client (likeobject?
). Defaults to true. Overrides the top levelfeature-nullable
keep-candid-case
- (Bool) Optional. If true, the names of properties and methods will keep the raw candid name. Otherwise they will be converted to something prettier. Defaults to false. Overrides the top levelkeep-candid-case
Custom Client Generators via Code
Due to the complexity of different use cases, custom tweaks to the output of the client generators might be helpful. This process
can be handled with calling the ClientCodeGenerator
manually and using the .NET CSharpSyntaxRewriter
(tutorial can be found HERE)
var options = new ClientGenerationOptions(
name: "MyClient",
@namespace: "My.Namespace",
noFolders: false,
featureNullable: true,
keepCandidCase: false
);
ClientSyntax syntax = await ClientCodeGenerator.GenerateClientFromCanisterAsync(canisterId, options);
var rewriter = new MyCustomCSharpSyntaxRewriter();
syntax = syntax.Rewrite(rewriter);
(string clientFile, List<(string Name, string Contents)> typeFiles) = syntax.GenerateFileContents();
// Write string contents to files...
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | 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 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. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
This package has no dependencies.
Version | Downloads | Last updated |
---|---|---|
7.0.0 | 50 | 1/15/2025 |
7.0.0-rc.1 | 82 | 1/4/2025 |
7.0.0-pre.1 | 67 | 10/27/2024 |
6.2.1 | 172 | 10/23/2024 |
6.2.0 | 127 | 10/21/2024 |
6.1.2 | 167 | 4/30/2024 |
6.1.1 | 141 | 4/17/2024 |
6.1.0 | 185 | 4/15/2024 |
6.0.0 | 239 | 3/21/2024 |
5.1.0 | 249 | 1/25/2024 |
5.0.0 | 309 | 1/12/2024 |
5.0.0-pre.2 | 207 | 12/13/2023 |
5.0.0-pre.1 | 119 | 12/11/2023 |
4.1.0 | 485 | 11/10/2023 |
4.0.1 | 521 | 11/1/2023 |
4.0.0 | 462 | 10/12/2023 |
4.0.0-pre.10 | 160 | 10/10/2023 |
4.0.0-pre.9 | 145 | 10/10/2023 |
4.0.0-pre.8 | 155 | 10/9/2023 |
4.0.0-pre.7 | 139 | 10/9/2023 |
4.0.0-pre.6 | 178 | 10/9/2023 |
4.0.0-pre.5 | 174 | 10/8/2023 |
4.0.0-pre.4 | 165 | 10/6/2023 |
4.0.0-pre.3 | 134 | 10/5/2023 |
4.0.0-pre.2 | 143 | 9/27/2023 |
4.0.0-pre.1 | 157 | 9/25/2023 |
3.2.2 | 548 | 9/22/2023 |
3.2.1 | 524 | 9/22/2023 |
3.2.0 | 436 | 8/2/2023 |
3.1.5 | 553 | 9/27/2023 |
3.1.4 | 402 | 7/20/2023 |
3.1.3 | 323 | 6/12/2023 |
3.1.2 | 412 | 5/11/2023 |
3.1.1 | 393 | 5/9/2023 |
3.1.0 | 343 | 5/9/2023 |
3.0.1 | 258 | 5/2/2023 |
3.0.0 | 307 | 5/1/2023 |
3.0.0-beta.1 | 153 | 4/17/2023 |
2.3.9 | 233 | 5/1/2023 |
2.3.8 | 261 | 4/28/2023 |
2.3.7 | 261 | 4/28/2023 |
2.3.6 | 222 | 4/28/2023 |
2.3.5 | 247 | 4/27/2023 |
2.3.4 | 242 | 4/27/2023 |
2.3.3 | 245 | 4/26/2023 |
2.3.2 | 262 | 4/26/2023 |
2.3.1 | 285 | 4/26/2023 |
2.3.0 | 307 | 4/25/2023 |
2.2.10 | 249 | 4/24/2023 |
2.2.9 | 277 | 4/24/2023 |
2.2.8 | 263 | 4/24/2023 |
2.2.7 | 278 | 4/17/2023 |
2.2.6 | 314 | 4/12/2023 |
2.2.5 | 308 | 4/12/2023 |
2.2.4 | 300 | 4/11/2023 |
2.2.3 | 307 | 4/11/2023 |
2.2.2 | 327 | 4/7/2023 |
2.2.1 | 335 | 4/7/2023 |
2.2.0 | 325 | 4/6/2023 |
2.1.1 | 331 | 3/30/2023 |
2.1.0 | 359 | 3/23/2023 |
2.0.8 | 396 | 3/20/2023 |
2.0.7 | 334 | 3/12/2023 |
2.0.2 | 371 | 3/10/2023 |
2.0.1 | 358 | 3/10/2023 |
2.0.0 | 342 | 3/8/2023 |
2.0.0-beta.26 | 155 | 3/8/2023 |
2.0.0-beta.25 | 153 | 3/8/2023 |
2.0.0-beta.24 | 137 | 3/7/2023 |
2.0.0-beta.23 | 144 | 3/6/2023 |
2.0.0-beta.22 | 141 | 3/1/2023 |
2.0.0-beta.21 | 149 | 2/28/2023 |
2.0.0-beta.20 | 149 | 2/20/2023 |
2.0.0-beta.19 | 150 | 2/14/2023 |
2.0.0-beta.18 | 146 | 2/14/2023 |
2.0.0-beta.17 | 141 | 2/14/2023 |
2.0.0-beta.16 | 145 | 2/11/2023 |
2.0.0-beta.15 | 152 | 2/10/2023 |
2.0.0-beta.14 | 140 | 2/6/2023 |
2.0.0-beta.13 | 147 | 2/3/2023 |
2.0.0-beta.12 | 155 | 2/2/2023 |
2.0.0-beta.11 | 151 | 1/30/2023 |
2.0.0-beta.10 | 148 | 1/23/2023 |
2.0.0-beta.9 | 144 | 1/19/2023 |
2.0.0-beta.7 | 138 | 1/12/2023 |
2.0.0-beta.6 | 143 | 12/31/2022 |
2.0.0-beta.5 | 138 | 12/30/2022 |
2.0.0-beta.4 | 134 | 12/21/2022 |
2.0.0-beta.3 | 146 | 12/19/2022 |
2.0.0-beta.2 | 132 | 12/10/2022 |
2.0.0-beta.1 | 144 | 12/2/2022 |
1.2.1 | 451 | 11/29/2022 |
1.2.0 | 400 | 11/28/2022 |
1.1.0 | 412 | 11/28/2022 |
1.0.3 | 434 | 11/25/2022 |
1.0.2 | 555 | 6/8/2022 |
1.0.1 | 534 | 6/7/2022 |
0.0.1-beta.20 | 172 | 6/1/2022 |
0.0.1-beta.19 | 177 | 5/20/2022 |
0.0.1-beta.14 | 177 | 5/19/2022 |