123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- "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");
- /**
- * The **BaseWallet** is a stream-lined implementation of a
- * [[Signer]] that operates with a private key.
- *
- * It is preferred to use the [[Wallet]] class, as it offers
- * additional functionality and simplifies loading a variety
- * of JSON formats, Mnemonic Phrases, etc.
- *
- * This class may be of use for those attempting to implement
- * a minimal Signer.
- */
- class BaseWallet extends index_js_3.AbstractSigner {
- /**
- * The wallet address.
- */
- address;
- #signingKey;
- /**
- * Creates a new BaseWallet for %%privateKey%%, optionally
- * connected to %%provider%%.
- *
- * If %%provider%% is not specified, only offline methods can
- * be used.
- */
- constructor(privateKey, provider) {
- super(provider);
- (0, index_js_5.assertArgument)(privateKey && typeof (privateKey.sign) === "function", "invalid private key", "privateKey", "[ REDACTED ]");
- this.#signingKey = privateKey;
- const address = (0, index_js_4.computeAddress)(this.signingKey.publicKey);
- (0, index_js_5.defineProperties)(this, { address });
- }
- // Store private values behind getters to reduce visibility
- // in console.log
- /**
- * The [[SigningKey]] used for signing payloads.
- */
- get signingKey() { return this.#signingKey; }
- /**
- * The private key for this wallet.
- */
- get privateKey() { return this.signingKey.privateKey; }
- async getAddress() { return this.address; }
- connect(provider) {
- return new BaseWallet(this.#signingKey, provider);
- }
- async signTransaction(tx) {
- tx = (0, index_js_3.copyRequest)(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.signMessageSync(message);
- }
- // @TODO: Add a secialized signTx and signTyped sync that enforces
- // all parameters are known?
- /**
- * Returns the signature for %%message%% signed with this wallet.
- */
- 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
|