random pick endpoints
This commit is contained in:
parent
586f819d41
commit
ce7abefa84
@ -41,6 +41,7 @@ Object.values(conf.value).forEach((imported) => {
|
|||||||
// continue only if the page is living
|
// continue only if the page is living
|
||||||
if (imported[i].endpoint) {
|
if (imported[i].endpoint) {
|
||||||
loadBalances(
|
loadBalances(
|
||||||
|
imported[i].chainName,
|
||||||
imported[i].endpoint || '',
|
imported[i].endpoint || '',
|
||||||
imported[i].address
|
imported[i].address
|
||||||
).finally(() => resolve());
|
).finally(() => resolve());
|
||||||
@ -170,15 +171,17 @@ async function addAddress(acc: AccountEntry) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (acc.endpoint) {
|
if (acc.endpoint) {
|
||||||
loadBalances(acc.endpoint, acc.address);
|
loadBalances(acc.chainName, acc.endpoint, acc.address);
|
||||||
}
|
}
|
||||||
|
|
||||||
localStorage.setItem('imported-addresses', JSON.stringify(conf.value));
|
localStorage.setItem('imported-addresses', JSON.stringify(conf.value));
|
||||||
}
|
}
|
||||||
|
|
||||||
// load balances for an address
|
// load balances for an address
|
||||||
async function loadBalances(endpoint: string, address: string) {
|
async function loadBalances(chainName: string, endpoint: string, address: string) {
|
||||||
const client = CosmosRestClient.newDefault(endpoint);
|
|
||||||
|
const endpointObj = chainStore.randomEndpoint(chainName)
|
||||||
|
const client = CosmosRestClient.newDefault(endpointObj?.address || endpoint);
|
||||||
await client.getBankBalances(address).then((res) => {
|
await client.getBankBalances(address).then((res) => {
|
||||||
balances.value[address] = res.balances.filter((x) => x.denom.length < 10);
|
balances.value[address] = res.balances.filter((x) => x.denom.length < 10);
|
||||||
});
|
});
|
||||||
|
@ -4,7 +4,7 @@ import type { Coin, Delegation } from '@/types';
|
|||||||
import { ref, watchEffect } from 'vue';
|
import { ref, watchEffect } from 'vue';
|
||||||
import type { AccountEntry } from './utils';
|
import type { AccountEntry } from './utils';
|
||||||
import { computed } from 'vue';
|
import { computed } from 'vue';
|
||||||
import { useBaseStore, useFormatter } from '@/stores';
|
import { useBaseStore, useBlockchain, useFormatter } from '@/stores';
|
||||||
import DonutChart from '@/components/charts/DonutChart.vue';
|
import DonutChart from '@/components/charts/DonutChart.vue';
|
||||||
import ApexCharts from 'vue3-apexcharts';
|
import ApexCharts from 'vue3-apexcharts';
|
||||||
import { get } from '@/libs';
|
import { get } from '@/libs';
|
||||||
@ -17,6 +17,7 @@ const conf = ref(
|
|||||||
AccountEntry[]
|
AccountEntry[]
|
||||||
>
|
>
|
||||||
);
|
);
|
||||||
|
const chainStore = useBlockchain();
|
||||||
const balances = ref({} as Record<string, Coin[]>);
|
const balances = ref({} as Record<string, Coin[]>);
|
||||||
const delegations = ref({} as Record<string, Delegation[]>);
|
const delegations = ref({} as Record<string, Delegation[]>);
|
||||||
const tokenMeta = ref({} as Record<string, AccountEntry>);
|
const tokenMeta = ref({} as Record<string, AccountEntry>);
|
||||||
@ -64,7 +65,8 @@ Object.values(conf.value).forEach((imported) => {
|
|||||||
imported.forEach((x) => {
|
imported.forEach((x) => {
|
||||||
if (x.endpoint && x.address) {
|
if (x.endpoint && x.address) {
|
||||||
loading.value += 1
|
loading.value += 1
|
||||||
const client = CosmosRestClient.newDefault(x.endpoint);
|
const endpoint = chainStore.randomEndpoint(x.chainName)
|
||||||
|
const client = CosmosRestClient.newDefault(endpoint?.address || x.endpoint);
|
||||||
client.getBankBalances(x.address).then((res) => {
|
client.getBankBalances(x.address).then((res) => {
|
||||||
const bal = res.balances.filter((x) => x.denom.length < 10);
|
const bal = res.balances.filter((x) => x.denom.length < 10);
|
||||||
if (bal) balances.value[x.address || ""] = bal;
|
if (bal) balances.value[x.address || ""] = bal;
|
||||||
|
@ -147,20 +147,25 @@ export const useBlockchain = defineStore('blockchain', {
|
|||||||
useBlockModule().initial();
|
useBlockModule().initial();
|
||||||
},
|
},
|
||||||
|
|
||||||
async randomSetupEndpoint() {
|
randomEndpoint(chainName: string) : Endpoint | undefined {
|
||||||
const end = localStorage.getItem(`endpoint-${this.chainName}`);
|
const end = localStorage.getItem(`endpoint-${chainName}`);
|
||||||
if (end) {
|
if (end) {
|
||||||
this.setRestEndpoint(JSON.parse(end));
|
return JSON.parse(end);
|
||||||
} else {
|
} else {
|
||||||
const all = this.current?.endpoints?.rest;
|
const all = this.current?.endpoints?.rest;
|
||||||
if (all) {
|
if (all) {
|
||||||
const rn = Math.random();
|
const rn = Math.random();
|
||||||
const endpoint = all[Math.floor(rn * all.length)];
|
const endpoint = all[Math.floor(rn * all.length)];
|
||||||
await this.setRestEndpoint(endpoint);
|
return endpoint
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
async randomSetupEndpoint() {
|
||||||
|
const endpoint = this.randomEndpoint(this.chainName)
|
||||||
|
if(endpoint) await this.setRestEndpoint(endpoint);
|
||||||
|
},
|
||||||
|
|
||||||
async setRestEndpoint(endpoint: Endpoint) {
|
async setRestEndpoint(endpoint: Endpoint) {
|
||||||
this.connErr = '';
|
this.connErr = '';
|
||||||
this.endpoint = endpoint;
|
this.endpoint = endpoint;
|
||||||
|
Loading…
Reference in New Issue
Block a user