Skip to content

Commit

Permalink
Pass config service down to PolkadotService
Browse files Browse the repository at this point in the history
  • Loading branch information
nohaapav committed Oct 5, 2023
1 parent fc39784 commit 732a96e
Show file tree
Hide file tree
Showing 3 changed files with 45 additions and 13 deletions.
13 changes: 8 additions & 5 deletions packages/sdk/src/getTransferData/getTransferData.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
/* eslint-disable @typescript-eslint/no-use-before-define */
import type { TransactionResponse } from '@ethersproject/abstract-provider';
import { TransferConfig } from '@moonbeam-network/xcm-config';
import { IConfigService, TransferConfig } from '@moonbeam-network/xcm-config';
import { AssetAmount } from '@moonbeam-network/xcm-types';
import { convertDecimals, toBigInt } from '@moonbeam-network/xcm-utils';
import Big from 'big.js';
Expand All @@ -15,22 +15,24 @@ import { getDestinationData } from './getDestinationData';
import { getSourceData } from './getSourceData';

export interface GetTransferDataParams extends Partial<Signers> {
configService: IConfigService;
destinationAddress: string;
sourceAddress: string;
transferConfig: TransferConfig;
}

export async function getTransferData({
configService,
destinationAddress,
evmSigner,
polkadotSigner,
sourceAddress,
transferConfig,
}: GetTransferDataParams): Promise<TransferData> {
const [destPolkadot, srcPolkadot] = await PolkadotService.createMulti([
transferConfig.destination.chain,
transferConfig.source.chain,
]);
const [destPolkadot, srcPolkadot] = await PolkadotService.createMulti(
[transferConfig.destination.chain, transferConfig.source.chain],
configService,
);

const destination = await getDestinationData({
destinationAddress,
Expand Down Expand Up @@ -78,6 +80,7 @@ export async function getTransferData({
source,
async swap() {
return getTransferData({
configService,
destinationAddress: sourceAddress,
evmSigner,
polkadotSigner,
Expand Down
34 changes: 28 additions & 6 deletions packages/sdk/src/polkadot/PolkadotService.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ import {
SubstrateQueryConfig,
} from '@moonbeam-network/xcm-builder';
import {
IConfigService,
darwiniaPangoro,
eq,
equilibriumAlphanet,
Expand All @@ -28,17 +29,38 @@ export class PolkadotService {

readonly chain: AnyParachain;

constructor(api: ApiPromise, chain: AnyParachain) {
readonly configService: IConfigService;

constructor(
api: ApiPromise,
chain: AnyParachain,
configService: IConfigService,
) {
this.api = api;
this.chain = chain;
this.configService = configService;
}

static async create(chain: AnyParachain): Promise<PolkadotService> {
return new PolkadotService(await getPolkadotApi(chain.ws), chain);
static async create(
chain: AnyParachain,
configService: IConfigService,
): Promise<PolkadotService> {
return new PolkadotService(
await getPolkadotApi(chain.ws),
chain,
configService,
);
}

static async createMulti(chains: AnyParachain[]): Promise<PolkadotService[]> {
return Promise.all(chains.map(PolkadotService.create));
static async createMulti(
chains: AnyParachain[],
configService: IConfigService,
): Promise<PolkadotService[]> {
return Promise.all(
chains.map((chain: AnyParachain) =>
PolkadotService.create(chain, configService),
),
);
}

get decimals(): number {
Expand All @@ -64,7 +86,7 @@ export class PolkadotService {
throw new Error('No native symbol key found');
}

const asset = this.chain.assetsData.get(key)?.asset;
const asset = this.configService.getAsset(key);

if (!asset) {
throw new Error(`No asset found for key "${key}" and symbol "${symbol}"`);
Expand Down
11 changes: 9 additions & 2 deletions packages/sdk/src/sdk.ts
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
/* eslint-disable sort-keys */
import { ConfigBuilder, IConfigService } from '@moonbeam-network/xcm-config';
import {
ConfigBuilder,
ConfigService,
IConfigService,
} from '@moonbeam-network/xcm-config';
import { AnyChain, Asset, Ecosystem } from '@moonbeam-network/xcm-types';
import { getTransferData as gtd } from './getTransferData/getTransferData';
import { Signers, TransferData } from './sdk.interfaces';
Expand All @@ -9,7 +13,8 @@ export interface SdkOptions extends Partial<Signers> {
}

export function Sdk(options?: SdkOptions) {
const configService = options?.configService;
const configService = options?.configService ?? new ConfigService();

return {
assets(ecosystem?: Ecosystem) {
const { assets, asset } = ConfigBuilder(configService).assets(ecosystem);
Expand All @@ -35,6 +40,7 @@ export function Sdk(options?: SdkOptions) {
): Promise<TransferData> {
return gtd({
...options,
configService,
destinationAddress,
evmSigner: signers?.evmSigner ?? signers?.ethersSigner,
sourceAddress,
Expand All @@ -61,6 +67,7 @@ export function Sdk(options?: SdkOptions) {
sourceKeyOrChain,
}: SdkTransferParams): Promise<TransferData> {
return gtd({
configService,
destinationAddress,
evmSigner: evmSigner ?? ethersSigner,
polkadotSigner,
Expand Down

0 comments on commit 732a96e

Please sign in to comment.