ethers.js/lib.commonjs/wallet/base-wallet.js
2022-11-10 04:05:51 -05:00

82 lines
3.7 KiB
JavaScript

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.BaseWallet = void 0;
const index_js_1 = require("../address/index.js");
const index_js_2 = require("../hash/index.js");
const index_js_3 = require("../providers/index.js");
const index_js_4 = require("../transaction/index.js");
const index_js_5 = require("../utils/index.js");
const json_keystore_js_1 = require("./json-keystore.js");
class BaseWallet extends index_js_3.AbstractSigner {
address;
#signingKey;
constructor(privateKey, provider) {
super(provider);
this.#signingKey = privateKey;
const address = (0, index_js_4.computeAddress)(this.signingKey.publicKey);
(0, index_js_5.defineProperties)(this, { address });
}
// Store these in getters to reduce visibility in console.log
get signingKey() { return this.#signingKey; }
get privateKey() { return this.signingKey.privateKey; }
async getAddress() { return this.address; }
connect(provider) {
return new BaseWallet(this.#signingKey, provider);
}
async encrypt(password, progressCallback) {
const account = { address: this.address, privateKey: this.privateKey };
return await (0, json_keystore_js_1.encryptKeystoreJson)(account, password, { progressCallback });
}
encryptSync(password) {
const account = { address: this.address, privateKey: this.privateKey };
return (0, json_keystore_js_1.encryptKeystoreJsonSync)(account, password);
}
async signTransaction(tx) {
// Replace any Addressable or ENS name with an address
const { to, from } = await (0, index_js_5.resolveProperties)({
to: (tx.to ? (0, index_js_1.resolveAddress)(tx.to, this.provider) : undefined),
from: (tx.from ? (0, index_js_1.resolveAddress)(tx.from, this.provider) : undefined)
});
if (to != null) {
tx.to = to;
}
if (from != null) {
tx.from = from;
}
if (tx.from != null) {
(0, index_js_5.assertArgument)((0, index_js_1.getAddress)((tx.from)) === this.address, "transaction from address mismatch", "tx.from", tx.from);
delete tx.from;
}
// Build the transaction
const btx = index_js_4.Transaction.from(tx);
btx.signature = this.signingKey.sign(btx.unsignedHash);
return btx.serialized;
}
async signMessage(message) {
return this.signingKey.sign((0, index_js_2.hashMessage)(message)).serialized;
}
// @TODO: Add a secialized signTx and signTyped sync that enforces
// all parameters are known?
signMessageSync(message) {
return this.signingKey.sign((0, index_js_2.hashMessage)(message)).serialized;
}
async signTypedData(domain, types, value) {
// Populate any ENS names
const populated = await index_js_2.TypedDataEncoder.resolveNames(domain, types, value, async (name) => {
// @TODO: this should use resolveName; addresses don't
// need a provider
(0, index_js_5.assert)(this.provider != null, "cannot resolve ENS names without a provider", "UNSUPPORTED_OPERATION", {
operation: "resolveName",
info: { name }
});
const address = await this.provider.resolveName(name);
(0, index_js_5.assert)(address != null, "unconfigured ENS name", "UNCONFIGURED_NAME", {
value: name
});
return address;
});
return this.signingKey.sign(index_js_2.TypedDataEncoder.hash(populated.domain, types, populated.value)).serialized;
}
}
exports.BaseWallet = BaseWallet;
//# sourceMappingURL=base-wallet.js.map