Offchain Swap + Whitebit
Предзаказ обмена
Получить перечень валют для offChainSwap с перечнем маркетов:
query {
offChainSwapCurrencies {
currencyId
offChainSwapMarkets {
id
baseCurrencyId
baseCurrency { # наш обычный Сurrency тип (лого, цвета и пр.)
id
precision
}
quoteCurrencyId
quoteCurrency { # наш обычный Сurrency тип (лого, цвета и пр.)
id
precision
}
enabled
offChainSwapPricePrecision # сколько знаков после запятой показывать в прайсе
offChainMinBaseAmount # минимальное количество обмена в базовой валюте
offChainMaxBaseAmount # максимальное количество обмена в базовой валюте
offChainMinQuoteAmount # минимальное количество обмена в квотируемой валюте
offChainMaxQuoteAmount # максимальное количество обмена в квотируемой валюте
offChainSwapEnabled # флаг включения оффчейн обмена на рынке
}
}
}
Пример ответа:
{
"data": {
"offChainSwapCurrencies": [
{
"currencyId": "BTC",
"offChainSwapMarkets": [
{
"id": "BTC-USDT",
"baseCurrencyId": "BTC",
"baseCurrency": {
"id": "BTC",
"precision": 8
},
"quoteCurrencyId": "USDT",
"quoteCurrency": {
"id": "USDT",
"precision": 2
},
"enabled": true,
"offChainSwapPricePrecision": 5,
"offChainMinBaseAmount": 0.0001,
"offChainMaxBaseAmount": 2,
"offChainMinQuoteAmount": 10.01,
"offChainMaxQuoteAmount": 95000,
"offChainSwapEnabled": true
},
{
"id": "LTC-BTC",
"baseCurrencyId": "LTC",
"baseCurrency": {
"id": "LTC",
"precision": 4
},
"quoteCurrencyId": "BTC",
"quoteCurrency": {
"id": "BTC",
"precision": 8
},
"enabled": true,
"offChainSwapPricePrecision": 5,
"offChainMinBaseAmount": 1,
"offChainMaxBaseAmount": 100,
"offChainMinQuoteAmount": 0.0001,
"offChainMaxQuoteAmount": 2,
"offChainSwapEnabled": true
}
]
},
{
"currencyId": "USDT",
"offChainSwapMarkets": [
{
"id": "BTC-USDT",
"baseCurrencyId": "BTC",
"baseCurrency": {
"id": "BTC",
"precision": 8
},
"quoteCurrencyId": "USDT",
"quoteCurrency": {
"id": "USDT",
"precision": 2
},
"enabled": true,
"offChainSwapPricePrecision": 5,
"offChainMinBaseAmount": 0.0001,
"offChainMaxBaseAmount": 2,
"offChainMinQuoteAmount": 10.01,
"offChainMaxQuoteAmount": 95000,
"offChainSwapEnabled": true
},
{
"id": "ETH-USDT",
"baseCurrencyId": "ETH",
"baseCurrency": {
"id": "ETH",
"precision": 6
},
"quoteCurrencyId": "USDT",
"quoteCurrency": {
"id": "USDT",
"precision": 2
},
"enabled": true,
"offChainSwapPricePrecision": 4,
"offChainMinBaseAmount": 0.001001,
"offChainMaxBaseAmount": 10,
"offChainMinQuoteAmount": 9.01,
"offChainMaxQuoteAmount": 15.01,
"offChainSwapEnabled": true
}
]
},
{
"currencyId": "ETH",
"offChainSwapMarkets": [
{
"id": "ETH-USDT",
"baseCurrencyId": "ETH",
"baseCurrency": {
"id": "ETH",
"precision": 6
},
"quoteCurrencyId": "USDT",
"quoteCurrency": {
"id": "USDT",
"precision": 2
},
"enabled": true,
"offChainSwapPricePrecision": 4,
"offChainMinBaseAmount": 0.001001,
"offChainMaxBaseAmount": 10,
"offChainMinQuoteAmount": 9.01,
"offChainMaxQuoteAmount": 15.01,
"offChainSwapEnabled": true
}
]
},
{
"currencyId": "LTC",
"offChainSwapMarkets": [
{
"id": "LTC-BTC",
"baseCurrencyId": "LTC",
"baseCurrency": {
"id": "LTC",
"precision": 4
},
"quoteCurrencyId": "BTC",
"quoteCurrency": {
"id": "BTC",
"precision": 8
},
"enabled": true,
"offChainSwapPricePrecision": 5,
"offChainMinBaseAmount": 1,
"offChainMaxBaseAmount": 100,
"offChainMinQuoteAmount": 0.0001,
"offChainMaxQuoteAmount": 2,
"offChainSwapEnabled": true
}
]
}
]
}
}
Получить перечень доступных для offChainSwap маркетов:
query {
offChainSwapMarkets {
id
baseCurrencyId
baseCurrency {
id
precision
}
quoteCurrencyId
quoteCurrency {
id
precision
}
enabled
offChainSwapPricePrecision # сколько знаков после запятой показывать в прайсе
offChainMinBaseAmount # минимальное количество обмена в базовой валюте
offChainMaxBaseAmount # максимальное количество обмена в базовой валюте
offChainMinQuoteAmount # минимальное количество обмена в квотируемой валюте
offChainMaxQuoteAmount # максимальное количество обмена в квотируемой валюте
offChainSwapEnabled # флаг включения оффчейн обмена на рынке
}
}
Пример ответа:
Предзаказ обмена
Сначала необходимо получить квоту (информацию о цене, по которой можно будет обменять деньги).
В ответе присутствуют поля createdAt и expireAt: перед запрос квоты необходимо сохранить текущее время пользователя. После получения ответа от сервера рассчитать разницу между серверным временем и временем пользователя и использовать эту разницу для расчета expireAt во времени пользователя.
Результат запроса:
Возможные ошибки:
Превышен max amount:
Не достигнут min amount:
Не найден рынок или на рынке enabled = false или offChainSwapEnabled = false:
Ошибка сервиса - не получается получить квоту:
Подтверждение квоты (запуск обмена)
Ответ на подтверждение
________________________________________
Отримання рейту - потрібне ДО формування квоти, для розуміння Юзером витраченної комісіі та приблизного рейту після обміну.
Квота запитується при кожній зміні кількості у формі обміну. Буде один єдиний крок обміну.
Умови валідацї на підтвердження Обміну:
- Мінімум та максимум для обміну з налаштувань (нове)
- Баланс Юзера
- Баланс брокера (при отриманні квоти). Юзер бачить як неможливість обміну у формі.
Потребує змін дизайну:
- Показувати мінімум та максимум для Обміну
- Прибрати зайві поля. Залишається один рейт, без можливості робити реверс рейту ( погодити )
- Прибрати поле з комісією
1.1. При отриманні Квоті(перехід на крок підтвердження Квоти) має враховуватись баланс Брокера
Це вираховується на стороні Бека. Пункти при яких буде запитуватися квота:
- зміна кількості на обмін From
- зміна валют Send/Receive
- зміна пари методом “Реверс”
- інтервальне оновлення кожні 10 секунд
1.2. При невдалому отриманні Квоти - повідомляти причину помилки
Погодити тексти помилок для Юзера.
Popup in case of successful swap:
Your swap was successful
1.3. Попередня форма, до формування Квоти, має бути “калькулятором” для прозорого розуміння Юзером сплати комісіі, обрахунок, рейт
Ця можливсть буде присутня в межах баланса брокера і в межах налаштувань мінімума та максимума на Обміну.
1.4 Користивуч не має бути прив'язаний до Балансу Брокера, на етапі приблизного обрахування його обміну
Буде прив'язанийПри цій запропонованій побудові - Фронт має отримувати зміну по квоті при кожній зміни кількості на обмін. Фронт не зможе адекватно обробляти це бо:
Юзер може протягом короткоко часу ввести, змінити, додати Кількість на обмін багато разів - що приводить кожного разу до Нового запиту отримання Квоти, відповідно отримання Квоти може бути успішним/неуспішним та отримання Квоти може зайняти тривалий час .
Це побуджує велечезну кількість запитів на отримання квоти, що буде означати не зовсім неочікуєму роботу обрахунку у формі на Фронті
Це питання вирішується на стороні БекуВ нас має бути можливість користуватися офф-чейн свапом з підключеною зовнішньою Платформою та без, в контексті однієї форми для обміну.
Якщо - ні , то налаштування потрібно розділити : ЮзерАпп з 2ма видами налаштувань обміну або внутрішній/або зовнішній . Поєднати це проблематично та потребує досліджень та роз'яснень, а потім погодження як це має бути для Операторів, які не потребують інтеграціі зовнішних Платформ.
Це питання потрібно погодити з Менеджментом, враховуючі Операторів які не очікують інтеграцію з зовнішніми платформамиДля Обміну було б раціонально мати РейтСорс у налаштуваннях маркету з показником ЛастПрайс, отриманий з Трейдінгу(або інший рейт-сорс Зовнішньої платформи)
Додатково: у маркета мало б бути делька рейт-сорсів. Та припиненні роботи одного рейт-сорсу(падііня сервісу) - вмикання наступного. Це запобігає некоректній роботі Свапу на платформі.
Тільки для внутрішього Обміну це буде потрібноВ якій валюті береться комісія за Обмін на Зовнішній платформі?
В нас є можливисть налаштування як у базовій так і у валюті квотування - чи не буде це ломати наш Обмін в Операціях?
Це питання потрібно погодити з Менеджментом
Чи показувати взагалі комісію ЮзеруТакож змінилася структура отримання даних для свопу, колись ми отримували масив маркетів для кожної валюти, зараз ми отримуємо всі маркети в одному масиві
Вирішено. Зараз отримуємо в контексті Валюти в новому запиті.ще таке загальне питання до беків, по отриманню даних,
Конкретно до сутності маркетів, до чого вони унаслідувалися від моделі типу «Market» на базі неї будувався логіна свопу, інста ордер і дт., зараз зʼявилася ще одна нова сутність «BasicMarket»
Питання:
Її ми будемо використовувати тільки для off/on chain swap?
Чи ми переходимо тільки на неї?
Після дзвінку:Бек робить оновлення сутностей, найменування полів та їх чищення. В ітозі будуть впровадженні нові сутності а старі видалені згодом.
Фронт буде прибирати поля, які не будуть використовуватитись у сутності Market
Фронт додає нову сутність SwapMarket
____________________________________________________________________
UX/UI User stories
As a User, I can press the 'Swap' button on Currency Wallet 'Card' and... Open the 'Quick Swap' form as a modal window
In case there are no available markets to Swap the Currency 'Swap' button is deactivated
...See the following details in the modal window: 'Quick Swap' header
Send section with main details:
'Drop down' button to select Currency to Send with logo and ID (Ticker)
In case there is only one option for Currency to Send: the user can observe just this option with logo and currency ID in a drop-down
Currency to Send is selected according to Wallet selected (by default for each Wallet) with logo and ID (Ticker)
Input field for amount to Swap (Send internally), pre-set "Minimum amount" to Swap by default
"Max" button for Maximum amount input
Asset's balance available for operation, in selected currency with currency ID
'Reverse' button for changing Currency positions between 'Send' and 'Receive'
Receive the section with the main details:'Drop down' button to select Currency to Receive with logo and ID (Ticker)
The field 'Receive' with a calculated amount (Approximate) in Currency to Receive
The second Asset's balance (Currency to Receive) currently available in its Wallet
"i" icon and notice the text message "Exchange rate refreshes with counter"
"Rate" portion for selected Market Pair: Base Currency -> Quote Currency (price precision, according to market settings)
"Rate" animated circle statement for the rate updated periodically after a certain time has elapsed (10 seconds by default).
"Swap" button
The 'X' button below the main form to close the modal window
...Press the 'Drop Down' button to change Currency to Send and... Open the Currencies drop-down list
See the list of currencies suggested as Currencies to Send (according to Market Pairs on the platform) with the main details:
Input field to search Currency to Send by ID or Name of the Currency
Logo
ID/Ticker
Available Balances of the Currencies to Send
Selected Currency is marked
Select the Currency to Send from the list
See the Swap details changed according to the Market parameters with new selected Currency:Pre-set for Send in the Input field for amount to Send (Minimum amount to send according to market settings)
Current Balance of Currency to Send
Option(s) for Currency(ies) to receive
Field 'Receive' with a calculated amount (Approximate) in Currency to Receive
Current Balance of Currency to Receive
Rate
...Press the 'Drop Down' button to change Currency to Receive and... Open the Currencies drop-down list
See the list of currencies suggested as Currencies to Receive (according to Market Pairs on the platform) with the main details:
Input field to search Currency to Receive by ID or Name of the Currency
Logo
ID/Ticker
Available Balances of the Currencies to Receive
Selected Currency is marked
Select the Currency to Receive from the list
See the Swap details changed according to the Market parameters with new selected Currency:Pre-set for Send in the Input field for amount to Send (Minimum amount to send according to market settings)
Current Balance of Currency to Send
Option(s) for Currency(ies) to Send
The field 'Receive' with calculated amount (Approximate) in Currency to Receive
Current Balance of Currency to Receive
Rate
...Click on the Input field for an amount to Send and see... Previous input clears automatically and the 'Minimum amount to send' notification is on top of the input field "Send" (according to market settings)
The "Max" button deactivated
The field 'Receive' with the error text '0.00' in the field 'Receive'
Rate with "--" (empty data)
See the 'Swap' Button deactivated
...Input amount for Send and... See calculated amount (Approximate) of Currency to Receive in the field 'Receive'
Observe Amount of the Currency to Receive depends on the rate of the selected Market Pair and changes if the Amount to Send
See the 'Swap' Button activated if the input amount fits the requirements
...Input-only 'dot' first and... See automatically changing to ' 0. ' in the Input field
...Input amount of the Currency to Swap lower than minimum allowed and... 'Minimum amount to send' notification on top of the input field "Amount" (according to market settings)
The "Max" button deactivated
The field 'Receive' with the error text '0.00' in the field 'Receive'
Rate with "--" (empty data)
See the 'Swap' Button deactivated
...Input amount of the Currency to Swap higher than the maximum allowed and... 'Maximum amount to send' notification on top of the input field "Amount" (according to market settings)
The "Max" button deactivated
The field 'Receive' with the error text '0.00' in the field 'Receive'
Rate with "--" (empty data)
See the 'Swap' Button deactivated
...Input amount of the Currency to Send bigger than the amount of the Available Assets and higher than the maximum allowed: 'Maximum amount to send' notification on top of the input field "Amount" (according to market settings)
The "Max" button deactivated
The field 'Receive' with the error text '0.00' in the field 'Receive'
Rate with "--" (empty data)
See the 'Swap' Button deactivated
...Input amount of the Currency to Send bigger than the amount of the Available Assets: - "Max" button deactivated
The field 'Receive' with the error text '0.00' in the field 'Receive'
Rate with "--" (empty data)
See the 'Swap' Button deactivated
...Leave the input field for Amount to Send empty: 'Minimum amount to send' notification on top of the input field "Amount" (according to market settings)
The "Max" button deactivated
The field 'Receive' with the error text '0.00' in the field 'Receive'
Rate with "--" (empty data)
See the 'Swap' Button deactivated
...In case the available balance of the Currency to Send is lower than the amount of the Currency to Send (the first time open the form) See the amount pre-set equal to minimum amount to Send in the input field for Currency to Send
The "Max" button deactivated
The field 'Receive' with the error text '0.00' in the field 'Receive'
Rate with "--" (empty data)
See the 'Swap' Button deactivated
...Press the 'Swap' button and... See the popup notification 'Your swap was successful' if everything is correct
Observe Available Balances of the Base and Quote currencies are changed
...Press the 'X' button below the 'Swap' form and... Close the modal window 'Swap form' and get back to Wallet details