TypeScript library for using Haveno.
npm install haveno-ts
import { HavenoClient } from "haveno-ts";
// create client connected to Haveno daemon
const alice = new HavenoClient("http://localhost:8080", "apitest");
// use Haveno daemon
const balances = await alice.getBalances();
const paymentAccounts = await alice.getPaymentAccounts();
const myOffers = await alice.getMyOffers("ETH");
const offers = await alice.getOffers("ETH", "BUY");
const trade = await alice.takeOffer(offers[0].getId(), paymentAccounts[0].getId());
// disconnect client
await alice.disconnect();
See TypeDocs.
Running the API tests is the best way to develop and test Haveno end-to-end. HavenoClient.ts
provides the client interface to Haveno's backend daemon.
You first need to start a local Haveno network which can be done manually or using docker.
make user1-daemon-local
. You may omit the arbitrator registration steps since it's done automatically in the tests.git clone https://github.com/haveno-dex/haveno-ts
docker run --network host --rm --add-host host.docker.internal:host-gateway -it -v ~/git/haveno-ts/config/envoy.test.yaml:/envoy.test.yaml -p 8079:8079 -p 8080:8080 -p 8081:8081 -p 8082:8082 -p 8083:8083 -p 8084:8084 -p 8085:8085 -p 8086:8086 envoyproxy/envoy-dev:latest -c /envoy.test.yaml
cd ~/git/haveno && make funding-wallet-local
.Alternatively, start a local Haveno network with docker:
cd ~/git/haveno-ts/docker
sudo docker-compose up
. This will start docker and initialize the network.Docker Tips
- Stop:
sudo docker-compose stop
- Rebuild:
sudo docker-compose build
- Stop and delete contains:
sudo docker-compose stop
protoc-gen-grpc-web
plugin and make executable as shown here.cd haveno-ts
npm install
npm run test -- --baseCurrencyNetwork=XMR_LOCAL
to run all tests or npm run test -- --baseCurrencyNetwork=XMR_LOCAL -t "Can get the version"
to run tests by name.Generated using TypeDoc