Code Monkey home page Code Monkey logo

feature-toggle's People

Watchers

 avatar

feature-toggle's Issues

Implementar funcionalidades principais das Feature

Nesta tarefa vamos implementar somente as duas principais necessidades de uma funcionalidade em uso. O GET performático de se ela está ativa ou não, e métodos pra mudar seu estado de ativo para inativo ou vice versa.

1 - Implementar GET de funcionalidade.

GET
caminho: /feature-toggle/{id}
retorno: Status: 200, retornando um objeto com somente um atributo, { "active": true }.

2 - Implementar um endpoint POST para alterar o valor do atributo de ativo e inativo.

POST
caminho: /feature-toggle/{id}
body:
{
"active": true
}
retorno: Status 200

Implementar CRUD de funcionalidades

Nesta tarefa precisamos implementar o CRUD básico das funcionalidades.

1 - Criar a entidade funcionalidades (feature)

id - integer - chave primária.
name - String - NOT NULL
active - Boolean - NOT NULL
responsible - User - NULL (Inicialmente vamos deixar nulo, mas depois na parte de autenticação vamos deixar obrigatório)
data de criação - DATE - NOT NULL
data de update - DATE - NULL

2 - Implementar endpoints de Create, Read, Update e Delete.

Todos eles vão ter métodos diferentes mas todos estarão no caminho: /feature
Cada endpoint deverá ter um teste unitário e de integração.

GET
caminho: /feature/{id}
retorno: Status: 200, retornando um objeto com todas as informações do funcionalidade.

POST
caminho: /feature
body:

{
"name": "payments",
"active": true
}
retorno: Status 201

PATCH - Atualizando somente os atributos enviados no objeto.
caminho: /feature/{id})

{
"name": "payments-pix",
"active": true
}
retorno: Status 201

DELETE
caminho: /feature/{id})
retorno: Status 202

Inicializar o projeto Spring

Vamos utilizar o Spring inicializer para iniciar o projeto.

Vamos adicionar as seguintes dependências:

  • Spring web para a camada REST.

Vamos utilizar o Gradle como gerenciador de dependência.

Implementar autenticação das requisições

Precisamos nessa tarefa criar toda a parte de autenticação de requisição. Vamos utilizar o JWT para criar tokens e retornar no login.

1 - Implementar um endpoint de LOGIN, onde vamos receber um usuário e senha, e retornamos um token criado.

GET
caminho: /login

body: {
"name: "user",
"password": "pass"
}
retorno: {
"token: "bearer"
}

2 - Implementar a autenticação nas requisições necessárias.

  • A parte de funcionalidades não podem ser utilizadas por qualquer um.
  • Precisamos criar um usuário ADMIN no banco para conseguir adicionar os outros.

Implementar CRUD de usuários

Nesta tarefa precisamos implementar o CRUD básico de usuários.

1 - Criar a entidade usuários:

  • id - integer - chave primária.
  • name - String - NOT NULL
  • password - String - NOT NULL
  • data de criação - DATE - NOT NULL
  • data de update - DATE - NULL

2 - Implementar endpoints de Create, Read, Update e Delete.

  • Todos eles vão ter métodos diferentes mas todos estarão no caminho: /user
  • Cada endpoint deverá ter um teste unitário e de integração.

GET
caminho: /user/{id}
retorno: Status: 200, retornando um objeto com todas as informações do usuário menos a senha.

POST
caminho: /user
body:

{
  "name": "leo",
  "password": "batata"
}

retorno: Status 201

PATCH - Atualizando somente os atributos enviados no objeto.
caminho: /user/{id})

{
  "name": "leo",
  "password": "batata"
}

retorno: Status 201

DELETE
caminho: /user/{id})
retorno: Status 202

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.