CDK construct to deploy a Hyperledger Fabric network running on Amazon Managed Blockchain
Project description
Hyperledger Fabric on Amazon Managed Blockchain
This repository contains a CDK construct to deploy a Hyperledger Fabric network running on Amazon Managed Blockchain. It builds out a member and its nodes, a VPC and associated endpoint to access them, and a set of users enrolled on the network.
The following functionality is planned for future releases:
- Create channels on nodes
- Instantiate chaincode on nodes
Installation
Note that this construct requires AWS CDK v2.
JavaScript
npm install --save @cdklabs/cdk-hyperledger-fabric-network
Python
pip3 install cdklabs.cdk-hyperledger-fabric-network
Java
Add the following to pom.xml
:
<dependency>
<groupId>io.github.cdklabs</groupId>
<artifactId>cdk-hyperledger-fabric-network</artifactId>
</dependency>
.NET
dotnet add package Cdklabs.CdkHyperledgerFabricNetwork
Usage
A minimally complete deployment is shown below. By default, a standard network
will be created running Hyperledger Fabric 1.4 with a single bc.t3.small
node.
import { Stack, StackProps } from 'aws-cdk-lib';
import { Construct } from 'constructs';
import { HyperledgerFabricNetwork } from '@cdklabs/cdk-hyperledger-fabric-network';
class MyStack extends Stack {
constructor(scope: Construct, id: string, props?: StackProps) {
super(scope, id, props);
new HyperledgerFabricNetwork(this, 'Example', {
networkName: 'MyNetwork',
memberName: 'MyMember',
});
}
}
The equivalent Python code is as follows:
from aws_cdk import Stack
from cdklabs.cdk_hyperledger_fabric_network import HyperledgerFabricNetwork
class MyStack(Stack):
def __init__(self, scope, id, **kwargs):
super().__init__(scope, id, **kwargs)
HyperledgerFabricNetwork(
self, 'Example',
network_name='MyNetwork',
member_name='MyMember',
)
The following is a more complex instantiation illustrating some of the options available.
new HyperledgerFabricNetwork(this, 'Example', {
networkName: 'MyNetwork',
networkDescription: 'This is my Hyperledger Fabric network',
memberName: 'MyMember',
networkDescription: 'This is my Hyperledger Fabric member',
frameworkVersion: hyperledger.FrameworkVersion.VERSION_1_2,
proposalDurationInHours: 48,
thresholdPercentage: 75,
nodes: [
{
availabilityZone: 'us-east-1a',
instanceType: hyperledger.InstanceType.STANDARD5_LARGE,
},
{
availabilityZone: 'us-east-1b',
instanceType: hyperledger.InstanceType.STANDARD5_LARGE,
},
],
users: [
{ userId: 'AppUser1', affilitation: 'MyMember' },
{ userId: 'AppUser2', affilitation: 'MyMember.department1' },
],
});
See the API Documentation for details on all available input and output parameters.
References
Contributing
Pull requests are welcomed. Please review the Contributing Guidelines and the Code of Conduct.
Security
See CONTRIBUTING for more information.
Authors
- Jud Neer (judneer@amazon.com)
- Vignesh Rajasingh (vrajasin@amazon.com)
License
This project is licensed under the MIT-0 License. See the LICENSE file for details.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Hashes for cdklabs.cdk-hyperledger-fabric-network-0.8.545.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | a5215a34d04b5d04f37ca373edcb5abaf95ea84c09e5291f344cf49bfc57b0d7 |
|
MD5 | a7ded07ee720d5a8cc9424fff85ee19b |
|
BLAKE2b-256 | 229f9def6b8c394f51de5c675537609a69b8c0a0a5d8bfd47033c0b6f529a59b |
Hashes for cdklabs.cdk_hyperledger_fabric_network-0.8.545-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 267f5e099bccc358656e41446a7adbd6a9d5b3973f56225b105c35a2983d02cd |
|
MD5 | 36b4be1dcf3136d963150a2d93929d42 |
|
BLAKE2b-256 | e45aa8dc9bb8bb6543cc6e0bd54c3336088ee0a39d69b504b090b64c1a423bc3 |