Skip to content

burobrasil/olddragon-api

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 

Repository files navigation

Old Dragon Online API

Bem vindo à API do Old Dragon Online! Se você quer integrar sua aplicação com o OldDragon.com.br ou criar uma nova aplicação utilizando dados do ODO, você está no lugar certo. Obrigado por fazer parte da incrível comunidade Old Dragon!

Esta API ainda está em constante desenvolvimento. Se você achar qualquer problema ou tiver dificuldade com algo que deva ser um erro, abra uma "Issue" neste repositório, ou envie um email para [email protected].

Chamadas para API

Todas as URLs começam com https://olddragon.com.br/. URLs devem usar HTTPS, HTTP não é suportado.

Para fazer uma chamada para carregar todos os monstros disponíveis para usuários não loggados, basta fazer uma chamada para https://olddragon.com.br/monstros.json. Usando cURL, é assim:

curl -A 'MinhaAplicacao ([email protected])' https://olddragon.com.br/monstros.json

Autenticação

Para autenticar você deve usar o protocolo de autenticação OAuth 2.0. OAuth 2.0 permite que os usuários autorizem seu aplicativo a usar o Old Dragon Online em seu nome sem precisar copiar/colar tokens de API ou tocar em informações de login confidenciais, de maneira prática e segura para todas as partes.

Leia mais sobre Autenticação

Identifique sua aplicação

Você deve incluir o cabeçalho HTTP User-Agent com ambos os dados:

  • O nome da sua aplicação
  • Um endereço de email para contactar o desenvolvedor, ou o endereço de sua aplicação.

Nós usamos estas informações para poder entrar em contato com você caso haja algum problema, ou para reconhecer o seu trabalho. Exemplo: User-Agent: O Maravilhoso Gerador de Personagens ([email protected]) ou User-Agent: Gerador de Encontros Aleatórios (https://example.org/gerador).

Se você não incluir um cabeçalho User-Agent, você poderá receber o erro 400 Bad Request.

Apenas JSON

Nós apenas aceitamos e usamos JSON em todas as chamadas da API. Você deve incluir o cabeçalho HTTP Content-Type como Content-Type: application/json; charset=utf-8 em chamadas POST ou PUT. Todas as URLs da API tem final .json para indicar que retornam JSON. Você também pode optar por enviar o cabeçalho Accept: application/json.

Paginação

Todas as coleções (listas com múltiplos itens) de resultado tem seu resultado paginado. O número de resultados pode variar conforme o tamanho da coleção. A nossa API segue a especificação RFC5988 de usar o cabeçalho HTTP Link para fornecer URLs para páginas relacionadas. Siga essa convenção para acessar outras páginas.

Aqui está um exemplo de cabeçalho de resposta da solicitação:

Link: <https://olddragon.com.br/monstros.json?page=1>; rel="first", <https://olddragon.com.br/monstros.json?page=2>; rel="next", <https://olddragon.com.br/monstros.json?page=21>; rel="last"

No resultado, dentro de Link, é possível identificar a primeira página (first), a próxima página (next), e a última página da coleção (last).

Além de Link, também retornamos os cabeçalhos Current-Page com o número da página atual, Total-Pages com o número total de páginas, e Total-Count com o número total de resultados na coleção, dado os filtros aplicados de busca.

Exemplo de cabeçalhos:

Current-Page: 1
Total-Count: 400
Total-Pages: 20

Cache HTTP

Você deve usar os cabeçalhos de atualidade HTTP para acelerar a sua aplicação e aliviar a carga nos nossos servidores. A maioria das respostas da API incluirá um cabeçalho ETag ou Last-Modified. Quando você requisitar um recurso pela primeira vez, armazene esses valores. Em solicitações subsequentes, submeta-os de volta para nós como If-None-Match e If-Modified-Since, respectivamente. Se o recurso não tiver sido alterado desde a sua última solicitação, você receberá uma resposta 304 Not Modified sem corpo, poupando-lhe tempo e largura de banda ao enviar algo que você já possui.

Tratando Erros

Clientes da API devem esperar e tratar de maneira elegante erros temporários do servidor e limites de uso. Recomendamos incorporar tentativas elegantes de 5xx e 429 desde o início na sua integração, para que os erros sejam tratados automaticamente.

Limitação de uso (429 Too Many Requests)

Retornamos uma resposta 429 Too Many Requests quando você excedeu um limite de uso. Consulte o cabeçalho de resposta Retry-After para determinar quanto tempo esperar (em segundos) antes de tentar a solicitação novamente.

Planeje com antecedência para tratar com elegância os modos de falha que a contrapressão da API exercerá sobre sua integração. Vários limites de taxa estão em vigor, por exemplo, para solicitações GET vs POST e limites por segundo/hora/dia, e eles são ajustados dinamicamente, então respondê-los dinamicamente é essencial, particularmente em níveis de tráfego elevados.

Para ter uma noção de escala, o primeiro limite de taxa que você comumente encontrará é atualmente de 50 solicitações por período de 10 segundos por endereço IP.

Erros no Servidor (5xx server errors)

Se o Old Dragon Online estiver com problemas, você receberá uma resposta com um código de status 5xx indicando um erro no servidor. 500 (Internal Server Error), 502 (Bad Gateway), 503 (Service Unavailable), e 504 (Gateway Timeout) podem ser tentados novamente com redução exponencial.

Página não encontrada (404 Not Found)

Solicitações de API podem receber 404 devido a conteúdo excluído, uma conta inativa, permissões de usuário ausentes, etc. Detecte estas condições para dar aos seus usuários uma explicação clara sobre por que eles não podem se conectar ao Basecamp. Não tente novamente automaticamente essas solicitações.

Conteúdo em texto rico (rich text)

Muitos recursos, incluindo mensagens, documentos e comentários, representam seu conteúdo como texto rico (rich text) em HTML e Markdown. O conteúdo em texto rico pode conter listas, citações em bloco, formatação simples e anexos inline, como menções, imagens e arquivos.

Endpoints da API

Suporte

Se você tem alguma dúvida sobre a API, envie um email para [email protected].

Licença

Toda a documentação de API neste repositório de código é licenciado sob a Creative Commons (CC BY-SA 4.0). Compartilhe, remixe, e distribua como desejar.

About

API do Old Dragon Online (olddragon.com.br)

Topics

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published