mirror of
https://github.com/hyperledger/fabric-samples.git
synced 2026-06-17 07:25:10 +00:00
FAB-17456 fabric-samples read ccp (#117)
Have the application read the common connection profile to build a JSON object used for the gateway connect and for a fabric-ca client instance. Signed-off-by: Bret Harrison <beharrison@nc.rr.com>
This commit is contained in:
parent
965ed1fa84
commit
3dbe116a30
19 changed files with 141 additions and 4995 deletions
|
|
@ -6,7 +6,9 @@ steps:
|
|||
- script: bash startFabric.sh javascript
|
||||
workingDirectory: fabcar
|
||||
displayName: Start Fabric
|
||||
- script: retry -- npm install
|
||||
- script: |
|
||||
retry -- npm install
|
||||
npm ls
|
||||
workingDirectory: fabcar/javascript
|
||||
displayName: Install FabCar application dependencies
|
||||
- script: |
|
||||
|
|
|
|||
File diff suppressed because it is too large
Load diff
File diff suppressed because it is too large
Load diff
|
|
@ -9,12 +9,11 @@ const { Wallets } = require('fabric-network');
|
|||
const fs = require('fs');
|
||||
const path = require('path');
|
||||
|
||||
const ccpPath = path.resolve(__dirname, '..', '..', 'first-network', 'connection-org1.json');
|
||||
const ccpJSON = fs.readFileSync(ccpPath, 'utf8');
|
||||
const ccp = JSON.parse(ccpJSON);
|
||||
|
||||
async function main() {
|
||||
try {
|
||||
// load the network configuration
|
||||
const ccpPath = path.resolve(__dirname, '..', '..', 'first-network', 'connection-org1.json');
|
||||
const ccp = JSON.parse(fs.readFileSync(ccpPath, 'utf8'));
|
||||
|
||||
// Create a new CA client for interacting with the CA.
|
||||
const caInfo = ccp.certificateAuthorities['ca.org1.example.com'];
|
||||
|
|
|
|||
|
|
@ -5,12 +5,14 @@
|
|||
'use strict';
|
||||
|
||||
const { Gateway, Wallets } = require('fabric-network');
|
||||
const fs = require('fs');
|
||||
const path = require('path');
|
||||
|
||||
const ccpPath = path.resolve(__dirname, '..', '..', 'first-network', 'connection-org1.json');
|
||||
|
||||
async function main() {
|
||||
try {
|
||||
// load the network configuration
|
||||
const ccpPath = path.resolve(__dirname, '..', '..', 'first-network', 'connection-org1.json');
|
||||
let ccp = JSON.parse(fs.readFileSync(ccpPath, 'utf8'));
|
||||
|
||||
// Create a new file system based wallet for managing identities.
|
||||
const walletPath = path.join(process.cwd(), 'wallet');
|
||||
|
|
@ -27,7 +29,7 @@ async function main() {
|
|||
|
||||
// Create a new gateway for connecting to our peer node.
|
||||
const gateway = new Gateway();
|
||||
await gateway.connect(ccpPath, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
|
||||
await gateway.connect(ccp, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
|
||||
|
||||
// Get the network (channel) our contract is deployed to.
|
||||
const network = await gateway.getNetwork('mychannel');
|
||||
|
|
|
|||
|
|
@ -15,7 +15,6 @@
|
|||
"author": "Hyperledger",
|
||||
"license": "Apache-2.0",
|
||||
"dependencies": {
|
||||
"fabric-client": "beta",
|
||||
"fabric-ca-client": "beta",
|
||||
"fabric-network": "beta"
|
||||
},
|
||||
|
|
|
|||
|
|
@ -6,11 +6,14 @@
|
|||
|
||||
const { Gateway, Wallets } = require('fabric-network');
|
||||
const path = require('path');
|
||||
const fs = require('fs');
|
||||
|
||||
const ccpPath = path.resolve(__dirname, '..', '..', 'first-network', 'connection-org1.json');
|
||||
|
||||
async function main() {
|
||||
try {
|
||||
// load the network configuration
|
||||
const ccpPath = path.resolve(__dirname, '..', '..', 'first-network', 'connection-org1.json');
|
||||
const ccp = JSON.parse(fs.readFileSync(ccpPath, 'utf8'));
|
||||
|
||||
// Create a new file system based wallet for managing identities.
|
||||
const walletPath = path.join(process.cwd(), 'wallet');
|
||||
|
|
@ -27,7 +30,7 @@ async function main() {
|
|||
|
||||
// Create a new gateway for connecting to our peer node.
|
||||
const gateway = new Gateway();
|
||||
await gateway.connect(ccpPath, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
|
||||
await gateway.connect(ccp, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
|
||||
|
||||
// Get the network (channel) our contract is deployed to.
|
||||
const network = await gateway.getNetwork('mychannel');
|
||||
|
|
|
|||
|
|
@ -4,13 +4,20 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
const { Gateway, Wallets } = require('fabric-network');
|
||||
const { Wallets } = require('fabric-network');
|
||||
const FabricCAServices = require('fabric-ca-client');
|
||||
const fs = require('fs');
|
||||
const path = require('path');
|
||||
|
||||
const ccpPath = path.resolve(__dirname, '..', '..', 'first-network', 'connection-org1.json');
|
||||
|
||||
async function main() {
|
||||
try {
|
||||
// load the network configuration
|
||||
const ccpPath = path.resolve(__dirname, '..', '..', 'first-network', 'connection-org1.json');
|
||||
const ccp = JSON.parse(fs.readFileSync(ccpPath, 'utf8'));
|
||||
|
||||
// Create a new CA client for interacting with the CA.
|
||||
const caURL = ccp.certificateAuthorities['ca.org1.example.com'].url;
|
||||
const ca = new FabricCAServices(caURL);
|
||||
|
||||
// Create a new file system based wallet for managing identities.
|
||||
const walletPath = path.join(process.cwd(), 'wallet');
|
||||
|
|
@ -32,18 +39,20 @@ async function main() {
|
|||
return;
|
||||
}
|
||||
|
||||
// Create a new gateway for connecting to our peer node.
|
||||
const gateway = new Gateway();
|
||||
await gateway.connect(ccpPath, { wallet, identity: 'admin', discovery: { enabled: true, asLocalhost: true } });
|
||||
|
||||
// Get the CA client object from the gateway for interacting with the CA.
|
||||
const client = gateway.getClient();
|
||||
const ca = client.getCertificateAuthority();
|
||||
const adminUser = await client.getUserContext('admin', false);
|
||||
// build a user object for authenticating with the CA
|
||||
const provider = wallet.getProviderRegistry().getProvider(adminIdentity.type);
|
||||
const adminUser = await provider.getUserContext(adminIdentity, 'admin');
|
||||
|
||||
// Register the user, enroll the user, and import the new identity into the wallet.
|
||||
const secret = await ca.register({ affiliation: 'org1.department1', enrollmentID: 'user1', role: 'client' }, adminUser);
|
||||
const enrollment = await ca.enroll({ enrollmentID: 'user1', enrollmentSecret: secret });
|
||||
const secret = await ca.register({
|
||||
affiliation: 'org1.department1',
|
||||
enrollmentID: 'user1',
|
||||
role: 'client'
|
||||
}, adminUser);
|
||||
const enrollment = await ca.enroll({
|
||||
enrollmentID: 'user1',
|
||||
enrollmentSecret: secret
|
||||
});
|
||||
const x509Identity = {
|
||||
credentials: {
|
||||
certificate: enrollment.certificate,
|
||||
|
|
|
|||
|
|
@ -7,12 +7,11 @@ import { Wallets, X509Identity } from 'fabric-network';
|
|||
import * as fs from 'fs';
|
||||
import * as path from 'path';
|
||||
|
||||
const ccpPath = path.resolve(__dirname, '..', '..', '..', 'first-network', 'connection-org1.json');
|
||||
const ccpJSON = fs.readFileSync(ccpPath, 'utf8');
|
||||
const ccp = JSON.parse(ccpJSON);
|
||||
|
||||
async function main() {
|
||||
try {
|
||||
// load the network configuration
|
||||
const ccpPath = path.resolve(__dirname, '..', '..', '..', 'first-network', 'connection-org1.json');
|
||||
const ccp = JSON.parse(fs.readFileSync(ccpPath, 'utf8'));
|
||||
|
||||
// Create a new CA client for interacting with the CA.
|
||||
const caInfo = ccp.certificateAuthorities['ca.org1.example.com'];
|
||||
|
|
|
|||
|
|
@ -4,11 +4,13 @@
|
|||
|
||||
import { Gateway, Wallets } from 'fabric-network';
|
||||
import * as path from 'path';
|
||||
|
||||
const ccpPath = path.resolve(__dirname, '..', '..', '..', 'first-network', 'connection-org1.json');
|
||||
import * as fs from 'fs';
|
||||
|
||||
async function main() {
|
||||
try {
|
||||
// load the network configuration
|
||||
const ccpPath = path.resolve(__dirname, '..', '..', '..', 'first-network', 'connection-org1.json');
|
||||
const ccp = JSON.parse(fs.readFileSync(ccpPath, 'utf8'));
|
||||
|
||||
// Create a new file system based wallet for managing identities.
|
||||
const walletPath = path.join(process.cwd(), 'wallet');
|
||||
|
|
@ -25,7 +27,7 @@ async function main() {
|
|||
|
||||
// Create a new gateway for connecting to our peer node.
|
||||
const gateway = new Gateway();
|
||||
await gateway.connect(ccpPath, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
|
||||
await gateway.connect(ccp, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
|
||||
|
||||
// Get the network (channel) our contract is deployed to.
|
||||
const network = await gateway.getNetwork('mychannel');
|
||||
|
|
|
|||
|
|
@ -4,11 +4,14 @@
|
|||
|
||||
import { Gateway, Wallets } from 'fabric-network';
|
||||
import * as path from 'path';
|
||||
import * as fs from 'fs';
|
||||
|
||||
const ccpPath = path.resolve(__dirname, '..', '..', '..', 'first-network', 'connection-org1.json');
|
||||
|
||||
async function main() {
|
||||
try {
|
||||
// load the network configuration
|
||||
const ccpPath = path.resolve(__dirname, '..', '..', '..', 'first-network', 'connection-org1.json');
|
||||
const ccp = JSON.parse(fs.readFileSync(ccpPath, 'utf8'));
|
||||
|
||||
// Create a new file system based wallet for managing identities.
|
||||
const walletPath = path.join(process.cwd(), 'wallet');
|
||||
|
|
@ -25,7 +28,7 @@ async function main() {
|
|||
|
||||
// Create a new gateway for connecting to our peer node.
|
||||
const gateway = new Gateway();
|
||||
await gateway.connect(ccpPath, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
|
||||
await gateway.connect(ccp, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
|
||||
|
||||
// Get the network (channel) our contract is deployed to.
|
||||
const network = await gateway.getNetwork('mychannel');
|
||||
|
|
|
|||
|
|
@ -2,13 +2,20 @@
|
|||
* SPDX-License-Identifier: Apache-2.0
|
||||
*/
|
||||
|
||||
import { Gateway, Wallets, X509Identity } from 'fabric-network';
|
||||
import { Wallets, X509Identity } from 'fabric-network';
|
||||
import * as FabricCAServices from 'fabric-ca-client';
|
||||
import * as path from 'path';
|
||||
|
||||
const ccpPath = path.resolve(__dirname, '..', '..', '..', 'first-network', 'connection-org1.json');
|
||||
import * as fs from 'fs';
|
||||
|
||||
async function main() {
|
||||
try {
|
||||
// load the network configuration
|
||||
const ccpPath = path.resolve(__dirname, '..', '..', '..', 'first-network', 'connection-org1.json');
|
||||
let ccp = JSON.parse(fs.readFileSync(ccpPath, 'utf8'));
|
||||
|
||||
// Create a new CA client for interacting with the CA.
|
||||
const caURL = ccp.certificateAuthorities['ca.org1.example.com'].url;
|
||||
const ca = new FabricCAServices(caURL);
|
||||
|
||||
// Create a new file system based wallet for managing identities.
|
||||
const walletPath = path.join(process.cwd(), 'wallet');
|
||||
|
|
@ -30,14 +37,9 @@ async function main() {
|
|||
return;
|
||||
}
|
||||
|
||||
// Create a new gateway for connecting to our peer node.
|
||||
const gateway = new Gateway();
|
||||
await gateway.connect(ccpPath, { wallet, identity: 'admin', discovery: { enabled: true, asLocalhost: true } });
|
||||
|
||||
// Get the CA client object from the gateway for interacting with the CA.
|
||||
const client = gateway.getClient();
|
||||
const ca = client.getCertificateAuthority();
|
||||
const adminUser = await client.getUserContext('admin', false);
|
||||
// build a user object for authenticating with the CA
|
||||
const provider = wallet.getProviderRegistry().getProvider(adminIdentity.type);
|
||||
const adminUser = await provider.getUserContext(adminIdentity, 'admin');
|
||||
|
||||
// Register the user, enroll the user, and import the new identity into the wallet.
|
||||
const secret = await ca.register({ affiliation: 'org1.department1', enrollmentID: 'user1', role: 'client' }, adminUser);
|
||||
|
|
|
|||
|
|
@ -2,7 +2,7 @@
|
|||
* Copyright IBM Corp. All Rights Reserved.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
*
|
||||
*/
|
||||
|
||||
/*
|
||||
|
|
@ -28,7 +28,7 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
const { FileSystemWallet, Gateway } = require('fabric-network');
|
||||
const { Wallets, Gateway } = require('fabric-network');
|
||||
const fs = require('fs');
|
||||
const path = require('path');
|
||||
|
||||
|
|
@ -75,12 +75,12 @@ async function main() {
|
|||
// Configure a wallet. This wallet must already be primed with an identity that
|
||||
// the application can use to interact with the peer node.
|
||||
const walletPath = path.resolve(__dirname, 'wallet');
|
||||
const wallet = new FileSystemWallet(walletPath);
|
||||
const wallet = await Wallets.newFileSystemWallet(walletPath);
|
||||
|
||||
// Create a new gateway, and connect to the gateway peer node(s). The identity
|
||||
// specified must already exist in the specified wallet.
|
||||
const gateway = new Gateway();
|
||||
await gateway.connect(ccpPath, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
|
||||
await gateway.connect(ccp, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
|
||||
|
||||
// Get the network channel that the smart contract is deployed to.
|
||||
const network = await gateway.getNetwork(channelid);
|
||||
|
|
|
|||
|
|
@ -2,7 +2,7 @@
|
|||
* Copyright IBM Corp. All Rights Reserved.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
*
|
||||
*/
|
||||
|
||||
/*
|
||||
|
|
@ -40,17 +40,13 @@ is automatically created and initialized to zero if it does not exist.
|
|||
|
||||
'use strict';
|
||||
|
||||
const { FileSystemWallet, Gateway } = require('fabric-network');
|
||||
const { Wallets, Gateway } = require('fabric-network');
|
||||
const fs = require('fs');
|
||||
const path = require('path');
|
||||
|
||||
const couchdbutil = require('./couchdbutil.js');
|
||||
const blockProcessing = require('./blockProcessing.js');
|
||||
|
||||
const ccpPath = path.resolve(__dirname, '..', 'first-network', 'connection-org1.json');
|
||||
const ccpJSON = fs.readFileSync(ccpPath, 'utf8');
|
||||
const ccp = JSON.parse(ccpJSON);
|
||||
|
||||
const config = require('./config.json');
|
||||
const channelid = config.channelid;
|
||||
const peer_name = config.peer_name;
|
||||
|
|
@ -98,26 +94,30 @@ async function main() {
|
|||
|
||||
// Create a new file system based wallet for managing identities.
|
||||
const walletPath = path.join(process.cwd(), 'wallet');
|
||||
const wallet = new FileSystemWallet(walletPath);
|
||||
const wallet = await Wallets.newFileSystemWallet(walletPath);
|
||||
console.log(`Wallet path: ${walletPath}`);
|
||||
|
||||
// Check to see if we've already enrolled the user.
|
||||
const userExists = await wallet.exists('user1');
|
||||
const userExists = await wallet.get('user1');
|
||||
if (!userExists) {
|
||||
console.log('An identity for the user "user1" does not exist in the wallet');
|
||||
console.log('Run the enrollUser.js application before retrying');
|
||||
return;
|
||||
}
|
||||
|
||||
// Parse the connection profile. This would be the path to the file downloaded
|
||||
// from the IBM Blockchain Platform operational console.
|
||||
const ccpPath = path.resolve(__dirname, '..', 'first-network', 'connection-org1.json');
|
||||
const ccp = JSON.parse(fs.readFileSync(ccpPath, 'utf8'));
|
||||
// Create a new gateway for connecting to our peer node.
|
||||
const gateway = new Gateway();
|
||||
await gateway.connect(ccpPath, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
|
||||
await gateway.connect(ccp, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
|
||||
|
||||
// Get the network (channel) our contract is deployed to.
|
||||
const network = await gateway.getNetwork('mychannel');
|
||||
|
||||
const listener = await network.addBlockListener('offchain-listener',
|
||||
async (err, block) => {
|
||||
const listener = await network.addBlockListener(
|
||||
async (err, blockNum, block) => {
|
||||
if (err) {
|
||||
console.error(err);
|
||||
return;
|
||||
|
|
@ -125,10 +125,10 @@ async function main() {
|
|||
// Add the block to the processing map by block number
|
||||
await ProcessingMap.set(block.header.number, block);
|
||||
|
||||
console.log(`Added block ${block.header.number} to ProcessingMap`)
|
||||
console.log(`Added block ${blockNum} to ProcessingMap`)
|
||||
},
|
||||
// set the starting block for the listener
|
||||
{ startBlock: parseInt(nextBlock, 10) }
|
||||
{ filtered: false, startBlock: parseInt(nextBlock, 10) }
|
||||
);
|
||||
|
||||
console.log(`Listening for block events, nextblock: ${nextBlock}`);
|
||||
|
|
|
|||
|
|
@ -50,14 +50,14 @@ exports.processBlockEvent = async function (channelname, block, use_couchdb, nan
|
|||
// filter through valid tx, refer below for list of error codes
|
||||
// https://github.com/hyperledger/fabric-sdk-node/blob/release-1.4/fabric-client/lib/protos/peer/transaction.proto
|
||||
if (txSuccess[dataItem] !== 0) {
|
||||
continue();
|
||||
continue;
|
||||
}
|
||||
|
||||
const timestamp = dataArray[dataItem].payload.header.channel_header.timestamp;
|
||||
|
||||
// continue to next tx if no actions are set
|
||||
if (dataArray[dataItem].payload.data.actions == undefined) {
|
||||
continue();
|
||||
continue;
|
||||
}
|
||||
|
||||
// actions are stored as an array. In Fabric 1.4.3 only one
|
||||
|
|
|
|||
|
|
@ -2,7 +2,7 @@
|
|||
* Copyright IBM Corp. All Rights Reserved.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
*
|
||||
*/
|
||||
|
||||
/*
|
||||
|
|
@ -16,7 +16,7 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
const { FileSystemWallet, Gateway } = require('fabric-network');
|
||||
const { Wallets, Gateway } = require('fabric-network');
|
||||
const fs = require('fs');
|
||||
const path = require('path');
|
||||
|
||||
|
|
@ -42,12 +42,12 @@ async function main() {
|
|||
// Configure a wallet. This wallet must already be primed with an identity that
|
||||
// the application can use to interact with the peer node.
|
||||
const walletPath = path.resolve(__dirname, 'wallet');
|
||||
const wallet = new FileSystemWallet(walletPath);
|
||||
const wallet = await Wallets.newFileSystemWallet(walletPath);
|
||||
|
||||
// Create a new gateway, and connect to the gateway peer node(s). The identity
|
||||
// specified must already exist in the specified wallet.
|
||||
const gateway = new Gateway();
|
||||
await gateway.connect(ccpPath, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
|
||||
await gateway.connect(ccp, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
|
||||
|
||||
// Get the network channel that the smart contract is deployed to.
|
||||
const network = await gateway.getNetwork(channelid);
|
||||
|
|
|
|||
|
|
@ -2,22 +2,21 @@
|
|||
* Copyright IBM Corp. All Rights Reserved.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
*
|
||||
*/
|
||||
|
||||
'use strict';
|
||||
|
||||
const FabricCAServices = require('fabric-ca-client');
|
||||
const { FileSystemWallet, X509WalletMixin } = require('fabric-network');
|
||||
const { Wallets, X509WalletMixin } = require('fabric-network');
|
||||
const fs = require('fs');
|
||||
const path = require('path');
|
||||
|
||||
const ccpPath = path.resolve(__dirname, '..', 'first-network', 'connection-org1.json');
|
||||
const ccpJSON = fs.readFileSync(ccpPath, 'utf8');
|
||||
const ccp = JSON.parse(ccpJSON);
|
||||
|
||||
async function main() {
|
||||
try {
|
||||
// load the network configuration
|
||||
const ccpPath = path.resolve(__dirname, '..', 'first-network', 'connection-org1.json');
|
||||
let ccp = JSON.parse(fs.readFileSync(ccpPath, 'utf8'));
|
||||
|
||||
// Create a new CA client for interacting with the CA.
|
||||
const caURL = ccp.certificateAuthorities['ca.org1.example.com'].url;
|
||||
|
|
@ -25,11 +24,11 @@ async function main() {
|
|||
|
||||
// Create a new file system based wallet for managing identities.
|
||||
const walletPath = path.join(process.cwd(), 'wallet');
|
||||
const wallet = new FileSystemWallet(walletPath);
|
||||
const wallet = await Wallets.newFileSystemWallet(walletPath);
|
||||
console.log(`Wallet path: ${walletPath}`);
|
||||
|
||||
// Check to see if we've already enrolled the admin user.
|
||||
const adminExists = await wallet.exists('admin');
|
||||
const adminExists = await wallet.get('admin');
|
||||
if (adminExists) {
|
||||
console.log('An identity for the admin user "admin" already exists in the wallet');
|
||||
return;
|
||||
|
|
@ -37,8 +36,15 @@ async function main() {
|
|||
|
||||
// Enroll the admin user, and import the new identity into the wallet.
|
||||
const enrollment = await ca.enroll({ enrollmentID: 'admin', enrollmentSecret: 'adminpw' });
|
||||
const identity = X509WalletMixin.createIdentity('Org1MSP', enrollment.certificate, enrollment.key.toBytes());
|
||||
wallet.import('admin', identity);
|
||||
const x509Identity = {
|
||||
credentials: {
|
||||
certificate: enrollment.certificate,
|
||||
privateKey: enrollment.key.toBytes(),
|
||||
},
|
||||
mspId: 'Org1MSP',
|
||||
type: 'X.509',
|
||||
};
|
||||
await wallet.put('admin', x509Identity);
|
||||
console.log('Successfully enrolled admin user "admin" and imported it into the wallet');
|
||||
|
||||
} catch (error) {
|
||||
|
|
|
|||
|
|
@ -2,55 +2,69 @@
|
|||
* Copyright IBM Corp. All Rights Reserved.
|
||||
*
|
||||
* SPDX-License-Identifier: Apache-2.0
|
||||
*
|
||||
*
|
||||
*/
|
||||
|
||||
'use strict';
|
||||
|
||||
const { FileSystemWallet, Gateway, X509WalletMixin } = require('fabric-network');
|
||||
const { Wallets, Gateway, X509WalletMixin } = require('fabric-network');
|
||||
const FabricCAServices = require('fabric-ca-client');
|
||||
const fs = require('fs');
|
||||
const path = require('path');
|
||||
|
||||
const ccpPath = path.resolve(__dirname, '..', 'first-network', 'connection-org1.json');
|
||||
const ccpJSON = fs.readFileSync(ccpPath, 'utf8');
|
||||
const ccp = JSON.parse(ccpJSON);
|
||||
|
||||
async function main() {
|
||||
try {
|
||||
// load the network configuration
|
||||
const ccpPath = path.resolve(__dirname, '..', 'first-network', 'connection-org1.json');
|
||||
const ccp = JSON.parse(fs.readFileSync(ccpPath, 'utf8'));
|
||||
|
||||
// Create a new CA client for interacting with the CA.
|
||||
const caURL = ccp.certificateAuthorities['ca.org1.example.com'].url;
|
||||
const ca = new FabricCAServices(caURL);
|
||||
|
||||
// Create a new file system based wallet for managing identities.
|
||||
const walletPath = path.join(process.cwd(), 'wallet');
|
||||
const wallet = new FileSystemWallet(walletPath);
|
||||
const wallet = await Wallets.newFileSystemWallet(walletPath);
|
||||
console.log(`Wallet path: ${walletPath}`);
|
||||
|
||||
// Check to see if we've already enrolled the user.
|
||||
const userExists = await wallet.exists('user1');
|
||||
const userExists = await wallet.get('user1');
|
||||
if (userExists) {
|
||||
console.log('An identity for the user "user1" already exists in the wallet');
|
||||
return;
|
||||
}
|
||||
|
||||
// Check to see if we've already enrolled the admin user.
|
||||
const adminExists = await wallet.exists('admin');
|
||||
if (!adminExists) {
|
||||
const adminIdentity = await wallet.get('admin');
|
||||
if (!adminIdentity) {
|
||||
console.log('An identity for the admin user "admin" does not exist in the wallet');
|
||||
console.log('Run the enrollAdmin.js application before retrying');
|
||||
return;
|
||||
}
|
||||
|
||||
// Create a new gateway for connecting to our peer node.
|
||||
const gateway = new Gateway();
|
||||
await gateway.connect(ccp, { wallet, identity: 'admin', discovery: { enabled: false } });
|
||||
|
||||
// Get the CA client object from the gateway for interacting with the CA.
|
||||
const ca = gateway.getClient().getCertificateAuthority();
|
||||
const adminIdentity = gateway.getCurrentIdentity();
|
||||
// build a user object for authenticating with the CA
|
||||
const provider = wallet.getProviderRegistry().getProvider(adminIdentity.type);
|
||||
const adminUser = await provider.getUserContext(adminIdentity, 'admin');
|
||||
|
||||
// Register the user, enroll the user, and import the new identity into the wallet.
|
||||
const secret = await ca.register({ affiliation: 'org1.department1', enrollmentID: 'user1', role: 'client' }, adminIdentity);
|
||||
const enrollment = await ca.enroll({ enrollmentID: 'user1', enrollmentSecret: secret });
|
||||
const userIdentity = X509WalletMixin.createIdentity('Org1MSP', enrollment.certificate, enrollment.key.toBytes());
|
||||
wallet.import('user1', userIdentity);
|
||||
const secret = await ca.register({
|
||||
affiliation: 'org1.department1',
|
||||
enrollmentID: 'user1',
|
||||
role: 'client'
|
||||
}, adminUser);
|
||||
const enrollment = await ca.enroll({
|
||||
enrollmentID: 'user1',
|
||||
enrollmentSecret: secret
|
||||
});
|
||||
const x509Identity = {
|
||||
credentials: {
|
||||
certificate: enrollment.certificate,
|
||||
privateKey: enrollment.key.toBytes(),
|
||||
},
|
||||
mspId: 'Org1MSP',
|
||||
type: 'X.509',
|
||||
};
|
||||
await wallet.put('user1', x509Identity);
|
||||
console.log('Successfully registered and enrolled admin user "user1" and imported it into the wallet');
|
||||
|
||||
} catch (error) {
|
||||
|
|
|
|||
|
|
@ -15,7 +15,7 @@
|
|||
|
||||
'use strict';
|
||||
|
||||
const { FileSystemWallet, Gateway } = require('fabric-network');
|
||||
const { Wallets, Gateway } = require('fabric-network');
|
||||
const fs = require('fs');
|
||||
const path = require('path');
|
||||
|
||||
|
|
@ -42,12 +42,12 @@ async function main() {
|
|||
// Configure a wallet. This wallet must already be primed with an identity that
|
||||
// the application can use to interact with the peer node.
|
||||
const walletPath = path.resolve(__dirname, 'wallet');
|
||||
const wallet = new FileSystemWallet(walletPath);
|
||||
const wallet = await Wallets.newFileSystemWallet(walletPath);
|
||||
|
||||
// Create a new gateway, and connect to the gateway peer node(s). The identity
|
||||
// specified must already exist in the specified wallet.
|
||||
const gateway = new Gateway();
|
||||
await gateway.connect(ccpPath, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
|
||||
await gateway.connect(ccp, { wallet, identity: 'user1', discovery: { enabled: true, asLocalhost: true } });
|
||||
|
||||
// Get the network channel that the smart contract is deployed to.
|
||||
const network = await gateway.getNetwork(channelid);
|
||||
|
|
|
|||
Loading…
Reference in a new issue