LucidOcean.MultiChain
0.0.0.13
See the version list below for details.
dotnet add package LucidOcean.MultiChain --version 0.0.0.13
NuGet\Install-Package LucidOcean.MultiChain -Version 0.0.0.13
<PackageReference Include="LucidOcean.MultiChain" Version="0.0.0.13" />
paket add LucidOcean.MultiChain --version 0.0.0.13
#r "nuget: LucidOcean.MultiChain, 0.0.0.13"
// Install LucidOcean.MultiChain as a Cake Addin #addin nuget:?package=LucidOcean.MultiChain&version=0.0.0.13 // Install LucidOcean.MultiChain as a Cake Tool #tool nuget:?package=LucidOcean.MultiChain&version=0.0.0.13
LucidOcean.MultiChain Assembly
The library is an unofficial wrapper for multichain_cli JSON RPC. Refer to https://www.multichain.com/developers/json-rpc-api/ for more information on each JSON RPC call and how it is used.
Follow these instructions to create your own chain. https://www.multichain.com/developers/creating-connecting/
The Source is in Visual Studio 2022 Community Edition.
The compiled Assemblies is targeting 4.8 and Core 6.0
NUGET: https://www.nuget.org/packages/LucidOcean.MultiChain/0.0.0.11
This library divides the calls into
- MultiChainClient.Address
- MultiChainClient.Asset
- MultiChainClient.Block
- MultiChainClient.Peer
- MultiChainClient.Permission
- MultiChainClient.Transaction
- MultiChainClient.Utility
- MultiChainClient.Wallet
- MultiChainClient.Stream
Create your own chain
create https://www.multichain.com/developers/creating-connecting/
and run your test chain
NOTE: This library is only available for v1 RPC
Set up your connection
- edit your multichain.conf
- add port to your firewall
- allow your ip
example multichain.conf (use your settings)
rpcuser=multichainrpc rpcpassword=1jm2VNf2MdGK8ULQiMGg7Q4C8Jy89BJrzNJ5y9Mj7qaS rpcallowip=127.0.0.1
Get your RPC port
view in your params.dat file
default-network-port = 9265 # Default TCP/IP port for peer-to-peer connection with other nodes. default-rpc-port = 9264 # USE THIS - Default TCP/IP port for incoming JSON-RPC API requests.
example usage:
MultiChainConnection connection = new MultiChainConnection()
{
Hostname = "IP",
Port = 100,
Username = "multichainrpc",
Password = "password",
ChainName = "chain1",
BurnAddress = "address",
RootNodeAddress = "address"
};
MultiChainClient _Client = new MultiChainClient(connection);
response = _Client.Wallet.GetNewAddress();
There are sync and async versions.
Issue and Send an Asset
MultiChainConnection connection = new MultiChainConnection()
{
Hostname = "IP",
Port = 100,
Username = "multichainrpc",
Password = "password",
ChainName = "chain1",
BurnAddress = "address",
RootNodeAddress = "address"
};
MultiChainClient _Client = new MultiChainClient(connection);
JsonRpcResponse<string> response = _Client.Asset.Issue(issueAddress, assetName, quantity, units);
_Client.Asset.Send(toAddress, assetName, amount);
//Use SendAssetFrom to specify an address FROM and and address To
Using List
_Client.Asset.ListAssetsAsync(assetName,true);
Issue and Subscribe
var response = _Client.Asset.Issue(fromAddress, new { name = assetName, open = true }, 10, 1, asset);
_Client.Asset.Subscribe(response.Result, true);
MultiChain Explorer
- MultiChain explorer running on C# ASP.NET MVC 5.2.3
- Change connection details in LucidOcean.MultiChain.Explorer.Data.ExplorerSettings to connect the explorer to your node.
* This works the same as seen in example of issue and sending of an asset.
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. |
.NET Framework | net48 is compatible. net481 was computed. |
-
.NETFramework 4.8
- Microsoft.NETCore.Platforms (>= 7.0.4)
- Newtonsoft.Json (>= 13.0.3)
-
net6.0
- Microsoft.NETCore.Platforms (>= 7.0.4)
- Newtonsoft.Json (>= 13.0.3)
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.0.0.17 | 326 | 2/19/2024 |
0.0.0.14 | 129 | 2/7/2024 |
0.0.0.13 | 105 | 2/7/2024 |
0.0.0.12 | 113 | 2/6/2024 |
0.0.0.11 | 201 | 10/4/2023 |
0.0.0.10 | 2,242 | 2/22/2018 |
0.0.0.9 | 4,780 | 12/19/2017 |
0.0.0.8 | 1,272 | 11/8/2017 |
0.0.0.7 | 1,297 | 10/9/2017 |
0.0.0.6 | 985 | 10/3/2017 |
0.0.0.4 | 997 | 9/19/2017 |
0.0.0.3 | 971 | 9/15/2017 |
-- Changed build from AMD64 to x64. The build type was not specified in the cspoj so assumed the build machine cpu.
-- Listlockunspent response changed to UnspentResponse
-- ListStreamResponse "keys" changed to dynamic type to account for int and string[] (0.0.0.11 was changed from int to string[] but neglected the fact that arrays come back as int. Publishers: 0, Keys: 0 instead of Keys : [] or Publishers : []
-- ListStreamPublisherItems/ListStreamPublisherItemsAsync/ListStreamPublishers/ListStreamPublishersAsync changed to ListStreamResponse