MyCrypto/common/libs/wallet/privkey.js

83 lines
2.1 KiB
JavaScript
Raw Normal View History

2017-06-29 23:03:11 +00:00
// @flow
import type { IWallet } from './IWallet';
2017-07-04 03:21:19 +00:00
import {
privateToPublic,
publicToAddress,
toChecksumAddress
} from 'ethereumjs-util';
import { randomBytes } from 'crypto';
import { pkeyToKeystore } from 'libs/keystore';
import { signRawTxWithPrivKey, signMessageWithPrivKey } from 'libs/signing';
import { isValidPrivKey } from 'libs/validators';
import type { RawTransaction } from 'libs/transaction';
import type { UtcKeystore } from 'libs/keystore';
import { stripHexPrefixAndLower } from 'libs/values';
2017-06-29 23:03:11 +00:00
export default class PrivKeyWallet implements IWallet {
2017-07-04 03:21:19 +00:00
privKey: Buffer;
pubKey: Buffer;
address: Buffer;
constructor(privkey: Buffer) {
if (!isValidPrivKey(privkey)) {
throw new Error('Invalid private key');
}
this.privKey = privkey;
2017-07-04 03:21:19 +00:00
this.pubKey = privateToPublic(this.privKey);
this.address = publicToAddress(this.pubKey);
}
2017-06-29 23:03:11 +00:00
getAddress(): Promise<string> {
return Promise.resolve(
toChecksumAddress(`0x${this.address.toString('hex')}`)
);
2017-07-04 03:21:19 +00:00
}
getPrivateKey() {
return this.privKey.toString('hex');
}
static generate() {
return new PrivKeyWallet(randomBytes(32));
}
getNakedAddress(): Promise<string> {
return new Promise(resolve => {
this.getAddress().then(address => {
resolve(stripHexPrefixAndLower(address));
});
});
}
toKeystore(password: string): Promise<UtcKeystore> {
return new Promise(resolve => {
this.getNakedAddress().then(address => {
resolve(pkeyToKeystore(this.privKey, address, password));
});
});
}
unlock(): Promise<any> {
return Promise.resolve();
}
signRawTransaction(rawTx: RawTransaction): Promise<string> {
return new Promise((resolve, reject) => {
try {
resolve(signRawTxWithPrivKey(this.privKey, rawTx));
} catch (err) {
reject(err);
}
});
}
signMessage(msg: string, address: string, date: string): Promise<any> {
return new Promise((resolve, reject) => {
try {
resolve(signMessageWithPrivKey(this.privKey, msg, address, date));
} catch (err) {
reject(err);
}
});
}
2017-06-29 23:03:11 +00:00
}