Compare commits
17 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 55f40238c6 | |||
| 0e97d6c040 | |||
| 854dccd79c | |||
| a792313b68 | |||
| 7778adb493 | |||
| 33988b5164 | |||
| 284c25ff5a | |||
| 9d72229fa6 | |||
| da8d14ae84 | |||
| 2e4f7bbc70 | |||
| cbafe4adcf | |||
| 967b6c8e34 | |||
| c3dad4231d | |||
| ba8ed878c9 | |||
| 744860d4f9 | |||
| 0013e7ac40 | |||
| 0fcc42e02d |
@@ -4,7 +4,7 @@ on:
|
||||
|
||||
jobs:
|
||||
publish:
|
||||
runs-on: arc-ubuntu-22.04
|
||||
runs-on: ubuntu-latest
|
||||
steps:
|
||||
- uses: actions/checkout@v4
|
||||
|
||||
@@ -17,10 +17,13 @@ jobs:
|
||||
- name: Setup yarn
|
||||
run: npm install -g yarn
|
||||
|
||||
- name: Install Rust stable
|
||||
- name: Install rust toolchain
|
||||
uses: actions-rs/toolchain@v1
|
||||
with:
|
||||
profile: minimal
|
||||
toolchain: stable
|
||||
override: true
|
||||
components: rustfmt, clippy
|
||||
|
||||
- name: Install wasm-pack
|
||||
run: curl https://rustwasm.github.io/wasm-pack/installer/init.sh -sSf | sh
|
||||
@@ -29,9 +32,9 @@ jobs:
|
||||
run: cargo install wasm-opt
|
||||
|
||||
- name: Set up Go
|
||||
uses: actions/setup-go@v5
|
||||
uses: actions/setup-go@v6
|
||||
with:
|
||||
go-version: "1.23.7"
|
||||
go-version: "1.24.6"
|
||||
|
||||
- name: Install dependencies
|
||||
run: yarn
|
||||
|
||||
Generated
+8
-7
@@ -2262,7 +2262,7 @@ dependencies = [
|
||||
"libc",
|
||||
"option-ext",
|
||||
"redox_users",
|
||||
"windows-sys 0.59.0",
|
||||
"windows-sys 0.60.2",
|
||||
]
|
||||
|
||||
[[package]]
|
||||
@@ -2579,7 +2579,7 @@ dependencies = [
|
||||
|
||||
[[package]]
|
||||
name = "extension-storage"
|
||||
version = "1.4.0-rc.0"
|
||||
version = "1.4.1"
|
||||
dependencies = [
|
||||
"bip39",
|
||||
"console_error_panic_hook",
|
||||
@@ -4478,7 +4478,7 @@ dependencies = [
|
||||
|
||||
[[package]]
|
||||
name = "mix-fetch-wasm"
|
||||
version = "1.4.0-rc.0"
|
||||
version = "1.4.1-rc1"
|
||||
dependencies = [
|
||||
"async-trait",
|
||||
"futures",
|
||||
@@ -4488,6 +4488,7 @@ dependencies = [
|
||||
"nym-ordered-buffer",
|
||||
"nym-service-providers-common",
|
||||
"nym-socks5-requests",
|
||||
"nym-validator-client",
|
||||
"rand 0.8.5",
|
||||
"serde",
|
||||
"serde-wasm-bindgen 0.6.5",
|
||||
@@ -5283,7 +5284,7 @@ dependencies = [
|
||||
|
||||
[[package]]
|
||||
name = "nym-client-wasm"
|
||||
version = "1.4.0-rc.0"
|
||||
version = "1.4.1-rc1"
|
||||
dependencies = [
|
||||
"anyhow",
|
||||
"futures",
|
||||
@@ -6642,7 +6643,7 @@ dependencies = [
|
||||
|
||||
[[package]]
|
||||
name = "nym-node-tester-wasm"
|
||||
version = "1.3.0-rc.0"
|
||||
version = "1.3.1-rc0"
|
||||
dependencies = [
|
||||
"futures",
|
||||
"js-sys",
|
||||
@@ -7823,9 +7824,9 @@ checksum = "d05e27ee213611ffe7d6348b942e8f942b37114c00cc03cec254295a4a17852e"
|
||||
|
||||
[[package]]
|
||||
name = "openssl-sys"
|
||||
version = "0.9.109"
|
||||
version = "0.9.110"
|
||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||
checksum = "90096e2e47630d78b7d1c20952dc621f957103f8bc2c8359ec81290d75238571"
|
||||
checksum = "0a9f0075ba3c21b09f8e8b2026584b1d18d49388648f2fbbf3c97ea8deced8e2"
|
||||
dependencies = [
|
||||
"cc",
|
||||
"libc",
|
||||
|
||||
+1
-1
@@ -150,7 +150,7 @@ members = [
|
||||
"tools/internal/contract-state-importer/importer-cli",
|
||||
"tools/internal/contract-state-importer/importer-contract",
|
||||
"tools/internal/mixnet-connectivity-check",
|
||||
# "tools/internal/sdk-version-bump",
|
||||
# "tools/internal/sdk-version-bump",
|
||||
"tools/internal/ssl-inject",
|
||||
"tools/internal/testnet-manager",
|
||||
"tools/internal/testnet-manager/dkg-bypass-contract",
|
||||
|
||||
@@ -107,16 +107,16 @@ sdk-wasm-build:
|
||||
$(MAKE) -C nym-browser-extension/storage wasm-pack
|
||||
$(MAKE) -C wasm/client
|
||||
$(MAKE) -C wasm/node-tester
|
||||
# $(MAKE) -C wasm/mix-fetch
|
||||
$(MAKE) -C wasm/mix-fetch
|
||||
$(MAKE) -C wasm/zknym-lib
|
||||
# $(MAKE) -C wasm/full-nym-wasm
|
||||
|
||||
# run this from npm/yarn to ensure tools are in the path, e.g. yarn build:sdk from root of repo
|
||||
sdk-typescript-build:
|
||||
npx lerna run --scope @nymproject/sdk build --stream
|
||||
# npx lerna run --scope @nymproject/mix-fetch build --stream
|
||||
# npx lerna run --scope @nymproject/node-tester build --stream
|
||||
# yarn --cwd sdk/typescript/codegen/contract-clients build
|
||||
npx lerna run --scope @nymproject/mix-fetch build --stream
|
||||
npx lerna run --scope @nymproject/node-tester build --stream
|
||||
yarn --cwd sdk/typescript/codegen/contract-clients build
|
||||
|
||||
# NOTE: These targets are part of the main workspace (but not as wasm32-unknown-unknown)
|
||||
WASM_CRATES = extension-storage nym-client-wasm nym-node-tester-wasm zknym-lib
|
||||
|
||||
+16
-16
@@ -2,23 +2,23 @@
|
||||
|
||||
/** @type {import('next').NextConfig} */
|
||||
const nextConfig = {
|
||||
reactStrictMode: true,
|
||||
reactStrictMode: true,
|
||||
|
||||
basePath: "/explorer",
|
||||
assetPrefix: "/explorer",
|
||||
trailingSlash: false,
|
||||
basePath: "/explorer",
|
||||
assetPrefix: "/explorer",
|
||||
trailingSlash: false,
|
||||
|
||||
async redirects() {
|
||||
return [
|
||||
// Change the basePath to /explorer
|
||||
{
|
||||
source: "/",
|
||||
destination: "/explorer",
|
||||
basePath: false,
|
||||
permanent: true,
|
||||
},
|
||||
];
|
||||
},
|
||||
async redirects() {
|
||||
return [
|
||||
// Change the basePath to /explorer
|
||||
{
|
||||
source: "/",
|
||||
destination: "/explorer",
|
||||
basePath: false,
|
||||
permanent: true,
|
||||
},
|
||||
];
|
||||
},
|
||||
};
|
||||
|
||||
module.exports = nextConfig
|
||||
module.exports = nextConfig;
|
||||
|
||||
@@ -1,5 +1,6 @@
|
||||
"use client";
|
||||
import type { IObservatoryNode } from "@/app/api/types";
|
||||
import { NYM_ACCOUNT_ADDRESS } from "@/app/api/urls";
|
||||
import { Search } from "@mui/icons-material";
|
||||
import {
|
||||
Autocomplete,
|
||||
@@ -13,7 +14,6 @@ import { useQuery } from "@tanstack/react-query";
|
||||
import { useRouter } from "next/navigation";
|
||||
import { useState } from "react";
|
||||
import { fetchObservatoryNodes } from "../../app/api";
|
||||
import { NYM_ACCOUNT_ADDRESS } from "@/app/api/urls";
|
||||
|
||||
const NodeAndAddressSearch = () => {
|
||||
const router = useRouter();
|
||||
@@ -50,7 +50,7 @@ const NodeAndAddressSearch = () => {
|
||||
}
|
||||
} catch {
|
||||
setErrorText(
|
||||
"No node found with the provided Name, Node ID or Identity Key. Please check your input and try again."
|
||||
"No node found with the provided Name, Node ID or Identity Key. Please check your input and try again.",
|
||||
);
|
||||
setIsLoading(false); // Stop loading
|
||||
|
||||
@@ -58,7 +58,7 @@ const NodeAndAddressSearch = () => {
|
||||
}
|
||||
} else {
|
||||
setErrorText(
|
||||
"No node found with the provided Name, Node ID or Identity Key. Please check your input and try again."
|
||||
"No node found with the provided Name, Node ID or Identity Key. Please check your input and try again.",
|
||||
);
|
||||
setIsLoading(false); // Stop loading
|
||||
|
||||
@@ -68,7 +68,7 @@ const NodeAndAddressSearch = () => {
|
||||
// Check if it's a node identity key
|
||||
if (nymNodes) {
|
||||
const matchingNode = nymNodes.find(
|
||||
(node) => node.identity_key === inputValue
|
||||
(node) => node.identity_key === inputValue,
|
||||
);
|
||||
|
||||
if (matchingNode) {
|
||||
@@ -77,13 +77,13 @@ const NodeAndAddressSearch = () => {
|
||||
}
|
||||
}
|
||||
setErrorText(
|
||||
"No node found with the provided Name, Node ID or Identity Key. Please check your input and try again."
|
||||
"No node found with the provided Name, Node ID or Identity Key. Please check your input and try again.",
|
||||
);
|
||||
setIsLoading(false);
|
||||
}
|
||||
} catch (error) {
|
||||
setErrorText(
|
||||
"No node found with the provided Name, Node ID or Identity Key. Please check your input and try again."
|
||||
"No node found with the provided Name, Node ID or Identity Key. Please check your input and try again.",
|
||||
);
|
||||
console.error(error);
|
||||
setIsLoading(false); // Stop loading
|
||||
@@ -92,7 +92,7 @@ const NodeAndAddressSearch = () => {
|
||||
|
||||
// Handle search input change
|
||||
const handleSearchInputChange = (
|
||||
event: React.ChangeEvent<HTMLInputElement>
|
||||
event: React.ChangeEvent<HTMLInputElement>,
|
||||
) => {
|
||||
const value = event.target.value;
|
||||
setInputValue(value);
|
||||
@@ -107,7 +107,7 @@ const NodeAndAddressSearch = () => {
|
||||
const filteredNodes = nymNodes.filter((node) =>
|
||||
node.self_description?.moniker
|
||||
?.toLowerCase()
|
||||
.includes(value.toLowerCase())
|
||||
.includes(value.toLowerCase()),
|
||||
);
|
||||
setSearchOptions(filteredNodes);
|
||||
} else {
|
||||
@@ -118,7 +118,7 @@ const NodeAndAddressSearch = () => {
|
||||
// Handle node selection from dropdown
|
||||
const handleNodeSelect = (
|
||||
event: React.SyntheticEvent,
|
||||
value: string | IObservatoryNode | null
|
||||
value: string | IObservatoryNode | null,
|
||||
) => {
|
||||
if (value && typeof value !== "string") {
|
||||
setIsLoading(true); // Show loading spinner
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
[package]
|
||||
name = "extension-storage"
|
||||
version = "1.4.0-rc.0"
|
||||
version = "1.4.1"
|
||||
edition = "2024"
|
||||
license = "Apache-2.0"
|
||||
repository = "https://github.com/nymtech/nym"
|
||||
|
||||
@@ -80,6 +80,7 @@
|
||||
"@types/big.js": "^6.1.6",
|
||||
"@types/bs58": "^4.0.1",
|
||||
"@types/jest": "^27.0.1",
|
||||
"@types/minimatch": "5.1.2",
|
||||
"@types/node": "^16.7.13",
|
||||
"@types/qrcode.react": "^1.0.2",
|
||||
"@types/react": "^18.0.26",
|
||||
@@ -131,5 +132,8 @@
|
||||
"webpack-favicons": "^1.3.8",
|
||||
"webpack-merge": "^5.8.0"
|
||||
},
|
||||
"resolutions": {
|
||||
"@types/minimatch": "5.1.2"
|
||||
},
|
||||
"private": false
|
||||
}
|
||||
@@ -1,32 +1,32 @@
|
||||
import React from 'react';
|
||||
import { Box, Typography, Grid, Link, Card, CardContent, Stack } from '@mui/material';
|
||||
import { NymCard } from '..';
|
||||
import BitfinexIcon from 'src/svg-icons/bitfinex.svg';
|
||||
import KrakenIcon from 'src/svg-icons/kraken.svg';
|
||||
import BybitIcon from 'src/svg-icons/bybit.svg';
|
||||
import GateIcon from 'src/svg-icons/gate22.svg';
|
||||
import HTXIcon from 'src/svg-icons/htx.svg';
|
||||
import { NymCard } from '..';
|
||||
|
||||
const ExchangeCard = ({
|
||||
name,
|
||||
tokenType,
|
||||
url,
|
||||
IconComponent
|
||||
const ExchangeCard = ({
|
||||
name,
|
||||
tokenType,
|
||||
url,
|
||||
IconComponent,
|
||||
}: {
|
||||
name: string;
|
||||
tokenType: string;
|
||||
url: string;
|
||||
IconComponent: React.FunctionComponent<React.SVGProps<SVGSVGElement>>;
|
||||
}) => (
|
||||
<Card
|
||||
variant="outlined"
|
||||
sx={{
|
||||
<Card
|
||||
variant="outlined"
|
||||
sx={{
|
||||
height: '100%',
|
||||
transition: 'all 0.2s ease-in-out',
|
||||
'&:hover': {
|
||||
transform: 'translateY(-2px)',
|
||||
boxShadow: 2,
|
||||
}
|
||||
},
|
||||
}}
|
||||
>
|
||||
<CardContent sx={{ p: 3 }}>
|
||||
@@ -51,17 +51,17 @@ const ExchangeCard = ({
|
||||
<Typography variant="body2" sx={{ color: 'text.secondary' }}>
|
||||
{tokenType}
|
||||
</Typography>
|
||||
<Link
|
||||
href={url}
|
||||
target="_blank"
|
||||
<Link
|
||||
href={url}
|
||||
target="_blank"
|
||||
variant="body2"
|
||||
data-testid="link-get-nym"
|
||||
sx={{
|
||||
sx={{
|
||||
textDecoration: 'underline',
|
||||
fontWeight: 500,
|
||||
'&:hover': {
|
||||
textDecoration: 'none',
|
||||
}
|
||||
},
|
||||
}}
|
||||
>
|
||||
GET NYM
|
||||
@@ -78,44 +78,40 @@ export const Tutorial = () => {
|
||||
name: 'Bitfinex',
|
||||
tokenType: 'Native NYM, ERC-20',
|
||||
url: 'https://www.bitfinex.com/',
|
||||
IconComponent: BitfinexIcon
|
||||
IconComponent: BitfinexIcon,
|
||||
},
|
||||
{
|
||||
name: 'Kraken',
|
||||
tokenType: 'Native NYM',
|
||||
url: 'https://www.kraken.com/',
|
||||
IconComponent: KrakenIcon
|
||||
IconComponent: KrakenIcon,
|
||||
},
|
||||
{
|
||||
name: 'Bybit',
|
||||
tokenType: 'ERC-20',
|
||||
url: 'https://www.bybit.com/en/',
|
||||
IconComponent: BybitIcon
|
||||
IconComponent: BybitIcon,
|
||||
},
|
||||
{
|
||||
name: 'Gate.io',
|
||||
tokenType: 'ERC-20',
|
||||
url: 'https://www.gate.io/',
|
||||
IconComponent: GateIcon
|
||||
IconComponent: GateIcon,
|
||||
},
|
||||
{
|
||||
name: 'HTX',
|
||||
tokenType: 'ERC-20',
|
||||
url: 'https://www.htx.com/',
|
||||
IconComponent: HTXIcon
|
||||
IconComponent: HTXIcon,
|
||||
},
|
||||
];
|
||||
|
||||
return (
|
||||
<NymCard
|
||||
borderless
|
||||
title="Where you can get NYM tokens"
|
||||
sx={{ mt: 4 }}
|
||||
>
|
||||
<NymCard borderless title="Where you can get NYM tokens" sx={{ mt: 4 }}>
|
||||
<Typography mb={3} fontSize={14} sx={{ color: 'text.secondary' }}>
|
||||
You can get NYM tokens from these exchanges
|
||||
</Typography>
|
||||
|
||||
|
||||
<Grid container spacing={3}>
|
||||
{exchanges.map((exchange) => (
|
||||
<Grid item xs={12} md={6} lg={4} key={exchange.name}>
|
||||
|
||||
+41
-40
@@ -1,49 +1,41 @@
|
||||
{
|
||||
"name": "@nymproject/nymsphere",
|
||||
"version": "1.0.0",
|
||||
"private": true,
|
||||
"version": "1.0.1",
|
||||
"license": "Apache 2.0",
|
||||
"workspaces": [
|
||||
"sdk/typescript/packages/**",
|
||||
"sdk/typescript/examples/**",
|
||||
"ts-packages/*",
|
||||
"nym-wallet",
|
||||
"explorer-nextjs",
|
||||
"explorer-v2",
|
||||
"types",
|
||||
"clients/validator",
|
||||
"sdk/typescript/packages/**",
|
||||
"sdk/typescript/examples/**",
|
||||
"sdk/typescript/codegen/**"
|
||||
],
|
||||
"scripts": {
|
||||
"nuke": "npx rimraf **/node_modules node_modules",
|
||||
"scrub": "npx rimraf **/dist dist",
|
||||
"clean": "lerna run clean",
|
||||
"audit:fix": "npm_config_yes=true npx yarn-audit-fix -- --dry-run",
|
||||
"build": "run-s build:types build:packages",
|
||||
"build:wasm": "make sdk-wasm-build",
|
||||
"build:types": "lerna run --scope @nymproject/types build --stream",
|
||||
"build:packages": "run-s build:packages:theme build:packages:react",
|
||||
"build:packages:theme": "lerna run --scope @nymproject/mui-theme build",
|
||||
"build:packages:react": "lerna run --scope @nymproject/react build",
|
||||
"build:playground": "lerna run --scope @nymproject/react storybook:build --stream",
|
||||
"build:ci": "run-s build:types build:packages build:wasm build:ci:sdk",
|
||||
"build:ci:sdk": "lerna run --scope '{@nymproject/sdk,@nymproject/node-tester,@nymproject/sdk-react,@nymproject/mix-fetch,@nymproject/nodejs-client,@nymproject/mix-fetch-node}' build --stream",
|
||||
"build:ci:storybook": "yarn build && yarn dev:on && run-p build:playground && yarn build:ci:storybook:collect-artifacts ",
|
||||
"build:ci:storybook:collect-artifacts": "mkdir -p ts-packages/dist && mv sdk/typescript/packages/react-components/storybook-static ts-packages/dist/storybook ",
|
||||
"prebuild:ci": "yarn dev:on && yarn",
|
||||
"build:ci": "run-s build:types build:packages build:wasm build:ci:sdk",
|
||||
"postbuild:ci": "yarn dev:off",
|
||||
"build:ci:sdk": "lerna run --scope '{@nymproject/sdk,@nymproject/node-tester,@nymproject/sdk-react,@nymproject/mix-fetch,@nymproject/nodejs-client,@nymproject/mix-fetch-node}' build --stream",
|
||||
"build:packages": "run-s build:packages:theme build:packages:react",
|
||||
"build:packages:react": "lerna run --scope @nymproject/react build",
|
||||
"build:packages:theme": "lerna run --scope @nymproject/mui-theme build",
|
||||
"build:playground": "lerna run --scope @nymproject/react storybook:build --stream",
|
||||
"build:types": "lerna run --scope @nymproject/types build --stream",
|
||||
"build:wasm": "make sdk-wasm-build",
|
||||
"clean": "lerna run clean",
|
||||
"dev:off": "node sdk/typescript/scripts/dev-mode-remove.mjs",
|
||||
"dev:on": "node sdk/typescript/scripts/dev-mode-add.mjs",
|
||||
"docs:prod:build": "run-s docs:prod:build:ws",
|
||||
"docs:prod:build:ws": "lerna run docs:prod:build --stream",
|
||||
"sdk:build": "./sdk/typescript/scripts/build-prod-sdk.sh",
|
||||
"sdk:publish": "./sdk/typescript/scripts/publish.sh",
|
||||
"lint": "lerna run lint --stream",
|
||||
"lint:fix": "lerna run lint:fix --stream",
|
||||
"nuke": "npx rimraf **/node_modules node_modules",
|
||||
"postbuild:ci": "yarn dev:off",
|
||||
"prebuild:ci": "yarn dev:on && yarn",
|
||||
"scrub": "npx rimraf **/dist dist",
|
||||
"sdk:build": "./sdk/typescript/scripts/build-prod-sdk.sh",
|
||||
"sdk:publish": "./sdk/typescript/scripts/publish.sh",
|
||||
"sdk:versions:add-rc": "cargo run -p sdk-version-bump --pre-release",
|
||||
"sdk:versions:bump": "cargo run -p sdk-version-bump bump-version",
|
||||
"sdk:versions:remove-rc": "cargo run -p sdk-version-bump remove-suffix",
|
||||
"tsc": "lerna run tsc --stream",
|
||||
"types:lint:fix": "lerna run lint:fix --scope @nymproject/types --scope @nymproject/nym-wallet-app",
|
||||
"audit:fix": "npm_config_yes=true npx yarn-audit-fix -- --dry-run",
|
||||
"dev:on": "node sdk/typescript/scripts/dev-mode-add.mjs",
|
||||
"dev:off": "node sdk/typescript/scripts/dev-mode-remove.mjs"
|
||||
"types:lint:fix": "lerna run lint:fix --scope @nymproject/types --scope @nymproject/nym-wallet-app"
|
||||
},
|
||||
"dependencies": {
|
||||
"lucide-react": "^0.453.0"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@npmcli/node-gyp": "^3.0.0",
|
||||
@@ -53,14 +45,23 @@
|
||||
"npm-run-all": "^4.1.5",
|
||||
"tslog": "3.3.3"
|
||||
},
|
||||
"dependencies": {
|
||||
"lucide-react": "^0.453.0"
|
||||
},
|
||||
"private": true,
|
||||
"resolutions": {
|
||||
"@cosmjs/amino": "^0.32.4",
|
||||
"@cosmjs/cosmwasm-stargate": "^0.32.4",
|
||||
"@cosmjs/proto-signing": "^0.32.4",
|
||||
"@cosmjs/stargate": "^0.32.4",
|
||||
"@cosmjs/cosmwasm-stargate": "^0.32.4",
|
||||
"cosmjs-types": "^0.9.0"
|
||||
}
|
||||
}
|
||||
},
|
||||
"workspaces": [
|
||||
"ts-packages/*",
|
||||
"nym-wallet",
|
||||
"explorer-nextjs",
|
||||
"explorer-v2",
|
||||
"types",
|
||||
"clients/validator",
|
||||
"sdk/typescript/packages/mix-fetch/internal-dev",
|
||||
"sdk/typescript/packages/react-components",
|
||||
"sdk/typescript/packages/mui-theme"
|
||||
]
|
||||
}
|
||||
@@ -3,13 +3,11 @@ import codegen from '@cosmwasm/ts-codegen';
|
||||
codegen
|
||||
.default({
|
||||
contracts: [
|
||||
{ name: 'coconut-bandwidth', dir: '../../../../contracts/coconut-bandwidth' },
|
||||
{ name: 'ecash', dir: '../../../../contracts/ecash' },
|
||||
{ name: 'coconut-dkg', dir: '../../../../contracts/coconut-dkg' },
|
||||
{ name: 'mixnet', dir: '../../../../contracts/mixnet' },
|
||||
{ name: 'cw3-flex-multisig', dir: '../../../../contracts/multisig/cw3-flex-multisig' },
|
||||
{ name: 'cw4-group', dir: '../../../../contracts/multisig/cw4-group' },
|
||||
{ name: 'name-service', dir: '../../../../contracts/name-service' },
|
||||
{ name: 'service-provider-directory', dir: '../../../../contracts/service-provider-directory' },
|
||||
{ name: 'vesting', dir: '../../../../contracts/vesting' },
|
||||
],
|
||||
outPath: './src',
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/contract-clients",
|
||||
"version": "1.3.0-rc.0",
|
||||
"version": "1.3.1-rc0",
|
||||
"description": "A client for all Nym smart contracts",
|
||||
"license": "Apache-2.0",
|
||||
"author": "Nym Technologies SA",
|
||||
@@ -18,7 +18,7 @@
|
||||
"docs:watch": "nodemon --ext ts --watch './src/**/*' --watch './typedoc.json' --exec \"yarn docs:generate\""
|
||||
},
|
||||
"devDependencies": {
|
||||
"@cosmwasm/ts-codegen": "^0.35.3",
|
||||
"@cosmwasm/ts-codegen": "^1.13.3",
|
||||
"nodemon": "3.0.1",
|
||||
"npm-run-all": "^4.1.5",
|
||||
"reload": "^3.2.1",
|
||||
@@ -27,4 +27,4 @@
|
||||
},
|
||||
"private": false,
|
||||
"types": "./dist/index.d.ts"
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,23 +1,58 @@
|
||||
/**
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@0.35.3.
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@1.13.3.
|
||||
* DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,
|
||||
* and run the @cosmwasm/ts-codegen generate command to regenerate this file.
|
||||
*/
|
||||
|
||||
import { CosmWasmClient, SigningCosmWasmClient, ExecuteResult } from "@cosmjs/cosmwasm-stargate";
|
||||
import { Coin, StdFee } from "@cosmjs/amino";
|
||||
import { InstantiateMsg, TimeConfiguration, ExecuteMsg, ContractSafeBytes, Addr, QueryMsg, MigrateMsg, PagedDealerResponse, DealerDetails, Timestamp, Uint64, EpochState, Epoch, DealerType, DealerDetailsResponse, PagedDealingsResponse, ContractDealing, NullableInitialReplacementData, InitialReplacementData, PagedVKSharesResponse, ContractVKShare } from "./CoconutDkg.types";
|
||||
|
||||
import { ICosmWasmClient, ISigningCosmWasmClient } from "./baseClient";
|
||||
import { Coin, StdFee } from "@interchainjs/types";
|
||||
import { InstantiateMsg, TimeConfiguration, ExecuteMsg, ContractSafeBytes, DealingChunkInfo, PartialContractDealing, QueryMsg, MigrateMsg, EpochState, Timestamp, Uint64, StateAdvanceResponse, StateProgress, ContractVersion, Addr, PagedDealerResponse, DealerDetails, Epoch, DealerDealingsStatusResponse, DealerType, DealerDetailsResponse, PagedDealerIndexResponse, DealingChunkResponse, DealingChunkStatusResponse, ChunkSubmissionStatus, DealingStatusResponse, DealingStatus, DealingMetadataResponse, DealingMetadata, PagedDealerAddressesResponse, NullableEpoch, RegisteredDealerDetails, DealerRegistrationDetails, Cw4Contract, State, VkShareResponse, ContractVKShare, PagedVKSharesResponse } from "./CoconutDkg.types";
|
||||
export interface CoconutDkgReadOnlyInterface {
|
||||
contractAddress: string;
|
||||
getState: () => Promise<State>;
|
||||
getCurrentEpochState: () => Promise<Epoch>;
|
||||
getEpochStateAtHeight: ({
|
||||
height
|
||||
}: {
|
||||
height: number;
|
||||
}) => Promise<NullableEpoch>;
|
||||
getCurrentEpochThreshold: () => Promise<Uint64>;
|
||||
getInitialDealers: () => Promise<NullableInitialReplacementData>;
|
||||
getEpochThreshold: ({
|
||||
epochId
|
||||
}: {
|
||||
epochId: number;
|
||||
}) => Promise<Uint64>;
|
||||
canAdvanceState: () => Promise<StateAdvanceResponse>;
|
||||
getRegisteredDealer: ({
|
||||
dealerAddress,
|
||||
epochId
|
||||
}: {
|
||||
dealerAddress: string;
|
||||
epochId?: number;
|
||||
}) => Promise<RegisteredDealerDetails>;
|
||||
getDealerDetails: ({
|
||||
dealerAddress
|
||||
}: {
|
||||
dealerAddress: string;
|
||||
}) => Promise<DealerDetailsResponse>;
|
||||
getEpochDealersAddresses: ({
|
||||
epochId,
|
||||
limit,
|
||||
startAfter
|
||||
}: {
|
||||
epochId: number;
|
||||
limit?: number;
|
||||
startAfter?: string;
|
||||
}) => Promise<PagedDealerAddressesResponse>;
|
||||
getEpochDealers: ({
|
||||
epochId,
|
||||
limit,
|
||||
startAfter
|
||||
}: {
|
||||
epochId: number;
|
||||
limit?: number;
|
||||
startAfter?: string;
|
||||
}) => Promise<PagedDealerResponse>;
|
||||
getCurrentDealers: ({
|
||||
limit,
|
||||
startAfter
|
||||
@@ -25,22 +60,67 @@ export interface CoconutDkgReadOnlyInterface {
|
||||
limit?: number;
|
||||
startAfter?: string;
|
||||
}) => Promise<PagedDealerResponse>;
|
||||
getPastDealers: ({
|
||||
getDealerIndices: ({
|
||||
limit,
|
||||
startAfter
|
||||
}: {
|
||||
limit?: number;
|
||||
startAfter?: string;
|
||||
}) => Promise<PagedDealerResponse>;
|
||||
getDealing: ({
|
||||
idx,
|
||||
limit,
|
||||
startAfter
|
||||
}) => Promise<PagedDealerIndexResponse>;
|
||||
getDealingsMetadata: ({
|
||||
dealer,
|
||||
dealingIndex,
|
||||
epochId
|
||||
}: {
|
||||
idx: number;
|
||||
limit?: number;
|
||||
startAfter?: string;
|
||||
}) => Promise<PagedDealingsResponse>;
|
||||
dealer: string;
|
||||
dealingIndex: number;
|
||||
epochId: number;
|
||||
}) => Promise<DealingMetadataResponse>;
|
||||
getDealerDealingsStatus: ({
|
||||
dealer,
|
||||
epochId
|
||||
}: {
|
||||
dealer: string;
|
||||
epochId: number;
|
||||
}) => Promise<DealerDealingsStatusResponse>;
|
||||
getDealingStatus: ({
|
||||
dealer,
|
||||
dealingIndex,
|
||||
epochId
|
||||
}: {
|
||||
dealer: string;
|
||||
dealingIndex: number;
|
||||
epochId: number;
|
||||
}) => Promise<DealingStatusResponse>;
|
||||
getDealingChunkStatus: ({
|
||||
chunkIndex,
|
||||
dealer,
|
||||
dealingIndex,
|
||||
epochId
|
||||
}: {
|
||||
chunkIndex: number;
|
||||
dealer: string;
|
||||
dealingIndex: number;
|
||||
epochId: number;
|
||||
}) => Promise<DealingChunkStatusResponse>;
|
||||
getDealingChunk: ({
|
||||
chunkIndex,
|
||||
dealer,
|
||||
dealingIndex,
|
||||
epochId
|
||||
}: {
|
||||
chunkIndex: number;
|
||||
dealer: string;
|
||||
dealingIndex: number;
|
||||
epochId: number;
|
||||
}) => Promise<DealingChunkResponse>;
|
||||
getVerificationKey: ({
|
||||
epochId,
|
||||
owner
|
||||
}: {
|
||||
epochId: number;
|
||||
owner: string;
|
||||
}) => Promise<VkShareResponse>;
|
||||
getVerificationKeys: ({
|
||||
epochId,
|
||||
limit,
|
||||
@@ -50,37 +130,89 @@ export interface CoconutDkgReadOnlyInterface {
|
||||
limit?: number;
|
||||
startAfter?: string;
|
||||
}) => Promise<PagedVKSharesResponse>;
|
||||
getCw2ContractVersion: () => Promise<GetCw2ContractVersionResponse>;
|
||||
}
|
||||
export class CoconutDkgQueryClient implements CoconutDkgReadOnlyInterface {
|
||||
client: CosmWasmClient;
|
||||
client: ICosmWasmClient;
|
||||
contractAddress: string;
|
||||
|
||||
constructor(client: CosmWasmClient, contractAddress: string) {
|
||||
constructor(client: ICosmWasmClient, contractAddress: string) {
|
||||
this.client = client;
|
||||
this.contractAddress = contractAddress;
|
||||
this.getState = this.getState.bind(this);
|
||||
this.getCurrentEpochState = this.getCurrentEpochState.bind(this);
|
||||
this.getEpochStateAtHeight = this.getEpochStateAtHeight.bind(this);
|
||||
this.getCurrentEpochThreshold = this.getCurrentEpochThreshold.bind(this);
|
||||
this.getInitialDealers = this.getInitialDealers.bind(this);
|
||||
this.getEpochThreshold = this.getEpochThreshold.bind(this);
|
||||
this.canAdvanceState = this.canAdvanceState.bind(this);
|
||||
this.getRegisteredDealer = this.getRegisteredDealer.bind(this);
|
||||
this.getDealerDetails = this.getDealerDetails.bind(this);
|
||||
this.getEpochDealersAddresses = this.getEpochDealersAddresses.bind(this);
|
||||
this.getEpochDealers = this.getEpochDealers.bind(this);
|
||||
this.getCurrentDealers = this.getCurrentDealers.bind(this);
|
||||
this.getPastDealers = this.getPastDealers.bind(this);
|
||||
this.getDealing = this.getDealing.bind(this);
|
||||
this.getDealerIndices = this.getDealerIndices.bind(this);
|
||||
this.getDealingsMetadata = this.getDealingsMetadata.bind(this);
|
||||
this.getDealerDealingsStatus = this.getDealerDealingsStatus.bind(this);
|
||||
this.getDealingStatus = this.getDealingStatus.bind(this);
|
||||
this.getDealingChunkStatus = this.getDealingChunkStatus.bind(this);
|
||||
this.getDealingChunk = this.getDealingChunk.bind(this);
|
||||
this.getVerificationKey = this.getVerificationKey.bind(this);
|
||||
this.getVerificationKeys = this.getVerificationKeys.bind(this);
|
||||
this.getCw2ContractVersion = this.getCw2ContractVersion.bind(this);
|
||||
}
|
||||
|
||||
getState = async (): Promise<State> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_state: {}
|
||||
});
|
||||
};
|
||||
getCurrentEpochState = async (): Promise<Epoch> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_current_epoch_state: {}
|
||||
});
|
||||
};
|
||||
getEpochStateAtHeight = async ({
|
||||
height
|
||||
}: {
|
||||
height: number;
|
||||
}): Promise<NullableEpoch> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_epoch_state_at_height: {
|
||||
height
|
||||
}
|
||||
});
|
||||
};
|
||||
getCurrentEpochThreshold = async (): Promise<Uint64> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_current_epoch_threshold: {}
|
||||
});
|
||||
};
|
||||
getInitialDealers = async (): Promise<NullableInitialReplacementData> => {
|
||||
getEpochThreshold = async ({
|
||||
epochId
|
||||
}: {
|
||||
epochId: number;
|
||||
}): Promise<Uint64> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_initial_dealers: {}
|
||||
get_epoch_threshold: {
|
||||
epoch_id: epochId
|
||||
}
|
||||
});
|
||||
};
|
||||
canAdvanceState = async (): Promise<StateAdvanceResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
can_advance_state: {}
|
||||
});
|
||||
};
|
||||
getRegisteredDealer = async ({
|
||||
dealerAddress,
|
||||
epochId
|
||||
}: {
|
||||
dealerAddress: string;
|
||||
epochId?: number;
|
||||
}): Promise<RegisteredDealerDetails> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_registered_dealer: {
|
||||
dealer_address: dealerAddress,
|
||||
epoch_id: epochId
|
||||
}
|
||||
});
|
||||
};
|
||||
getDealerDetails = async ({
|
||||
@@ -94,6 +226,40 @@ export class CoconutDkgQueryClient implements CoconutDkgReadOnlyInterface {
|
||||
}
|
||||
});
|
||||
};
|
||||
getEpochDealersAddresses = async ({
|
||||
epochId,
|
||||
limit,
|
||||
startAfter
|
||||
}: {
|
||||
epochId: number;
|
||||
limit?: number;
|
||||
startAfter?: string;
|
||||
}): Promise<PagedDealerAddressesResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_epoch_dealers_addresses: {
|
||||
epoch_id: epochId,
|
||||
limit,
|
||||
start_after: startAfter
|
||||
}
|
||||
});
|
||||
};
|
||||
getEpochDealers = async ({
|
||||
epochId,
|
||||
limit,
|
||||
startAfter
|
||||
}: {
|
||||
epochId: number;
|
||||
limit?: number;
|
||||
startAfter?: string;
|
||||
}): Promise<PagedDealerResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_epoch_dealers: {
|
||||
epoch_id: epochId,
|
||||
limit,
|
||||
start_after: startAfter
|
||||
}
|
||||
});
|
||||
};
|
||||
getCurrentDealers = async ({
|
||||
limit,
|
||||
startAfter
|
||||
@@ -108,34 +274,119 @@ export class CoconutDkgQueryClient implements CoconutDkgReadOnlyInterface {
|
||||
}
|
||||
});
|
||||
};
|
||||
getPastDealers = async ({
|
||||
getDealerIndices = async ({
|
||||
limit,
|
||||
startAfter
|
||||
}: {
|
||||
limit?: number;
|
||||
startAfter?: string;
|
||||
}): Promise<PagedDealerResponse> => {
|
||||
}): Promise<PagedDealerIndexResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_past_dealers: {
|
||||
get_dealer_indices: {
|
||||
limit,
|
||||
start_after: startAfter
|
||||
}
|
||||
});
|
||||
};
|
||||
getDealing = async ({
|
||||
idx,
|
||||
limit,
|
||||
startAfter
|
||||
getDealingsMetadata = async ({
|
||||
dealer,
|
||||
dealingIndex,
|
||||
epochId
|
||||
}: {
|
||||
idx: number;
|
||||
limit?: number;
|
||||
startAfter?: string;
|
||||
}): Promise<PagedDealingsResponse> => {
|
||||
dealer: string;
|
||||
dealingIndex: number;
|
||||
epochId: number;
|
||||
}): Promise<DealingMetadataResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_dealing: {
|
||||
idx,
|
||||
limit,
|
||||
start_after: startAfter
|
||||
get_dealings_metadata: {
|
||||
dealer,
|
||||
dealing_index: dealingIndex,
|
||||
epoch_id: epochId
|
||||
}
|
||||
});
|
||||
};
|
||||
getDealerDealingsStatus = async ({
|
||||
dealer,
|
||||
epochId
|
||||
}: {
|
||||
dealer: string;
|
||||
epochId: number;
|
||||
}): Promise<DealerDealingsStatusResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_dealer_dealings_status: {
|
||||
dealer,
|
||||
epoch_id: epochId
|
||||
}
|
||||
});
|
||||
};
|
||||
getDealingStatus = async ({
|
||||
dealer,
|
||||
dealingIndex,
|
||||
epochId
|
||||
}: {
|
||||
dealer: string;
|
||||
dealingIndex: number;
|
||||
epochId: number;
|
||||
}): Promise<DealingStatusResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_dealing_status: {
|
||||
dealer,
|
||||
dealing_index: dealingIndex,
|
||||
epoch_id: epochId
|
||||
}
|
||||
});
|
||||
};
|
||||
getDealingChunkStatus = async ({
|
||||
chunkIndex,
|
||||
dealer,
|
||||
dealingIndex,
|
||||
epochId
|
||||
}: {
|
||||
chunkIndex: number;
|
||||
dealer: string;
|
||||
dealingIndex: number;
|
||||
epochId: number;
|
||||
}): Promise<DealingChunkStatusResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_dealing_chunk_status: {
|
||||
chunk_index: chunkIndex,
|
||||
dealer,
|
||||
dealing_index: dealingIndex,
|
||||
epoch_id: epochId
|
||||
}
|
||||
});
|
||||
};
|
||||
getDealingChunk = async ({
|
||||
chunkIndex,
|
||||
dealer,
|
||||
dealingIndex,
|
||||
epochId
|
||||
}: {
|
||||
chunkIndex: number;
|
||||
dealer: string;
|
||||
dealingIndex: number;
|
||||
epochId: number;
|
||||
}): Promise<DealingChunkResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_dealing_chunk: {
|
||||
chunk_index: chunkIndex,
|
||||
dealer,
|
||||
dealing_index: dealingIndex,
|
||||
epoch_id: epochId
|
||||
}
|
||||
});
|
||||
};
|
||||
getVerificationKey = async ({
|
||||
epochId,
|
||||
owner
|
||||
}: {
|
||||
epochId: number;
|
||||
owner: string;
|
||||
}): Promise<VkShareResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_verification_key: {
|
||||
epoch_id: epochId,
|
||||
owner
|
||||
}
|
||||
});
|
||||
};
|
||||
@@ -156,91 +407,142 @@ export class CoconutDkgQueryClient implements CoconutDkgReadOnlyInterface {
|
||||
}
|
||||
});
|
||||
};
|
||||
getCw2ContractVersion = async (): Promise<GetCw2ContractVersionResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_cw2_contract_version: {}
|
||||
});
|
||||
};
|
||||
}
|
||||
export interface CoconutDkgInterface extends CoconutDkgReadOnlyInterface {
|
||||
contractAddress: string;
|
||||
sender: string;
|
||||
initiateDkg: (fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
registerDealer: ({
|
||||
announceAddress,
|
||||
bteKeyWithProof,
|
||||
identityKey,
|
||||
resharing
|
||||
}: {
|
||||
announceAddress: string;
|
||||
bteKeyWithProof: string;
|
||||
identityKey: string;
|
||||
resharing: boolean;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
commitDealing: ({
|
||||
dealingBytes,
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
commitDealingsMetadata: ({
|
||||
chunks,
|
||||
dealingIndex,
|
||||
resharing
|
||||
}: {
|
||||
dealingBytes: ContractSafeBytes;
|
||||
chunks: DealingChunkInfo[];
|
||||
dealingIndex: number;
|
||||
resharing: boolean;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
commitDealingsChunk: ({
|
||||
chunk
|
||||
}: {
|
||||
chunk: PartialContractDealing;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
commitVerificationKeyShare: ({
|
||||
resharing,
|
||||
share
|
||||
}: {
|
||||
resharing: boolean;
|
||||
share: string;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
verifyVerificationKeyShare: ({
|
||||
owner,
|
||||
resharing
|
||||
}: {
|
||||
owner: Addr;
|
||||
owner: string;
|
||||
resharing: boolean;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
surpassedThreshold: (fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
advanceEpochState: (fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
advanceEpochState: (fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
triggerReset: (fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
triggerResharing: (fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
transferOwnership: ({
|
||||
transferTo
|
||||
}: {
|
||||
transferTo: string;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
updateAnnounceAddress: ({
|
||||
newAddress
|
||||
}: {
|
||||
newAddress: string;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
}
|
||||
export class CoconutDkgClient extends CoconutDkgQueryClient implements CoconutDkgInterface {
|
||||
client: SigningCosmWasmClient;
|
||||
client: ISigningCosmWasmClient;
|
||||
sender: string;
|
||||
contractAddress: string;
|
||||
|
||||
constructor(client: SigningCosmWasmClient, sender: string, contractAddress: string) {
|
||||
constructor(client: ISigningCosmWasmClient, sender: string, contractAddress: string) {
|
||||
super(client, contractAddress);
|
||||
this.client = client;
|
||||
this.sender = sender;
|
||||
this.contractAddress = contractAddress;
|
||||
this.initiateDkg = this.initiateDkg.bind(this);
|
||||
this.registerDealer = this.registerDealer.bind(this);
|
||||
this.commitDealing = this.commitDealing.bind(this);
|
||||
this.commitDealingsMetadata = this.commitDealingsMetadata.bind(this);
|
||||
this.commitDealingsChunk = this.commitDealingsChunk.bind(this);
|
||||
this.commitVerificationKeyShare = this.commitVerificationKeyShare.bind(this);
|
||||
this.verifyVerificationKeyShare = this.verifyVerificationKeyShare.bind(this);
|
||||
this.surpassedThreshold = this.surpassedThreshold.bind(this);
|
||||
this.advanceEpochState = this.advanceEpochState.bind(this);
|
||||
this.triggerReset = this.triggerReset.bind(this);
|
||||
this.triggerResharing = this.triggerResharing.bind(this);
|
||||
this.transferOwnership = this.transferOwnership.bind(this);
|
||||
this.updateAnnounceAddress = this.updateAnnounceAddress.bind(this);
|
||||
}
|
||||
|
||||
initiateDkg = async (fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
initiate_dkg: {}
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
registerDealer = async ({
|
||||
announceAddress,
|
||||
bteKeyWithProof,
|
||||
identityKey,
|
||||
resharing
|
||||
}: {
|
||||
announceAddress: string;
|
||||
bteKeyWithProof: string;
|
||||
identityKey: string;
|
||||
resharing: boolean;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
register_dealer: {
|
||||
announce_address: announceAddress,
|
||||
bte_key_with_proof: bteKeyWithProof,
|
||||
identity_key: identityKey,
|
||||
resharing
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
commitDealing = async ({
|
||||
dealingBytes,
|
||||
commitDealingsMetadata = async ({
|
||||
chunks,
|
||||
dealingIndex,
|
||||
resharing
|
||||
}: {
|
||||
dealingBytes: ContractSafeBytes;
|
||||
chunks: DealingChunkInfo[];
|
||||
dealingIndex: number;
|
||||
resharing: boolean;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
commit_dealing: {
|
||||
dealing_bytes: dealingBytes,
|
||||
commit_dealings_metadata: {
|
||||
chunks,
|
||||
dealing_index: dealingIndex,
|
||||
resharing
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
commitDealingsChunk = async ({
|
||||
chunk
|
||||
}: {
|
||||
chunk: PartialContractDealing;
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
commit_dealings_chunk: {
|
||||
chunk
|
||||
}
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
commitVerificationKeyShare = async ({
|
||||
resharing,
|
||||
@@ -248,36 +550,63 @@ export class CoconutDkgClient extends CoconutDkgQueryClient implements CoconutDk
|
||||
}: {
|
||||
resharing: boolean;
|
||||
share: string;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
commit_verification_key_share: {
|
||||
resharing,
|
||||
share
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
verifyVerificationKeyShare = async ({
|
||||
owner,
|
||||
resharing
|
||||
}: {
|
||||
owner: Addr;
|
||||
owner: string;
|
||||
resharing: boolean;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
verify_verification_key_share: {
|
||||
owner,
|
||||
resharing
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
surpassedThreshold = async (fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
surpassed_threshold: {}
|
||||
}, fee, memo, _funds);
|
||||
};
|
||||
advanceEpochState = async (fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
advanceEpochState = async (fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
advance_epoch_state: {}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
}
|
||||
triggerReset = async (fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
trigger_reset: {}
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
triggerResharing = async (fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
trigger_resharing: {}
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
transferOwnership = async ({
|
||||
transferTo
|
||||
}: {
|
||||
transferTo: string;
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
transfer_ownership: {
|
||||
transfer_to: transferTo
|
||||
}
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
updateAnnounceAddress = async ({
|
||||
newAddress
|
||||
}: {
|
||||
newAddress: string;
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
update_announce_address: {
|
||||
new_address: newAddress
|
||||
}
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
}
|
||||
@@ -1,11 +1,12 @@
|
||||
/**
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@0.35.3.
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@1.13.3.
|
||||
* DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,
|
||||
* and run the @cosmwasm/ts-codegen generate command to regenerate this file.
|
||||
*/
|
||||
|
||||
export interface InstantiateMsg {
|
||||
group_addr: string;
|
||||
key_size: number;
|
||||
mix_denom: string;
|
||||
multisig_addr: string;
|
||||
time_configuration?: TimeConfiguration | null;
|
||||
@@ -19,16 +20,24 @@ export interface TimeConfiguration {
|
||||
verification_key_validation_time_secs: number;
|
||||
}
|
||||
export type ExecuteMsg = {
|
||||
initiate_dkg: {};
|
||||
} | {
|
||||
register_dealer: {
|
||||
announce_address: string;
|
||||
bte_key_with_proof: string;
|
||||
identity_key: string;
|
||||
resharing: boolean;
|
||||
};
|
||||
} | {
|
||||
commit_dealing: {
|
||||
dealing_bytes: ContractSafeBytes;
|
||||
commit_dealings_metadata: {
|
||||
chunks: DealingChunkInfo[];
|
||||
dealing_index: number;
|
||||
resharing: boolean;
|
||||
};
|
||||
} | {
|
||||
commit_dealings_chunk: {
|
||||
chunk: PartialContractDealing;
|
||||
};
|
||||
} | {
|
||||
commit_verification_key_share: {
|
||||
resharing: boolean;
|
||||
@@ -36,41 +45,115 @@ export type ExecuteMsg = {
|
||||
};
|
||||
} | {
|
||||
verify_verification_key_share: {
|
||||
owner: Addr;
|
||||
owner: string;
|
||||
resharing: boolean;
|
||||
};
|
||||
} | {
|
||||
surpassed_threshold: {};
|
||||
} | {
|
||||
advance_epoch_state: {};
|
||||
} | {
|
||||
trigger_reset: {};
|
||||
} | {
|
||||
trigger_resharing: {};
|
||||
} | {
|
||||
transfer_ownership: {
|
||||
transfer_to: string;
|
||||
};
|
||||
} | {
|
||||
update_announce_address: {
|
||||
new_address: string;
|
||||
};
|
||||
};
|
||||
export type ContractSafeBytes = number[];
|
||||
export type Addr = string;
|
||||
export interface DealingChunkInfo {
|
||||
size: number;
|
||||
}
|
||||
export interface PartialContractDealing {
|
||||
chunk_index: number;
|
||||
data: ContractSafeBytes;
|
||||
dealing_index: number;
|
||||
}
|
||||
export type QueryMsg = {
|
||||
get_state: {};
|
||||
} | {
|
||||
get_current_epoch_state: {};
|
||||
} | {
|
||||
get_epoch_state_at_height: {
|
||||
height: number;
|
||||
};
|
||||
} | {
|
||||
get_current_epoch_threshold: {};
|
||||
} | {
|
||||
get_initial_dealers: {};
|
||||
get_epoch_threshold: {
|
||||
epoch_id: number;
|
||||
};
|
||||
} | {
|
||||
can_advance_state: {};
|
||||
} | {
|
||||
get_registered_dealer: {
|
||||
dealer_address: string;
|
||||
epoch_id?: number | null;
|
||||
};
|
||||
} | {
|
||||
get_dealer_details: {
|
||||
dealer_address: string;
|
||||
};
|
||||
} | {
|
||||
get_epoch_dealers_addresses: {
|
||||
epoch_id: number;
|
||||
limit?: number | null;
|
||||
start_after?: string | null;
|
||||
};
|
||||
} | {
|
||||
get_epoch_dealers: {
|
||||
epoch_id: number;
|
||||
limit?: number | null;
|
||||
start_after?: string | null;
|
||||
};
|
||||
} | {
|
||||
get_current_dealers: {
|
||||
limit?: number | null;
|
||||
start_after?: string | null;
|
||||
};
|
||||
} | {
|
||||
get_past_dealers: {
|
||||
get_dealer_indices: {
|
||||
limit?: number | null;
|
||||
start_after?: string | null;
|
||||
};
|
||||
} | {
|
||||
get_dealing: {
|
||||
idx: number;
|
||||
limit?: number | null;
|
||||
start_after?: string | null;
|
||||
get_dealings_metadata: {
|
||||
dealer: string;
|
||||
dealing_index: number;
|
||||
epoch_id: number;
|
||||
};
|
||||
} | {
|
||||
get_dealer_dealings_status: {
|
||||
dealer: string;
|
||||
epoch_id: number;
|
||||
};
|
||||
} | {
|
||||
get_dealing_status: {
|
||||
dealer: string;
|
||||
dealing_index: number;
|
||||
epoch_id: number;
|
||||
};
|
||||
} | {
|
||||
get_dealing_chunk_status: {
|
||||
chunk_index: number;
|
||||
dealer: string;
|
||||
dealing_index: number;
|
||||
epoch_id: number;
|
||||
};
|
||||
} | {
|
||||
get_dealing_chunk: {
|
||||
chunk_index: number;
|
||||
dealer: string;
|
||||
dealing_index: number;
|
||||
epoch_id: number;
|
||||
};
|
||||
} | {
|
||||
get_verification_key: {
|
||||
epoch_id: number;
|
||||
owner: string;
|
||||
};
|
||||
} | {
|
||||
get_verification_keys: {
|
||||
@@ -78,22 +161,11 @@ export type QueryMsg = {
|
||||
limit?: number | null;
|
||||
start_after?: string | null;
|
||||
};
|
||||
} | {
|
||||
get_cw2_contract_version: {};
|
||||
};
|
||||
export interface MigrateMsg {}
|
||||
export interface PagedDealerResponse {
|
||||
dealers: DealerDetails[];
|
||||
per_page: number;
|
||||
start_next_after?: Addr | null;
|
||||
}
|
||||
export interface DealerDetails {
|
||||
address: Addr;
|
||||
announce_address: string;
|
||||
assigned_index: number;
|
||||
bte_public_key_with_proof: string;
|
||||
}
|
||||
export type Timestamp = Uint64;
|
||||
export type Uint64 = number;
|
||||
export type EpochState = "in_progress" | {
|
||||
export type EpochState = ("waiting_initialisation" | "in_progress") | {
|
||||
public_key_submission: {
|
||||
resharing: boolean;
|
||||
};
|
||||
@@ -114,36 +186,132 @@ export type EpochState = "in_progress" | {
|
||||
resharing: boolean;
|
||||
};
|
||||
};
|
||||
export type Timestamp = Uint64;
|
||||
export type Uint64 = number;
|
||||
export interface StateAdvanceResponse {
|
||||
current_state: EpochState;
|
||||
deadline?: Timestamp | null;
|
||||
is_complete: boolean;
|
||||
progress: StateProgress;
|
||||
reached_deadline: boolean;
|
||||
}
|
||||
export interface StateProgress {
|
||||
registered_dealers: number;
|
||||
registered_resharing_dealers: number;
|
||||
submitted_dealings: number;
|
||||
submitted_key_shares: number;
|
||||
verified_keys: number;
|
||||
}
|
||||
export interface ContractVersion {
|
||||
contract: string;
|
||||
version: string;
|
||||
}
|
||||
export type Addr = string;
|
||||
export interface PagedDealerResponse {
|
||||
dealers: DealerDetails[];
|
||||
per_page: number;
|
||||
start_next_after?: Addr | null;
|
||||
}
|
||||
export interface DealerDetails {
|
||||
address: Addr;
|
||||
announce_address: string;
|
||||
assigned_index: number;
|
||||
bte_public_key_with_proof: string;
|
||||
ed25519_identity: string;
|
||||
}
|
||||
export interface Epoch {
|
||||
deadline?: Timestamp | null;
|
||||
epoch_id: number;
|
||||
finish_timestamp: Timestamp;
|
||||
state: EpochState;
|
||||
state_progress: StateProgress;
|
||||
time_configuration: TimeConfiguration;
|
||||
}
|
||||
export type DealerType = "current" | "past" | "unknown";
|
||||
export interface DealerDealingsStatusResponse {
|
||||
all_dealings_fully_submitted: boolean;
|
||||
dealer: Addr;
|
||||
dealing_submission_status: {};
|
||||
epoch_id: number;
|
||||
}
|
||||
export type DealerType = "unknown" | {
|
||||
current: {
|
||||
assigned_index: number;
|
||||
};
|
||||
} | {
|
||||
past: {
|
||||
assigned_index: number;
|
||||
};
|
||||
};
|
||||
export interface DealerDetailsResponse {
|
||||
dealer_type: DealerType;
|
||||
details?: DealerDetails | null;
|
||||
}
|
||||
export interface PagedDealingsResponse {
|
||||
dealings: ContractDealing[];
|
||||
per_page: number;
|
||||
export interface PagedDealerIndexResponse {
|
||||
indices: [Addr, number][];
|
||||
start_next_after?: Addr | null;
|
||||
}
|
||||
export interface ContractDealing {
|
||||
export interface DealingChunkResponse {
|
||||
chunk?: ContractSafeBytes | null;
|
||||
chunk_index: number;
|
||||
dealer: Addr;
|
||||
dealing: ContractSafeBytes;
|
||||
dealing_index: number;
|
||||
epoch_id: number;
|
||||
}
|
||||
export type NullableInitialReplacementData = InitialReplacementData | null;
|
||||
export interface InitialReplacementData {
|
||||
initial_dealers: Addr[];
|
||||
initial_height: number;
|
||||
export interface DealingChunkStatusResponse {
|
||||
chunk_index: number;
|
||||
dealer: Addr;
|
||||
dealing_index: number;
|
||||
epoch_id: number;
|
||||
status: ChunkSubmissionStatus;
|
||||
}
|
||||
export interface PagedVKSharesResponse {
|
||||
per_page: number;
|
||||
shares: ContractVKShare[];
|
||||
export interface ChunkSubmissionStatus {
|
||||
submission_height?: number | null;
|
||||
}
|
||||
export interface DealingStatusResponse {
|
||||
dealer: Addr;
|
||||
dealing_index: number;
|
||||
epoch_id: number;
|
||||
status: DealingStatus;
|
||||
}
|
||||
export interface DealingStatus {
|
||||
chunk_submission_status: {};
|
||||
fully_submitted: boolean;
|
||||
has_metadata: boolean;
|
||||
}
|
||||
export interface DealingMetadataResponse {
|
||||
dealer: Addr;
|
||||
dealing_index: number;
|
||||
epoch_id: number;
|
||||
metadata?: DealingMetadata | null;
|
||||
}
|
||||
export interface DealingMetadata {
|
||||
dealing_index: number;
|
||||
submitted_chunks: {};
|
||||
}
|
||||
export interface PagedDealerAddressesResponse {
|
||||
dealers: Addr[];
|
||||
start_next_after?: Addr | null;
|
||||
}
|
||||
export type NullableEpoch = Epoch | null;
|
||||
export interface RegisteredDealerDetails {
|
||||
details?: DealerRegistrationDetails | null;
|
||||
}
|
||||
export interface DealerRegistrationDetails {
|
||||
announce_address: string;
|
||||
bte_public_key_with_proof: string;
|
||||
ed25519_identity: string;
|
||||
}
|
||||
export type Cw4Contract = Addr;
|
||||
export interface State {
|
||||
group_addr: Cw4Contract;
|
||||
key_size: number;
|
||||
mix_denom: string;
|
||||
multisig_addr: Addr;
|
||||
}
|
||||
export interface VkShareResponse {
|
||||
epoch_id: number;
|
||||
owner: Addr;
|
||||
share?: ContractVKShare | null;
|
||||
}
|
||||
export interface ContractVKShare {
|
||||
announce_address: string;
|
||||
epoch_id: number;
|
||||
@@ -151,4 +319,9 @@ export interface ContractVKShare {
|
||||
owner: Addr;
|
||||
share: string;
|
||||
verified: boolean;
|
||||
}
|
||||
export interface PagedVKSharesResponse {
|
||||
per_page: number;
|
||||
shares: ContractVKShare[];
|
||||
start_next_after?: Addr | null;
|
||||
}
|
||||
@@ -1,13 +1,12 @@
|
||||
/**
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@0.35.3.
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@1.13.3.
|
||||
* DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,
|
||||
* and run the @cosmwasm/ts-codegen generate command to regenerate this file.
|
||||
*/
|
||||
|
||||
import { CosmWasmClient, SigningCosmWasmClient, ExecuteResult } from "@cosmjs/cosmwasm-stargate";
|
||||
import { StdFee } from "@cosmjs/amino";
|
||||
import { Executor, Addr, Duration, Uint128, UncheckedDenom, Threshold, Decimal, InstantiateMsg, UncheckedDepositInfo, ExecuteMsg, Expiration, Timestamp, Uint64, CosmosMsgForEmpty, BankMsg, StakingMsg, DistributionMsg, Binary, IbcMsg, WasmMsg, GovMsg, VoteOption, Vote, Coin, Empty, IbcTimeout, IbcTimeoutBlock, MemberChangedHookMsg, MemberDiff, QueryMsg, MigrateMsg, Cw4Contract, Denom, Config, DepositInfo, Status, ThresholdResponse, ProposalListResponseForEmpty, ProposalResponseForEmpty, VoterListResponse, VoterDetail, VoteListResponse, VoteInfo, VoteResponse, VoterResponse } from "./Cw3FlexMultisig.types";
|
||||
|
||||
import { ICosmWasmClient, ISigningCosmWasmClient } from "./baseClient";
|
||||
import { StdFee } from "@interchainjs/types";
|
||||
import { Executor, Addr, Duration, Uint128, UncheckedDenom, Threshold, Decimal, InstantiateMsg, UncheckedDepositInfo, ExecuteMsg, Expiration, Timestamp, Uint64, CosmosMsgForEmpty, BankMsg, WasmMsg, Binary, Vote, Coin, Empty, MemberChangedHookMsg, MemberDiff, QueryMsg, MigrateMsg, Cw4Contract, Denom, Config, DepositInfo, Status, ThresholdResponse, ProposalListResponseForEmpty, ProposalResponseForEmpty, VoterListResponse, VoterDetail, VoteListResponse, VoteInfo, VoteResponse, VoterResponse } from "./Cw3FlexMultisig.types";
|
||||
export interface Cw3FlexMultisigReadOnlyInterface {
|
||||
contractAddress: string;
|
||||
threshold: () => Promise<ThresholdResponse>;
|
||||
@@ -61,10 +60,9 @@ export interface Cw3FlexMultisigReadOnlyInterface {
|
||||
config: () => Promise<Config>;
|
||||
}
|
||||
export class Cw3FlexMultisigQueryClient implements Cw3FlexMultisigReadOnlyInterface {
|
||||
client: CosmWasmClient;
|
||||
client: ICosmWasmClient;
|
||||
contractAddress: string;
|
||||
|
||||
constructor(client: CosmWasmClient, contractAddress: string) {
|
||||
constructor(client: ICosmWasmClient, contractAddress: string) {
|
||||
this.client = client;
|
||||
this.contractAddress = contractAddress;
|
||||
this.threshold = this.threshold.bind(this);
|
||||
@@ -77,7 +75,6 @@ export class Cw3FlexMultisigQueryClient implements Cw3FlexMultisigReadOnlyInterf
|
||||
this.listVoters = this.listVoters.bind(this);
|
||||
this.config = this.config.bind(this);
|
||||
}
|
||||
|
||||
threshold = async (): Promise<ThresholdResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
threshold: {}
|
||||
@@ -197,36 +194,35 @@ export interface Cw3FlexMultisigInterface extends Cw3FlexMultisigReadOnlyInterfa
|
||||
latest?: Expiration;
|
||||
msgs: CosmosMsgForEmpty[];
|
||||
title: string;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
// vote: ({
|
||||
// proposalId,
|
||||
// vote
|
||||
// }: {
|
||||
// proposalId: number;
|
||||
// vote: Vote;
|
||||
// }, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
vote: ({
|
||||
proposalId,
|
||||
vote
|
||||
}: {
|
||||
proposalId: number;
|
||||
vote: Vote;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
execute: ({
|
||||
proposalId
|
||||
}: {
|
||||
proposalId: number;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
close: ({
|
||||
proposalId
|
||||
}: {
|
||||
proposalId: number;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
memberChangedHook: ({
|
||||
diffs
|
||||
}: {
|
||||
diffs: MemberDiff[];
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
}
|
||||
export class Cw3FlexMultisigClient extends Cw3FlexMultisigQueryClient implements Cw3FlexMultisigInterface {
|
||||
client: SigningCosmWasmClient;
|
||||
client: ISigningCosmWasmClient;
|
||||
sender: string;
|
||||
contractAddress: string;
|
||||
|
||||
constructor(client: SigningCosmWasmClient, sender: string, contractAddress: string) {
|
||||
constructor(client: ISigningCosmWasmClient, sender: string, contractAddress: string) {
|
||||
super(client, contractAddress);
|
||||
this.client = client;
|
||||
this.sender = sender;
|
||||
@@ -237,7 +233,6 @@ export class Cw3FlexMultisigClient extends Cw3FlexMultisigQueryClient implements
|
||||
this.close = this.close.bind(this);
|
||||
this.memberChangedHook = this.memberChangedHook.bind(this);
|
||||
}
|
||||
|
||||
propose = async ({
|
||||
description,
|
||||
latest,
|
||||
@@ -248,7 +243,7 @@ export class Cw3FlexMultisigClient extends Cw3FlexMultisigQueryClient implements
|
||||
latest?: Expiration;
|
||||
msgs: CosmosMsgForEmpty[];
|
||||
title: string;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
propose: {
|
||||
description,
|
||||
@@ -256,53 +251,53 @@ export class Cw3FlexMultisigClient extends Cw3FlexMultisigQueryClient implements
|
||||
msgs,
|
||||
title
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
vote = async ({
|
||||
proposalId,
|
||||
vote
|
||||
}: {
|
||||
proposalId: number;
|
||||
vote: Vote;
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
vote: {
|
||||
proposal_id: proposalId,
|
||||
vote
|
||||
}
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
// vote = async ({
|
||||
// proposalId,
|
||||
// vote
|
||||
// }: {
|
||||
// proposalId: number;
|
||||
// vote: Vote;
|
||||
// }, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
// return await this.client.execute(this.sender, this.contractAddress, {
|
||||
// vote: {
|
||||
// proposal_id: proposalId,
|
||||
// vote
|
||||
// }
|
||||
// }, fee, memo, _funds);
|
||||
// };
|
||||
execute = async ({
|
||||
proposalId
|
||||
}: {
|
||||
proposalId: number;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
execute: {
|
||||
proposal_id: proposalId
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
close = async ({
|
||||
proposalId
|
||||
}: {
|
||||
proposalId: number;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
close: {
|
||||
proposal_id: proposalId
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
memberChangedHook = async ({
|
||||
diffs
|
||||
}: {
|
||||
diffs: MemberDiff[];
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
member_changed_hook: {
|
||||
diffs
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
}
|
||||
}
|
||||
@@ -1,5 +1,5 @@
|
||||
/**
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@0.35.3.
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@1.13.3.
|
||||
* DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,
|
||||
* and run the @cosmwasm/ts-codegen generate command to regenerate this file.
|
||||
*/
|
||||
@@ -84,86 +84,17 @@ export type CosmosMsgForEmpty = {
|
||||
bank: BankMsg;
|
||||
} | {
|
||||
custom: Empty;
|
||||
} | {
|
||||
staking: StakingMsg;
|
||||
} | {
|
||||
distribution: DistributionMsg;
|
||||
} | {
|
||||
stargate: {
|
||||
type_url: string;
|
||||
value: Binary;
|
||||
[k: string]: unknown;
|
||||
};
|
||||
} | {
|
||||
ibc: IbcMsg;
|
||||
} | {
|
||||
wasm: WasmMsg;
|
||||
} | {
|
||||
gov: GovMsg;
|
||||
};
|
||||
export type BankMsg = {
|
||||
send: {
|
||||
amount: Coin[];
|
||||
to_address: string;
|
||||
[k: string]: unknown;
|
||||
};
|
||||
} | {
|
||||
burn: {
|
||||
amount: Coin[];
|
||||
[k: string]: unknown;
|
||||
};
|
||||
};
|
||||
export type StakingMsg = {
|
||||
delegate: {
|
||||
amount: Coin;
|
||||
validator: string;
|
||||
[k: string]: unknown;
|
||||
};
|
||||
} | {
|
||||
undelegate: {
|
||||
amount: Coin;
|
||||
validator: string;
|
||||
[k: string]: unknown;
|
||||
};
|
||||
} | {
|
||||
redelegate: {
|
||||
amount: Coin;
|
||||
dst_validator: string;
|
||||
src_validator: string;
|
||||
[k: string]: unknown;
|
||||
};
|
||||
};
|
||||
export type DistributionMsg = {
|
||||
set_withdraw_address: {
|
||||
address: string;
|
||||
[k: string]: unknown;
|
||||
};
|
||||
} | {
|
||||
withdraw_delegator_reward: {
|
||||
validator: string;
|
||||
[k: string]: unknown;
|
||||
};
|
||||
};
|
||||
export type Binary = string;
|
||||
export type IbcMsg = {
|
||||
transfer: {
|
||||
amount: Coin;
|
||||
channel_id: string;
|
||||
timeout: IbcTimeout;
|
||||
to_address: string;
|
||||
[k: string]: unknown;
|
||||
};
|
||||
} | {
|
||||
send_packet: {
|
||||
channel_id: string;
|
||||
data: Binary;
|
||||
timeout: IbcTimeout;
|
||||
[k: string]: unknown;
|
||||
};
|
||||
} | {
|
||||
close_channel: {
|
||||
channel_id: string;
|
||||
[k: string]: unknown;
|
||||
};
|
||||
};
|
||||
export type WasmMsg = {
|
||||
@@ -171,7 +102,6 @@ export type WasmMsg = {
|
||||
contract_addr: string;
|
||||
funds: Coin[];
|
||||
msg: Binary;
|
||||
[k: string]: unknown;
|
||||
};
|
||||
} | {
|
||||
instantiate: {
|
||||
@@ -180,54 +110,30 @@ export type WasmMsg = {
|
||||
funds: Coin[];
|
||||
label: string;
|
||||
msg: Binary;
|
||||
[k: string]: unknown;
|
||||
};
|
||||
} | {
|
||||
migrate: {
|
||||
contract_addr: string;
|
||||
msg: Binary;
|
||||
new_code_id: number;
|
||||
[k: string]: unknown;
|
||||
};
|
||||
} | {
|
||||
update_admin: {
|
||||
admin: string;
|
||||
contract_addr: string;
|
||||
[k: string]: unknown;
|
||||
};
|
||||
} | {
|
||||
clear_admin: {
|
||||
contract_addr: string;
|
||||
[k: string]: unknown;
|
||||
};
|
||||
};
|
||||
export type GovMsg = {
|
||||
vote: {
|
||||
proposal_id: number;
|
||||
vote: VoteOption;
|
||||
[k: string]: unknown;
|
||||
};
|
||||
};
|
||||
export type VoteOption = "yes" | "no" | "abstain" | "no_with_veto";
|
||||
export type Binary = string;
|
||||
export type Vote = "yes" | "no" | "abstain" | "veto";
|
||||
export interface Coin {
|
||||
amount: Uint128;
|
||||
denom: string;
|
||||
[k: string]: unknown;
|
||||
}
|
||||
export interface Empty {
|
||||
[k: string]: unknown;
|
||||
}
|
||||
export interface IbcTimeout {
|
||||
block?: IbcTimeoutBlock | null;
|
||||
timestamp?: Timestamp | null;
|
||||
[k: string]: unknown;
|
||||
}
|
||||
export interface IbcTimeoutBlock {
|
||||
height: number;
|
||||
revision: number;
|
||||
[k: string]: unknown;
|
||||
}
|
||||
export interface Empty {}
|
||||
export interface MemberChangedHookMsg {
|
||||
diffs: MemberDiff[];
|
||||
}
|
||||
|
||||
@@ -1,13 +1,12 @@
|
||||
/**
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@0.35.3.
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@1.13.3.
|
||||
* DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,
|
||||
* and run the @cosmwasm/ts-codegen generate command to regenerate this file.
|
||||
*/
|
||||
|
||||
import { CosmWasmClient, SigningCosmWasmClient, ExecuteResult } from "@cosmjs/cosmwasm-stargate";
|
||||
import { Coin, StdFee } from "@cosmjs/amino";
|
||||
import { ICosmWasmClient, ISigningCosmWasmClient } from "./baseClient";
|
||||
import { Coin, StdFee } from "@interchainjs/types";
|
||||
import { InstantiateMsg, Member, ExecuteMsg, QueryMsg, MigrateMsg, AdminResponse, HooksResponse, MemberListResponse, MemberResponse, TotalWeightResponse } from "./Cw4Group.types";
|
||||
|
||||
export interface Cw4GroupReadOnlyInterface {
|
||||
contractAddress: string;
|
||||
admin: () => Promise<AdminResponse>;
|
||||
@@ -33,10 +32,9 @@ export interface Cw4GroupReadOnlyInterface {
|
||||
hooks: () => Promise<HooksResponse>;
|
||||
}
|
||||
export class Cw4GroupQueryClient implements Cw4GroupReadOnlyInterface {
|
||||
client: CosmWasmClient;
|
||||
client: ICosmWasmClient;
|
||||
contractAddress: string;
|
||||
|
||||
constructor(client: CosmWasmClient, contractAddress: string) {
|
||||
constructor(client: ICosmWasmClient, contractAddress: string) {
|
||||
this.client = client;
|
||||
this.contractAddress = contractAddress;
|
||||
this.admin = this.admin.bind(this);
|
||||
@@ -45,7 +43,6 @@ export class Cw4GroupQueryClient implements Cw4GroupReadOnlyInterface {
|
||||
this.member = this.member.bind(this);
|
||||
this.hooks = this.hooks.bind(this);
|
||||
}
|
||||
|
||||
admin = async (): Promise<AdminResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
admin: {}
|
||||
@@ -103,31 +100,30 @@ export interface Cw4GroupInterface extends Cw4GroupReadOnlyInterface {
|
||||
admin
|
||||
}: {
|
||||
admin?: string;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
updateMembers: ({
|
||||
add,
|
||||
remove
|
||||
}: {
|
||||
add: Member[];
|
||||
remove: string[];
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
addHook: ({
|
||||
addr
|
||||
}: {
|
||||
addr: string;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
removeHook: ({
|
||||
addr
|
||||
}: {
|
||||
addr: string;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
}
|
||||
export class Cw4GroupClient extends Cw4GroupQueryClient implements Cw4GroupInterface {
|
||||
client: SigningCosmWasmClient;
|
||||
client: ISigningCosmWasmClient;
|
||||
sender: string;
|
||||
contractAddress: string;
|
||||
|
||||
constructor(client: SigningCosmWasmClient, sender: string, contractAddress: string) {
|
||||
constructor(client: ISigningCosmWasmClient, sender: string, contractAddress: string) {
|
||||
super(client, contractAddress);
|
||||
this.client = client;
|
||||
this.sender = sender;
|
||||
@@ -137,17 +133,16 @@ export class Cw4GroupClient extends Cw4GroupQueryClient implements Cw4GroupInter
|
||||
this.addHook = this.addHook.bind(this);
|
||||
this.removeHook = this.removeHook.bind(this);
|
||||
}
|
||||
|
||||
updateAdmin = async ({
|
||||
admin
|
||||
}: {
|
||||
admin?: string;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
update_admin: {
|
||||
admin
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
updateMembers = async ({
|
||||
add,
|
||||
@@ -155,34 +150,34 @@ export class Cw4GroupClient extends Cw4GroupQueryClient implements Cw4GroupInter
|
||||
}: {
|
||||
add: Member[];
|
||||
remove: string[];
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
update_members: {
|
||||
add,
|
||||
remove
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
addHook = async ({
|
||||
addr
|
||||
}: {
|
||||
addr: string;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
add_hook: {
|
||||
addr
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
removeHook = async ({
|
||||
addr
|
||||
}: {
|
||||
addr: string;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
remove_hook: {
|
||||
addr
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
}
|
||||
}
|
||||
@@ -1,5 +1,5 @@
|
||||
/**
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@0.35.3.
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@1.13.3.
|
||||
* DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,
|
||||
* and run the @cosmwasm/ts-codegen generate command to regenerate this file.
|
||||
*/
|
||||
|
||||
@@ -0,0 +1,256 @@
|
||||
/**
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@1.13.3.
|
||||
* DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,
|
||||
* and run the @cosmwasm/ts-codegen generate command to regenerate this file.
|
||||
*/
|
||||
|
||||
import { ICosmWasmClient, ISigningCosmWasmClient } from "./baseClient";
|
||||
import { StdFee } from "@interchainjs/types";
|
||||
import { Uint128, InstantiateMsg, Coin, ExecuteMsg, QueryMsg, MigrateMsg, PagedBlacklistedAccountResponse, BlacklistedAccount, Blacklisting, BlacklistedAccountResponse, DepositResponse, Deposit, PagedDepositsResponse, DepositData, LatestDepositResponse } from "./Ecash.types";
|
||||
export interface EcashReadOnlyInterface {
|
||||
contractAddress: string;
|
||||
getBlacklistedAccount: ({
|
||||
publicKey
|
||||
}: {
|
||||
publicKey: string;
|
||||
}) => Promise<BlacklistedAccountResponse>;
|
||||
getBlacklistPaged: ({
|
||||
limit,
|
||||
startAfter
|
||||
}: {
|
||||
limit?: number;
|
||||
startAfter?: string;
|
||||
}) => Promise<PagedBlacklistedAccountResponse>;
|
||||
getRequiredDepositAmount: () => Promise<Coin>;
|
||||
getDeposit: ({
|
||||
depositId
|
||||
}: {
|
||||
depositId: number;
|
||||
}) => Promise<DepositResponse>;
|
||||
getLatestDeposit: () => Promise<LatestDepositResponse>;
|
||||
getDepositsPaged: ({
|
||||
limit,
|
||||
startAfter
|
||||
}: {
|
||||
limit?: number;
|
||||
startAfter?: number;
|
||||
}) => Promise<PagedDepositsResponse>;
|
||||
}
|
||||
export class EcashQueryClient implements EcashReadOnlyInterface {
|
||||
client: ICosmWasmClient;
|
||||
contractAddress: string;
|
||||
constructor(client: ICosmWasmClient, contractAddress: string) {
|
||||
this.client = client;
|
||||
this.contractAddress = contractAddress;
|
||||
this.getBlacklistedAccount = this.getBlacklistedAccount.bind(this);
|
||||
this.getBlacklistPaged = this.getBlacklistPaged.bind(this);
|
||||
this.getRequiredDepositAmount = this.getRequiredDepositAmount.bind(this);
|
||||
this.getDeposit = this.getDeposit.bind(this);
|
||||
this.getLatestDeposit = this.getLatestDeposit.bind(this);
|
||||
this.getDepositsPaged = this.getDepositsPaged.bind(this);
|
||||
}
|
||||
getBlacklistedAccount = async ({
|
||||
publicKey
|
||||
}: {
|
||||
publicKey: string;
|
||||
}): Promise<BlacklistedAccountResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_blacklisted_account: {
|
||||
public_key: publicKey
|
||||
}
|
||||
});
|
||||
};
|
||||
getBlacklistPaged = async ({
|
||||
limit,
|
||||
startAfter
|
||||
}: {
|
||||
limit?: number;
|
||||
startAfter?: string;
|
||||
}): Promise<PagedBlacklistedAccountResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_blacklist_paged: {
|
||||
limit,
|
||||
start_after: startAfter
|
||||
}
|
||||
});
|
||||
};
|
||||
getRequiredDepositAmount = async (): Promise<Coin> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_required_deposit_amount: {}
|
||||
});
|
||||
};
|
||||
getDeposit = async ({
|
||||
depositId
|
||||
}: {
|
||||
depositId: number;
|
||||
}): Promise<DepositResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_deposit: {
|
||||
deposit_id: depositId
|
||||
}
|
||||
});
|
||||
};
|
||||
getLatestDeposit = async (): Promise<LatestDepositResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_latest_deposit: {}
|
||||
});
|
||||
};
|
||||
getDepositsPaged = async ({
|
||||
limit,
|
||||
startAfter
|
||||
}: {
|
||||
limit?: number;
|
||||
startAfter?: number;
|
||||
}): Promise<PagedDepositsResponse> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_deposits_paged: {
|
||||
limit,
|
||||
start_after: startAfter
|
||||
}
|
||||
});
|
||||
};
|
||||
}
|
||||
export interface EcashInterface extends EcashReadOnlyInterface {
|
||||
contractAddress: string;
|
||||
sender: string;
|
||||
depositTicketBookFunds: ({
|
||||
identityKey
|
||||
}: {
|
||||
identityKey: string;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
requestRedemption: ({
|
||||
commitmentBs58,
|
||||
numberOfTickets
|
||||
}: {
|
||||
commitmentBs58: string;
|
||||
numberOfTickets: number;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
redeemTickets: ({
|
||||
gw,
|
||||
n
|
||||
}: {
|
||||
gw: string;
|
||||
n: number;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
updateAdmin: ({
|
||||
admin
|
||||
}: {
|
||||
admin: string;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
updateDepositValue: ({
|
||||
newDeposit
|
||||
}: {
|
||||
newDeposit: Coin;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
proposeToBlacklist: ({
|
||||
publicKey
|
||||
}: {
|
||||
publicKey: string;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
addToBlacklist: ({
|
||||
publicKey
|
||||
}: {
|
||||
publicKey: string;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
}
|
||||
export class EcashClient extends EcashQueryClient implements EcashInterface {
|
||||
client: ISigningCosmWasmClient;
|
||||
sender: string;
|
||||
contractAddress: string;
|
||||
constructor(client: ISigningCosmWasmClient, sender: string, contractAddress: string) {
|
||||
super(client, contractAddress);
|
||||
this.client = client;
|
||||
this.sender = sender;
|
||||
this.contractAddress = contractAddress;
|
||||
this.depositTicketBookFunds = this.depositTicketBookFunds.bind(this);
|
||||
this.requestRedemption = this.requestRedemption.bind(this);
|
||||
this.redeemTickets = this.redeemTickets.bind(this);
|
||||
this.updateAdmin = this.updateAdmin.bind(this);
|
||||
this.updateDepositValue = this.updateDepositValue.bind(this);
|
||||
this.proposeToBlacklist = this.proposeToBlacklist.bind(this);
|
||||
this.addToBlacklist = this.addToBlacklist.bind(this);
|
||||
}
|
||||
depositTicketBookFunds = async ({
|
||||
identityKey
|
||||
}: {
|
||||
identityKey: string;
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
deposit_ticket_book_funds: {
|
||||
identity_key: identityKey
|
||||
}
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
requestRedemption = async ({
|
||||
commitmentBs58,
|
||||
numberOfTickets
|
||||
}: {
|
||||
commitmentBs58: string;
|
||||
numberOfTickets: number;
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
request_redemption: {
|
||||
commitment_bs58: commitmentBs58,
|
||||
number_of_tickets: numberOfTickets
|
||||
}
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
redeemTickets = async ({
|
||||
gw,
|
||||
n
|
||||
}: {
|
||||
gw: string;
|
||||
n: number;
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
redeem_tickets: {
|
||||
gw,
|
||||
n
|
||||
}
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
updateAdmin = async ({
|
||||
admin
|
||||
}: {
|
||||
admin: string;
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
update_admin: {
|
||||
admin
|
||||
}
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
updateDepositValue = async ({
|
||||
newDeposit
|
||||
}: {
|
||||
newDeposit: Coin;
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
update_deposit_value: {
|
||||
new_deposit: newDeposit
|
||||
}
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
proposeToBlacklist = async ({
|
||||
publicKey
|
||||
}: {
|
||||
publicKey: string;
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
propose_to_blacklist: {
|
||||
public_key: publicKey
|
||||
}
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
addToBlacklist = async ({
|
||||
publicKey
|
||||
}: {
|
||||
publicKey: string;
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
add_to_blacklist: {
|
||||
public_key: publicKey
|
||||
}
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
}
|
||||
@@ -0,0 +1,106 @@
|
||||
/**
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@1.13.3.
|
||||
* DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,
|
||||
* and run the @cosmwasm/ts-codegen generate command to regenerate this file.
|
||||
*/
|
||||
|
||||
export type Uint128 = string;
|
||||
export interface InstantiateMsg {
|
||||
deposit_amount: Coin;
|
||||
group_addr: string;
|
||||
holding_account: string;
|
||||
multisig_addr: string;
|
||||
}
|
||||
export interface Coin {
|
||||
amount: Uint128;
|
||||
denom: string;
|
||||
}
|
||||
export type ExecuteMsg = {
|
||||
deposit_ticket_book_funds: {
|
||||
identity_key: string;
|
||||
};
|
||||
} | {
|
||||
request_redemption: {
|
||||
commitment_bs58: string;
|
||||
number_of_tickets: number;
|
||||
};
|
||||
} | {
|
||||
redeem_tickets: {
|
||||
gw: string;
|
||||
n: number;
|
||||
};
|
||||
} | {
|
||||
update_admin: {
|
||||
admin: string;
|
||||
};
|
||||
} | {
|
||||
update_deposit_value: {
|
||||
new_deposit: Coin;
|
||||
};
|
||||
} | {
|
||||
propose_to_blacklist: {
|
||||
public_key: string;
|
||||
};
|
||||
} | {
|
||||
add_to_blacklist: {
|
||||
public_key: string;
|
||||
};
|
||||
};
|
||||
export type QueryMsg = {
|
||||
get_blacklisted_account: {
|
||||
public_key: string;
|
||||
};
|
||||
} | {
|
||||
get_blacklist_paged: {
|
||||
limit?: number | null;
|
||||
start_after?: string | null;
|
||||
};
|
||||
} | {
|
||||
get_required_deposit_amount: {};
|
||||
} | {
|
||||
get_deposit: {
|
||||
deposit_id: number;
|
||||
};
|
||||
} | {
|
||||
get_latest_deposit: {};
|
||||
} | {
|
||||
get_deposits_paged: {
|
||||
limit?: number | null;
|
||||
start_after?: number | null;
|
||||
};
|
||||
};
|
||||
export interface MigrateMsg {}
|
||||
export interface PagedBlacklistedAccountResponse {
|
||||
accounts: BlacklistedAccount[];
|
||||
per_page: number;
|
||||
start_next_after?: string | null;
|
||||
}
|
||||
export interface BlacklistedAccount {
|
||||
info: Blacklisting;
|
||||
public_key: string;
|
||||
}
|
||||
export interface Blacklisting {
|
||||
finalized_at_height?: number | null;
|
||||
proposal_id: number;
|
||||
}
|
||||
export interface BlacklistedAccountResponse {
|
||||
account?: Blacklisting | null;
|
||||
}
|
||||
export interface DepositResponse {
|
||||
deposit?: Deposit | null;
|
||||
id: number;
|
||||
}
|
||||
export interface Deposit {
|
||||
bs58_encoded_ed25519_pubkey: string;
|
||||
}
|
||||
export interface PagedDepositsResponse {
|
||||
deposits: DepositData[];
|
||||
start_next_after?: number | null;
|
||||
}
|
||||
export interface DepositData {
|
||||
deposit: Deposit;
|
||||
id: number;
|
||||
}
|
||||
export interface LatestDepositResponse {
|
||||
deposit?: DepositData | null;
|
||||
}
|
||||
File diff suppressed because it is too large
Load Diff
@@ -1,80 +1,66 @@
|
||||
/**
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@0.35.3.
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@1.13.3.
|
||||
* DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,
|
||||
* and run the @cosmwasm/ts-codegen generate command to regenerate this file.
|
||||
*/
|
||||
|
||||
export type Decimal = string;
|
||||
export type Percent = Decimal;
|
||||
|
||||
/**
|
||||
* This instantiates the contract.
|
||||
*/
|
||||
export type Uint128 = string;
|
||||
export interface InstantiateMsg {
|
||||
current_nym_node_version: string;
|
||||
epoch_duration: Duration;
|
||||
epochs_in_interval: number;
|
||||
initial_rewarding_params: InitialRewardingParams;
|
||||
interval_operating_cost?: RangedValueForUint128;
|
||||
key_validity_in_epochs?: number | null;
|
||||
profit_margin?: RangedValueForPercent;
|
||||
rewarding_denom: string;
|
||||
rewarding_validator_address: string;
|
||||
version_score_params?: VersionScoreFormulaParams;
|
||||
version_score_weights?: OutdatedVersionWeights;
|
||||
vesting_contract_address: string;
|
||||
}
|
||||
export interface Duration {
|
||||
nanos: number;
|
||||
secs: number;
|
||||
[k: string]: unknown;
|
||||
}
|
||||
export interface InitialRewardingParams {
|
||||
active_set_size: number;
|
||||
active_set_work_factor: Decimal;
|
||||
initial_reward_pool: Decimal;
|
||||
initial_staking_supply: Decimal;
|
||||
interval_pool_emission: Percent;
|
||||
rewarded_set_size: number;
|
||||
rewarded_set_params: RewardedSetParams;
|
||||
staking_supply_scale_factor: Percent;
|
||||
sybil_resistance: Percent;
|
||||
}
|
||||
export interface RewardedSetParams {
|
||||
entry_gateways: number;
|
||||
exit_gateways: number;
|
||||
mixnodes: number;
|
||||
standby: number;
|
||||
}
|
||||
export interface RangedValueForUint128 {
|
||||
maximum: Uint128;
|
||||
minimum: Uint128;
|
||||
}
|
||||
export interface RangedValueForPercent {
|
||||
maximum: Percent;
|
||||
minimum: Percent;
|
||||
}
|
||||
export interface VersionScoreFormulaParams {
|
||||
penalty: Decimal;
|
||||
penalty_scaling: Decimal;
|
||||
}
|
||||
export interface OutdatedVersionWeights {
|
||||
major: number;
|
||||
minor: number;
|
||||
patch: number;
|
||||
prerelease: number;
|
||||
}
|
||||
export type ExecuteMsg = {
|
||||
assign_node_layer: {
|
||||
layer: Layer;
|
||||
mix_id: number;
|
||||
};
|
||||
} | {
|
||||
create_family: {
|
||||
label: string;
|
||||
};
|
||||
} | {
|
||||
join_family: {
|
||||
family_head: FamilyHead;
|
||||
join_permit: MessageSignature;
|
||||
};
|
||||
} | {
|
||||
leave_family: {
|
||||
family_head: FamilyHead;
|
||||
};
|
||||
} | {
|
||||
kick_family_member: {
|
||||
member: string;
|
||||
};
|
||||
} | {
|
||||
create_family_on_behalf: {
|
||||
label: string;
|
||||
owner_address: string;
|
||||
};
|
||||
} | {
|
||||
join_family_on_behalf: {
|
||||
family_head: FamilyHead;
|
||||
join_permit: MessageSignature;
|
||||
member_address: string;
|
||||
};
|
||||
} | {
|
||||
leave_family_on_behalf: {
|
||||
family_head: FamilyHead;
|
||||
member_address: string;
|
||||
};
|
||||
} | {
|
||||
kick_family_member_on_behalf: {
|
||||
head_address: string;
|
||||
member: string;
|
||||
update_admin: {
|
||||
admin: string;
|
||||
};
|
||||
} | {
|
||||
update_rewarding_validator_address: {
|
||||
@@ -82,12 +68,16 @@ export type ExecuteMsg = {
|
||||
};
|
||||
} | {
|
||||
update_contract_state_params: {
|
||||
updated_parameters: ContractStateParams;
|
||||
update: ContractStateParamsUpdate;
|
||||
};
|
||||
} | {
|
||||
update_active_set_size: {
|
||||
active_set_size: number;
|
||||
update_current_nym_node_semver: {
|
||||
current_version: string;
|
||||
};
|
||||
} | {
|
||||
update_active_set_distribution: {
|
||||
force_immediately: boolean;
|
||||
update: ActiveSetUpdate;
|
||||
};
|
||||
} | {
|
||||
update_rewarding_params: {
|
||||
@@ -102,24 +92,23 @@ export type ExecuteMsg = {
|
||||
};
|
||||
} | {
|
||||
begin_epoch_transition: {};
|
||||
} | {
|
||||
advance_current_epoch: {
|
||||
expected_active_set_size: number;
|
||||
new_rewarded_set: LayerAssignment[];
|
||||
};
|
||||
} | {
|
||||
reconcile_epoch_events: {
|
||||
limit?: number | null;
|
||||
};
|
||||
} | {
|
||||
assign_roles: {
|
||||
assignment: RoleAssignment;
|
||||
};
|
||||
} | {
|
||||
bond_mixnode: {
|
||||
cost_params: MixNodeCostParams;
|
||||
cost_params: NodeCostParams;
|
||||
mix_node: MixNode;
|
||||
owner_signature: MessageSignature;
|
||||
};
|
||||
} | {
|
||||
bond_mixnode_on_behalf: {
|
||||
cost_params: MixNodeCostParams;
|
||||
cost_params: NodeCostParams;
|
||||
mix_node: MixNode;
|
||||
owner: string;
|
||||
owner_signature: MessageSignature;
|
||||
@@ -146,12 +135,12 @@ export type ExecuteMsg = {
|
||||
owner: string;
|
||||
};
|
||||
} | {
|
||||
update_mixnode_cost_params: {
|
||||
new_costs: MixNodeCostParams;
|
||||
update_cost_params: {
|
||||
new_costs: NodeCostParams;
|
||||
};
|
||||
} | {
|
||||
update_mixnode_cost_params_on_behalf: {
|
||||
new_costs: MixNodeCostParams;
|
||||
new_costs: NodeCostParams;
|
||||
owner: string;
|
||||
};
|
||||
} | {
|
||||
@@ -163,6 +152,8 @@ export type ExecuteMsg = {
|
||||
new_config: MixNodeConfigUpdate;
|
||||
owner: string;
|
||||
};
|
||||
} | {
|
||||
migrate_mixnode: {};
|
||||
} | {
|
||||
bond_gateway: {
|
||||
gateway: Gateway;
|
||||
@@ -190,8 +181,24 @@ export type ExecuteMsg = {
|
||||
owner: string;
|
||||
};
|
||||
} | {
|
||||
delegate_to_mixnode: {
|
||||
mix_id: number;
|
||||
migrate_gateway: {
|
||||
cost_params?: NodeCostParams | null;
|
||||
};
|
||||
} | {
|
||||
bond_nym_node: {
|
||||
cost_params: NodeCostParams;
|
||||
node: NymNode;
|
||||
owner_signature: MessageSignature;
|
||||
};
|
||||
} | {
|
||||
unbond_nym_node: {};
|
||||
} | {
|
||||
update_node_config: {
|
||||
update: NodeConfigUpdate;
|
||||
};
|
||||
} | {
|
||||
delegate: {
|
||||
node_id: number;
|
||||
};
|
||||
} | {
|
||||
delegate_to_mixnode_on_behalf: {
|
||||
@@ -199,8 +206,8 @@ export type ExecuteMsg = {
|
||||
mix_id: number;
|
||||
};
|
||||
} | {
|
||||
undelegate_from_mixnode: {
|
||||
mix_id: number;
|
||||
undelegate: {
|
||||
node_id: number;
|
||||
};
|
||||
} | {
|
||||
undelegate_from_mixnode_on_behalf: {
|
||||
@@ -208,9 +215,9 @@ export type ExecuteMsg = {
|
||||
mix_id: number;
|
||||
};
|
||||
} | {
|
||||
reward_mixnode: {
|
||||
mix_id: number;
|
||||
performance: Percent;
|
||||
reward_node: {
|
||||
node_id: number;
|
||||
params: NodeRewardingParameters;
|
||||
};
|
||||
} | {
|
||||
withdraw_operator_reward: {};
|
||||
@@ -220,42 +227,62 @@ export type ExecuteMsg = {
|
||||
};
|
||||
} | {
|
||||
withdraw_delegator_reward: {
|
||||
mix_id: number;
|
||||
node_id: number;
|
||||
};
|
||||
} | {
|
||||
withdraw_delegator_reward_on_behalf: {
|
||||
mix_id: number;
|
||||
owner: string;
|
||||
};
|
||||
} | {
|
||||
migrate_vested_mix_node: {};
|
||||
} | {
|
||||
migrate_vested_delegation: {
|
||||
mix_id: number;
|
||||
};
|
||||
};
|
||||
export type Layer = "One" | "Two" | "Three";
|
||||
export type FamilyHead = string;
|
||||
export type Role = "eg" | "l1" | "l2" | "l3" | "xg" | "stb";
|
||||
export type MessageSignature = number[];
|
||||
export type Uint128 = string;
|
||||
export interface ContractStateParams {
|
||||
minimum_gateway_pledge: Coin;
|
||||
minimum_mixnode_delegation?: Coin | null;
|
||||
minimum_mixnode_pledge: Coin;
|
||||
export interface ContractStateParamsUpdate {
|
||||
config_score_params?: ConfigScoreParamsUpdate | null;
|
||||
delegations_params?: DelegationsParams | null;
|
||||
operators_params?: OperatorsParamsUpdate | null;
|
||||
}
|
||||
export interface ConfigScoreParamsUpdate {
|
||||
version_score_formula_params?: VersionScoreFormulaParams | null;
|
||||
version_weights?: OutdatedVersionWeights | null;
|
||||
}
|
||||
export interface DelegationsParams {
|
||||
minimum_delegation?: Coin | null;
|
||||
}
|
||||
export interface Coin {
|
||||
amount: Uint128;
|
||||
denom: string;
|
||||
[k: string]: unknown;
|
||||
}
|
||||
export interface OperatorsParamsUpdate {
|
||||
interval_operating_cost?: RangedValueForUint128 | null;
|
||||
minimum_pledge?: Coin | null;
|
||||
profit_margin?: RangedValueForPercent | null;
|
||||
}
|
||||
export interface ActiveSetUpdate {
|
||||
entry_gateways: number;
|
||||
exit_gateways: number;
|
||||
mixnodes: number;
|
||||
}
|
||||
export interface IntervalRewardingParamsUpdate {
|
||||
active_set_work_factor?: Decimal | null;
|
||||
interval_pool_emission?: Percent | null;
|
||||
reward_pool?: Decimal | null;
|
||||
rewarded_set_size?: number | null;
|
||||
rewarded_set_params?: RewardedSetParams | null;
|
||||
staking_supply?: Decimal | null;
|
||||
staking_supply_scale_factor?: Percent | null;
|
||||
sybil_resistance_percent?: Percent | null;
|
||||
}
|
||||
export interface LayerAssignment {
|
||||
layer: Layer;
|
||||
mix_id: number;
|
||||
export interface RoleAssignment {
|
||||
nodes: number[];
|
||||
role: Role;
|
||||
}
|
||||
export interface MixNodeCostParams {
|
||||
export interface NodeCostParams {
|
||||
interval_operating_cost: Coin;
|
||||
profit_margin_percent: Percent;
|
||||
}
|
||||
@@ -291,32 +318,22 @@ export interface GatewayConfigUpdate {
|
||||
mix_port: number;
|
||||
version: string;
|
||||
}
|
||||
export interface NymNode {
|
||||
custom_http_port?: number | null;
|
||||
host: string;
|
||||
identity_key: string;
|
||||
}
|
||||
export interface NodeConfigUpdate {
|
||||
custom_http_port?: number | null;
|
||||
host?: string | null;
|
||||
restore_default_http_port?: boolean;
|
||||
}
|
||||
export interface NodeRewardingParameters {
|
||||
performance: Percent;
|
||||
work_factor: Decimal;
|
||||
}
|
||||
export type QueryMsg = {
|
||||
get_all_families_paged: {
|
||||
limit?: number | null;
|
||||
start_after?: string | null;
|
||||
};
|
||||
} | {
|
||||
get_all_members_paged: {
|
||||
limit?: number | null;
|
||||
start_after?: string | null;
|
||||
};
|
||||
} | {
|
||||
get_family_by_head: {
|
||||
head: string;
|
||||
};
|
||||
} | {
|
||||
get_family_by_label: {
|
||||
label: string;
|
||||
};
|
||||
} | {
|
||||
get_family_members_by_head: {
|
||||
head: string;
|
||||
};
|
||||
} | {
|
||||
get_family_members_by_label: {
|
||||
label: string;
|
||||
};
|
||||
admin: {};
|
||||
} | {
|
||||
get_contract_version: {};
|
||||
} | {
|
||||
@@ -327,17 +344,19 @@ export type QueryMsg = {
|
||||
get_state_params: {};
|
||||
} | {
|
||||
get_state: {};
|
||||
} | {
|
||||
get_current_nym_node_version: {};
|
||||
} | {
|
||||
get_nym_node_version_history: {
|
||||
limit?: number | null;
|
||||
start_after?: number | null;
|
||||
};
|
||||
} | {
|
||||
get_rewarding_params: {};
|
||||
} | {
|
||||
get_epoch_status: {};
|
||||
} | {
|
||||
get_current_interval_details: {};
|
||||
} | {
|
||||
get_rewarded_set: {
|
||||
limit?: number | null;
|
||||
start_after?: number | null;
|
||||
};
|
||||
} | {
|
||||
get_mix_node_bonds: {
|
||||
limit?: number | null;
|
||||
@@ -389,8 +408,6 @@ export type QueryMsg = {
|
||||
get_bonded_mixnode_details_by_identity: {
|
||||
mix_identity: string;
|
||||
};
|
||||
} | {
|
||||
get_layer_distribution: {};
|
||||
} | {
|
||||
get_gateways: {
|
||||
limit?: number | null;
|
||||
@@ -405,9 +422,71 @@ export type QueryMsg = {
|
||||
address: string;
|
||||
};
|
||||
} | {
|
||||
get_mixnode_delegations: {
|
||||
get_preassigned_gateway_ids: {
|
||||
limit?: number | null;
|
||||
mix_id: number;
|
||||
start_after?: string | null;
|
||||
};
|
||||
} | {
|
||||
get_nym_node_bonds_paged: {
|
||||
limit?: number | null;
|
||||
start_after?: number | null;
|
||||
};
|
||||
} | {
|
||||
get_nym_nodes_detailed_paged: {
|
||||
limit?: number | null;
|
||||
start_after?: number | null;
|
||||
};
|
||||
} | {
|
||||
get_unbonded_nym_node: {
|
||||
node_id: number;
|
||||
};
|
||||
} | {
|
||||
get_unbonded_nym_nodes_paged: {
|
||||
limit?: number | null;
|
||||
start_after?: number | null;
|
||||
};
|
||||
} | {
|
||||
get_unbonded_nym_nodes_by_owner_paged: {
|
||||
limit?: number | null;
|
||||
owner: string;
|
||||
start_after?: number | null;
|
||||
};
|
||||
} | {
|
||||
get_unbonded_nym_nodes_by_identity_key_paged: {
|
||||
identity_key: string;
|
||||
limit?: number | null;
|
||||
start_after?: number | null;
|
||||
};
|
||||
} | {
|
||||
get_owned_nym_node: {
|
||||
address: string;
|
||||
};
|
||||
} | {
|
||||
get_nym_node_details: {
|
||||
node_id: number;
|
||||
};
|
||||
} | {
|
||||
get_nym_node_details_by_identity_key: {
|
||||
node_identity: string;
|
||||
};
|
||||
} | {
|
||||
get_node_rewarding_details: {
|
||||
node_id: number;
|
||||
};
|
||||
} | {
|
||||
get_node_stake_saturation: {
|
||||
node_id: number;
|
||||
};
|
||||
} | {
|
||||
get_role_assignment: {
|
||||
role: Role;
|
||||
};
|
||||
} | {
|
||||
get_rewarded_set_metadata: {};
|
||||
} | {
|
||||
get_node_delegations: {
|
||||
limit?: number | null;
|
||||
node_id: number;
|
||||
start_after?: string | null;
|
||||
};
|
||||
} | {
|
||||
@@ -419,7 +498,7 @@ export type QueryMsg = {
|
||||
} | {
|
||||
get_delegation_details: {
|
||||
delegator: string;
|
||||
mix_id: number;
|
||||
node_id: number;
|
||||
proxy?: string | null;
|
||||
};
|
||||
} | {
|
||||
@@ -432,26 +511,27 @@ export type QueryMsg = {
|
||||
address: string;
|
||||
};
|
||||
} | {
|
||||
get_pending_mix_node_operator_reward: {
|
||||
mix_id: number;
|
||||
get_pending_node_operator_reward: {
|
||||
node_id: number;
|
||||
};
|
||||
} | {
|
||||
get_pending_delegator_reward: {
|
||||
address: string;
|
||||
mix_id: number;
|
||||
node_id: number;
|
||||
proxy?: string | null;
|
||||
};
|
||||
} | {
|
||||
get_estimated_current_epoch_operator_reward: {
|
||||
estimated_performance: Percent;
|
||||
mix_id: number;
|
||||
estimated_work?: Decimal | null;
|
||||
node_id: number;
|
||||
};
|
||||
} | {
|
||||
get_estimated_current_epoch_delegator_reward: {
|
||||
address: string;
|
||||
estimated_performance: Percent;
|
||||
mix_id: number;
|
||||
proxy?: string | null;
|
||||
estimated_work?: Decimal | null;
|
||||
node_id: number;
|
||||
};
|
||||
} | {
|
||||
get_pending_epoch_events: {
|
||||
@@ -477,10 +557,18 @@ export type QueryMsg = {
|
||||
get_signing_nonce: {
|
||||
address: string;
|
||||
};
|
||||
} | {
|
||||
get_key_rotation_state: {};
|
||||
} | {
|
||||
get_key_rotation_id: {};
|
||||
};
|
||||
export interface MigrateMsg {
|
||||
unsafe_skip_state_updates?: boolean | null;
|
||||
vesting_contract_address?: string | null;
|
||||
}
|
||||
export interface AdminResponse {
|
||||
admin?: string | null;
|
||||
}
|
||||
export type Addr = string;
|
||||
export interface PagedAllDelegationsResponse {
|
||||
delegations: Delegation[];
|
||||
@@ -490,23 +578,10 @@ export interface Delegation {
|
||||
amount: Coin;
|
||||
cumulative_reward_ratio: Decimal;
|
||||
height: number;
|
||||
mix_id: number;
|
||||
node_id: number;
|
||||
owner: Addr;
|
||||
proxy?: Addr | null;
|
||||
}
|
||||
export interface PagedFamiliesResponse {
|
||||
families: Family[];
|
||||
start_next_after?: string | null;
|
||||
}
|
||||
export interface Family {
|
||||
head: FamilyHead;
|
||||
label: string;
|
||||
proxy?: string | null;
|
||||
}
|
||||
export interface PagedMembersResponse {
|
||||
members: [string, FamilyHead][];
|
||||
start_next_after?: string | null;
|
||||
}
|
||||
export interface MixnodeDetailsByIdentityResponse {
|
||||
identity_key: string;
|
||||
mixnode_details?: MixNodeDetails | null;
|
||||
@@ -514,12 +589,11 @@ export interface MixnodeDetailsByIdentityResponse {
|
||||
export interface MixNodeDetails {
|
||||
bond_information: MixNodeBond;
|
||||
pending_changes?: PendingMixNodeChanges;
|
||||
rewarding_details: MixNodeRewarding;
|
||||
rewarding_details: NodeRewarding;
|
||||
}
|
||||
export interface MixNodeBond {
|
||||
bonding_height: number;
|
||||
is_unbonding: boolean;
|
||||
layer: Layer;
|
||||
mix_id: number;
|
||||
mix_node: MixNode;
|
||||
original_pledge: Coin;
|
||||
@@ -527,10 +601,11 @@ export interface MixNodeBond {
|
||||
proxy?: Addr | null;
|
||||
}
|
||||
export interface PendingMixNodeChanges {
|
||||
cost_params_change?: number | null;
|
||||
pledge_change?: number | null;
|
||||
}
|
||||
export interface MixNodeRewarding {
|
||||
cost_params: MixNodeCostParams;
|
||||
export interface NodeRewarding {
|
||||
cost_params: NodeCostParams;
|
||||
delegates: Decimal;
|
||||
last_rewarded_epoch: number;
|
||||
operator: Decimal;
|
||||
@@ -545,9 +620,12 @@ export interface ContractVersion {
|
||||
export interface ContractBuildInformation {
|
||||
build_timestamp: string;
|
||||
build_version: string;
|
||||
cargo_debug?: string;
|
||||
cargo_opt_level?: string;
|
||||
commit_branch: string;
|
||||
commit_sha: string;
|
||||
commit_timestamp: string;
|
||||
contract_name?: string;
|
||||
rustc_version: string;
|
||||
}
|
||||
export interface CurrentIntervalResponse {
|
||||
@@ -563,11 +641,29 @@ export interface Interval {
|
||||
epochs_in_interval: number;
|
||||
id: number;
|
||||
total_elapsed_epochs: number;
|
||||
[k: string]: unknown;
|
||||
}
|
||||
export interface MixNodeDelegationResponse {
|
||||
export interface CurrentNymNodeVersionResponse {
|
||||
version?: HistoricalNymNodeVersionEntry | null;
|
||||
}
|
||||
export interface HistoricalNymNodeVersionEntry {
|
||||
id: number;
|
||||
version_information: HistoricalNymNodeVersion;
|
||||
}
|
||||
export interface HistoricalNymNodeVersion {
|
||||
difference_since_genesis: TotalVersionDifference;
|
||||
introduced_at_height: number;
|
||||
semver: string;
|
||||
}
|
||||
export interface TotalVersionDifference {
|
||||
major: number;
|
||||
minor: number;
|
||||
patch: number;
|
||||
prerelease: number;
|
||||
}
|
||||
export interface NodeDelegationResponse {
|
||||
delegation?: Delegation | null;
|
||||
mixnode_still_bonded: boolean;
|
||||
node_still_bonded: boolean;
|
||||
}
|
||||
export interface PagedDelegatorDelegationsResponse {
|
||||
delegations: Delegation[];
|
||||
@@ -578,7 +674,11 @@ export type EpochState = "in_progress" | {
|
||||
final_node_id: number;
|
||||
last_rewarded: number;
|
||||
};
|
||||
} | "reconciling_events" | "advancing_epoch";
|
||||
} | "reconciling_events" | {
|
||||
role_assignment: {
|
||||
next: Role;
|
||||
};
|
||||
};
|
||||
export interface EpochStatus {
|
||||
being_advanced_by: Addr;
|
||||
state: EpochState;
|
||||
@@ -590,22 +690,6 @@ export interface EstimatedCurrentEpochRewardResponse {
|
||||
estimation?: Coin | null;
|
||||
original_stake?: Coin | null;
|
||||
}
|
||||
export interface FamilyByHeadResponse {
|
||||
family?: Family | null;
|
||||
head: FamilyHead;
|
||||
}
|
||||
export interface FamilyByLabelResponse {
|
||||
family?: Family | null;
|
||||
label: string;
|
||||
}
|
||||
export interface FamilyMembersByHeadResponse {
|
||||
head: FamilyHead;
|
||||
members: string[];
|
||||
}
|
||||
export interface FamilyMembersByLabelResponse {
|
||||
label: string;
|
||||
members: string[];
|
||||
}
|
||||
export interface GatewayBondResponse {
|
||||
gateway?: GatewayBond | null;
|
||||
identity: string;
|
||||
@@ -622,10 +706,12 @@ export interface PagedGatewayResponse {
|
||||
per_page: number;
|
||||
start_next_after?: string | null;
|
||||
}
|
||||
export interface LayerDistribution {
|
||||
layer1: number;
|
||||
layer2: number;
|
||||
layer3: number;
|
||||
export interface KeyRotationIdResponse {
|
||||
rotation_id: number;
|
||||
}
|
||||
export interface KeyRotationState {
|
||||
initial_epoch_id: number;
|
||||
validity_epochs: number;
|
||||
}
|
||||
export interface PagedMixnodeBondsResponse {
|
||||
nodes: MixNodeBond[];
|
||||
@@ -637,22 +723,68 @@ export interface PagedMixnodesDetailsResponse {
|
||||
per_page: number;
|
||||
start_next_after?: number | null;
|
||||
}
|
||||
export interface PagedMixNodeDelegationsResponse {
|
||||
delegations: Delegation[];
|
||||
start_next_after?: string | null;
|
||||
}
|
||||
export interface MixnodeDetailsResponse {
|
||||
mix_id: number;
|
||||
mixnode_details?: MixNodeDetails | null;
|
||||
}
|
||||
export interface MixnodeRewardingDetailsResponse {
|
||||
mix_id: number;
|
||||
rewarding_details?: MixNodeRewarding | null;
|
||||
rewarding_details?: NodeRewarding | null;
|
||||
}
|
||||
export interface PagedNodeDelegationsResponse {
|
||||
delegations: Delegation[];
|
||||
start_next_after?: string | null;
|
||||
}
|
||||
export interface NodeRewardingDetailsResponse {
|
||||
node_id: number;
|
||||
rewarding_details?: NodeRewarding | null;
|
||||
}
|
||||
export interface StakeSaturationResponse {
|
||||
current_saturation?: Decimal | null;
|
||||
node_id: number;
|
||||
uncapped_saturation?: Decimal | null;
|
||||
}
|
||||
export interface NumberOfPendingEventsResponse {
|
||||
epoch_events: number;
|
||||
interval_events: number;
|
||||
}
|
||||
export interface PagedNymNodeBondsResponse {
|
||||
nodes: NymNodeBond[];
|
||||
start_next_after?: number | null;
|
||||
}
|
||||
export interface NymNodeBond {
|
||||
bonding_height: number;
|
||||
is_unbonding: boolean;
|
||||
node: NymNode;
|
||||
node_id: number;
|
||||
original_pledge: Coin;
|
||||
owner: Addr;
|
||||
}
|
||||
export interface NodeDetailsResponse {
|
||||
details?: NymNodeDetails | null;
|
||||
node_id: number;
|
||||
}
|
||||
export interface NymNodeDetails {
|
||||
bond_information: NymNodeBond;
|
||||
pending_changes: PendingNodeChanges;
|
||||
rewarding_details: NodeRewarding;
|
||||
}
|
||||
export interface PendingNodeChanges {
|
||||
cost_params_change?: number | null;
|
||||
pledge_change?: number | null;
|
||||
}
|
||||
export interface NodeDetailsByIdentityResponse {
|
||||
details?: NymNodeDetails | null;
|
||||
identity_key: string;
|
||||
}
|
||||
export interface NymNodeVersionHistoryResponse {
|
||||
history: HistoricalNymNodeVersionEntry[];
|
||||
start_next_after?: number | null;
|
||||
}
|
||||
export interface PagedNymNodeDetailsResponse {
|
||||
nodes: NymNodeDetails[];
|
||||
start_next_after?: number | null;
|
||||
}
|
||||
export interface GatewayOwnershipResponse {
|
||||
address: Addr;
|
||||
gateway?: GatewayBond | null;
|
||||
@@ -661,32 +793,47 @@ export interface MixOwnershipResponse {
|
||||
address: Addr;
|
||||
mixnode_details?: MixNodeDetails | null;
|
||||
}
|
||||
export interface NodeOwnershipResponse {
|
||||
address: Addr;
|
||||
details?: NymNodeDetails | null;
|
||||
}
|
||||
export interface PendingRewardResponse {
|
||||
amount_earned?: Coin | null;
|
||||
amount_earned_detailed?: Decimal | null;
|
||||
amount_staked?: Coin | null;
|
||||
mixnode_still_fully_bonded: boolean;
|
||||
node_still_fully_bonded: boolean;
|
||||
}
|
||||
export type PendingEpochEventKind = {
|
||||
delegate: {
|
||||
amount: Coin;
|
||||
mix_id: number;
|
||||
node_id: number;
|
||||
owner: Addr;
|
||||
proxy?: Addr | null;
|
||||
};
|
||||
} | {
|
||||
undelegate: {
|
||||
mix_id: number;
|
||||
node_id: number;
|
||||
owner: Addr;
|
||||
proxy?: Addr | null;
|
||||
};
|
||||
} | {
|
||||
pledge_more: {
|
||||
nym_node_pledge_more: {
|
||||
amount: Coin;
|
||||
node_id: number;
|
||||
};
|
||||
} | {
|
||||
mixnode_pledge_more: {
|
||||
amount: Coin;
|
||||
mix_id: number;
|
||||
};
|
||||
} | {
|
||||
decrease_pledge: {
|
||||
nym_node_decrease_pledge: {
|
||||
decrease_by: Coin;
|
||||
node_id: number;
|
||||
};
|
||||
} | {
|
||||
mixnode_decrease_pledge: {
|
||||
decrease_by: Coin;
|
||||
mix_id: number;
|
||||
};
|
||||
@@ -695,8 +842,12 @@ export type PendingEpochEventKind = {
|
||||
mix_id: number;
|
||||
};
|
||||
} | {
|
||||
update_active_set_size: {
|
||||
new_size: number;
|
||||
unbond_nym_node: {
|
||||
node_id: number;
|
||||
};
|
||||
} | {
|
||||
update_active_set: {
|
||||
update: ActiveSetUpdate;
|
||||
};
|
||||
};
|
||||
export interface PendingEpochEventResponse {
|
||||
@@ -719,7 +870,12 @@ export interface PendingEpochEvent {
|
||||
export type PendingIntervalEventKind = {
|
||||
change_mix_cost_params: {
|
||||
mix_id: number;
|
||||
new_costs: MixNodeCostParams;
|
||||
new_costs: NodeCostParams;
|
||||
};
|
||||
} | {
|
||||
change_nym_node_cost_params: {
|
||||
new_costs: NodeCostParams;
|
||||
node_id: number;
|
||||
};
|
||||
} | {
|
||||
update_rewarding_params: {
|
||||
@@ -748,15 +904,34 @@ export interface PendingIntervalEvent {
|
||||
event: PendingIntervalEventData;
|
||||
id: number;
|
||||
}
|
||||
export type RewardedSetNodeStatus = "active" | "standby";
|
||||
export interface PagedRewardedSetResponse {
|
||||
nodes: [number, RewardedSetNodeStatus][];
|
||||
start_next_after?: number | null;
|
||||
export interface PreassignedGatewayIdsResponse {
|
||||
ids: PreassignedId[];
|
||||
start_next_after?: string | null;
|
||||
}
|
||||
export interface PreassignedId {
|
||||
identity: string;
|
||||
node_id: number;
|
||||
}
|
||||
export interface RolesMetadataResponse {
|
||||
metadata: RewardedSetMetadata;
|
||||
}
|
||||
export interface RewardedSetMetadata {
|
||||
entry_gateway_metadata: RoleMetadata;
|
||||
epoch_id: number;
|
||||
exit_gateway_metadata: RoleMetadata;
|
||||
fully_assigned: boolean;
|
||||
layer1_metadata: RoleMetadata;
|
||||
layer2_metadata: RoleMetadata;
|
||||
layer3_metadata: RoleMetadata;
|
||||
standby_metadata: RoleMetadata;
|
||||
}
|
||||
export interface RoleMetadata {
|
||||
highest_id: number;
|
||||
num_nodes: number;
|
||||
}
|
||||
export interface RewardingParams {
|
||||
active_set_size: number;
|
||||
interval: IntervalRewardParams;
|
||||
rewarded_set_size: number;
|
||||
rewarded_set: RewardedSetParams;
|
||||
}
|
||||
export interface IntervalRewardParams {
|
||||
active_set_work_factor: Decimal;
|
||||
@@ -769,19 +944,37 @@ export interface IntervalRewardParams {
|
||||
sybil_resistance: Percent;
|
||||
}
|
||||
export type String = string;
|
||||
export interface EpochAssignmentResponse {
|
||||
epoch_id: number;
|
||||
nodes: number[];
|
||||
}
|
||||
export type Uint32 = number;
|
||||
export interface StakeSaturationResponse {
|
||||
export interface MixStakeSaturationResponse {
|
||||
current_saturation?: Decimal | null;
|
||||
mix_id: number;
|
||||
uncapped_saturation?: Decimal | null;
|
||||
}
|
||||
export interface ContractState {
|
||||
owner: Addr;
|
||||
owner?: Addr | null;
|
||||
params: ContractStateParams;
|
||||
rewarding_denom: string;
|
||||
rewarding_validator_address: Addr;
|
||||
vesting_contract_address: Addr;
|
||||
}
|
||||
export interface ContractStateParams {
|
||||
config_score_params: ConfigScoreParams;
|
||||
delegations_params: DelegationsParams;
|
||||
operators_params: OperatorsParams;
|
||||
}
|
||||
export interface ConfigScoreParams {
|
||||
version_score_formula_params: VersionScoreFormulaParams;
|
||||
version_weights: OutdatedVersionWeights;
|
||||
}
|
||||
export interface OperatorsParams {
|
||||
interval_operating_cost: RangedValueForUint128;
|
||||
minimum_pledge: Coin;
|
||||
profit_margin: RangedValueForPercent;
|
||||
}
|
||||
export interface UnbondedMixnodeResponse {
|
||||
mix_id: number;
|
||||
unbonded_info?: UnbondedMixnode | null;
|
||||
@@ -797,3 +990,17 @@ export interface PagedUnbondedMixnodesResponse {
|
||||
per_page: number;
|
||||
start_next_after?: number | null;
|
||||
}
|
||||
export interface UnbondedNodeResponse {
|
||||
details?: UnbondedNymNode | null;
|
||||
node_id: number;
|
||||
}
|
||||
export interface UnbondedNymNode {
|
||||
identity_key: string;
|
||||
node_id: number;
|
||||
owner: Addr;
|
||||
unbonding_height: number;
|
||||
}
|
||||
export interface PagedUnbondedNymNodesResponse {
|
||||
nodes: UnbondedNymNode[];
|
||||
start_next_after?: number | null;
|
||||
}
|
||||
@@ -1,13 +1,12 @@
|
||||
/**
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@0.35.3.
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@1.13.3.
|
||||
* DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,
|
||||
* and run the @cosmwasm/ts-codegen generate command to regenerate this file.
|
||||
*/
|
||||
|
||||
import { CosmWasmClient, SigningCosmWasmClient, ExecuteResult } from "@cosmjs/cosmwasm-stargate";
|
||||
import { StdFee } from "@cosmjs/amino";
|
||||
import { InstantiateMsg, ExecuteMsg, FamilyHead, MessageSignature, Uint128, Percent, Decimal, PledgeCap, Coin, MixNodeCostParams, MixNodeConfigUpdate, VestingSpecification, MixNode, Gateway, GatewayConfigUpdate, QueryMsg, Timestamp, Uint64, MigrateMsg, Addr, Account, VestingPeriod, AccountsResponse, BaseVestingAccountInfo, VestingCoinsResponse, AccountVestingCoins, AllDelegationsResponse, VestingDelegation, ContractVersion, ContractBuildInformation, Period, DelegationTimesResponse, NullablePledgeData, PledgeData, OriginalVestingResponse } from "./Vesting.types";
|
||||
import { GetCw2ContractVersionResponse } from './types';
|
||||
import { ICosmWasmClient, ISigningCosmWasmClient } from "./baseClient";
|
||||
import { StdFee } from "@interchainjs/types";
|
||||
import { InstantiateMsg, ExecuteMsg, Uint128, Percent, Decimal, PledgeCap, MessageSignature, Coin, NodeCostParams, MixNodeConfigUpdate, VestingSpecification, MixNode, Gateway, GatewayConfigUpdate, QueryMsg, Timestamp, Uint64, MigrateMsg, Addr, Account, VestingPeriod, AccountsResponse, BaseVestingAccountInfo, VestingCoinsResponse, AccountVestingCoins, AllDelegationsResponse, VestingDelegation, ContractVersion, ContractBuildInformation, Period, DelegationTimesResponse, NullablePledgeData, PledgeData, OriginalVestingResponse } from "./Vesting.types";
|
||||
export interface VestingReadOnlyInterface {
|
||||
contractAddress: string;
|
||||
getContractVersion: () => Promise<ContractBuildInformation>;
|
||||
@@ -156,10 +155,9 @@ export interface VestingReadOnlyInterface {
|
||||
}) => Promise<AllDelegationsResponse>;
|
||||
}
|
||||
export class VestingQueryClient implements VestingReadOnlyInterface {
|
||||
client: CosmWasmClient;
|
||||
client: ICosmWasmClient;
|
||||
contractAddress: string;
|
||||
|
||||
constructor(client: CosmWasmClient, contractAddress: string) {
|
||||
constructor(client: ICosmWasmClient, contractAddress: string) {
|
||||
this.client = client;
|
||||
this.contractAddress = contractAddress;
|
||||
this.getContractVersion = this.getContractVersion.bind(this);
|
||||
@@ -189,7 +187,6 @@ export class VestingQueryClient implements VestingReadOnlyInterface {
|
||||
this.getDelegationTimes = this.getDelegationTimes.bind(this);
|
||||
this.getAllDelegations = this.getAllDelegations.bind(this);
|
||||
}
|
||||
|
||||
getContractVersion = async (): Promise<ContractBuildInformation> => {
|
||||
return this.client.queryContractSmart(this.contractAddress, {
|
||||
get_contract_version: {}
|
||||
@@ -501,56 +498,34 @@ export class VestingQueryClient implements VestingReadOnlyInterface {
|
||||
export interface VestingInterface extends VestingReadOnlyInterface {
|
||||
contractAddress: string;
|
||||
sender: string;
|
||||
createFamily: ({
|
||||
label
|
||||
}: {
|
||||
label: string;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
joinFamily: ({
|
||||
familyHead,
|
||||
joinPermit
|
||||
}: {
|
||||
familyHead: FamilyHead;
|
||||
joinPermit: MessageSignature;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
leaveFamily: ({
|
||||
familyHead
|
||||
}: {
|
||||
familyHead: FamilyHead;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
kickFamilyMember: ({
|
||||
member
|
||||
}: {
|
||||
member: string;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
trackReward: ({
|
||||
address,
|
||||
amount
|
||||
}: {
|
||||
address: string;
|
||||
amount: Coin;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
claimOperatorReward: (fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
claimOperatorReward: (fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
claimDelegatorReward: ({
|
||||
mixId
|
||||
}: {
|
||||
mixId: number;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
updateMixnodeCostParams: ({
|
||||
newCosts
|
||||
}: {
|
||||
newCosts: MixNodeCostParams;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
newCosts: NodeCostParams;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
updateMixnodeConfig: ({
|
||||
newConfig
|
||||
}: {
|
||||
newConfig: MixNodeConfigUpdate;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
updateMixnetAddress: ({
|
||||
address
|
||||
}: {
|
||||
address: string;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
delegateToMixnode: ({
|
||||
amount,
|
||||
mixId,
|
||||
@@ -559,14 +534,14 @@ export interface VestingInterface extends VestingReadOnlyInterface {
|
||||
amount: Coin;
|
||||
mixId: number;
|
||||
onBehalfOf?: string;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
undelegateFromMixnode: ({
|
||||
mixId,
|
||||
onBehalfOf
|
||||
}: {
|
||||
mixId: number;
|
||||
onBehalfOf?: string;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
createAccount: ({
|
||||
cap,
|
||||
ownerAddress,
|
||||
@@ -577,12 +552,12 @@ export interface VestingInterface extends VestingReadOnlyInterface {
|
||||
ownerAddress: string;
|
||||
stakingAddress?: string;
|
||||
vestingSpec?: VestingSpecification;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
withdrawVestedCoins: ({
|
||||
amount
|
||||
}: {
|
||||
amount: Coin;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
trackUndelegation: ({
|
||||
amount,
|
||||
mixId,
|
||||
@@ -591,7 +566,7 @@ export interface VestingInterface extends VestingReadOnlyInterface {
|
||||
amount: Coin;
|
||||
mixId: number;
|
||||
owner: string;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
bondMixnode: ({
|
||||
amount,
|
||||
costParams,
|
||||
@@ -599,35 +574,35 @@ export interface VestingInterface extends VestingReadOnlyInterface {
|
||||
ownerSignature
|
||||
}: {
|
||||
amount: Coin;
|
||||
costParams: MixNodeCostParams;
|
||||
costParams: NodeCostParams;
|
||||
mixNode: MixNode;
|
||||
ownerSignature: MessageSignature;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
pledgeMore: ({
|
||||
amount
|
||||
}: {
|
||||
amount: Coin;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
decreasePledge: ({
|
||||
amount
|
||||
}: {
|
||||
amount: Coin;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
unbondMixnode: (fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
unbondMixnode: (fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
trackUnbondMixnode: ({
|
||||
amount,
|
||||
owner
|
||||
}: {
|
||||
amount: Coin;
|
||||
owner: string;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
trackDecreasePledge: ({
|
||||
amount,
|
||||
owner
|
||||
}: {
|
||||
amount: Coin;
|
||||
owner: string;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
bondGateway: ({
|
||||
amount,
|
||||
gateway,
|
||||
@@ -636,52 +611,59 @@ export interface VestingInterface extends VestingReadOnlyInterface {
|
||||
amount: Coin;
|
||||
gateway: Gateway;
|
||||
ownerSignature: MessageSignature;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
unbondGateway: (fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
unbondGateway: (fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
trackUnbondGateway: ({
|
||||
amount,
|
||||
owner
|
||||
}: {
|
||||
amount: Coin;
|
||||
owner: string;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
updateGatewayConfig: ({
|
||||
newConfig
|
||||
}: {
|
||||
newConfig: GatewayConfigUpdate;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
transferOwnership: ({
|
||||
toAddress
|
||||
}: {
|
||||
toAddress: string;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
updateStakingAddress: ({
|
||||
toAddress
|
||||
}: {
|
||||
toAddress?: string;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
updateLockedPledgeCap: ({
|
||||
address,
|
||||
cap
|
||||
}: {
|
||||
address: string;
|
||||
cap: PledgeCap;
|
||||
}, fee?: number | StdFee | "auto", memo?: string, _funds?: Coin[]) => Promise<ExecuteResult>;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
trackMigratedMixnode: ({
|
||||
owner
|
||||
}: {
|
||||
owner: string;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
trackMigratedDelegation: ({
|
||||
mixId,
|
||||
owner
|
||||
}: {
|
||||
mixId: number;
|
||||
owner: string;
|
||||
}, fee_?: number | StdFee | "auto", memo_?: string, funds_?: Coin[]) => Promise<any>;
|
||||
}
|
||||
export class VestingClient extends VestingQueryClient implements VestingInterface {
|
||||
client: SigningCosmWasmClient;
|
||||
client: ISigningCosmWasmClient;
|
||||
sender: string;
|
||||
contractAddress: string;
|
||||
|
||||
constructor(client: SigningCosmWasmClient, sender: string, contractAddress: string) {
|
||||
constructor(client: ISigningCosmWasmClient, sender: string, contractAddress: string) {
|
||||
super(client, contractAddress);
|
||||
this.client = client;
|
||||
this.sender = sender;
|
||||
this.contractAddress = contractAddress;
|
||||
this.createFamily = this.createFamily.bind(this);
|
||||
this.joinFamily = this.joinFamily.bind(this);
|
||||
this.leaveFamily = this.leaveFamily.bind(this);
|
||||
this.kickFamilyMember = this.kickFamilyMember.bind(this);
|
||||
this.trackReward = this.trackReward.bind(this);
|
||||
this.claimOperatorReward = this.claimOperatorReward.bind(this);
|
||||
this.claimDelegatorReward = this.claimDelegatorReward.bind(this);
|
||||
@@ -706,117 +688,71 @@ export class VestingClient extends VestingQueryClient implements VestingInterfac
|
||||
this.transferOwnership = this.transferOwnership.bind(this);
|
||||
this.updateStakingAddress = this.updateStakingAddress.bind(this);
|
||||
this.updateLockedPledgeCap = this.updateLockedPledgeCap.bind(this);
|
||||
this.trackMigratedMixnode = this.trackMigratedMixnode.bind(this);
|
||||
this.trackMigratedDelegation = this.trackMigratedDelegation.bind(this);
|
||||
}
|
||||
|
||||
createFamily = async ({
|
||||
label
|
||||
}: {
|
||||
label: string;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
create_family: {
|
||||
label
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
};
|
||||
joinFamily = async ({
|
||||
familyHead,
|
||||
joinPermit
|
||||
}: {
|
||||
familyHead: FamilyHead;
|
||||
joinPermit: MessageSignature;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
join_family: {
|
||||
family_head: familyHead,
|
||||
join_permit: joinPermit
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
};
|
||||
leaveFamily = async ({
|
||||
familyHead
|
||||
}: {
|
||||
familyHead: FamilyHead;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
leave_family: {
|
||||
family_head: familyHead
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
};
|
||||
kickFamilyMember = async ({
|
||||
member
|
||||
}: {
|
||||
member: string;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
kick_family_member: {
|
||||
member
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
};
|
||||
trackReward = async ({
|
||||
address,
|
||||
amount
|
||||
}: {
|
||||
address: string;
|
||||
amount: Coin;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
track_reward: {
|
||||
address,
|
||||
amount
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
claimOperatorReward = async (fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
claimOperatorReward = async (fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
claim_operator_reward: {}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
claimDelegatorReward = async ({
|
||||
mixId
|
||||
}: {
|
||||
mixId: number;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
claim_delegator_reward: {
|
||||
mix_id: mixId
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
updateMixnodeCostParams = async ({
|
||||
newCosts
|
||||
}: {
|
||||
newCosts: MixNodeCostParams;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
newCosts: NodeCostParams;
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
update_mixnode_cost_params: {
|
||||
new_costs: newCosts
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
updateMixnodeConfig = async ({
|
||||
newConfig
|
||||
}: {
|
||||
newConfig: MixNodeConfigUpdate;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
update_mixnode_config: {
|
||||
new_config: newConfig
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
updateMixnetAddress = async ({
|
||||
address
|
||||
}: {
|
||||
address: string;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
update_mixnet_address: {
|
||||
address
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
delegateToMixnode = async ({
|
||||
amount,
|
||||
@@ -826,14 +762,14 @@ export class VestingClient extends VestingQueryClient implements VestingInterfac
|
||||
amount: Coin;
|
||||
mixId: number;
|
||||
onBehalfOf?: string;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
delegate_to_mixnode: {
|
||||
amount,
|
||||
mix_id: mixId,
|
||||
on_behalf_of: onBehalfOf
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
undelegateFromMixnode = async ({
|
||||
mixId,
|
||||
@@ -841,13 +777,13 @@ export class VestingClient extends VestingQueryClient implements VestingInterfac
|
||||
}: {
|
||||
mixId: number;
|
||||
onBehalfOf?: string;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
undelegate_from_mixnode: {
|
||||
mix_id: mixId,
|
||||
on_behalf_of: onBehalfOf
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
createAccount = async ({
|
||||
cap,
|
||||
@@ -859,7 +795,7 @@ export class VestingClient extends VestingQueryClient implements VestingInterfac
|
||||
ownerAddress: string;
|
||||
stakingAddress?: string;
|
||||
vestingSpec?: VestingSpecification;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
create_account: {
|
||||
cap,
|
||||
@@ -867,18 +803,18 @@ export class VestingClient extends VestingQueryClient implements VestingInterfac
|
||||
staking_address: stakingAddress,
|
||||
vesting_spec: vestingSpec
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
withdrawVestedCoins = async ({
|
||||
amount
|
||||
}: {
|
||||
amount: Coin;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
withdraw_vested_coins: {
|
||||
amount
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
trackUndelegation = async ({
|
||||
amount,
|
||||
@@ -888,14 +824,14 @@ export class VestingClient extends VestingQueryClient implements VestingInterfac
|
||||
amount: Coin;
|
||||
mixId: number;
|
||||
owner: string;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
track_undelegation: {
|
||||
amount,
|
||||
mix_id: mixId,
|
||||
owner
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
bondMixnode = async ({
|
||||
amount,
|
||||
@@ -904,10 +840,10 @@ export class VestingClient extends VestingQueryClient implements VestingInterfac
|
||||
ownerSignature
|
||||
}: {
|
||||
amount: Coin;
|
||||
costParams: MixNodeCostParams;
|
||||
costParams: NodeCostParams;
|
||||
mixNode: MixNode;
|
||||
ownerSignature: MessageSignature;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
bond_mixnode: {
|
||||
amount,
|
||||
@@ -915,34 +851,34 @@ export class VestingClient extends VestingQueryClient implements VestingInterfac
|
||||
mix_node: mixNode,
|
||||
owner_signature: ownerSignature
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
pledgeMore = async ({
|
||||
amount
|
||||
}: {
|
||||
amount: Coin;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
pledge_more: {
|
||||
amount
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
decreasePledge = async ({
|
||||
amount
|
||||
}: {
|
||||
amount: Coin;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
decrease_pledge: {
|
||||
amount
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
unbondMixnode = async (fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
unbondMixnode = async (fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
unbond_mixnode: {}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
trackUnbondMixnode = async ({
|
||||
amount,
|
||||
@@ -950,13 +886,13 @@ export class VestingClient extends VestingQueryClient implements VestingInterfac
|
||||
}: {
|
||||
amount: Coin;
|
||||
owner: string;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
track_unbond_mixnode: {
|
||||
amount,
|
||||
owner
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
trackDecreasePledge = async ({
|
||||
amount,
|
||||
@@ -964,13 +900,13 @@ export class VestingClient extends VestingQueryClient implements VestingInterfac
|
||||
}: {
|
||||
amount: Coin;
|
||||
owner: string;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
track_decrease_pledge: {
|
||||
amount,
|
||||
owner
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
bondGateway = async ({
|
||||
amount,
|
||||
@@ -980,19 +916,19 @@ export class VestingClient extends VestingQueryClient implements VestingInterfac
|
||||
amount: Coin;
|
||||
gateway: Gateway;
|
||||
ownerSignature: MessageSignature;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
bond_gateway: {
|
||||
amount,
|
||||
gateway,
|
||||
owner_signature: ownerSignature
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
unbondGateway = async (fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
unbondGateway = async (fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
unbond_gateway: {}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
trackUnbondGateway = async ({
|
||||
amount,
|
||||
@@ -1000,46 +936,46 @@ export class VestingClient extends VestingQueryClient implements VestingInterfac
|
||||
}: {
|
||||
amount: Coin;
|
||||
owner: string;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
track_unbond_gateway: {
|
||||
amount,
|
||||
owner
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
updateGatewayConfig = async ({
|
||||
newConfig
|
||||
}: {
|
||||
newConfig: GatewayConfigUpdate;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
update_gateway_config: {
|
||||
new_config: newConfig
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
transferOwnership = async ({
|
||||
toAddress
|
||||
}: {
|
||||
toAddress: string;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
transfer_ownership: {
|
||||
to_address: toAddress
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
updateStakingAddress = async ({
|
||||
toAddress
|
||||
}: {
|
||||
toAddress?: string;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
update_staking_address: {
|
||||
to_address: toAddress
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
updateLockedPledgeCap = async ({
|
||||
address,
|
||||
@@ -1047,12 +983,37 @@ export class VestingClient extends VestingQueryClient implements VestingInterfac
|
||||
}: {
|
||||
address: string;
|
||||
cap: PledgeCap;
|
||||
}, fee: number | StdFee | "auto" = "auto", memo?: string, _funds?: Coin[]): Promise<ExecuteResult> => {
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
update_locked_pledge_cap: {
|
||||
address,
|
||||
cap
|
||||
}
|
||||
}, fee, memo, _funds);
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
}
|
||||
trackMigratedMixnode = async ({
|
||||
owner
|
||||
}: {
|
||||
owner: string;
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
track_migrated_mixnode: {
|
||||
owner
|
||||
}
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
trackMigratedDelegation = async ({
|
||||
mixId,
|
||||
owner
|
||||
}: {
|
||||
mixId: number;
|
||||
owner: string;
|
||||
}, fee_: number | StdFee | "auto" = "auto", memo_?: string, funds_?: Coin[]): Promise<any> => {
|
||||
return await this.client.execute(this.sender, this.contractAddress, {
|
||||
track_migrated_delegation: {
|
||||
mix_id: mixId,
|
||||
owner
|
||||
}
|
||||
}, fee_, memo_, funds_);
|
||||
};
|
||||
}
|
||||
@@ -1,5 +1,5 @@
|
||||
/**
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@0.35.3.
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@1.13.3.
|
||||
* DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,
|
||||
* and run the @cosmwasm/ts-codegen generate command to regenerate this file.
|
||||
*/
|
||||
@@ -9,23 +9,6 @@ export interface InstantiateMsg {
|
||||
mixnet_contract_address: string;
|
||||
}
|
||||
export type ExecuteMsg = {
|
||||
create_family: {
|
||||
label: string;
|
||||
};
|
||||
} | {
|
||||
join_family: {
|
||||
family_head: FamilyHead;
|
||||
join_permit: MessageSignature;
|
||||
};
|
||||
} | {
|
||||
leave_family: {
|
||||
family_head: FamilyHead;
|
||||
};
|
||||
} | {
|
||||
kick_family_member: {
|
||||
member: string;
|
||||
};
|
||||
} | {
|
||||
track_reward: {
|
||||
address: string;
|
||||
amount: Coin;
|
||||
@@ -38,7 +21,7 @@ export type ExecuteMsg = {
|
||||
};
|
||||
} | {
|
||||
update_mixnode_cost_params: {
|
||||
new_costs: MixNodeCostParams;
|
||||
new_costs: NodeCostParams;
|
||||
};
|
||||
} | {
|
||||
update_mixnode_config: {
|
||||
@@ -79,7 +62,7 @@ export type ExecuteMsg = {
|
||||
} | {
|
||||
bond_mixnode: {
|
||||
amount: Coin;
|
||||
cost_params: MixNodeCostParams;
|
||||
cost_params: NodeCostParams;
|
||||
mix_node: MixNode;
|
||||
owner_signature: MessageSignature;
|
||||
};
|
||||
@@ -133,9 +116,16 @@ export type ExecuteMsg = {
|
||||
address: string;
|
||||
cap: PledgeCap;
|
||||
};
|
||||
} | {
|
||||
track_migrated_mixnode: {
|
||||
owner: string;
|
||||
};
|
||||
} | {
|
||||
track_migrated_delegation: {
|
||||
mix_id: number;
|
||||
owner: string;
|
||||
};
|
||||
};
|
||||
export type FamilyHead = string;
|
||||
export type MessageSignature = number[];
|
||||
export type Uint128 = string;
|
||||
export type Percent = Decimal;
|
||||
export type Decimal = string;
|
||||
@@ -144,12 +134,12 @@ export type PledgeCap = {
|
||||
} | {
|
||||
absolute: Uint128;
|
||||
};
|
||||
export type MessageSignature = number[];
|
||||
export interface Coin {
|
||||
amount: Uint128;
|
||||
denom: string;
|
||||
[k: string]: unknown;
|
||||
}
|
||||
export interface MixNodeCostParams {
|
||||
export interface NodeCostParams {
|
||||
interval_operating_cost: Coin;
|
||||
profit_margin_percent: Percent;
|
||||
}
|
||||
@@ -353,9 +343,12 @@ export interface ContractVersion {
|
||||
export interface ContractBuildInformation {
|
||||
build_timestamp: string;
|
||||
build_version: string;
|
||||
cargo_debug?: string;
|
||||
cargo_opt_level?: string;
|
||||
commit_branch: string;
|
||||
commit_sha: string;
|
||||
commit_timestamp: string;
|
||||
contract_name?: string;
|
||||
rustc_version: string;
|
||||
}
|
||||
export type Period = "before" | {
|
||||
|
||||
@@ -0,0 +1,200 @@
|
||||
/**
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@1.13.3.
|
||||
* DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,
|
||||
* and run the @cosmwasm/ts-codegen generate command to regenerate this file.
|
||||
*/
|
||||
|
||||
|
||||
import { StdFee, Coin } from '@interchainjs/types';
|
||||
import { DirectSigner } from '@interchainjs/cosmos';
|
||||
import { getSmartContractState } from 'interchainjs/cosmwasm/wasm/v1/query.rpc.func';
|
||||
import { executeContract } from 'interchainjs/cosmwasm/wasm/v1/tx.rpc.func';
|
||||
import { QuerySmartContractStateRequest, QuerySmartContractStateResponse } from 'interchainjs/cosmwasm/wasm/v1/query';
|
||||
import { MsgExecuteContract } from 'interchainjs/cosmwasm/wasm/v1/tx';
|
||||
import { Chain } from '@chain-registry/v2-types';
|
||||
|
||||
// Encoding utility functions
|
||||
const fromUint8Array = <T>(uint8Array: Uint8Array): T => {
|
||||
const text = new TextDecoder().decode(uint8Array);
|
||||
return JSON.parse(text);
|
||||
};
|
||||
|
||||
const toUint8Array = (obj: any): Uint8Array => {
|
||||
const text = JSON.stringify(obj);
|
||||
return new TextEncoder().encode(text);
|
||||
};
|
||||
|
||||
// Chain registry configuration
|
||||
// The amount under gasPrice represents gas price per unit
|
||||
export interface ChainConfig {
|
||||
chain?: Chain;
|
||||
gasPrice?: {
|
||||
denom: string;
|
||||
amount: string;
|
||||
};
|
||||
}
|
||||
|
||||
// Gas fee calculation utilities
|
||||
export const calculateGasFromChain = (chain: Chain, gasAmount: string): StdFee => {
|
||||
try {
|
||||
const feeTokens = chain.fees?.feeTokens;
|
||||
|
||||
if (feeTokens && feeTokens.length > 0) {
|
||||
const primaryToken = feeTokens[0];
|
||||
// v2 chain-registry uses camelCase: averageGasPrice, lowGasPrice, fixedMinGasPrice
|
||||
const gasPrice = primaryToken.averageGasPrice || primaryToken.lowGasPrice || primaryToken.fixedMinGasPrice || 0.025;
|
||||
const gasAmountNum = parseInt(gasAmount);
|
||||
const feeAmount = Math.ceil(gasAmountNum * gasPrice).toString();
|
||||
|
||||
return {
|
||||
amount: [{
|
||||
denom: primaryToken.denom,
|
||||
amount: feeAmount
|
||||
}],
|
||||
gas: gasAmount
|
||||
};
|
||||
}
|
||||
} catch (error) {
|
||||
console.warn('Failed to calculate gas from chain registry:', error);
|
||||
}
|
||||
|
||||
// Fallback to default
|
||||
return { amount: [], gas: gasAmount };
|
||||
};
|
||||
|
||||
// Default gas amount - users can easily change this
|
||||
export let DEFAULT_GAS_AMOUNT = '200000';
|
||||
|
||||
// Allow users to set their preferred default gas amount
|
||||
export const setDefaultGasAmount = (gasAmount: string): void => {
|
||||
DEFAULT_GAS_AMOUNT = gasAmount;
|
||||
};
|
||||
|
||||
// Get current default gas amount
|
||||
export const getDefaultGasAmount = (): string => DEFAULT_GAS_AMOUNT;
|
||||
|
||||
export const getAutoGasFee = (chainConfig?: ChainConfig): StdFee => {
|
||||
const gasAmount = DEFAULT_GAS_AMOUNT;
|
||||
|
||||
if (chainConfig?.chain) {
|
||||
return calculateGasFromChain(chainConfig.chain, gasAmount);
|
||||
}
|
||||
|
||||
if (chainConfig?.gasPrice) {
|
||||
const gasAmountNum = parseInt(gasAmount);
|
||||
const gasPriceNum = parseFloat(chainConfig.gasPrice.amount);
|
||||
const feeAmount = Math.ceil(gasAmountNum * gasPriceNum).toString();
|
||||
|
||||
return {
|
||||
amount: [{
|
||||
denom: chainConfig.gasPrice.denom,
|
||||
amount: feeAmount
|
||||
}],
|
||||
gas: gasAmount
|
||||
};
|
||||
}
|
||||
|
||||
// Fallback: no fee tokens, just gas amount
|
||||
return { amount: [], gas: gasAmount };
|
||||
};
|
||||
|
||||
// InterchainJS interfaces for CosmWasm clients
|
||||
export interface ICosmWasmClient {
|
||||
queryContractSmart(contractAddr: string, query: any): Promise<any>;
|
||||
}
|
||||
|
||||
export interface ISigningCosmWasmClient extends ICosmWasmClient {
|
||||
execute(
|
||||
sender: string,
|
||||
contractAddress: string,
|
||||
msg: any,
|
||||
fee?: number | StdFee | "auto",
|
||||
memo?: string,
|
||||
funds?: Coin[],
|
||||
chainConfig?: ChainConfig
|
||||
): Promise<any>;
|
||||
}
|
||||
|
||||
export interface ISigningClient {
|
||||
signAndBroadcast(
|
||||
signerAddress: string,
|
||||
messages: any[],
|
||||
fee: number | StdFee | "auto",
|
||||
memo?: string
|
||||
): Promise<any>;
|
||||
}
|
||||
|
||||
// Helper functions to create InterchainJS clients
|
||||
export function getCosmWasmClient(rpcEndpoint: string): ICosmWasmClient {
|
||||
return {
|
||||
queryContractSmart: async (contractAddr: string, query: any) => {
|
||||
// Create the request object
|
||||
const request: QuerySmartContractStateRequest = {
|
||||
address: contractAddr,
|
||||
queryData: toUint8Array(query)
|
||||
};
|
||||
|
||||
// Execute the query using InterchainJS
|
||||
const response: QuerySmartContractStateResponse = await getSmartContractState(rpcEndpoint, request);
|
||||
|
||||
// Parse and return the result
|
||||
return fromUint8Array(response.data);
|
||||
},
|
||||
};
|
||||
}
|
||||
|
||||
export function getSigningCosmWasmClient(signingClient: DirectSigner, rpcEndpoint?: string): ISigningCosmWasmClient {
|
||||
return {
|
||||
queryContractSmart: async (contractAddr: string, query: any) => {
|
||||
if (!rpcEndpoint) {
|
||||
throw new Error('rpcEndpoint is required for queryContractSmart in signing client');
|
||||
}
|
||||
const request: QuerySmartContractStateRequest = {
|
||||
address: contractAddr,
|
||||
queryData: toUint8Array(query)
|
||||
};
|
||||
const response: QuerySmartContractStateResponse = await getSmartContractState(rpcEndpoint, request);
|
||||
return fromUint8Array(response.data);
|
||||
},
|
||||
execute: async (
|
||||
sender: string,
|
||||
contractAddress: string,
|
||||
msg: any,
|
||||
fee?: number | StdFee | "auto",
|
||||
memo?: string,
|
||||
funds?: Coin[],
|
||||
chainConfig?: ChainConfig
|
||||
) => {
|
||||
// Handle fee conversion
|
||||
let finalFee: StdFee;
|
||||
if (typeof fee === 'number') {
|
||||
finalFee = { amount: [], gas: fee.toString() };
|
||||
} else if (fee === 'auto') {
|
||||
finalFee = getAutoGasFee(chainConfig);
|
||||
} else if (fee) {
|
||||
finalFee = fee;
|
||||
} else {
|
||||
finalFee = getAutoGasFee(chainConfig);
|
||||
}
|
||||
|
||||
// Create the message object
|
||||
const message: MsgExecuteContract = {
|
||||
sender,
|
||||
contract: contractAddress,
|
||||
msg: toUint8Array(msg),
|
||||
funds: funds || []
|
||||
};
|
||||
|
||||
// Execute the transaction using InterchainJS
|
||||
const result = await executeContract(
|
||||
signingClient as any,
|
||||
sender,
|
||||
message,
|
||||
finalFee,
|
||||
memo || ''
|
||||
);
|
||||
|
||||
return result;
|
||||
},
|
||||
};
|
||||
}
|
||||
@@ -1,35 +1,48 @@
|
||||
/**
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@0.35.3.
|
||||
* DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,
|
||||
* and run the @cosmwasm/ts-codegen generate command to regenerate this file.
|
||||
*/
|
||||
* This file was automatically generated by @cosmwasm/ts-codegen@1.13.3.
|
||||
* DO NOT MODIFY IT BY HAND. Instead, modify the source JSONSchema file,
|
||||
* and run the @cosmwasm/ts-codegen generate command to regenerate this file.
|
||||
*/
|
||||
|
||||
import * as _0 from './CoconutBandwidth.types';
|
||||
import * as _1 from './CoconutBandwidth.client';
|
||||
import * as _2 from './CoconutDkg.types';
|
||||
import * as _3 from './CoconutDkg.client';
|
||||
import * as _4 from './Mixnet.types';
|
||||
import * as _5 from './Mixnet.client';
|
||||
import * as _6 from './Cw3FlexMultisig.types';
|
||||
import * as _7 from './Cw3FlexMultisig.client';
|
||||
import * as _8 from './Cw4Group.types';
|
||||
import * as _9 from './Cw4Group.client';
|
||||
import * as _10 from './NameService.types';
|
||||
import * as _11 from './NameService.client';
|
||||
import * as _12 from './ServiceProviderDirectory.types';
|
||||
import * as _13 from './ServiceProviderDirectory.client';
|
||||
import * as _14 from './Vesting.types';
|
||||
import * as _15 from './Vesting.client';
|
||||
export * from './types';
|
||||
|
||||
/** @namespace */
|
||||
import * as _0 from "./Ecash.types";
|
||||
import * as _1 from "./Ecash.client";
|
||||
import * as _2 from "./CoconutDkg.types";
|
||||
import * as _3 from "./CoconutDkg.client";
|
||||
import * as _4 from "./Mixnet.types";
|
||||
import * as _5 from "./Mixnet.client";
|
||||
import * as _6 from "./Cw3FlexMultisig.types";
|
||||
import * as _7 from "./Cw3FlexMultisig.client";
|
||||
import * as _8 from "./Cw4Group.types";
|
||||
import * as _9 from "./Cw4Group.client";
|
||||
import * as _10 from "./Vesting.types";
|
||||
import * as _11 from "./Vesting.client";
|
||||
import * as _12 from "./baseClient";
|
||||
export namespace contracts {
|
||||
export const CoconutBandwidth = { ..._0, ..._1 };
|
||||
export const CoconutDkg = { ..._2, ..._3 };
|
||||
export const Mixnet = { ..._4, ..._5 };
|
||||
export const Cw3FlexMultisig = { ..._6, ..._7 };
|
||||
export const Cw4Group = { ..._8, ..._9 };
|
||||
export const NameService = { ..._10, ..._11 };
|
||||
export const ServiceProviderDirectory = { ..._12, ..._13 };
|
||||
export const Vesting = { ..._14, ..._15 };
|
||||
}
|
||||
export const Ecash = {
|
||||
..._0,
|
||||
..._1
|
||||
};
|
||||
export const CoconutDkg = {
|
||||
..._2,
|
||||
..._3
|
||||
};
|
||||
export const Mixnet = {
|
||||
..._4,
|
||||
..._5
|
||||
};
|
||||
export const Cw3FlexMultisig = {
|
||||
..._6,
|
||||
..._7
|
||||
};
|
||||
export const Cw4Group = {
|
||||
..._8,
|
||||
..._9
|
||||
};
|
||||
export const Vesting = {
|
||||
..._10,
|
||||
..._11
|
||||
};
|
||||
export const baseClient = {
|
||||
..._12
|
||||
};
|
||||
}
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/sdk-example-plain-html-parcel",
|
||||
"version": "1.0.4-rc.2",
|
||||
"version": "1.0.5",
|
||||
"description": "An example project that uses WASM and plain HTML bundled with Parcel v2",
|
||||
"license": "Apache-2.0",
|
||||
"scripts": {
|
||||
@@ -15,7 +15,7 @@
|
||||
"tsc:watch": "tsc --watch"
|
||||
},
|
||||
"dependencies": {
|
||||
"@nymproject/sdk": ">=1.2.2-rc.0 || ^1"
|
||||
"@nymproject/sdk": ">=1.2.3-rc.0 || ^1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@types/jest": "^27.0.1",
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/sdk-example-plain-html",
|
||||
"version": "1.0.4-rc.2",
|
||||
"version": "1.0.5",
|
||||
"description": "An example project that uses WASM and plain HTML",
|
||||
"license": "Apache-2.0",
|
||||
"scripts": {
|
||||
@@ -16,7 +16,7 @@
|
||||
"tsc:watch": "tsc --watch"
|
||||
},
|
||||
"dependencies": {
|
||||
"@nymproject/sdk": ">=1.2.2-rc.0 || ^1"
|
||||
"@nymproject/sdk": ">=1.2.3-rc.0 || ^1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@babel/core": "^7.15.0",
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/sdk-example-react-webpack-wasm",
|
||||
"version": "1.0.4-rc.2",
|
||||
"version": "1.0.5",
|
||||
"description": "An example project that uses WASM, React, Webpack, Typescript and the Nym theme + components library",
|
||||
"license": "Apache-2.0",
|
||||
"scripts": {
|
||||
@@ -20,7 +20,7 @@
|
||||
"@mui/lab": "^5.0.0-alpha.72",
|
||||
"@mui/material": "^5.0.1",
|
||||
"@mui/styles": "^5.0.1",
|
||||
"@nymproject/sdk": ">=1.2.2-rc.0 || ^1",
|
||||
"@nymproject/sdk": ">=1.2.3-rc.0 || ^1",
|
||||
"react": "^18.2.0",
|
||||
"react-dom": "^18.2.0",
|
||||
"react-dropzone": "^14.2.3",
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/sdk-example-chrome-extension",
|
||||
"version": "1.0.4-rc.2",
|
||||
"version": "1.0.5",
|
||||
"description": "This is an example of how Nym can be used within the context of a Chrome extension.",
|
||||
"license": "ISC",
|
||||
"author": "",
|
||||
@@ -9,7 +9,7 @@
|
||||
"build": "webpack"
|
||||
},
|
||||
"dependencies": {
|
||||
"@nymproject/sdk": ">=1.2.2-rc.0 || ^1"
|
||||
"@nymproject/sdk": ">=1.2.3-rc.0 || ^1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"clean-webpack-plugin": "^4.0.0",
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/sdk-example-firefox-extension",
|
||||
"version": "1.0.4-rc.2",
|
||||
"version": "1.0.5",
|
||||
"description": "This is an example of how Nym can be used within the context of a Firefox extension.",
|
||||
"license": "ISC",
|
||||
"author": "",
|
||||
@@ -9,7 +9,7 @@
|
||||
"build": "yarn webpack"
|
||||
},
|
||||
"dependencies": {
|
||||
"@nymproject/sdk": ">=1.2.2-rc.0 || ^1"
|
||||
"@nymproject/sdk": ">=1.2.3-rc.0 || ^1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"copy-webpack-plugin": "^11.0.0",
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/mix-fetch-example-parcel",
|
||||
"version": "1.0.4-rc.2",
|
||||
"version": "1.0.5",
|
||||
"license": "Apache-2.0",
|
||||
"scripts": {
|
||||
"build": "parcel build --no-cache --no-content-hash",
|
||||
@@ -8,7 +8,7 @@
|
||||
"start": "parcel --no-cache"
|
||||
},
|
||||
"dependencies": {
|
||||
"@nymproject/mix-fetch": ">=1.2.2-rc.0 || ^1",
|
||||
"@nymproject/mix-fetch": ">=1.2.3-rc.0 || ^1",
|
||||
"parcel": "^2.9.3"
|
||||
},
|
||||
"private": false,
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/sdk-example-node-tester-plain-html-parcel",
|
||||
"version": "1.0.4-rc.2",
|
||||
"version": "1.0.5",
|
||||
"description": "An example project that uses WASM and plain HTML bundled with Parcel v2",
|
||||
"license": "Apache-2.0",
|
||||
"scripts": {
|
||||
@@ -15,7 +15,7 @@
|
||||
"tsc:watch": "tsc --watch"
|
||||
},
|
||||
"dependencies": {
|
||||
"@nymproject/sdk": ">=1.2.2-rc.0 || ^1"
|
||||
"@nymproject/sdk": ">=1.2.3-rc.0 || ^1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@types/jest": "^27.0.1",
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/sdk-example-node-tester-plain-html",
|
||||
"version": "1.0.4-rc.2",
|
||||
"version": "1.0.5",
|
||||
"description": "An example project that uses WASM node tester and plain HTML",
|
||||
"license": "Apache-2.0",
|
||||
"scripts": {
|
||||
@@ -16,7 +16,7 @@
|
||||
"tsc:watch": "tsc --watch"
|
||||
},
|
||||
"dependencies": {
|
||||
"@nymproject/sdk": ">=1.2.2-rc.0 || ^1"
|
||||
"@nymproject/sdk": ">=1.2.3-rc.0 || ^1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@babel/core": "^7.15.0",
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/sdk-example-node-tester-react",
|
||||
"version": "1.0.4-rc.2",
|
||||
"version": "1.0.5",
|
||||
"description": "An example project that uses WASM node tester and React",
|
||||
"license": "Apache-2.0",
|
||||
"scripts": {
|
||||
@@ -11,7 +11,7 @@
|
||||
"@emotion/styled": "^11.11.0",
|
||||
"@mui/icons-material": "^5.14.0",
|
||||
"@mui/material": "^5.14.0",
|
||||
"@nymproject/sdk": ">=1.2.2-rc.0 || ^1",
|
||||
"@nymproject/sdk": ">=1.2.3-rc.0 || ^1",
|
||||
"parcel": "^2.9.3",
|
||||
"react": "^18.2.0",
|
||||
"react-dom": "^18.2.0"
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/mix-fetch-node",
|
||||
"version": "1.4.0-rc.0",
|
||||
"version": "1.4.1-rc0",
|
||||
"description": "This package is a drop-in replacement for `fetch` in NodeJS to send HTTP requests over the Nym Mixnet.",
|
||||
"license": "Apache-2.0",
|
||||
"author": "Nym Technologies SA",
|
||||
@@ -28,7 +28,7 @@
|
||||
"tsc": "tsc --noEmit true"
|
||||
},
|
||||
"dependencies": {
|
||||
"@nymproject/mix-fetch-wasm-node": ">=1.2.4-rc.2 || ^1",
|
||||
"@nymproject/mix-fetch-wasm-node": ">=1.2.5-rc.0 || ^1",
|
||||
"comlink": "^4.3.1",
|
||||
"fake-indexeddb": "^5.0.0",
|
||||
"node-fetch": "^3.3.2",
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/mix-fetch-tester-webpack",
|
||||
"version": "1.0.4-rc.2",
|
||||
"version": "1.0.5",
|
||||
"license": "Apache-2.0",
|
||||
"scripts": {
|
||||
"build": "webpack build --progress --config webpack.prod.js",
|
||||
@@ -8,7 +8,7 @@
|
||||
"start": "webpack serve --progress --port 3000"
|
||||
},
|
||||
"dependencies": {
|
||||
"@nymproject/mix-fetch": ">=1.2.2-rc.0 || ^1"
|
||||
"@nymproject/mix-fetch": ">=1.2.3-rc.0 || ^1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@babel/core": "^7.22.10",
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/mix-fetch-tester-parcel",
|
||||
"version": "1.0.4-rc.2",
|
||||
"version": "1.0.5",
|
||||
"license": "Apache-2.0",
|
||||
"scripts": {
|
||||
"build": "npx parcel build --no-cache --no-content-hash",
|
||||
@@ -8,7 +8,7 @@
|
||||
"start": "npx parcel --no-cache"
|
||||
},
|
||||
"dependencies": {
|
||||
"@nymproject/mix-fetch": ">=1.2.2-rc.0 || ^1"
|
||||
"@nymproject/mix-fetch": ">=1.2.3-rc.0 || ^1"
|
||||
},
|
||||
"private": false,
|
||||
"source": "../src/index.html"
|
||||
|
||||
@@ -21,6 +21,7 @@ async function main() {
|
||||
|
||||
// const addr =
|
||||
// 'EVdJ66jqpoVzmktVecy5UJxsTCEWo5gMn5zDZR7Hm8jy.GXNpoX7RcYcxKvBkV3dSHqC78WaPuWieweRPWzYqNhh5@GAjhJcrd6f1edaqUkfWCff6zdHoqo756qYrc2TfPuCXJ';
|
||||
// const addr = '7Y9eyF1p1JmzHnd7TVZufnQHkh93ASc9sRBCFY57ZGr8.F8KPyVMVqFQ5yJC3LqeP2ZC7fukzj9a1T426rjo432yT@q2A2cbooyC16YJzvdYaSMH9X3cSiieZNtfBr8cE8Fi1';
|
||||
const addr = undefined;
|
||||
|
||||
appendOutput('About to set up mixFetch...');
|
||||
@@ -54,12 +55,12 @@ async function main() {
|
||||
appendOutput(JSON.stringify(resp, null, 2));
|
||||
appendOutput(JSON.stringify({ text }, null, 2));
|
||||
|
||||
console.log('disconnecting');
|
||||
await disconnectMixFetch();
|
||||
console.log('disconnected! all further usages should fail');
|
||||
// console.log('disconnecting');
|
||||
// await disconnectMixFetch();
|
||||
// console.log('disconnected! all further usages should fail');
|
||||
|
||||
// get an image
|
||||
url = 'https://nymtech.net/favicon.svg';
|
||||
url = 'https://matrix.org/assets/frontpage/github-mark.svg';
|
||||
resp = await mixFetch(url, args);
|
||||
console.log({ resp });
|
||||
const buffer = await resp.arrayBuffer();
|
||||
|
||||
@@ -35,7 +35,8 @@ module.exports = mergeWithRules({
|
||||
{
|
||||
// copy the WASM files, because webpack doesn't do this automatically even though there are
|
||||
// `new URL(..., import.meta.url)` statements in the web worker
|
||||
from: path.resolve(path.dirname(require.resolve('@nymproject/mix-fetch/package.json')), 'dist/esm/*.wasm'),
|
||||
// from: path.resolve(path.dirname(require.resolve('@nymproject/mix-fetch/package.json')), 'dist/esm/*.wasm'),
|
||||
from: path.resolve(path.dirname(require.resolve('@nymproject/mix-fetch/package.json')), '*.wasm'),
|
||||
to: '[name][ext]',
|
||||
},
|
||||
],
|
||||
|
||||
@@ -1,7 +1,5 @@
|
||||
const { mergeWithRules } = require('webpack-merge');
|
||||
const webpack = require('webpack');
|
||||
const ReactRefreshWebpackPlugin = require('@pmmmwh/react-refresh-webpack-plugin');
|
||||
const ReactRefreshTypeScript = require('react-refresh-typescript');
|
||||
const commonConfig = require('./webpack.common');
|
||||
|
||||
module.exports = mergeWithRules({
|
||||
@@ -22,7 +20,7 @@ module.exports = mergeWithRules({
|
||||
exclude: /node_modules/,
|
||||
options: {
|
||||
getCustomTransformers: () => ({
|
||||
before: [ReactRefreshTypeScript()],
|
||||
before: [],
|
||||
}),
|
||||
// `ts-loader` does not work with HMR unless `transpileOnly` is used.
|
||||
// If you need type checking, `ForkTsCheckerWebpackPlugin` is an alternative.
|
||||
@@ -36,8 +34,6 @@ module.exports = mergeWithRules({
|
||||
],
|
||||
},
|
||||
plugins: [
|
||||
new ReactRefreshWebpackPlugin(),
|
||||
|
||||
// this can be included automatically by the dev server, however build mode fails if missing
|
||||
new webpack.HotModuleReplacementPlugin(),
|
||||
],
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/mix-fetch",
|
||||
"version": "1.4.0-rc.0",
|
||||
"version": "1.4.1-rc1",
|
||||
"description": "This package is a drop-in replacement for `fetch` to send HTTP requests over the Nym Mixnet.",
|
||||
"license": "Apache-2.0",
|
||||
"author": "Nym Technologies SA",
|
||||
@@ -34,7 +34,7 @@
|
||||
"tsc": "tsc --noEmit true"
|
||||
},
|
||||
"dependencies": {
|
||||
"@nymproject/mix-fetch-wasm": ">=1.2.4-rc.2 || ^1",
|
||||
"@nymproject/mix-fetch-wasm": "^1.4.1-rc1",
|
||||
"comlink": "^4.3.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/node-tester",
|
||||
"version": "1.3.0-rc.0",
|
||||
"version": "1.3.1",
|
||||
"description": "This package provides a tester that can send test packets to mixnode that is part of the Nym Mixnet.",
|
||||
"license": "Apache-2.0",
|
||||
"author": "Nym Technologies SA",
|
||||
@@ -25,7 +25,7 @@
|
||||
"tsc": "tsc --noEmit true"
|
||||
},
|
||||
"dependencies": {
|
||||
"@nymproject/nym-node-tester-wasm": ">=1.2.4-rc.2 || ^1",
|
||||
"@nymproject/nym-node-tester-wasm": ">=1.2.5-rc.0 || ^1",
|
||||
"comlink": "^4.3.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
@@ -71,4 +71,4 @@
|
||||
"private": false,
|
||||
"type": "module",
|
||||
"types": "./dist/esm/index.d.ts"
|
||||
}
|
||||
}
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/nodejs-client",
|
||||
"version": "1.4.0-rc.0",
|
||||
"version": "1.4.1-rc0",
|
||||
"license": "Apache-2.0",
|
||||
"author": "Nym Technologies SA",
|
||||
"files": [
|
||||
@@ -25,7 +25,7 @@
|
||||
"tsc": "tsc --noEmit true"
|
||||
},
|
||||
"dependencies": {
|
||||
"@nymproject/nym-client-wasm-node": ">=1.2.4-rc.2 || ^1",
|
||||
"@nymproject/nym-client-wasm-node": ">=1.2.5-rc.0 || ^1",
|
||||
"comlink": "^4.3.1",
|
||||
"fake-indexeddb": "^4.0.2",
|
||||
"rollup-plugin-polyfill": "^4.2.0",
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/sdk-react",
|
||||
"version": "1.4.0-rc.0",
|
||||
"version": "1.4.1",
|
||||
"license": "Apache-2.0",
|
||||
"author": "Nym Technologies SA",
|
||||
"files": [
|
||||
@@ -20,7 +20,7 @@
|
||||
"tsc": "tsc --noEmit true"
|
||||
},
|
||||
"dependencies": {
|
||||
"@nymproject/sdk": ">=1.2.2-rc.0 || ^1"
|
||||
"@nymproject/sdk": ">=1.2.3-rc.0 || ^1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@babel/core": "^7.17.5",
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "@nymproject/sdk",
|
||||
"version": "1.4.0-rc.0",
|
||||
"version": "1.4.1-rc1",
|
||||
"license": "Apache-2.0",
|
||||
"author": "Nym Technologies SA",
|
||||
"files": [
|
||||
@@ -30,11 +30,8 @@
|
||||
"test": "node --experimental-vm-modules --no-warnings node_modules/jest/bin/jest.js -c=jest.config.mjs --no-cache",
|
||||
"tsc": "tsc --noEmit true"
|
||||
},
|
||||
"typeRoots": [
|
||||
"./node_modules/@types/*"
|
||||
],
|
||||
"dependencies": {
|
||||
"@nymproject/nym-client-wasm": ">=1.2.4-rc.2 || ^1",
|
||||
"@nymproject/nym-client-wasm": "^1.4.1-rc1",
|
||||
"comlink": "^4.3.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
@@ -83,5 +80,8 @@
|
||||
},
|
||||
"private": false,
|
||||
"type": "module",
|
||||
"typeRoots": [
|
||||
"./node_modules/@types/*"
|
||||
],
|
||||
"types": "./dist/esm/index.d.ts"
|
||||
}
|
||||
|
||||
@@ -21,7 +21,7 @@ yarn
|
||||
yarn build:ci:sdk
|
||||
|
||||
# build documentation
|
||||
yarn docs:prod:build
|
||||
#yarn docs:prod:build
|
||||
|
||||
# turn dev mode off
|
||||
yarn dev:off
|
||||
|
||||
@@ -23,33 +23,33 @@ cd dist
|
||||
#react/sdk-react
|
||||
#)
|
||||
packages=(
|
||||
"wasm/client"
|
||||
"wasm/mix-fetch"
|
||||
"wasm/node-tester"
|
||||
"wasm/extension-storage"
|
||||
#"wasm/client"
|
||||
#"wasm/mix-fetch"
|
||||
#"wasm/node-tester"
|
||||
##"wasm/extension-storage"
|
||||
|
||||
"node/wasm/client"
|
||||
"node/wasm/mix-fetch"
|
||||
#"node/wasm/client"
|
||||
##"node/wasm/mix-fetch"
|
||||
|
||||
"ts/sdk/mix-fetch/cjs"
|
||||
"ts/sdk/mix-fetch/cjs-full-fat"
|
||||
"ts/sdk/mix-fetch/esm"
|
||||
"ts/sdk/mix-fetch/esm-full-fat"
|
||||
|
||||
"ts/sdk/nodejs-client/cjs"
|
||||
"ts/sdk/mix-fetch-node/cjs"
|
||||
#"ts/sdk/nodejs-client/cjs"
|
||||
#"ts/sdk/mix-fetch-node/cjs"
|
||||
|
||||
"ts/sdk/node-tester/cjs"
|
||||
"ts/sdk/node-tester/cjs-full-fat"
|
||||
"ts/sdk/node-tester/esm"
|
||||
"ts/sdk/node-tester/esm-full-fat"
|
||||
#"ts/sdk/node-tester/cjs"
|
||||
#"ts/sdk/node-tester/cjs-full-fat"
|
||||
#"ts/sdk/node-tester/esm"
|
||||
#"ts/sdk/node-tester/esm-full-fat"
|
||||
|
||||
"ts/sdk/sdk/cjs"
|
||||
"ts/sdk/sdk/cjs-full-fat"
|
||||
"ts/sdk/sdk/esm"
|
||||
"ts/sdk/sdk/esm-full-fat"
|
||||
|
||||
"ts/sdk/contract-clients"
|
||||
#"ts/sdk/contract-clients"
|
||||
)
|
||||
|
||||
pushd () {
|
||||
@@ -66,7 +66,7 @@ for item in "${packages[@]}"
|
||||
do
|
||||
pushd "$item"
|
||||
jq -r '. | "📦 " + .version + " " +.name' < package.json
|
||||
popd
|
||||
popd
|
||||
done
|
||||
|
||||
echo ""
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
// Copyright 2023 - Nym Technologies SA <contact@nymtech.net>
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
use anyhow::{bail, Context};
|
||||
use anyhow::{Context, bail};
|
||||
use semver::{Prerelease, Version};
|
||||
use std::collections::HashSet;
|
||||
use std::path::Path;
|
||||
@@ -72,7 +72,9 @@ pub(crate) fn try_bump_raw_prerelease(raw: &str) -> anyhow::Result<Prerelease> {
|
||||
impl VersionBumpExt for Version {
|
||||
fn try_bump_prerelease(&self) -> anyhow::Result<Self> {
|
||||
if self.pre.is_empty() {
|
||||
bail!("the current version ({self}) does not have pre-release data set - are you sure you followed the release process correctly?")
|
||||
bail!(
|
||||
"the current version ({self}) does not have pre-release data set - are you sure you followed the release process correctly?"
|
||||
)
|
||||
}
|
||||
|
||||
Ok(Version {
|
||||
@@ -86,7 +88,9 @@ impl VersionBumpExt for Version {
|
||||
|
||||
fn try_bump_patch_without_pre(&self) -> anyhow::Result<Self> {
|
||||
if !self.pre.is_empty() {
|
||||
bail!("the current version ({self}) has pre-release data set - are you sure you followed the release process correctly?")
|
||||
bail!(
|
||||
"the current version ({self}) has pre-release data set - are you sure you followed the release process correctly?"
|
||||
)
|
||||
}
|
||||
|
||||
let mut updated = self.clone();
|
||||
@@ -96,7 +100,9 @@ impl VersionBumpExt for Version {
|
||||
|
||||
fn set_initial_release_candidate(&self) -> anyhow::Result<Self> {
|
||||
if !self.pre.is_empty() {
|
||||
bail!("the current version ({self}) has pre-release data set - are you sure you followed the release process correctly?")
|
||||
bail!(
|
||||
"the current version ({self}) has pre-release data set - are you sure you followed the release process correctly?"
|
||||
)
|
||||
}
|
||||
Ok(Version {
|
||||
major: self.major,
|
||||
@@ -109,7 +115,9 @@ impl VersionBumpExt for Version {
|
||||
|
||||
fn try_remove_prerelease(&self) -> anyhow::Result<Self> {
|
||||
if self.pre.is_empty() {
|
||||
bail!("the current version ({self}) does not have pre-release data set - are you sure you followed the release process correctly?")
|
||||
bail!(
|
||||
"the current version ({self}) does not have pre-release data set - are you sure you followed the release process correctly?"
|
||||
)
|
||||
}
|
||||
Ok(Version {
|
||||
major: self.major,
|
||||
|
||||
@@ -3,8 +3,8 @@
|
||||
|
||||
use crate::helpers::try_bump_raw_prerelease;
|
||||
use crate::json_types::DepsSet;
|
||||
use crate::{json_types, ReleasePackage};
|
||||
use anyhow::{bail, Context};
|
||||
use crate::{ReleasePackage, json_types};
|
||||
use anyhow::{Context, bail};
|
||||
use semver::{Comparator, Prerelease, Version, VersionReq};
|
||||
use std::collections::HashSet;
|
||||
use std::path::{Path, PathBuf};
|
||||
|
||||
@@ -4,7 +4,7 @@ authors = [
|
||||
"Dave Hrycyszyn <futurechimp@users.noreply.github.com>",
|
||||
"Jedrzej Stuczynski <andrew@nymtech.net>",
|
||||
]
|
||||
version = "1.4.0-rc.0"
|
||||
version = "1.4.1-rc1"
|
||||
edition = "2021"
|
||||
keywords = ["nym", "sphinx", "wasm", "webassembly", "privacy"]
|
||||
license = "Apache-2.0"
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
[package]
|
||||
name = "mix-fetch-wasm"
|
||||
authors = ["Jedrzej Stuczynski <andrew@nymtech.net>"]
|
||||
version = "1.4.0-rc.0"
|
||||
version = "1.4.1-rc1"
|
||||
edition = "2021"
|
||||
keywords = ["nym", "fetch", "wasm", "webassembly", "privacy"]
|
||||
license = "Apache-2.0"
|
||||
@@ -32,6 +32,7 @@ nym-http-api-client = { path = "../../common/http-api-client" }
|
||||
nym-socks5-requests = { path = "../../common/socks5/requests" }
|
||||
nym-ordered-buffer = { path = "../../common/socks5/ordered-buffer" }
|
||||
nym-service-providers-common = { path = "../../service-providers/common" }
|
||||
nym-validator-client = { path = "../../common/client-libs/validator-client", default-features = false }
|
||||
wasm-client-core = { path = "../../common/wasm/client-core" }
|
||||
wasm-utils = { path = "../../common/wasm/utils" }
|
||||
|
||||
|
||||
@@ -1,9 +1,7 @@
|
||||
module go-mix-conn
|
||||
|
||||
go 1.23.0
|
||||
go 1.24.0
|
||||
|
||||
toolchain go1.23.3
|
||||
require golang.org/x/net v0.46.0
|
||||
|
||||
require golang.org/x/net v0.38.0
|
||||
|
||||
require golang.org/x/text v0.23.0 // indirect
|
||||
require golang.org/x/text v0.30.0 // indirect
|
||||
|
||||
@@ -1,4 +1,8 @@
|
||||
golang.org/x/net v0.38.0 h1:vRMAPTMaeGqVhG5QyLJHqNDwecKTomGeqbnfZyKlBI8=
|
||||
golang.org/x/net v0.38.0/go.mod h1:ivrbrMbzFq5J41QOQh0siUuly180yBYtLp+CKbEaFx8=
|
||||
golang.org/x/net v0.46.0 h1:giFlY12I07fugqwPuWJi68oOnpfqFnJIJzaIIm2JVV4=
|
||||
golang.org/x/net v0.46.0/go.mod h1:Q9BGdFy1y4nkUwiLvT5qtyhAnEHgnQ/zd8PfU6nc210=
|
||||
golang.org/x/text v0.23.0 h1:D71I7dUrlY+VX0gQShAThNGHFxZ13dGLBHQLVl1mJlY=
|
||||
golang.org/x/text v0.23.0/go.mod h1:/BLNzu4aZCJ1+kcD0DNRotWKage4q2rGVAg4o22unh4=
|
||||
golang.org/x/text v0.30.0 h1:yznKA/E9zq54KzlzBEAWn1NXSQ8DIp/NYMy88xJjl4k=
|
||||
golang.org/x/text v0.30.0/go.mod h1:yDdHFIX9t+tORqspjENWgzaCVXgk0yYnYuSZ8UzzBVM=
|
||||
|
||||
@@ -1,10 +1,10 @@
|
||||
// Copyright 2023 - Nym Technologies SA <contact@nymtech.net>
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
use crate::harbourmaster::HarbourMasterApiError;
|
||||
use crate::RequestId;
|
||||
use nym_ordered_buffer::OrderedMessageError;
|
||||
use nym_socks5_requests::ConnectionError;
|
||||
use nym_validator_client::nym_api::error::NymAPIError;
|
||||
use thiserror::Error;
|
||||
use wasm_client_core::error::WasmCoreError;
|
||||
use wasm_client_core::ClientCoreError;
|
||||
@@ -22,9 +22,9 @@ pub enum MixFetchError {
|
||||
NoNetworkRequesters,
|
||||
|
||||
#[error("could not query for the service providers: {source}")]
|
||||
HarbourmasterError {
|
||||
ValidatorClientError {
|
||||
#[from]
|
||||
source: HarbourMasterApiError,
|
||||
source: NymAPIError,
|
||||
},
|
||||
|
||||
#[error("failed to parse mix fetch config options: {source}")]
|
||||
|
||||
@@ -94,10 +94,12 @@ pub fn setup_mix_fetch(opts: MixFetchOpts) -> Promise {
|
||||
}
|
||||
|
||||
future_to_promise(async move {
|
||||
let network_requester_address =
|
||||
get_network_requester(opts.base.preferred_network_requester.clone())
|
||||
.await
|
||||
.map_promise_err()?;
|
||||
let network_requester_address = get_network_requester(
|
||||
opts.nym_api_url.clone(),
|
||||
opts.base.preferred_network_requester.clone(),
|
||||
)
|
||||
.await
|
||||
.map_promise_err()?;
|
||||
|
||||
console_log!("going to use {network_requester_address} network requester");
|
||||
|
||||
|
||||
@@ -1,59 +0,0 @@
|
||||
// Copyright 2023 - Nym Technologies SA <contact@nymtech.net>
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
// this exists inside mix-fetch rather than being made into repo-wide library since it's a temporary solution
|
||||
// until the API is finalised and endpoints are moved to nym-api
|
||||
|
||||
use async_trait::async_trait;
|
||||
use nym_http_api_client::{ApiClient, HttpClientError, NO_PARAMS};
|
||||
use serde::Deserialize;
|
||||
|
||||
pub use nym_http_api_client::Client;
|
||||
|
||||
pub type HarbourMasterApiError = HttpClientError;
|
||||
|
||||
mod routes {
|
||||
pub const API_VERSION: &str = "v1";
|
||||
|
||||
pub const SERVICES: &str = "services";
|
||||
|
||||
pub const NEW: &str = "new";
|
||||
}
|
||||
|
||||
#[cfg_attr(target_arch = "wasm32", async_trait(?Send))]
|
||||
#[cfg_attr(not(target_arch = "wasm32"), async_trait)]
|
||||
pub trait HarbourMasterApiClientExt: ApiClient {
|
||||
// since it's a temporary thing don't worry about paging.
|
||||
async fn get_services_new(&self) -> Result<PagedResult<ServiceNew>, HarbourMasterApiError> {
|
||||
self.get_json(
|
||||
&[routes::API_VERSION, routes::SERVICES, routes::NEW],
|
||||
NO_PARAMS,
|
||||
)
|
||||
.await
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg_attr(target_arch = "wasm32", async_trait(?Send))]
|
||||
#[cfg_attr(not(target_arch = "wasm32"), async_trait)]
|
||||
impl HarbourMasterApiClientExt for Client {}
|
||||
|
||||
// https://gitlab.nymte.ch/nym/shipyard-test-and-earn/-/blob/main/harbour-master/src/http/mod.rs#L13
|
||||
#[allow(dead_code)]
|
||||
#[derive(Debug, Deserialize)]
|
||||
pub struct PagedResult<T> {
|
||||
pub page: u32,
|
||||
pub size: u32,
|
||||
pub total: i32,
|
||||
pub items: Vec<T>,
|
||||
}
|
||||
|
||||
// https://gitlab.nymte.ch/nym/shipyard-test-and-earn/-/blob/main/harbour-master/src/http/services.rs#L32
|
||||
#[allow(dead_code)]
|
||||
#[derive(Debug, Deserialize)]
|
||||
pub struct ServiceNew {
|
||||
pub service_provider_client_id: String,
|
||||
pub ip_address: String,
|
||||
pub last_successful_ping_utc: String,
|
||||
pub last_updated_utc: String,
|
||||
pub routing_score: f32,
|
||||
}
|
||||
@@ -2,36 +2,48 @@
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
use crate::error::MixFetchError;
|
||||
use crate::harbourmaster;
|
||||
use crate::harbourmaster::HarbourMasterApiClientExt;
|
||||
use crate::error::MixFetchError::NoNetworkRequesters;
|
||||
use nym_http_api_client::Client;
|
||||
use nym_validator_client::nym_api::NymApiClientExt;
|
||||
use rand::seq::SliceRandom;
|
||||
use rand::thread_rng;
|
||||
use wasm_utils::console_log;
|
||||
|
||||
// since this client is temporary (and will be properly integrated into nym-api eventually),
|
||||
// we're using hardcoded URL for mainnet
|
||||
const HARBOUR_MASTER: &str = "https://harbourmaster.nymtech.net";
|
||||
const NYM_API_URL: &str = "https://validator.nymtech.net/api/";
|
||||
|
||||
pub(crate) async fn get_network_requester(
|
||||
nym_api_url: Option<String>,
|
||||
preferred: Option<String>,
|
||||
) -> Result<String, MixFetchError> {
|
||||
if let Some(sp) = preferred {
|
||||
return Ok(sp);
|
||||
}
|
||||
|
||||
let client = harbourmaster::Client::new_url(HARBOUR_MASTER, None)?;
|
||||
let providers = client.get_services_new().await?;
|
||||
let client = Client::new(
|
||||
url::Url::parse(&nym_api_url.unwrap_or(NYM_API_URL.to_string()))?,
|
||||
None,
|
||||
);
|
||||
let nodes = client.get_all_described_nodes().await?;
|
||||
let providers: Vec<_> = nodes
|
||||
.iter()
|
||||
.filter_map(|node| {
|
||||
node.description
|
||||
.network_requester
|
||||
.clone()
|
||||
.map(|n| n.address)
|
||||
})
|
||||
.collect();
|
||||
console_log!(
|
||||
"obtained list of {} service providers on the network",
|
||||
providers.items.len()
|
||||
providers.len()
|
||||
);
|
||||
|
||||
// this will only return a `None` if the list is empty
|
||||
let mut rng = thread_rng();
|
||||
providers
|
||||
.items
|
||||
.choose(&mut rng)
|
||||
.map(|service| &service.service_provider_client_id)
|
||||
.ok_or(NoNetworkRequesters)
|
||||
.cloned()
|
||||
.ok_or(MixFetchError::NoNetworkRequesters)
|
||||
}
|
||||
|
||||
@@ -14,8 +14,6 @@ mod fetch;
|
||||
#[cfg(target_arch = "wasm32")]
|
||||
mod go_bridge;
|
||||
#[cfg(target_arch = "wasm32")]
|
||||
mod harbourmaster;
|
||||
#[cfg(target_arch = "wasm32")]
|
||||
mod helpers;
|
||||
#[cfg(target_arch = "wasm32")]
|
||||
mod request_writer;
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
[package]
|
||||
name = "nym-node-tester-wasm"
|
||||
authors = ["Jedrzej Stuczynski <andrew@nymtech.net>"]
|
||||
version = "1.3.0-rc.0"
|
||||
version = "1.3.1-rc0"
|
||||
edition = "2021"
|
||||
keywords = ["nym", "sphinx", "webassembly", "privacy", "tester"]
|
||||
license = "Apache-2.0"
|
||||
|
||||
Reference in New Issue
Block a user