forked from LiskArchive/app-registry
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathextractPublicKeyFromCertificate.js
51 lines (43 loc) · 1.55 KB
/
extractPublicKeyFromCertificate.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
/*
* Copyright © 2023 Lisk Foundation
*
* See the LICENSE file at the top-level directory of this distribution
* for licensing information.
*
* Unless otherwise agreed in a custom licensing agreement with the Lisk Foundation,
* no part of this software, including this file, may be copied, modified,
* propagated, or distributed except according to the terms contained in the
* LICENSE file.
*
* Removal or modification of this copyright notice is prohibited.
*
*/
const fs = require('fs');
const crypto = require('crypto');
// Function to generate the public key from PEM certificate
function extractPublicKeyFromCertificate(certFilePath, publicKeyFilePath) {
// Read the PEM certificate from the file
const pemCertificate = fs.readFileSync(certFilePath);
try {
// Create a certificate object from the PEM data
const certificate = crypto.createPublicKey({
key: pemCertificate,
format: 'pem',
});
// Convert the certificate to PEM format for public key
const publicKeyPem = certificate.export({
format: 'pem',
type: 'spki',
});
// Write the public key to the output file
fs.writeFileSync(publicKeyFilePath, publicKeyPem);
console.log(`Public key successfully extracted to: ${publicKeyFile}.`);
process.exit(0);
} catch (error) {
console.error(`Error occurred while extracting the public key: ${error.message}.`);
process.exit(1);
}
}
const pemCertificateFile = process.argv[2];
const publicKeyFile = process.argv[3];
extractPublicKeyFromCertificate(pemCertificateFile, publicKeyFile);