kondor-js
TypeScript icon, indicating that this package has built-in type declarations

1.1.0 • Public • Published

Kondor JS

Library to interact with Kondor, the browser extension for Koinos blockchain.

Table of Contents

  1. Install
  2. Usage
  3. Documentation
  4. License

Install

Install the package from NPM

npm install kondor-js

You can also load it directly to the browser by downloading the bunble file located at dist/kondor.min.js, or its non-minified version dist/kondor.js (useful for debugging).

Usage

Vanilla JS

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <title>My App</title>
    <script src="kondor.min.js"></script>
    <script src="koilib.min.js"></script>
    <script>
      (async () => {
        const accounts = await kondor.getAccounts();
        const userAddress = accounts[0].address;

        const koinContract = new Contract({
          id: "19JntSm8pSNETT9aHTwAUHC5RMoaSmgZPJ",
          abi: utils.tokenAbi,
          provider: kondor.getProvider("harbinger"),
          signer: kondor.getSigner(userAddress),
        });
        const koin = koinContract.functions;

        // Get balance
        const { result } = await koin.balanceOf({
          owner: userAddress,
        });
        console.log(balance.result);
      })();
    </script>
  </head>
  <body></body>
</html>

NOTE: For koilib check https://github.com/joticajulian/koilib

Using a framework

import * as kondor from "kondor-js";
import { Contract, utils } from "koilib";

(async () => {
  const accounts = await kondor.getAccounts();
  const userAddress = accounts[0].address;

  const koinContract = new Contract({
    id: "19JntSm8pSNETT9aHTwAUHC5RMoaSmgZPJ",
    abi: utils.tokenAbi,
    provider: kondor.getProvider("harbinger"),
    signer: kondor.getSigner(userAddress),
  });
  const koin = koinContract.functions;

  // Get balance
  const { result } = await koin.balanceOf({
    owner: userAddress,
  });
  console.log(balance.result);
})();

Known issues

In some cases Kondor triggers 2 popups. In particular when transaction options like chainId, rcLimit, and nonce are defined beforehand and then Kondor doesn't have to calculate them.

If this happens to you then define the signer in this way:

const provider = new Provider(["https://api.koinos.io"]);
const userAddress = "1K6oESWG87m3cB3M2WVkzxdTr38po8WToN";
const signer = kondor.getSigner(userAddress, {
  providerPrepareTransaction: provider,
});

With this definition, kondor will use providerPrepareTransaction in the preparation of the transaction instead of calling the kondor extension. This solves the race condition with double popups.

Take into account that if you use this code but the chainId, rcLimit, or nonce are not defined, then it's normal to see a delay between the click and the popup (because they are called using the provider before triggering the popup). In conclusion, define the 3 values when using providerPrepareTransaction to not experiment delays.

Note: This is a temporary solution while the race condition with double popups is fixed.

Test

Run yarn serve and open in the browser http://localhost:8081/test.html. This page contains a basic example to get accounts and make a transfer using Kondor.

Acknowledgments

Many thanks to the sponsors of this library: @levineam, @Amikob, @motoeng, @isaacdozier, @imjwalker, and the private sponsors.

If you would like to contribute to the development of this library consider becoming a sponsor in https://github.com/sponsors/joticajulian.

License

MIT License

Copyright (c) 2021 Julián González

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

Readme

Keywords

none

Package Sidebar

Install

npm i kondor-js

Weekly Downloads

22

Version

1.1.0

License

none

Unpacked Size

134 kB

Total Files

39

Last publish

Collaborators

  • joticajulian