{"id":23015615,"url":"https://github.com/rodrigo-dev7/restfull","last_synced_at":"2025-10-31T20:03:17.856Z","repository":{"id":122427239,"uuid":"248876714","full_name":"Rodrigo-dev7/RestFull","owner":"Rodrigo-dev7","description":"Estudando ReastFull","archived":false,"fork":false,"pushed_at":"2022-12-12T06:20:09.000Z","size":566,"stargazers_count":0,"open_issues_count":1,"forks_count":0,"subscribers_count":1,"default_branch":"master","last_synced_at":"2025-02-08T08:32:40.597Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":"","language":"JavaScript","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/Rodrigo-dev7.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2020-03-21T00:12:34.000Z","updated_at":"2020-03-29T15:36:34.000Z","dependencies_parsed_at":null,"dependency_job_id":"846df64c-ae91-4487-8ea8-d76725d3dfc8","html_url":"https://github.com/Rodrigo-dev7/RestFull","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Rodrigo-dev7%2FRestFull","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Rodrigo-dev7%2FRestFull/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Rodrigo-dev7%2FRestFull/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/Rodrigo-dev7%2FRestFull/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/Rodrigo-dev7","download_url":"https://codeload.github.com/Rodrigo-dev7/RestFull/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":246864076,"owners_count":20846371,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2024-12-15T11:12:45.536Z","updated_at":"2025-10-31T20:03:12.820Z","avatar_url":"https://github.com/Rodrigo-dev7.png","language":"JavaScript","readme":"# API, REST e RESTFUL\n\n## API\n\nAcrônimo de Application Programming Interface (Interface de Programação de Aplicações) é basicamente um conjunto de rotinas e padrões estabelecidos por uma aplicação, para que outras aplicações possam utilizar as funcionalidades desta aplicação.\n\n- Responsável por estabelecer comunicação entre diferentes serviços.\n- Meio de campo entre as tecnologias.\n- Intermediador para troca de informações.\n\n## REST\n\num acrônimo para Representational State Transfer (Transferência de Estado Representativo).\n\nSerá feita a transferência de dados de uma maneira simbólica, figurativa, representativa, de maneira didática.\n\nA transferência de dados, geralmente, usando o protocolo HTTP.\n\nO REST delimita algumas obrigações nessas transferências de dados.\n\nResources seria então: Uma entidade ou um objeto.\n\n### 6 NECESSIDADES (constraints) para ser RESTful\n\n- _Uniform Interface_: Manter uma uniformidade, uma constância, um padrão na construção da interface. Nossa API precisa ser coerente para quem vai consumi-lá. Precisa fazer sentido para o cliente e não ser confusa. Logo, coisas como: o uso correto dos verbos HTTP; endpoints coerentes (todos os endpoints no plural, por exemplo); usar somente uma linguagem de comunicação (json) e não várias ao mesmo tempo; sempre enviar respostas aos clientes; são exemplos de aplicação de uma interface uniforme.\n\n- _Client-server_: Separação do cliente e do armazenamento de dados (servidor), dessa forma, poderemos ter uma portabilidade do nosso sistema, usando o React para WEB e React Native para o smartphone, por exemplo.\n\n- _Stateless_: Cada requisição que o cliente faz para o servidor, deverá conter todas as informações necessárias para o servidor entender e responder (RESPONSE) a requisição (REQUEST). Exemplo: A sessão do usuário deverá ser enviada em todas as requisições, para saber se aquele usuário está autenticado e apto a usar os serviços, e o servidor não pode lembrar que o cliente foi autenticado na requisição anterior. Nos nossos cursos, temos por padrão usar tokens para as comunicações.\n\n- _Cacheable_: As respostas para uma requisição, deverão ser explicitas ao dizer se aquela resquição, pode ou não ser cacheada pelo cliente.\n\n- _Layered System_: O cliente acessa a um endpoint, sem precisar saber da complexidade, de quais passos estão sendo necessários para o servidor responder a requisição, ou quais outras camadas o servidor estará lidando, para que a requisição seja respondida.\n\n- _Code on demand (optional)_: Dá a possibilidade da nossa aplicação pegar códigos, como o javascript, por exemplo, e executar no cliente.\n\n## RESTFUL\n\nRESTful, é a aplicação dos padrões REST.\n\n## BOAS PRÁTICAS\n\n- Utilizar verbos HTTP para nossas requisições.\n- Utilizar plural ou singular na criação dos endpoints? _NÃO IMPORTA!_ use um padrão!!\n- Não deixar barra no final do endpoint\n- Nunca deixe o cliente sem resposta!\n\n### VERBOS HTTP\n\n- GET: Receber dados de um Resource.\n- POST: Enviar dados ou informações para serem processados por um Resource.\n- PUT: Atualizar dados de um Resource.\n- DELETE: Deletar um Resource\n\n### STATUS DAS RESPOSTAS\n\n- 1xx: Informação\n- 2xx: Sucesso\n  - 200: OK\n  - 201: CREATED\n  - 204: Não tem conteúdo PUT POST DELETE\n- 3xx: Redirection\n- 4xx: Client Error\n  - 400: Bad Request\n  - 404: Not Found!\n- 5xx: Server Error\n  500: Internal Server Error\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Frodrigo-dev7%2Frestfull","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Frodrigo-dev7%2Frestfull","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Frodrigo-dev7%2Frestfull/lists"}