Skip to content

alalavn/cybermen-api

 
 

Repository files navigation

REST Payment PHP

Esta api tem como proposta testar uma arquitetura desacoplada usando os conceitos de Dependency Injection, SOLID e DRY.

Por este motivo foi usado o mínimo de framework, afim de manter uma estrutura flexível e que facilmente pode adaptar as interfaces de inplementações que conversam com a camada de domínio(Negócio).

Esta estrutura não parece tão produtiva noinício quanto usar uma framework como o Laravel que prototipa rapidamente, porém é vantajosa a medida que o projeto avança. O ganho e produtividade é exponencial. Sem falar que dentro de um projeto de equipe, tendo progamadores juniores ou seniors é mais fácil entender a implementação e manter um padrão.

Dependências

  • Languagem: PHP
    Bibliotecas:
    • PHPSpec - Teste
    • Phinx - ORM
    • Slim - Middleware - PSR-7 - HTTP Router
    • PHP-DI - Dependency Injection Containers
    • Medoo - Query Abstraction

Instalação

  1. Clone ou baixe este repositório
  2. Se assegure de ter o composer instalado em sua máquina e o docker-compose
  3. Use os comendos para subir o server local:
$ docker-compose up -d 
$ docker-compose down -v
  1. Para facilitar o desenvolvimento, é recomendável usar o vscode com a extensão do docker.
  2. Assim que levantar os serviços com docker-compose, irá parecer a lista dos containers no vscode.
  3. Clique com o botão direito em 'Atach bash'
  4. Pronto!
  5. Agora é só rodar composer update e rodar as migrations com vendor\bin\phinx migrate

Testando a aplicação

Home API

GET /

Gets a info about API.

  • Status: 200
{"api":"payment-api","version":"0.1 Beta","timestamp":1600966072}

POST /signup

Create a new user payment.

  • ?name=Relâmpago Marquinhos // The name of the customer or merchant
  • [email protected] // Email is unique
  • ?cpf=cpf // If for customer or merchant
  • ?email=123456789 // Is only for merchant
  • ?password=123password // Is encrypted
  • ?confirm_password=123password // Is encrypted ===
  • Status: 200
Successfulcreated: {
  "body": {
    "name": "Relampago Marquinhos",
    "email": "[email protected]",
    "cpf": "1235123232323",
    "cnpj": "1234533323233",
    "password": "123",
    "password_confirmation": "123"
  }
}

POST /transaction

Create a new payment.

  • ?value=100.00 //The only information exposed to aplication
  • ?payer=4 // Secret key for user only see the information about your account
  • ?payee=5 // Secret key for user only see the information about your account ===
  • Status: 200

Ideia de Arquitetura

Ajustes e melhorias

O projeto ainda está em desenvolvimento e as próximas atualizações serão voltadas nas seguintes tarefas:

  • Autenticação
  • Inplementação de controle de permissões
  • Swagger
  • Enxugara camada de data e presentation

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • PHP 98.3%
  • Dockerfile 1.7%