mirror of
https://github.com/hyperledger/fabric-samples.git
synced 2026-06-17 15:35:09 +00:00
Update FabCar to use BYFN. As a result, the sample client applications need to change so that they use the correct connection profile paths, and so that they use service discovery. Change-Id: If02b7fb4ad308c6a7d1e1aa9f953e1bc4e942719 Signed-off-by: Simon Stone <sstone1@uk.ibm.com>
49 lines
1.9 KiB
JavaScript
49 lines
1.9 KiB
JavaScript
/*
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
'use strict';
|
|
|
|
const FabricCAServices = require('fabric-ca-client');
|
|
const { FileSystemWallet, 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 {
|
|
|
|
// Create a new CA client for interacting with the CA.
|
|
const caInfo = ccp.certificateAuthorities['ca.org1.example.com'];
|
|
const caTLSCACertsPath = path.resolve(__dirname, '..', '..', 'first-network', caInfo.tlsCACerts.path);
|
|
const caTLSCACerts = fs.readFileSync(caTLSCACertsPath);
|
|
const ca = new FabricCAServices(caInfo.url, { trustedRoots: caTLSCACerts, verify: false }, caInfo.caName);
|
|
|
|
// Create a new file system based wallet for managing identities.
|
|
const walletPath = path.join(process.cwd(), 'wallet');
|
|
const wallet = new FileSystemWallet(walletPath);
|
|
console.log(`Wallet path: ${walletPath}`);
|
|
|
|
// Check to see if we've already enrolled the admin user.
|
|
const adminExists = await wallet.exists('admin');
|
|
if (adminExists) {
|
|
console.log('An identity for the admin user "admin" already exists in the wallet');
|
|
return;
|
|
}
|
|
|
|
// 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());
|
|
await wallet.import('admin', identity);
|
|
console.log('Successfully enrolled admin user "admin" and imported it into the wallet');
|
|
|
|
} catch (error) {
|
|
console.error(`Failed to enroll admin user "admin": ${error}`);
|
|
process.exit(1);
|
|
}
|
|
}
|
|
|
|
main();
|