Skip to content

btcpimp/ImpleumBitcoinFullNode

 
 

Repository files navigation

Impleum Bitcoin

https://impleum.com

Bitcoin Implementation in C#

Impleum is an implementation of the Bitcoin protocol in C# on the .NET Core platform.
The node can run on the Bitcoin and Impleum networks.
Impleum Bitcoin is based on the NBitcoin project.

For Proof of Stake support on the Impleum token the node is using NStratis which is a POS implementation of NBitcoin.

.NET Core is an open source cross platform framework and enables the development of applications and services on Windows, macOS and Linux.
Join our community on discord.

The design

A Modular Approach

A Blockchain is made of many components, from a FullNode that validates blocks to a Simple Wallet that track addresses. The end goal is to develop a set of Nuget packages from which an implementer can cherry pick what he needs.

  • NBitcoin
  • Impleum.Bitcoin.Core - The bare minimum to run a pruned node.
  • Impleum.Bitcoin.Store - Store and relay blocks to peers.
  • Impleum.Bitcoin.MemoryPool - Track pending transaction.
  • Impleum.Bitcoin.Wallet - Send and Receive coins
  • Impleum.Bitcoin.Miner - POS or POW
  • Impleum.Bitcoin.Explorer

Create a Blockchain in a .NET Core style programming

  var node = new FullNodeBuilder()
   .UseNodeSettings(nodeSettings)
   .UseConsensus()
   .UseBlockStore()
   .UseMempool()
   .AddMining()
   .AddRPC()
   .Build();

  node.Run();

What's Next

We plan to add many more features on top of the Impleum Bitcoin blockchain: Sidechains, Private/Permissioned blockchain, Compiled Smart Contracts, NTumbleBit/Breeze wallet and more...

Running a FullNode

Our full node is currently in alpha.

git clone https://github.com/impleum/ImpleumBitcoinFullNode.git  
cd ImpleumBitcoinFullNode\src

dotnet restore
dotnet build

To run on the Bitcoin network: Impleum.BitcoinD\dotnet run
To run on the Impleum network: Impleum.ImpleumD\dotnet run

Getting Started Guide

More details on getting started are available here

Development

Up for some blockchain development?

Check this guides for more info:

There is a lot to do and we welcome contributers developers and testers who want to get some Blockchain experience. You can find tasks at the issues/projects or visit our C# dev discord channel.

Testing

CI build

We use AppVeyor for our CI build and to create nuget packages. Every time someone pushes to the master branch or create a pull request on it, a build is triggered and new nuget packages are created.

To skip a build, for example if you've made very minor changes, include the text [skip ci] or [ci skip] in your commits' comment (with the squared brackets).

Packages

No packages published

Languages

  • C# 99.9%
  • Other 0.1%