/* * SPDX-License-Identifier: Apache-2.0 * */ 'use strict'; const FabricCAServices = require('fabric-ca-client'); const { Wallets, X509WalletMixin } = require('fabric-network'); const fs = require('fs'); const path = require('path'); async function main() { try { // load the network configuration const ccpPath = path.resolve(__dirname, '..', 'test-network', 'organizations', 'peerOrganizations', 'org1.example.com', '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'); 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.get('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 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) { console.error(`Failed to enroll admin user "admin": ${error}`); process.exit(1); } } main();