/26-Blogs-api

API de Blog com Banco de dados

Primary LanguageJavaScript

Blogs API

Este projeto trata-se de uma API e um banco de dados para a produção de conteúdo para um blog!

Desafios:

  1. Desenvolver endpoints que estarão conectados ao banco de dados seguindo os princípios do REST;

  2. Para fazer um post é necessário usuário e login, portanto será trabalhada a relação entre user e post;

  3. Será necessária a utilização de categorias para os posts, trabalhando, assim, a relação de posts para categories e de categories para posts.

Técnologias usadas

Back-end:

Desenvolvido usando: Node.js, Express.js, Docker, Sequelize, JWT

Habilidades

Adquiri essas habilidades ao desenvolver esse projeto:

  • Aderência do código à especificação. O programa deve se comportar como especificado na próxima seção.

  • Organização do código.

  • A qualidade e a cobertura dos testes.

Preview da Aplicação

Swagger Diagrama DER
Home DER

Instalando Dependências

  • clone o projeto:

    git clone git@github.com:Andreyrvs/26-blogs-api.git

Docker

❗ Rode os serviços node e db com o comando.

docker-compose up -d --build

Esses serviços irão inicializar um container chamado blogs_api e outro chamado blogs_api_db.

docker exec -it blogs_api bash

Back-end

npm install

Executando aplicação

  • Para rodar o Banco de dados

    npm run drop
    # "npx sequelize-cli db:drop"

    Cria o banco e realiza as Migration

    npm run createdb
    # npx sequelize-cli db:create && npx sequelize-cli db:migrate

    Popula o banco de dados

    npm run seed
    # npx sequelize-cli db:seed:all

    O banco devera ter essas tabelas

    . Tablelas do banco .
    Login
  • Para rodar o Back-end:

    ⚠️ Use esses comandos dentro do container

    npm start
  • Modo desenvolvimento:

    npm run debug

Rota da Documentação do Swagger:

localhost:3000/