diff --git a/packages/milkomeda-wsc-provider/README.md b/packages/milkomeda-wsc-provider/README.md index 0b33999..e75ce16 100644 --- a/packages/milkomeda-wsc-provider/README.md +++ b/packages/milkomeda-wsc-provider/README.md @@ -1,5 +1,9 @@ # Provider -Injects the provider for wrapped smart contracts into the `window.ethereum` object. This provider invokes a l1 provider to abstract the milkomeda account on l2. +Injects the provider for wrapped smart contracts into: +1. [EIP-1193](https://eips.ethereum.org/EIPS/eip-1193) - the `window.ethereum` object +2. [EIP-6963](https://eips.ethereum.org/EIPS/eip-6963) with rdns `com.milkomeda.c1.wsc` / `com.milkomeda.a1.wsc` and UUID `d53bc7c3-e43a-4d0a-83d7-b6e7b7504beb` + +This provider invokes a L1 provider to abstract the Milkomeda account on L2. To see an example usage of this provider see the [example dapp](../dapp-example/). diff --git a/packages/milkomeda-wsc-provider/src/index.ts b/packages/milkomeda-wsc-provider/src/index.ts index 9635328..82a67c4 100644 --- a/packages/milkomeda-wsc-provider/src/index.ts +++ b/packages/milkomeda-wsc-provider/src/index.ts @@ -8,16 +8,66 @@ declare global { } } +// https://eips.ethereum.org/EIPS/eip-6963 +interface EIP6963ProviderInfo { + uuid: string; + name: string; + icon: string; + rdns: string; +} +interface EIP6963ProviderDetail { + info: EIP6963ProviderInfo; + // eslint-disable-next-line @typescript-eslint/no-explicit-any + provider: any; // EIP1193 window.ethereum injected provider +} +interface EIP6963AnnounceProviderEvent extends CustomEvent { + type: "eip6963:announceProvider"; + detail: EIP6963ProviderDetail; +} +const milkomedaSvg = + ""; +const wscUuid = "d53bc7c3-e43a-4d0a-83d7-b6e7b7504beb"; + +const cardanoWscEip6963Info: EIP6963ProviderInfo = { + uuid: wscUuid, + name: "Cardano C1 WSC", + icon: milkomedaSvg, + rdns: "com.milkomeda.c1.wsc", +} as const; +const algorandWscEip6963Info: EIP6963ProviderInfo = { + uuid: wscUuid, + name: "Cardano A1 WSC", + icon: milkomedaSvg, + rdns: "com.milkomeda.a1.wsc", +} as const; + +function addEip6963Listener(provider: EIP6963ProviderInfo) { + const announceEvent = new CustomEvent("eip6963:announceProvider", { + detail: Object.freeze({ info: cardanoWscEip6963Info, provider }), + }) as EIP6963AnnounceProviderEvent; + + // send an event for any dApp that was already listening to let them know about the WSC provider + window.dispatchEvent(announceEvent); + + // create a listener to respond to any dApp with WSC info + window.addEventListener("eip6963:requestProvider", () => { + window.dispatchEvent(announceEvent); + }); +} export const injectCardano = (oracleUrl: string, jsonRpcProviderUrl: string) => { - window.ethereum = new Provider(oracleUrl, jsonRpcProviderUrl, PROVIDER_TYPES.CARDANO); + const provider = new Provider(oracleUrl, jsonRpcProviderUrl, PROVIDER_TYPES.CARDANO); + window.ethereum = provider; // note: other wallets may override this or block this from even being set + addEip6963Listener(cardanoWscEip6963Info); - return window.ethereum; + return provider; }; export const injectAlgorand = (oracleUrl: string, jsonRpcProviderUrl: string) => { - window.ethereum = new Provider(oracleUrl, jsonRpcProviderUrl, PROVIDER_TYPES.ALGORAND); + const provider = new Provider(oracleUrl, jsonRpcProviderUrl, PROVIDER_TYPES.ALGORAND); + window.ethereum = provider; // note: other wallets may override this or block this from even being set + addEip6963Listener(algorandWscEip6963Info); - return window.ethereum; + return provider; }; export type { CardanoProvider, MilkomedaProvider };