EdjCase.ICP.Candid 0.0.1-beta.13

This is a prerelease version of EdjCase.ICP.Candid.
There is a newer version of this package available.
See the version list below for details.
dotnet add package EdjCase.ICP.Candid --version 0.0.1-beta.13                
NuGet\Install-Package EdjCase.ICP.Candid -Version 0.0.1-beta.13                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="EdjCase.ICP.Candid" Version="0.0.1-beta.13" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add EdjCase.ICP.Candid --version 0.0.1-beta.13                
#r "nuget: EdjCase.ICP.Candid, 0.0.1-beta.13"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install EdjCase.ICP.Candid as a Cake Addin
#addin nuget:?package=EdjCase.ICP.Candid&version=0.0.1-beta.13&prerelease

// Install EdjCase.ICP.Candid as a Cake Tool
#tool nuget:?package=EdjCase.ICP.Candid&version=0.0.1-beta.13&prerelease                

ICP.NET

Collection of Internet Computer Protocol (ICP) libraries for .NET/Blazor

  • Agent

    • Library to communicate to and from the Internet Computer
    • Nuget: EdjCase.ICP.Agent (*currently only pre-release versions are available)
  • Candid

    • Library of Candid Encoding, Models and Helpers
    • Nuget: EdjCase.ICP.Candid (*currently only pre-release versions are available)
  • Samples

    • A few projects to demo the capabilities of the ICP libraries
      • Blazor
      • AspNetCore
      • CLI

Roadmap/TODO

  • Serialization for custom C# models
  • Automatic Api Client/Model generation from Candid spec
  • Infer type from value, vs specifying value + type
  • DID file parsing

Agent

Usage

// Create identity
var identity = new AnonymousIdentity();

// Create http agent
IAgent agent = new HttpAgent(identity);

// Create Candid arg to send in request
CandidArg arg = CandidArg.FromCandid(
    CandidValueWithType.FromValueAndType( // WIP, will reduce redundancy
        CandidPrimitive.Nat64(1234),
        new PrimitiveCandidTypeDefinition(CandidPrimitiveType.Nat64)
    )
);

// Make request to IC
string method = "get_proposal_info";
Principal governanceCanisterId = Principal.FromText("rrkah-fqaaa-aaaaa-aaaaq-cai");
QueryResponse response = await agent.QueryAsync(governanceCanisterId, method, arg);

QueryReply reply = response.ThrowOrGetReply();

CandidArg responseArg = reply.Arg;
// Use response ...

Candid

Parse from bytes

CandidArg arg = CandidArg.FromBytes(rawCandidBytes);

Reading candid values directly

CandidArg arg = CandidArg.FromBytes(rawCandidBytes);
CandidValue firstArg = arg.Values[0];
string title = firstArg.AsRecord()["title"];

Converting candid to custom classes

(custom serialization doesn't exist yet but is on the roadmap)

CandidArg arg = CandidArg.FromBytes(rawCandidBytes);
MyObj obj = arg.Values[0].Value.AsRecord(r => new MyObj
{
    Title = r["title"].AsText(),
    IsGoodTitle = r["is_good_title"].AsBool()
});

public class MyObj
{
    public string Title { get; set; }
    public bool IsGoodTitle { get; set; }
}

Parse from Text

* DID file formats are currently not supported

string text = "record { field_1:nat64; field_2: vec nat8 }";
CandidRecordType type = CandidTextParser.Parse<CandidRecordType>(text);

Generate Text representation

var type = new CandidRecordType(new Dictionary<CandidTag, CandidType>
{
    {
        CandidTag.FromName("field_1"),
        new CandidPrimitiveType(PrimitiveType.Nat64)
    },
    {
        CandidTag.FromName("field_2"),
        new CandidVectorType(new CandidPrimitiveType(PrimitiveType.Nat8))
    }
});
string text = CandidTextGenerator.Generator(type, IndentType.Tab);
Product 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (3)

Showing the top 3 NuGet packages that depend on EdjCase.ICP.Candid:

Package Downloads
EdjCase.ICP.Agent

Package Description

EdjCase.ICP.InternetIdentity

Package Description

Qwer.Chains.Dfinity.Clients

Package Description

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
7.0.0-pre.1 122 10/27/2024
6.2.1 141 10/23/2024
6.2.0 134 10/21/2024
6.1.2 1,637 4/30/2024
6.1.1 193 4/17/2024
6.1.0 188 4/15/2024
6.0.0 206 3/21/2024
5.1.0 293 1/25/2024
5.0.0 1,224 1/12/2024
5.0.0-pre.2 126 12/13/2023
5.0.0-pre.1 78 12/11/2023
4.1.0 516 11/10/2023
4.0.1 294 11/1/2023
4.0.0 418 10/12/2023
4.0.0-pre.10 89 10/10/2023
4.0.0-pre.9 83 10/10/2023
4.0.0-pre.8 89 10/9/2023
4.0.0-pre.7 86 10/9/2023
4.0.0-pre.6 83 10/9/2023
4.0.0-pre.5 83 10/8/2023
4.0.0-pre.4 92 10/6/2023
4.0.0-pre.3 80 10/5/2023
4.0.0-pre.2 86 9/27/2023
4.0.0-pre.1 82 9/25/2023
3.2.2 537 9/22/2023
3.2.1 231 9/22/2023
3.2.0 829 8/2/2023
3.1.5 250 9/27/2023
3.1.4 394 7/20/2023
3.1.3 774 6/12/2023
3.1.2 1,263 5/11/2023
3.1.1 425 5/9/2023
3.1.0 340 5/9/2023
3.0.1 360 5/2/2023
3.0.0 346 5/1/2023
3.0.0-beta.1 118 4/17/2023
2.3.9 321 5/1/2023
2.3.8 359 4/28/2023
2.3.7 342 4/28/2023
2.3.6 351 4/28/2023
2.3.5 402 4/27/2023
2.3.4 372 4/27/2023
2.3.3 387 4/26/2023
2.3.2 369 4/26/2023
2.3.1 513 4/26/2023
2.3.0 402 4/25/2023
2.2.10 401 4/24/2023
2.2.9 359 4/24/2023
2.2.8 406 4/24/2023
2.2.7 618 4/17/2023
2.2.6 707 4/12/2023
2.2.5 405 4/12/2023
2.2.4 496 4/11/2023
2.2.3 414 4/11/2023
2.2.2 487 4/7/2023
2.2.1 429 4/7/2023
2.2.0 463 4/6/2023
2.1.1 602 3/30/2023
2.1.0 712 3/23/2023
2.0.8 543 3/20/2023
2.0.7 611 3/12/2023
2.0.6 295 3/12/2023
2.0.5 273 3/12/2023
2.0.4 303 3/12/2023
2.0.3 290 3/12/2023
2.0.2 521 3/10/2023
2.0.1 513 3/10/2023
2.0.0 549 3/8/2023
2.0.0-beta.26 123 3/8/2023
2.0.0-beta.25 121 3/8/2023
2.0.0-beta.24 129 3/7/2023
2.0.0-beta.23 125 3/6/2023
2.0.0-beta.22 123 3/1/2023
2.0.0-beta.21 123 2/28/2023
2.0.0-beta.20 139 2/20/2023
2.0.0-beta.19 129 2/14/2023
2.0.0-beta.18 127 2/14/2023
2.0.0-beta.17 131 2/14/2023
2.0.0-beta.16 130 2/11/2023
2.0.0-beta.15 135 2/10/2023
2.0.0-beta.14 139 2/6/2023
2.0.0-beta.13 139 2/3/2023
2.0.0-beta.12 147 2/2/2023
2.0.0-beta.11 153 1/30/2023
2.0.0-beta.10 145 1/23/2023
2.0.0-beta.9 154 1/19/2023
2.0.0-beta.8 141 1/19/2023
2.0.0-beta.7 153 1/12/2023
2.0.0-beta.6 147 12/31/2022
2.0.0-beta.5 136 12/30/2022
2.0.0-beta.4 142 12/21/2022
2.0.0-beta.3 140 12/19/2022
2.0.0-beta.2 141 12/10/2022
2.0.0-beta.1 143 12/2/2022
1.2.1 707 11/29/2022
1.2.0 645 11/28/2022
1.1.0 670 11/28/2022
1.0.3 658 11/25/2022
1.0.2 830 6/8/2022
1.0.1 866 6/7/2022
0.0.1-beta.20 176 6/1/2022
0.0.1-beta.19 174 5/20/2022
0.0.1-beta.18 168 5/20/2022
0.0.1-beta.14 182 5/19/2022
0.0.1-beta.13 176 5/18/2022
0.0.1-beta.2 206 5/16/2022
0.0.1-beta.1 188 5/11/2022