API de uma plataforma de receitas utilizando Spring MV e MongoDB
help
{{apiData.me.position}}˚ no Ranking
profile pic account_circle
Login Comece agora
Iniciar Desafio Iniciar Desafio Fórum
{{apiData.participant_count}} Participantes
Criado Por: Created by Daniel Blank
Java
Spring MVC
MongoDB

API de uma plataforma de receitas

Neste desafio você criará uma API para uma plataforma de receitas.

Tópicos

Neste desafio você aprenderá:

  • Java
  • Spring MVC
  • MongoDB

Requisitos

Para este desafio você precisará de:

  • Java 8 (ou superior)
  • Git
  • MongoDB 4.0 (ou superior)

MongoDB

Instalar o MongoDB e rodar na porta padrão 27017

https://docs.mongodb.com/manual/installation

Detalhes

A receita deve ser salva na collection recipe e seguir o seguinte esquema:

{
  "_id": "5bc698399531146718e31220",
  "title": "Bolo de chocolate",
  "description": "Bolo de chocolate caseiro",
  "likes": [
    "123",
    "456"
  ],
  "ingredients": [
    "ovo",
    "chocolate"
  ],
  "comments": [
    {
      "_id": "5bc6a737953114503ce9cd7f",
      "comment": "Muito gostoso!"
    }
  ]
}

A API deve responder pelas seguintes URLs:

POST /recipe

Adiciona uma nova receita. * Deve retornar o objeto adicionado com o id gerado.

Request body
{
  "title": "Bolo de chocolate",
  "description": "Bolo de chocolate caseiro",
  "ingredients": [
    "ovo",
    "chocolate"
  ]
}
Response body
{
  "id": "5bc698399531146718e31220",
  "title": "Bolo de chocolate",
  "description": "Bolo de chocolate caseiro",
  "ingredients": [
    "ovo",
    "chocolate"
  ]
}

PUT /recipe/{id}

Atualiza uma receita. * Somente os campos title, description e ingredients devem ser atualizados. * Os demais campos devem continuar iguais.

Request body:
{
  "title": "Bolo de chocolate",
  "description": "Bolo de chocolate caseiro",
  "ingredients": [
    "ovo",
    "chocolate"
  ]
}

DELETE /recipe/{id}

Remove uma receita.

GET /recipe/{id}

Retorna uma receita.

Response body
{
  "id": "5bc698399531146718e31220",
  "title": "Bolo de chocolate",
  "description": "Bolo de chocolate caseiro",
  "likes": [
    "123",
    "456"
  ],
  "ingredients": [
    "ovo",
    "chocolate"
  ],
  "comments": [
    {
      "id": "5bc6a737953114503ce9cd7f",
      "comment": "Muito gostoso!"
    }
  ]
}

GET /recipe/ingredient

Lista as receitas que possuem determinado ingrediente. * Ordenar pelo campo title em ordem alfabética ascendente. * Ex: /recipe/ingredient?ingredient=ovo

Request param
  • ingredient
Response body
[
  {
    "id": "5bc698399531146718e31220",
    "title": "Bolo de chocolate",
    "description": "Bolo de chocolate caseiro",
    "likes": [
      "123",
      "456"
    ],
    "ingredients": [
      "ovo",
      "chocolate"
    ],
    "comments": [
      {
        "id": "5bc6a737953114503ce9cd7f",
        "comment": "Muito gostoso!"
      }
    ]
  },
  {
    "id": "5bc932af9531144888cc2bd2",
    "title": "Sopa de legumes",
    "description": "Sopa de legumas com ovo e lentilha ",
    "ingredients": [
      "cenoura",
      "cebola",
      "ovo"
    ]
  }
]

GET /recipe/search

Pesquisa de receitas. * Deve pesquisar nos campos title e description * Deve pesquisar em qualquer lugar do texto * Deve pesquisar usando case-insensitive * Ordenar pelo campo title em ordem alfabética ascendente. * Ex: /recipe/search?search=choco

Request param
  • search
Response body
[
  {
    "id": "5bc698399531146718e31220",
    "title": "Bolo de chocolate",
    "description": "Bolo de chocolate caseiro",
    "likes": [
      "123",
      "456"
    ],
    "ingredients": [
      "ovo",
      "chocolate"
    ],
    "comments": [
      {
        "id": "5bc6a737953114503ce9cd7f",
        "comment": "Muito gostoso!"
      }
    ]
  },
  {
    "id": "5bc932949531144888cc2bd1",
    "title": "Torta de chocolate",
    "description": "Torta de chocolate com morango",
    "ingredients": [
      "chocolate",
      "morango"
    ]
  }
]

POST /recipe/{id}/like/{userId}

Curtir uma receita. * Deve ser enviado um userId arbitrário para dizer qual usuário está curtindo a receita. * Obs: Em uma aplicação real, o userId seria pego do usuário autenticado. * O userId deve ser inserido na última posição do array do campo likes

DELETE /recipe/{id}/like/{userId}

“Descurtir” uma receita. * Deve ser enviado um userId arbitrário para dizer qual usuário está “descurtindo” a receita. * Obs: Em uma aplicação real, o userId seria pego do usuário autenticado.

POST /recipe/{id}/comment

Adiciona um comentário em uma receita. * Gerar um ObjectId antes de salvar * Deve retornar o objeto adicionado com o id gerado. * O comentário deve ser inserido na última posição do array do campo comments

Request body
{
  "comment": "Muito gostoso!"
}
Response body
{
  "id": "5bcbef8b9531144334eaec8e",
  "comment": "Muito gostoso!"
}

PUT /recipe/{id}/comment/{commentId}

Atualiza um comentário de uma receita.

Request body
{
  "comment": "Muito gostoso!"
}

DELETE /recipe/{id}/comment/{commentId}

Remove um comentário de uma receita.


Rodando a aplicação

Executar o comando gradlew bootRun

A aplicação estará disponível em http://localhost:8080

codenation code review

Para receber Code review, compartilhe o link abaixo com colegas ou em nosso fórum de discussões:

codenation code review

Para receber Code review, você precisa primeiramente finalizar o desafio.

{{apiData.participant_count}} Participantes

Para definir seu posicionamento no ranking do desafio, utilizaremos a nota mais alta que tiver conquistado nele. Caso outra pessoa participante obtenha a mesma nota que a sua, o critério de desempate será data e hora de envio da mais recente.

empty ranking Ainda não temos participantes suficientes para o ranking!
Aproveite e seja um dos primeiros a participar desse desafio.
CODE:NOME NOTA
{{candidate.position}}. {{candidate.name}} {{candidate.score.toFixed(2)}}%
Spring Boot

Spring Boot makes it easy to create stand-alone, production-grade Spring based Applications that you can 'just run'.

Building a RESTful Web Service

This guide walks you through the process of creating a 'hello world' RESTful web service with Spring.

Spring Data MongoDB

Spring Data MongoDB - Reference Documentation

The MongoDB Manual

The MongoDB Manual