Skip to content

cosmostation/cosmostation-app-injection-example

Repository files navigation

Cosmostation App Wallet Injection Example

This code used the Cosmostation Wallet Injection Script to help developers to build dApps using the Cosmostation Mobile wallet and Cosmostation extension wallet.

By unifying the injection script interface, developers can seamlessly integrate both the Mobile wallet and Extension wallet within a single codebase.

Run example page

npm install

npm run dev

Flow Overview

  1. When the wallet is either installed or the page is loaded via the Cosmostation wallet (mobile or extension), cosmostation object will present as a window variable of global. This object allows you to execute the injected Script.

    Please navigate to the following from the mobile if you wish to test the functionality of your developing dApp

    Setting -> App Info -> Developer -> Enter the link of the developing dApp

  2. Upon the initialization of the app, an offlineSigner is used to create a cosmjs client, which is then added to the global context

    If you need assistance with the code regarding this, please refer to the following directory src/providers/ClientProvider.tsx

    To define the offlineSigner, simply refer to the code provided below

    // Example code of getOfflineSigner
    const getOfflineSigner = (chainId: string) => {
      const signer: OfflineSigner = {
        getAccounts: async () => {
          const account = await getAccount(chainId);
    
          if (!account) throw Error("getAccount Failed");
    
          return [
            {
              address: account.address,
              pubkey: account.publicKey,
              algo: "secp256k1",
            },
          ];
        },
        signDirect: async (_, signDoc: SignDoc) => {
          const response = await signDirect(signDoc);
    
          if (!response) throw Error("signDirect Failed");
    
          return {
            signed: {
              accountNumber: response.signed_doc.account_number,
              chainId: response.signed_doc.chain_id,
              authInfoBytes: response.signed_doc.auth_info_bytes,
              bodyBytes: response.signed_doc.body_bytes,
            },
            signature: {
              pub_key: response.pub_key,
              signature: response.signature,
            },
          };
        },
      };
      return signer;
    };
    // Example code of create client with signer
    const offlineSigner = await getOfflineSigner(chain.chainId);
    
    const client = await SigningStargateClient.connectWithSigner(
      chain.rpc,
      offlineSigner,
      { gasPrice: GasPrice.fromString(`0.025${chain.denom}`) }
    );
  3. With this setup, you can proceed to build your app using cosmjs.

    // Example code of sendTokens via cosmjs (src/hooks/useCosmJS.ts)
    await client.sendTokens(from, to, amount, fee, memo);

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages