Coder Social home page Coder Social logo

financial-api's Introduction

Financial API

Essa API é um projeto fictício que simula transações entre a carteira de dois usuário.

O desafio foi inspirado no teste do Picpay

Temos 2 tipos de usuários, os comuns e lojistas, ambos têm carteira com dinheiro e realizam transferências entre eles. Vamos nos atentar somente ao fluxo de transferência entre dois usuários.

Requisitos:

  • Para ambos tipos de usuário, precisamos do Nome Completo, CPF, e-mail e Senha. CPF/CNPJ e e-mails devem ser únicos no sistema. Sendo assim, seu sistema deve permitir apenas um cadastro com o mesmo CPF ou endereço de e-mail.
  • Usuários podem enviar dinheiro (efetuar transferência) para lojistas e entre usuários.
  • Lojistas só recebem transferências, não enviam dinheiro para ninguém.
  • Validar se o usuário tem saldo antes da transferência.
  • Antes de finalizar a transferência, deve-se consultar um serviço autorizador externo, use este mock para simular (https://run.mocky.io/v3/8fafdd68-a090-496f-8c9a-3442cf30dae6).
  • A operação de transferência deve ser uma transação (ou seja, revertida em qualquer caso de inconsistência) e o dinheiro deve voltar para a carteira do usuário que envia.
  • No recebimento de pagamento, o usuário ou lojista precisa receber notificação (envio de email, sms) enviada por um serviço de terceiro e eventualmente este serviço pode estar indisponível/instável. Use este mock para simular o envio (http://o4d9z.mocklab.io/notify).

A arquitetura do código é inspirada nos conceitos de arquitetura hexagonal e clean architecture.

São existentes dois ambientes, development utilizado para testes e production para simular um ambiente de produção.

Sendo assim são utilizados dois bancos Postgres para cada um dos ambientes, para executá-los a partir do diretório wallet-api:

docker-compose up -d

Para executar os testes unitários:

Executando migrations e seeders:

npm run migrate
npm run seed

Executando testes unitários:

npm run test:unit

Executando testes de integração:

npm run test:integration

Tecnologias e ferramentas:

  • Node 17
  • NPM
  • Postgres
  • Knex
  • Jest
  • Typescript
  • Express
  • Morgan e Winston (Logger)
  • ESLint e Prettier

financial-api's People

Contributors

felipegxavier avatar

Watchers

 avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.