... | ... | @@ -119,28 +119,75 @@ Description: https://trello.com/c/d67o9cLk/26-us09-criar-menu |
|
|
|
|
|
# Código
|
|
|
|
|
|
## Descrição
|
|
|
|
|
|
Aqui serão apresentadas as convenções do código desenvolvido. padrões, documentação e conceitos básicos serão alguns dos assuntos abordados.
|
|
|
|
|
|
## Sumário
|
|
|
|
|
|
- [Ferramentas](#ferramentas-de-padronização)
|
|
|
- [Nomenclatura de Arquivos](#nomenclatura-de-arquivos)
|
|
|
- [Documentação](#documentação)
|
|
|
|
|
|
## Ferramentas de Padronização
|
|
|
|
|
|
TBD
|
|
|
|
|
|
### Nomenclatura de Arquivos
|
|
|
|
|
|
TBD
|
|
|
|
|
|
### Documentação
|
|
|
|
|
|
TBD
|
|
|
|
|
|
### Código
|
|
|
|
|
|
TBD |
|
|
## Boas práticas no desenvolvimento
|
|
|
### O que são códigos de status HTTP ?
|
|
|
Sempre que você clicar em um link ou digitar uma URL e pressionar Enter, seu navegador envia um pedido ao servidor web para o site que você está tentando acessar. O servidor recebe e processa a solicitação, e depois envia de volta os recursos relevantes juntamente com um cabeçalho HTTP.
|
|
|
|
|
|
### Sobre as classes de código de status HTTP
|
|
|
Os códigos de status HTTP são divididos em 5 “classes", que são:
|
|
|
|
|
|
* **100**s: Códigos informativos indicando que a solicitação iniciada pelo navegador continua.
|
|
|
* **200**s: Códigos de sucesso retornados quando o pedido do navegador foi recebido, compreendido e processado pelo servidor.
|
|
|
* **300**s: Códigos de redirecionamento retornados quando um novo recurso foi substituído pelo recurso solicitado.
|
|
|
* **400**s: Códigos de erro do cliente indicando que houve um problema com o pedido.
|
|
|
* **500**s: Os códigos de erro do servidor indicam que a solicitação foi aceita, mas que um erro no servidor impediu o cumprimento da solicitação.
|
|
|
|
|
|
### Os mais utilizados
|
|
|
* **200**: "**OK**". Este é o código que é entregue quando uma página web ou um recurso age exatamente da maneira que é esperado.
|
|
|
* **201**: “**Created**”. O servidor cumpriu o pedido do navegador e, como resultado, criou um novo recurso.
|
|
|
* **204**: “**No content**”. Este código significa que o servidor processou a solicitação com sucesso, mas não vai devolver nenhum conteúdo.
|
|
|
* **400**: "**Bad Request**". O servidor não pode retornar uma resposta devido a um erro no lado do cliente. Veja o nosso guia para resolver este erro.
|
|
|
* **401**: “**Not authorized**”. Isto é devolvido pelo servidor quando o recurso alvo não possui credenciais de autenticação válidas.
|
|
|
* **403**: “**Forbidden**”. Este código é devolvido quando um usuário tenta acessar algo que não tem permissão para visualizar. Por exemplo, tentar chegar ao conteúdo protegido por senha sem entrar no sistema pode produzir um erro 403.
|
|
|
* **404**: “**Not Found**”. Esta é a mensagem de erro mais comum de todas elas. Este código significa que o recurso solicitado não existe, e o servidor não sabe se ele alguma vez existiu.
|
|
|
* **405**: “**Method Not Allowed**“. Isto é gerado quando o servidor de hospedagem (servidor de origem) suporta o método recebido, mas o recurso de destino não suporta.
|
|
|
* **500**: “**Interal Server Error**”. Este é um código genérico que significa simplesmente “erro interno do servidor”. Algo correu mal no servidor e o recurso solicitado não foi entregue.
|
|
|
* **502**: “**Bad Gateway**”. Este código de erro tipicamente significa que um servidor recebeu uma resposta inválida de outro, tal como quando um servidor proxy está em uso. Outras vezes uma consulta ou pedido demorará muito tempo, e por isso é cancelado ou morto pelo servidor e a conexão com a base de dados quebra.
|
|
|
|
|
|
Referência: [link](https://kinsta.com/pt/blog/lista-codigos-status-http/)
|
|
|
|
|
|
# Methods – Backend API
|
|
|
Nas requisições, especificamos o que chamamos de método HTTP ou verbo. Na versão 1.1 do protocolo HTTP(que é a que todos usamos atualmente) temos 9 verbos diferentes. Os mais utilizados são:
|
|
|
|
|
|
**GET**:
|
|
|
Essa é a requisição mais comum de todas. Através dessa requisição nós pedimos a representação de um recurso: que pode ser um arquivo html, xml, json, etc.
|
|
|
|
|
|
**POST**:
|
|
|
O método POST é utilizado quando queremos criar um recurso. Quando usamos POST, os dados vão no corpo da requisição e não na URI.
|
|
|
|
|
|
**PUT**:
|
|
|
Requisita que um recurso seja "guardado" na URI fornecida. Se o recurso já existir, ele deve ser atualizado. Se não existir, pode ser criado.
|
|
|
|
|
|
**DELETE**:
|
|
|
Exclui o recurso especificado.
|
|
|
|
|
|
**PATCH**:
|
|
|
Serve para atualizar partes de um recurso, e não o recurso todo.
|
|
|
|
|
|
Referência: [link](http://gabsferreira.com/os-metodos-http-e-a-diferenca-entre-eles/)
|
|
|
# Análise dos principios SOLID
|
|
|
O que é SOLID?
|
|
|
SOLID é um acrônimo criado por Michael Feathers, após observar que cinco princípios da orientação a objetos e design de código — Criados por Robert C. Martin (a.k.a. Uncle Bob) e abordados no artigo The Principles of OOD — poderiam se encaixar nesta palavra.
|
|
|
**S.O.L.I.D**: Os 5 princípios da P.O.O.(Programação Orientada a Objetos)
|
|
|
* S — Single Responsiblity Principle (Princípio da responsabilidade única) -
|
|
|
* O — Open-Closed Principle (Princípio Aberto-Fechado)
|
|
|
* L — Liskov Substitution Principle (Princípio da substituição de Liskov)
|
|
|
* I — Interface Segregation Principle (Princípio da Segregação da Interface)
|
|
|
* D — Dependency Inversion Principle (Princípio da inversão da dependência)
|
|
|
|
|
|
**SRP — Single Responsibility Principle**:
|
|
|
Princípio da Responsabilidade Única — Uma classe deve ter um, e somente um, motivo para mudar.
|
|
|
|
|
|
**OCP — Open-Closed Principle**:
|
|
|
Princípio Aberto-Fechado — Objetos ou entidades devem estar abertos para extensão, mas fechados para modificação, ou seja, quando novos comportamentos e recursos precisam ser adicionados no software, devemos estender e não alterar o código fonte original.
|
|
|
|
|
|
**LSP — Liskov Substitution Principle**:
|
|
|
Princípio da substituição de Liskov — Uma classe derivada deve ser substituível por sua classe base.
|
|
|
|
|
|
**ISP — Interface Segregation Principle**:
|
|
|
Princípio da Segregação da Interface — Uma classe não deve ser forçada a implementar interfaces e métodos que não irão utilizar.
|
|
|
|
|
|
**DIP — Dependency Inversion Principle**:
|
|
|
Princípio da Inversão de Dependência — Dependa de abstrações e não de implementações.
|
|
|
|
|
|
Referência: [link](https://medium.com/desenvolvendo-com-paixao/o-que-%C3%A9-solid-o-guia-completo-para-voc%C3%AA-entender-os-5-princ%C3%ADpios-da-poo-2b937b3fc530) |
|
|
\ No newline at end of file |