From 61a3294edc77412f4641f62118a4c4013ede9e41 Mon Sep 17 00:00:00 2001 From: lendihop Date: Fri, 29 Sep 2023 21:13:00 +0200 Subject: [PATCH 1/3] pairs added --- src/index.ts | 42 +++++--------- src/interfaces/alice-bob.interfaces.ts | 14 ++++- src/utils/alice-bob/create-alice-bob-order.ts | 2 +- .../alice-bob/get-alice-bob-pair-info.ts | 44 -------------- .../alice-bob/get-alice-bob-pairs-info.ts | 58 +++++++++++++++++++ 5 files changed, 84 insertions(+), 76 deletions(-) delete mode 100644 src/utils/alice-bob/get-alice-bob-pair-info.ts create mode 100644 src/utils/alice-bob/get-alice-bob-pairs-info.ts diff --git a/src/index.ts b/src/index.ts index ac0c5cd..faed72b 100644 --- a/src/index.ts +++ b/src/index.ts @@ -22,7 +22,7 @@ import { cancelAliceBobOrder } from './utils/alice-bob/cancel-alice-bob-order'; import { createAliceBobOrder } from './utils/alice-bob/create-alice-bob-order'; import { estimateAliceBobOutput } from './utils/alice-bob/estimate-alice-bob-output'; import { getAliceBobOrderInfo } from './utils/alice-bob/get-alice-bob-order-info'; -import { getAliceBobPairInfo } from './utils/alice-bob/get-alice-bob-pair-info'; +import { getAliceBobPairsInfo } from './utils/alice-bob/get-alice-bob-pairs-info'; import { coinGeckoTokens } from './utils/gecko-tokens'; import { getExternalApiErrorPayload, isDefined, isNonEmptyString } from './utils/helpers'; import logger from './utils/logger'; @@ -191,8 +191,6 @@ app.get('/api/exchange-rates', async (_req, res) => { app.get('/api/moonpay-sign', async (_req, res) => { try { const url = _req.query.url; - console.log('url: ', url); - console.log('url: type', typeof url); if (typeof url === 'string') { const signedUrl = getSignedMoonPayUrl(url); @@ -207,20 +205,19 @@ app.get('/api/moonpay-sign', async (_req, res) => { }); app.post('/api/alice-bob/create-order', async (_req, res) => { - const { isWithdraw, amount, userId, walletAddress, cardNumber } = _req.query; - const booleanIsWithdraw = isWithdraw === 'true'; + const { amount, from, to, userId, walletAddress, cardNumber } = _req.query; try { const exchangeInfo = { - from: booleanIsWithdraw ? 'TEZ' : 'CARDUAH', - to: booleanIsWithdraw ? 'CARDUAH' : 'TEZ', + from: String(from), + to: String(to), fromAmount: Number(amount), userId: String(userId), - toPaymentDetails: booleanIsWithdraw ? String(cardNumber) : String(walletAddress), + toPaymentDetails: isDefined(cardNumber) ? String(cardNumber) : String(walletAddress), redirectUrl: 'https://templewallet.com/mobile' }; - const orderInfo = await createAliceBobOrder(booleanIsWithdraw, exchangeInfo); + const orderInfo = await createAliceBobOrder(exchangeInfo); res.status(200).send({ orderInfo }); } catch (error) { @@ -242,13 +239,13 @@ app.post('/api/alice-bob/cancel-order', async (_req, res) => { } }); -app.get('/api/alice-bob/get-pair-info', async (_req, res) => { +app.get('/api/alice-bob/get-pairs-info', async (_req, res) => { const { isWithdraw } = _req.query; try { - const pairInfo = await getAliceBobPairInfo(isWithdraw === 'true'); + const pairsInfo = await getAliceBobPairsInfo(isWithdraw === 'true'); - res.status(200).send({ pairInfo }); + res.status(200).send({ pairsInfo }); } catch (error) { const { status, data } = getExternalApiErrorPayload(error); res.status(status).send(data); @@ -269,16 +266,16 @@ app.get('/api/alice-bob/check-order', async (_req, res) => { }); app.post('/api/alice-bob/estimate-amount', async (_req, res) => { - const { isWithdraw, amount } = _req.query; - const booleanIsWithdraw = isWithdraw === 'true'; + const { amount, from, to } = _req.query; try { const exchangeInfo = { - from: booleanIsWithdraw ? 'TEZ' : 'CARDUAH', - to: booleanIsWithdraw ? 'CARDUAH' : 'TEZ', + from: String(from), + to: String(to), fromAmount: Number(amount) }; const outputAmount = await estimateAliceBobOutput(exchangeInfo); + console.log(outputAmount, 'amount'); res.status(200).send({ outputAmount }); } catch (error) { @@ -288,19 +285,8 @@ app.post('/api/alice-bob/estimate-amount', async (_req, res) => { }); app.get('/api/mobile-check', async (_req, res) => { - console.log(1); - console.log('androidAppId', process.env.ANDROID_APP_ID); - console.log('iosAppId', process.env.IOS_APP_ID); - const platform = _req.query.platform; const appCheckToken = _req.query.appCheckToken; - console.log('token', appCheckToken); - - console.log(1); - console.log('androidAppId', process.env.ANDROID_APP_ID); - console.log('iosAppId', process.env.IOS_APP_ID); - - console.log('A123', platform, appCheckToken); if (!Boolean(appCheckToken) || appCheckToken === undefined) { return res.status(400).send({ error: 'App Check token is not defined' }); @@ -311,7 +297,6 @@ app.get('/api/mobile-check', async (_req, res) => { await iosApp.appCheck().verifyToken(appCheckToken as unknown as string); } else { await androidApp.appCheck().verifyToken(appCheckToken as unknown as string); - console.log('verification successful'); } res.status(200).send({ @@ -320,7 +305,6 @@ app.get('/api/mobile-check', async (_req, res) => { isAppCheckFailed: false }); } catch (err) { - console.log('err', err); res.status(200).send({ minIosVersion: MIN_IOS_APP_VERSION, minAndroidVersion: MIN_ANDROID_APP_VERSION, diff --git a/src/interfaces/alice-bob.interfaces.ts b/src/interfaces/alice-bob.interfaces.ts index eecba5b..7cee050 100644 --- a/src/interfaces/alice-bob.interfaces.ts +++ b/src/interfaces/alice-bob.interfaces.ts @@ -32,8 +32,18 @@ export interface aliceBobOrder { } export interface AliceBobPairInfo { - minamount: number; - maxamount: number; + from: string; + to: string; + fromnetwork: string | null; + tonetwork: string | null; + in: string; + out: string; + ratetype: string; + amount: string; + tofee: string; + fromfee: string; + minamount: string; + maxamount: string; } export interface AliceBobEstimateAmountPayload { diff --git a/src/utils/alice-bob/create-alice-bob-order.ts b/src/utils/alice-bob/create-alice-bob-order.ts index d97999c..536d431 100644 --- a/src/utils/alice-bob/create-alice-bob-order.ts +++ b/src/utils/alice-bob/create-alice-bob-order.ts @@ -3,7 +3,7 @@ import { aliceBobApi } from '../api.sevice'; import { getAliceBobRequestHeaders } from './get-alice-bob-request-headers'; import { getAliceBobSignature } from './get-alice-bob-signature'; -export const createAliceBobOrder = async (isWithdraw: boolean, payload: AliceBobCreateOrderPayload) => { +export const createAliceBobOrder = async (payload: AliceBobCreateOrderPayload) => { const { signature, now } = getAliceBobSignature(payload); const response = await aliceBobApi.post('/create-order', payload, { diff --git a/src/utils/alice-bob/get-alice-bob-pair-info.ts b/src/utils/alice-bob/get-alice-bob-pair-info.ts deleted file mode 100644 index 35fd0bf..0000000 --- a/src/utils/alice-bob/get-alice-bob-pair-info.ts +++ /dev/null @@ -1,44 +0,0 @@ -import { AxiosError } from 'axios'; - -import { AliceBobPairInfo } from '../../interfaces/alice-bob.interfaces'; -import { aliceBobApi } from '../api.sevice'; -import { estimateAliceBobOutput } from './estimate-alice-bob-output'; -import { getAliceBobRequestHeaders } from './get-alice-bob-request-headers'; -import { getAliceBobSignature } from './get-alice-bob-signature'; - -export const getAliceBobPairInfo = async (isWithdraw = false) => { - const pair = isWithdraw ? 'TEZ/CARDUAH' : 'CARDUAH/TEZ'; - - const { signature, now } = getAliceBobSignature(); - - const response = await aliceBobApi.get('/get-pair-info/' + pair, { - headers: getAliceBobRequestHeaders(signature, now) - }); - - /* - Output estimation at AliceBob errors later with `maxAmount` used as input amount. - Double-checking here, to have a valid `maxAmount` value. - */ - - let maxAmount = response.data.maxamount; - - if (isWithdraw === false) - try { - await estimateAliceBobOutput({ - from: 'CARDUAH', - to: 'TEZ', - fromAmount: maxAmount - }); - } catch (error) { - if ( - error instanceof AxiosError && - error.response?.status === 400 && - error.response.data.errorCode === 'EXCEEDING_LIMITS' - ) { - const altMaxAmount = Number(error.response.data.maxAmount); - if (Number.isFinite(altMaxAmount)) maxAmount = altMaxAmount; - } - } - - return { minAmount: response.data.minamount, maxAmount }; -}; diff --git a/src/utils/alice-bob/get-alice-bob-pairs-info.ts b/src/utils/alice-bob/get-alice-bob-pairs-info.ts new file mode 100644 index 0000000..e87d825 --- /dev/null +++ b/src/utils/alice-bob/get-alice-bob-pairs-info.ts @@ -0,0 +1,58 @@ +import { AxiosError } from 'axios'; + +import { AliceBobPairInfo } from '../../interfaces/alice-bob.interfaces'; +import { aliceBobApi } from '../api.sevice'; +import { estimateAliceBobOutput } from './estimate-alice-bob-output'; +import { getAliceBobRequestHeaders } from './get-alice-bob-request-headers'; +import { getAliceBobSignature } from './get-alice-bob-signature'; + +export const getAliceBobPairsInfo = async (isWithdraw = false) => { + const { signature, now } = getAliceBobSignature(); + + const { data } = await aliceBobApi.get('/get-pairs-info', { + headers: getAliceBobRequestHeaders(signature, now) + }); + + const pairsInfo = data.filter(pair => (isWithdraw ? pair.from === 'TEZ' : pair.from !== 'TEZ')); + + /* + Output estimation at AliceBob errors later with `maxAmount` used as input amount. + Double-checking here, to have a valid `maxAmount` value. + */ + if (!isWithdraw) { + const finalPairsInfo: AliceBobPairInfo[] = []; + + for (let i = 0; i < pairsInfo.length; i++) { + const currentPair = pairsInfo[i]; + + const [maxAmountString, currencyCode] = currentPair.maxamount.split(' '); + let maxAmount = Number(maxAmountString); + + try { + await estimateAliceBobOutput({ + from: currentPair.from, + to: 'TEZ', + fromAmount: maxAmount + }); + } catch (error) { + if ( + error instanceof AxiosError && + error.response?.status === 400 && + error.response.data.errorCode === 'EXCEEDING_LIMITS' + ) { + const altMaxAmount = Number(error.response.data.maxAmount); + if (Number.isFinite(altMaxAmount)) maxAmount = altMaxAmount; + } + } + + finalPairsInfo.push({ + ...currentPair, + maxamount: `${maxAmount} ${currencyCode}` + }); + } + + return finalPairsInfo; + } + + return pairsInfo; +}; From 2ab75fbc873099ab23756039098430b5ea4bc96e Mon Sep 17 00:00:00 2001 From: lendihop Date: Mon, 2 Oct 2023 10:52:28 +0200 Subject: [PATCH 2/3] small refactor --- .../alice-bob/get-alice-bob-pairs-info.ts | 60 +++++++++---------- 1 file changed, 30 insertions(+), 30 deletions(-) diff --git a/src/utils/alice-bob/get-alice-bob-pairs-info.ts b/src/utils/alice-bob/get-alice-bob-pairs-info.ts index e87d825..c00b226 100644 --- a/src/utils/alice-bob/get-alice-bob-pairs-info.ts +++ b/src/utils/alice-bob/get-alice-bob-pairs-info.ts @@ -15,44 +15,44 @@ export const getAliceBobPairsInfo = async (isWithdraw = false) => { const pairsInfo = data.filter(pair => (isWithdraw ? pair.from === 'TEZ' : pair.from !== 'TEZ')); + if (isWithdraw) { + return pairsInfo; + } + /* Output estimation at AliceBob errors later with `maxAmount` used as input amount. Double-checking here, to have a valid `maxAmount` value. */ - if (!isWithdraw) { - const finalPairsInfo: AliceBobPairInfo[] = []; - - for (let i = 0; i < pairsInfo.length; i++) { - const currentPair = pairsInfo[i]; - - const [maxAmountString, currencyCode] = currentPair.maxamount.split(' '); - let maxAmount = Number(maxAmountString); - - try { - await estimateAliceBobOutput({ - from: currentPair.from, - to: 'TEZ', - fromAmount: maxAmount - }); - } catch (error) { - if ( - error instanceof AxiosError && - error.response?.status === 400 && - error.response.data.errorCode === 'EXCEEDING_LIMITS' - ) { - const altMaxAmount = Number(error.response.data.maxAmount); - if (Number.isFinite(altMaxAmount)) maxAmount = altMaxAmount; - } - } + const finalPairsInfo: AliceBobPairInfo[] = []; - finalPairsInfo.push({ - ...currentPair, - maxamount: `${maxAmount} ${currencyCode}` + for (let i = 0; i < pairsInfo.length; i++) { + const currentPair = pairsInfo[i]; + + const [maxAmountString, currencyCode] = currentPair.maxamount.split(' '); + let maxAmount = Number(maxAmountString); + + try { + await estimateAliceBobOutput({ + from: currentPair.from, + to: 'TEZ', + fromAmount: maxAmount }); + } catch (error) { + if ( + error instanceof AxiosError && + error.response?.status === 400 && + error.response.data.errorCode === 'EXCEEDING_LIMITS' + ) { + const altMaxAmount = Number(error.response.data.maxAmount); + if (Number.isFinite(altMaxAmount)) maxAmount = altMaxAmount; + } } - return finalPairsInfo; + finalPairsInfo.push({ + ...currentPair, + maxamount: `${maxAmount} ${currencyCode}` + }); } - return pairsInfo; + return finalPairsInfo; }; From 5ffb644d9762d041618622b2782796b7e08a282b Mon Sep 17 00:00:00 2001 From: lendihop Date: Mon, 2 Oct 2023 11:23:47 +0200 Subject: [PATCH 3/3] log removed --- src/index.ts | 1 - 1 file changed, 1 deletion(-) diff --git a/src/index.ts b/src/index.ts index faed72b..34fa222 100644 --- a/src/index.ts +++ b/src/index.ts @@ -275,7 +275,6 @@ app.post('/api/alice-bob/estimate-amount', async (_req, res) => { fromAmount: Number(amount) }; const outputAmount = await estimateAliceBobOutput(exchangeInfo); - console.log(outputAmount, 'amount'); res.status(200).send({ outputAmount }); } catch (error) {