catalyst_cardano 0.4.0+3 copy "catalyst_cardano: ^0.4.0+3" to clipboard
catalyst_cardano: ^0.4.0+3 copied to clipboard

Platformweb

A Flutter plugin exposing the CIP-30 and CIP-95 APIs. Allows to communicate with the Cardano Wallet Extension via js_interop integration.

Content #

Features #

This package implements CIP-30 and CIP-95 APIs which allow the Flutter web app to communicate with the Cardano wallet extension.

In short, the package exposes window.{walletName} JS api taking away all the complexities of using js_interop.

Requirements #

  • Dart: 3.5.0+
  • Flutter: 3.24.1+

Install #

dependencies:
    catalyst_cardano_serialization: any # or the latest version on Pub
    catalyst_cardano: any # or the latest version on Pub
    catalyst_cardano_web: any # or the latest version on Pub
    catalyst_key_derivation: any # or the latest version on Pub
copied to clipboard

Web setup #

Add the following line at the end of <head> section in web/index.html:

<script type="module" src="/assets/packages/catalyst_cardano_web/assets/js/catalyst_cardano.js"></script>
copied to clipboard

Example #

Import package:catalyst_cardano_serialization/catalyst_cardano_serialization.dart and package:catalyst_cardano/catalyst_cardano.dart, instantiate TransactionBuilder, provide transaction inputs, outputs, add change address for any remaining unspent UTXOs and build the transaction body.

To obtain the witnessSet call api.signTx(transaction: unsignedTx);. Finally, create a signed transaction and submit it to the blockchain with api.submitTx(transaction: signedTx);

import 'dart:async';

import 'package:catalyst_cardano/catalyst_cardano.dart';
import 'package:catalyst_cardano_serialization/catalyst_cardano_serialization.dart';
import 'package:catalyst_key_derivation/catalyst_key_derivation.dart';

Future<void> main() async {
  await CatalystKeyDerivation.init();

  final wallets = await CatalystCardano.instance.getWallets();
  if (wallets.isEmpty) {
    // no wallet extension found, please install in your browser
    return;
  }

  final wallet = wallets.first;
  print(wallet.name);
  print(wallet.icon);
  print(wallet.apiVersion);
  print(wallet.supportedExtensions);

  final api = await wallet.enable();
  assert(await wallet.isEnabled(), 'wallet is enabled');

  print(await api.getBalance());
  print(await api.getExtensions());
  print(await api.getNetworkId());
  print(await api.getRewardAddresses());
  print(await api.getUnusedAddresses());
  print(await api.getUsedAddresses());

  final unsignedTx = _buildUnsignedTx(
    utxos: await api.getUtxos(
      amount: const Balance(
        coin: Coin(1000000),
      ),
    ),
    changeAddress: await api.getChangeAddress(),
  );

  final witnessSet = await api.signTx(transaction: unsignedTx);
  final signedTx = Transaction(
    body: unsignedTx.body,
    isValid: true,
    witnessSet: witnessSet,
  );
  await api.submitTx(transaction: signedTx);
}

Transaction _buildUnsignedTx({
  required Set<TransactionUnspentOutput> utxos,
  required ShelleyAddress changeAddress,
}) {
  const txBuilderConfig = TransactionBuilderConfig(
    feeAlgo: TieredFee(
      constant: 155381,
      coefficient: 44,
      refScriptByteCost: 15,
    ),
    maxTxSize: 16384,
    maxValueSize: 5000,
    coinsPerUtxoByte: Coin(4310),
  );

  /* cSpell:disable */
  final preprodFaucetAddress = ShelleyAddress.fromBech32(
    'addr_test1vzpwq95z3xyum8vqndgdd9mdnmafh3djcxnc6jemlgdmswcve6tkw',
  );
  /* cSpell:enable */

  final txOutput = TransactionOutput(
    address: preprodFaucetAddress,
    amount: const Balance(coin: Coin(1000000)),
  );

  final txBuilder = TransactionBuilder(
    config: txBuilderConfig,
    inputs: utxos,
    networkId: NetworkId.testnet,
  );

  final txBody = txBuilder
      .withOutput(txOutput)
      .withChangeAddressIfNeeded(changeAddress)
      .buildBody();

  return Transaction(
    body: txBody,
    isValid: true,
    witnessSet: const TransactionWitnessSet(vkeyWitnesses: {}),
  );
}
copied to clipboard

Limitations #

This package supports a minimal TransactionBuilder that does not yet work with Smart Contracts or scripts. However AuxiliaryMetadata is already supported thus it's possible to fulfill some of the use cases. NFTs are partially supported, i.e. to transfer them in a transaction.

Only Shelley era bech32 base and stake addresses are supported. Byron era addresses are not supported.

Reference documentation #

Support #

Post issues and feature requests on the GitHub issue tracker. Please read our CONTRIBUTING for guidelines on how to contribute.

License #

Licensed under either of Apache License, Version 2.0 or MIT license at your option.

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.

2
likes
160
points
29
downloads

Publisher

verified publisherprojectcatalyst.io

Weekly Downloads

2024.07.06 - 2025.01.18

A Flutter plugin exposing the CIP-30 and CIP-95 APIs. Allows to communicate with the Cardano Wallet Extension via js_interop integration.

Repository (GitHub)
View/report issues
Contributing

Topics

#blockchain #cardano #cryptocurrency #wallet

Documentation

API reference

License

Apache-2.0 (license)

Dependencies

catalyst_cardano_platform_interface, catalyst_cardano_serialization, catalyst_cardano_web, flutter

More

Packages that depend on catalyst_cardano