Merge pull request #534 from ivivanov/master

add chain specific getMintInflation func
This commit is contained in:
ping 2024-01-31 12:33:38 +08:00 committed by GitHub
commit 4c53591e85
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
8 changed files with 65 additions and 12 deletions

27
chains/mainnet/nolus.json Normal file
View File

@ -0,0 +1,27 @@
{
"chain_name": "nolus",
"coingecko": "nolus",
"api": [
{"provider": "Nolus", "address": "https://pirin-cl.nolus.network:1317"},
{"provider": "LavenderFive", "address": "https://nolus-api.lavenderfive.com:443"},
{"provider": "Allnodes", "address": "https://nolus-rest.publicnode.com"}
],
"rpc": [
{"provider": "Nolus", "address": "https://pirin-cl.nolus.network:26657"},
{"provider": "LavenderFive", "address": "https://nolus-rpc.lavenderfive.com:443"},
{"provider": "Allnodes", "address": "https://nolus-rpc.publicnode.com:443"}
],
"snapshot_provider": "",
"sdk_version": "v0.47.6",
"coin_type": "118",
"min_tx_fee": "0",
"addr_prefix": "nolus",
"logo": "/logos/nolus.svg",
"assets": [{
"base": "unls",
"symbol": "NLS",
"exponent": "6",
"coingecko_id": "nolus",
"logo": "/logos/nolus.svg"
}]
}

View File

@ -20,7 +20,7 @@ export class BaseRestClient<R extends AbstractRegistry> {
this.endpoint = endpoint; this.endpoint = endpoint;
this.registry = registry; this.registry = registry;
} }
async request<T>(request: Request<T>, args: Record<string, any>, query = '', adapter?: (source: any) => T ) { async request<T>(request: Request<T>, args: Record<string, any>, query = '', adapter?: (source: any) => Promise<T> ) {
let url = `${request.url.startsWith("http")?'':this.endpoint}${request.url}${query}`; let url = `${request.url.startsWith("http")?'':this.endpoint}${request.url}${query}`;
Object.keys(args).forEach((k) => { Object.keys(args).forEach((k) => {
url = url.replace(`{${k}}`, args[k] || ''); url = url.replace(`{${k}}`, args[k] || '');

View File

@ -21,11 +21,11 @@ function proposalAdapter(p: any): GovProposal {
} }
export const requests: Partial<RequestRegistry> = { export const requests: Partial<RequestRegistry> = {
mint_inflation: { url: '/evmos/inflation/v1/inflation_rate', adapter: (data: any) => ({inflation: (Number(data.inflation_rate || 0)/ 100 ).toFixed(2)}) }, mint_inflation: { url: '/evmos/inflation/v1/inflation_rate', adapter: async (data: any) => ({inflation: (Number(data.inflation_rate || 0)/ 100 ).toFixed(2)}) },
gov_params_voting: { url: '/cosmos/gov/v1/params/voting', adapter }, gov_params_voting: { url: '/cosmos/gov/v1/params/voting', adapter },
gov_params_tally: { url: '/cosmos/gov/v1/params/tallying', adapter }, gov_params_tally: { url: '/cosmos/gov/v1/params/tallying', adapter },
gov_params_deposit: { url: '/cosmos/gov/v1/params/deposit', adapter }, gov_params_deposit: { url: '/cosmos/gov/v1/params/deposit', adapter },
gov_proposals: { url: '/cosmos/gov/v1/proposals', adapter: (source: any): PaginatedProposals => { gov_proposals: { url: '/cosmos/gov/v1/proposals', adapter: async (source: any): Promise<PaginatedProposals> => {
const proposals = source.proposals.map((p:any) => proposalAdapter(p)) const proposals = source.proposals.map((p:any) => proposalAdapter(p))
return { return {
proposals, proposals,
@ -34,7 +34,7 @@ export const requests: Partial<RequestRegistry> = {
}}, }},
gov_proposals_proposal_id: { gov_proposals_proposal_id: {
url: '/cosmos/gov/v1/proposals/{proposal_id}', url: '/cosmos/gov/v1/proposals/{proposal_id}',
adapter: (source: any): {proposal: GovProposal} => { adapter: async (source: any): Promise<{proposal: GovProposal}> => {
return { return {
proposal: proposalAdapter(source.proposal) proposal: proposalAdapter(source.proposal)
} }

26
src/libs/clients/nolus.ts Normal file
View File

@ -0,0 +1,26 @@
import type { RequestRegistry } from '@/libs/registry'
import { CosmosRestClient } from '@/libs/client';
import { useBlockchain } from '@/stores';
import { adapter } from '@/libs/registry'
// Blockchain Name
export const name = 'nolus';
// nolus custom request
export const requests: Partial<RequestRegistry> = {
mint_inflation: {
url: '/nolus/mint/v1beta1/annual_inflation',
adapter: async (data: any): Promise<any> => {
try {
const client = CosmosRestClient.newDefault(useBlockchain().endpoint.address)
const staking = await client.getStakingPool()
const inflation = Number(data.annual_inflation) / Number(staking.pool.bonded_tokens) || 0;
return { inflation: inflation.toString() };
} catch (error) {
console.log("Error in adapter:", error);
return { inflation: "0" };
}
}
},
bank_supply_by_denom: { url: "/cosmos/bank/v1beta1/supply/by_denom?denom={denom}", adapter }
};

View File

@ -26,7 +26,7 @@ function proposalAdapter(p: any): GovProposal {
export const requests: Partial<RequestRegistry> = { export const requests: Partial<RequestRegistry> = {
mint_inflation: { mint_inflation: {
url: `https://public-osmosis-api.numia.xyz/apr?start_date=${new Date(new Date().getTime() - 186400*1000).toISOString().split('T')[0]}&end_date=${new Date().toISOString().split('T')[0]}`, url: `https://public-osmosis-api.numia.xyz/apr?start_date=${new Date(new Date().getTime() - 186400*1000).toISOString().split('T')[0]}&end_date=${new Date().toISOString().split('T')[0]}`,
adapter: (data: any) => { adapter: async (data: any) => {
const [first] = data const [first] = data
return {inflation: String(Number(first?.apr|| "0")/100.0)} return {inflation: String(Number(first?.apr|| "0")/100.0)}
} }
@ -34,7 +34,7 @@ export const requests: Partial<RequestRegistry> = {
gov_params_voting: { url: '/cosmos/gov/v1/params/voting', adapter }, gov_params_voting: { url: '/cosmos/gov/v1/params/voting', adapter },
gov_params_tally: { url: '/cosmos/gov/v1/params/tallying', adapter }, gov_params_tally: { url: '/cosmos/gov/v1/params/tallying', adapter },
gov_params_deposit: { url: '/cosmos/gov/v1/params/deposit', adapter }, gov_params_deposit: { url: '/cosmos/gov/v1/params/deposit', adapter },
gov_proposals: { url: '/cosmos/gov/v1/proposals', adapter: (source: any): PaginatedProposals => { gov_proposals: { url: '/cosmos/gov/v1/proposals', adapter: async (source: any): Promise<PaginatedProposals> => {
const proposals = source.proposals.map((p:any) => proposalAdapter(p)) const proposals = source.proposals.map((p:any) => proposalAdapter(p))
return { return {
proposals, proposals,
@ -43,7 +43,7 @@ export const requests: Partial<RequestRegistry> = {
}}, }},
gov_proposals_proposal_id: { gov_proposals_proposal_id: {
url: '/cosmos/gov/v1/proposals/{proposal_id}', url: '/cosmos/gov/v1/proposals/{proposal_id}',
adapter: (source: any): {proposal: GovProposal} => { adapter: async (source: any): Promise<{proposal: GovProposal}> => {
return { return {
proposal: proposalAdapter(source.proposal) proposal: proposalAdapter(source.proposal)
} }

View File

@ -33,7 +33,7 @@ export const requests: Partial<RequestRegistry> = {
gov_params_voting: { url: '/cosmos/gov/v1/params/voting', adapter }, gov_params_voting: { url: '/cosmos/gov/v1/params/voting', adapter },
gov_params_tally: { url: '/cosmos/gov/v1/params/tallying', adapter }, gov_params_tally: { url: '/cosmos/gov/v1/params/tallying', adapter },
gov_params_deposit: { url: '/cosmos/gov/v1/params/deposit', adapter }, gov_params_deposit: { url: '/cosmos/gov/v1/params/deposit', adapter },
gov_proposals: { url: '/cosmos/gov/v1/proposals', adapter: (source: any): PaginatedProposals => { gov_proposals: { url: '/cosmos/gov/v1/proposals', adapter: async (source: any): Promise<PaginatedProposals> => {
const proposals = source.proposals.map((p:any) => proposalAdapter(p)) const proposals = source.proposals.map((p:any) => proposalAdapter(p))
return { return {
proposals, proposals,
@ -42,7 +42,7 @@ export const requests: Partial<RequestRegistry> = {
}}, }},
gov_proposals_proposal_id: { gov_proposals_proposal_id: {
url: '/cosmos/gov/v1/proposals/{proposal_id}', url: '/cosmos/gov/v1/proposals/{proposal_id}',
adapter: (source: any): {proposal: GovProposal} => { adapter: async (source: any): Promise<{proposal: GovProposal}> => {
return { return {
proposal: proposalAdapter(source.proposal) proposal: proposalAdapter(source.proposal)
} }

View File

@ -2,7 +2,7 @@ import fetch from 'cross-fetch';
export async function fetchData<T>( export async function fetchData<T>(
url: string, url: string,
adapter: (source: any) => T adapter: (source: any) => Promise<T>
): Promise<T> { ): Promise<T> {
const response = await fetch(url); const response = await fetch(url);
if (!response.ok) { if (!response.ok) {

View File

@ -45,7 +45,7 @@ import type { PaginatedTxs, Tx, TxResponse } from '@/types';
import semver from 'semver' import semver from 'semver'
export interface Request<T> { export interface Request<T> {
url: string; url: string;
adapter: (source: any) => T; adapter: (source: any) => Promise<T>;
} }
export interface AbstractRegistry { export interface AbstractRegistry {
@ -154,7 +154,7 @@ export interface RequestRegistry extends AbstractRegistry {
interchain_security_ccv_provider_validator_consumer_addr: Request<{consumer_address: string}> interchain_security_ccv_provider_validator_consumer_addr: Request<{consumer_address: string}>
} }
export function adapter<T>(source: any): T { export function adapter<T>(source: any): Promise<T> {
return source; return source;
} }