| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131 | 
							- import { getAddress, resolveAddress } from "../address/index.js";
 
- import { hashMessage, TypedDataEncoder } from "../hash/index.js";
 
- import { AbstractSigner, copyRequest } from "../providers/index.js";
 
- import { computeAddress, Transaction } from "../transaction/index.js";
 
- import {
 
-     defineProperties, resolveProperties, assert, assertArgument
 
- } from "../utils/index.js";
 
- import type { SigningKey } from "../crypto/index.js";
 
- import type { TypedDataDomain, TypedDataField } from "../hash/index.js";
 
- import type { Provider, TransactionRequest } from "../providers/index.js";
 
- import type { TransactionLike } from "../transaction/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.
 
-  */
 
- export class BaseWallet extends AbstractSigner {
 
-     /**
 
-      *  The wallet address.
 
-      */
 
-     readonly address!: string;
 
-     readonly #signingKey: SigningKey;
 
-     /**
 
-      *  Creates a new BaseWallet for %%privateKey%%, optionally
 
-      *  connected to %%provider%%.
 
-      *
 
-      *  If %%provider%% is not specified, only offline methods can
 
-      *  be used.
 
-      */
 
-     constructor(privateKey: SigningKey, provider?: null | Provider) {
 
-         super(provider);
 
-         assertArgument(privateKey && typeof(privateKey.sign) === "function", "invalid private key", "privateKey", "[ REDACTED ]");
 
-         this.#signingKey = privateKey;
 
-         const address = computeAddress(this.signingKey.publicKey);
 
-         defineProperties<BaseWallet>(this, { address });
 
-     }
 
-     // Store private values behind getters to reduce visibility
 
-     // in console.log
 
-     /**
 
-      *  The [[SigningKey]] used for signing payloads.
 
-      */
 
-     get signingKey(): SigningKey { return this.#signingKey; }
 
-     /**
 
-      *  The private key for this wallet.
 
-      */
 
-     get privateKey(): string { return this.signingKey.privateKey; }
 
-     async getAddress(): Promise<string> { return this.address; }
 
-     connect(provider: null | Provider): BaseWallet {
 
-         return new BaseWallet(this.#signingKey, provider);
 
-     }
 
-     async signTransaction(tx: TransactionRequest): Promise<string> {
 
-         tx = copyRequest(tx);
 
-         // Replace any Addressable or ENS name with an address
 
-         const { to, from } = await resolveProperties({
 
-             to: (tx.to ? resolveAddress(tx.to, this.provider): undefined),
 
-             from: (tx.from ? resolveAddress(tx.from, this.provider): undefined)
 
-         });
 
-         if (to != null) { tx.to = to; }
 
-         if (from != null) { tx.from = from; }
 
-         if (tx.from != null) {
 
-             assertArgument(getAddress(<string>(tx.from)) === this.address,
 
-                 "transaction from address mismatch", "tx.from", tx.from);
 
-             delete tx.from;
 
-         }
 
-         // Build the transaction
 
-         const btx = Transaction.from(<TransactionLike<string>>tx);
 
-         btx.signature = this.signingKey.sign(btx.unsignedHash);
 
-         return btx.serialized;
 
-     }
 
-     async signMessage(message: string | Uint8Array): Promise<string> {
 
-         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: string | Uint8Array): string {
 
-         return this.signingKey.sign(hashMessage(message)).serialized;
 
-     }
 
-     async signTypedData(domain: TypedDataDomain, types: Record<string, Array<TypedDataField>>, value: Record<string, any>): Promise<string> {
 
-         // Populate any ENS names
 
-         const populated = await TypedDataEncoder.resolveNames(domain, types, value, async (name: string) => {
 
-             // @TODO: this should use resolveName; addresses don't
 
-             //        need a provider
 
-             assert(this.provider != null, "cannot resolve ENS names without a provider", "UNSUPPORTED_OPERATION", {
 
-                 operation: "resolveName",
 
-                 info: { name }
 
-             });
 
-             const address = await this.provider.resolveName(name);
 
-             assert(address != null, "unconfigured ENS name", "UNCONFIGURED_NAME", {
 
-                 value: name
 
-             });
 
-             return address;
 
-         });
 
-         return this.signingKey.sign(TypedDataEncoder.hash(populated.domain, types, populated.value)).serialized;
 
-     }
 
- }
 
 
  |