A API Liqi Swap 1.0 vem suprir a demanda por cotações monetárias.
O usuário pode converter os valores, por exemplo, de BRL para USD.
A documentação apresenta todos os símbolos de moedas disponíveis.
Com a API Liqi Swap você pode converter os valores de moedas com base na cotação atual, utilizando a versão 4 da Exchange Rate API.
Versão do Node: 18 Versão da API Exchange Rate: 4
nvm use 18 npm i node server.js
POST /api/currency/convert - Converte o valor de um montante de dinheiro em outra moeda.
GET /api/currency/symbols - Lista todas as moedas
Requisição:
POST http://localhost:3000/api/currency/convert
Content-Type: application/json
{
"amount": 100,
"sourceCurrency": "BRL",
"targetCurrency": "USD"
}
Resposta:
HTTP/1.1 200 OK
X-Powered-By: Express
Content-Type: application/json; charset=utf-8
Content-Length: 61
ETag: W/"3d-0/a/5RGtJZe0bVRwGEkuN9wVwu4"
Date: Wed, 03 Apr 2024 00:51:04 GMT
Connection: close
{
"amount": 19.8,
"sourceCurrency": "BRL",
"targetCurrency": "USD"
}
Requisição:
GET http://localhost:3000/api/currency/symbols
Resposta:
HTTP/1.1 200 OK
X-Powered-By: Express
Content-Type: application/json; charset=utf-8
Content-Length: 985
ETag: W/"3d9-Lx4A5plSe+mfAxgPB5hqCkewaMo"
Date: Wed, 03 Apr 2024 16:40:52 GMT
Connection: close
{
"symbols": [
"USD",
"AED",
"AFN",
"ALL",
"AMD",
"ANG",
"AOA",
"ARS",
"AUD",
...
"XPF",
"YER",
"ZAR",
"ZMW",
"ZWL"
]
}
Para rodar testes, executar o comando:
npm test
Existem dois arquivos de testes, que usam a biblioteca Jest para executar testes unitários sobre os Controllers de conversão de valores de moedas e de listagem dos símbolos.
Lista de Testes:
- should return converted amount and currencies
- should return error for invalid currency
- should return error for missing parameters
- should return error for API failure
- should return list of currency symbols
- should handle error when fetching currency symbols
A justificativa para o uso da versão 4 é que ela permita realizar a consulta necessária para o cálculo da conversão sem a necessidade de consumir créditos.