2019-12-11 09:08:39 +00:00
< br / >
2014-12-04 11:11:46 +00:00
2019-12-11 09:08:39 +00:00
< div align = "center" >
< img height = "200" src = "https://raw.githubusercontent.com/PokeAPI/media/master/logo/pokeapi.svg?sanitize=true" alt = "PokeAPI" >
2014-12-04 11:11:46 +00:00
2020-07-28 19:38:25 +00:00
[![build status ](https://img.shields.io/circleci/project/github/PokeAPI/pokeapi/master.svg )](https://circleci.com/gh/PokeAPI/pokeapi)
[![data status ](https://img.shields.io/circleci/build/github/PokeAPI/api-data?label=data )](https://github.com/PokeAPI/api-data)
[![deploy status ](https://img.shields.io/circleci/build/github/PokeAPI/deploy?label=deploy )](https://github.com/PokeAPI/deploy)
2020-09-19 06:01:28 +00:00
[![License ](https://img.shields.io/github/license/PokeAPI/pokeapi.svg )](https://github.com/PokeAPI/pokeapi/blob/master/LICENSE.md)
2020-07-28 19:38:25 +00:00
[![Backers on Open Collective ](https://opencollective.com/pokeapi/backers/badge.svg )](https://opencollective.com/pokeapi)
[![Sponsors on Open Collective ](https://opencollective.com/pokeapi/sponsors/badge.svg )](https://opencollective.com/pokeapi)
2016-08-25 13:22:18 +00:00
2019-12-11 09:08:39 +00:00
< br / >
2016-08-13 07:59:52 +00:00
2019-12-11 09:08:39 +00:00
< / div >
< br / >
A RESTful API for Pokémon - [pokeapi.co ](https://pokeapi.co )
2016-08-13 07:59:52 +00:00
2021-09-09 11:58:19 +00:00
> Beta GraphQL support is rolling out! Check out the [GraphQL paragraph](#graphql--) for more info.
2014-12-04 11:11:46 +00:00
2023-01-09 15:11:23 +00:00
## Setup [![pyVersion310](https://img.shields.io/badge/python-3.10-blue.svg)](https://www.python.org/download/releases/3.10/)
2014-12-04 11:11:46 +00:00
2020-07-10 13:05:53 +00:00
- Download this source code into a working directory, be sure to use the flag `--recurse-submodules` to clone also our submodules.
2014-12-04 11:11:46 +00:00
2014-12-04 12:11:57 +00:00
- Install the requirements using pip:
2019-01-04 14:37:59 +00:00
2019-12-11 09:08:39 +00:00
```sh
make install
# This will install all the required packages and libraries for using PokeAPI
```
2014-12-04 11:11:46 +00:00
2019-12-11 09:08:39 +00:00
- Set up the local development environment using the following command:
2019-01-04 14:37:59 +00:00
2019-12-11 09:08:39 +00:00
```sh
make setup
```
2019-01-04 14:37:59 +00:00
2024-01-21 20:59:02 +00:00
- Run the server on port `8000` using the following command:
2019-01-04 14:37:59 +00:00
2019-12-11 09:08:39 +00:00
```sh
make serve
```
2014-12-05 12:31:49 +00:00
2021-01-11 18:45:28 +00:00
### Database setup
2015-12-07 20:42:07 +00:00
2024-01-21 20:59:02 +00:00
To build or rebuild the database by applying any CSV file update, run
2019-01-04 14:37:59 +00:00
```sh
2023-04-25 22:57:57 +00:00
make build-db
2015-12-07 20:42:07 +00:00
```
2019-01-04 14:37:59 +00:00
2024-01-21 21:06:00 +00:00
Visit [localhost:8000/api/v2/ ](http://localhost:8000/api/v2/ ) to see the running API!
2019-12-11 09:08:39 +00:00
2024-01-21 20:59:02 +00:00
Each time the `build-db` script is run, it will iterate over each table in the database, wipe it, and rewrite each row using the data found in data/v2/csv.
2015-12-07 20:17:33 +00:00
2019-12-11 09:08:39 +00:00
If you ever need to wipe the database use this command:
```sh
2024-01-21 14:55:21 +00:00
make wipe-sqlite-db
2019-12-11 09:08:39 +00:00
```
2024-01-21 20:59:02 +00:00
If the database schema has changed, generate any outstanding migrations and apply them
```sh
make make-migrations
make migrate
```
Run `make help` to see all tasks.
2021-05-30 21:21:25 +00:00
## Docker and Compose [![docker hub](https://img.shields.io/docker/v/pokeapi/pokeapi?label=tag&sort=semver)](https://hub.docker.com/r/pokeapi/pokeapi)
2015-04-21 03:31:59 +00:00
2024-01-21 20:59:02 +00:00
There is also a multi-container setup, managed by [Docker Compose ](https://docs.docker.com/compose/ ). This setup allows you to deploy a production-like environment, with separate containers for each service, and is recommended if you need to simply spin up PokéAPI.
2015-11-12 02:17:20 +00:00
2021-03-23 19:01:28 +00:00
Start everything by
2015-11-12 02:17:20 +00:00
2019-01-04 14:37:59 +00:00
```sh
2021-01-11 18:45:28 +00:00
make docker-setup
2015-11-12 02:17:20 +00:00
```
2019-01-04 14:37:59 +00:00
2021-01-11 18:45:28 +00:00
If you don't have `make` on your machine you can use the following commands
2019-01-04 14:37:59 +00:00
```sh
2021-01-11 18:45:28 +00:00
docker-compose up -d
docker-compose exec -T app python manage.py migrate --settings=config.docker-compose
docker-compose exec -T app sh -c 'echo "from data.v2.build import build_all; build_all()" | python manage.py shell --settings=config.docker-compose'
2015-11-12 02:17:20 +00:00
```
2021-01-11 18:45:28 +00:00
Browse [localhost/api/v2/ ](http://localhost/api/v2/ ) or [localhost/api/v2/pokemon/bulbasaur/ ](http://localhost/api/v2/pokemon/bulbasaur/ ) on port `80` .
2016-07-07 12:23:59 +00:00
2024-01-21 20:59:02 +00:00
To rebuild the database and apply any CSV file updates, run
2024-01-21 14:55:21 +00:00
```sh
make docker-build-db
```
2024-01-21 20:59:02 +00:00
If the database schema has changed, generate the migrations and apply those
```sh
make docker-make-migrations
make docker-migrate
```
2021-05-30 21:21:25 +00:00
## GraphQL <a href="ttps://github.com/hasura/graphql-engine"><img height="29px" src="https://graphql-engine-cdn.hasura.io/img/powered_by_hasura_blue.svg"/></a>
2021-03-23 19:01:28 +00:00
2021-05-30 20:53:55 +00:00
When you start PokéAPI with the above docker-compose setup, an [Hasura Engine ](https://github.com/hasura/graphql-engine ) server is started as well. It's possible to track all the PokeAPI tables and foreign keys by simply
2021-03-23 19:01:28 +00:00
```sh
# hasura cli needs to be installed and available in your $PATH: https://hasura.io/docs/latest/graphql/core/hasura-cli/install-hasura-cli.html
2024-01-09 22:17:57 +00:00
# hasura cli's version has to greater than v2.0.8
2021-03-23 19:01:28 +00:00
make hasura-apply
```
When finished browse http://localhost:8080 and you will find the admin console. The GraphQL endpoint will be hosted at http://localhost:8080/v1/graphql.
A free public GraphiQL console is browsable at the address https://beta.pokeapi.co/graphql/console/. The relative GraphQL endpoint is accessible at https://beta.pokeapi.co/graphql/v1beta
2024-01-21 20:59:02 +00:00
A set of examples is provided in the directory [/graphql/examples ](./graphql/examples ) of this repository.
2021-03-23 19:01:28 +00:00
2021-05-30 21:23:26 +00:00
## Kubernetes [![k8s status](https://github.com/PokeAPI/pokeapi/actions/workflows/kustomize.yml/badge.svg?branch=master)](https://github.com/PokeAPI/pokeapi/actions/workflows/kustomize.yml)
2021-05-30 20:53:08 +00:00
2021-06-05 20:58:10 +00:00
[Kustomize ](https://kubernetes.io/docs/tasks/manage-kubernetes-objects/kustomization/ ) files are provided in the folder https://github.com/PokeAPI/pokeapi/tree/master/Resources/k8s/kustomize/base/. Create and change your secrets:
2021-05-30 20:53:08 +00:00
```sh
2021-06-05 20:58:10 +00:00
cp Resources/k8s/kustomize/base/secrets/postgres.env.sample Resources/k8s/kustomize/base/secrets/postgres.env
cp Resources/k8s/kustomize/base/secrets/graphql.env.sample Resources/k8s/kustomize/base/secrets/graphql.env
cp Resources/k8s/kustomize/base/config/pokeapi.env.sample Resources/k8s/kustomize/base/config/pokeapi.env
2021-05-30 20:53:08 +00:00
# Edit the newly created files
```
Configure `kubectl` to point to a cluster and then run the following commands to start a PokéAPI service.
```sh
2021-06-05 20:58:10 +00:00
kubectl apply -k Resources/k8s/kustomize/base/
2021-05-30 20:53:08 +00:00
kubectl config set-context --current --namespace pokeapi # (Optional) Set pokeapi ns as the working ns
# Wait for the cluster to spin up
kubectl exec --namespace pokeapi deployment/pokeapi -- python manage.py migrate --settings=config.docker-compose # Migrate the DB
kubectl exec --namespace pokeapi deployment/pokeapi -- sh -c 'echo "from data.v2.build import build_all; build_all()" | python manage.py shell --settings=config.docker-compose' # Build the db
kubectl wait --namespace pokeapi --timeout=120s --for=condition=complete job/load-graphql # Wait for Graphql configuration job to finish
```
This k8s setup creates all k8s resources inside the _Namespace_ `pokeapi` , run `kubectl delete namespace pokeapi` to delete them. It also creates a _Service_ of type `LoadBalancer` which is exposed on port `80` and `443` . Data is persisted on `12Gi` of `ReadWriteOnce` volumes.
2021-07-14 13:44:02 +00:00
## Wrappers
| Official wrapper | Repository | Features |
| --- | --- | --- |
| Node server-side | [PokeAPI/pokedex-promise-v2 ](https://github.com/PokeAPI/pokedex-promise-v2 ) | _Auto caching_ |
| Browser client-side | [PokeAPI/pokeapi-js-wrapper ](https://github.com/PokeAPI/pokeapi-js-wrapper ) | _Auto caching_ , _Image caching_ |
| Java/Kotlin | [PokeAPI/pokekotlin ](https://github.com/PokeAPI/pokekotlin ) | |
| Python 2/3 | [PokeAPI/pokepy ](https://github.com/PokeAPI/pokepy ) | _Auto caching_ |
| Python 3 | [PokeAPI/pokebase ](https://github.com/PokeAPI/pokebase ) | _Auto caching_ , _Image caching_ |
| Wrapper | Repository | Features |
| --- | --- | --- |
| PHP | [lmerotta/phpokeapi ](https://github.com/lmerotta/phpokeapi ) | _Auto caching, lazy loading_ |
| Ruby | [rdavid1099/poke-api-v2 ](https://github.com/rdavid1099/poke-api-v2 ) | |
| .Net Standard | [mtrdp642/PokeApiNet ](https://github.com/mtrdp642/PokeApiNet ) | _Auto caching_ |
| Go | [mtslzr/pokeapi-go ](https://github.com/mtslzr/pokeapi-go ) | _Auto caching_ |
| Dart | [prathanbomb/pokedart ](https://github.com/prathanbomb/pokedart ) | |
| Rust | [lunik1/pokerust ](https://gitlab.com/lunik1/pokerust ) | _Auto caching_ |
| Spring Boot | [dlfigueira/spring-pokeapi ](https://github.com/dlfigueira/spring-pokeapi ) | _Auto caching_ |
| Swift | [kinkofer/PokemonAPI ](https://github.com/kinkofer/PokemonAPI ) | |
| Typescript server-side/client-side | [Gabb-c/Pokenode-ts ](https://github.com/Gabb-c/pokenode-ts ) | _Auto caching_ |
2022-03-07 20:46:09 +00:00
| Python | [beastmatser/aiopokeapi ](https://github.com/beastmatser/aiopokeapi ) | _Auto caching, asynchronous_
2022-07-08 08:40:51 +00:00
| Scala | [juliano/pokeapi-scala ](https://github.com/juliano/pokeapi-scala ) | _Auto caching_ |
2021-03-23 19:01:28 +00:00
2019-12-11 09:08:39 +00:00
## Donations
2016-07-07 12:23:59 +00:00
2023-04-25 22:57:57 +00:00
Help to keep PokéAPI running! If you're using PokéAPI as a teaching resource or for a project, consider sending us a $10 donation to help keep the service up. We get 330 million requests a month!
2016-07-07 12:23:59 +00:00
2019-12-11 09:08:39 +00:00
Thank you to all our backers! [Become a backer ](https://opencollective.com/pokeapi#backer )
2016-07-07 12:23:59 +00:00
2019-12-11 09:08:39 +00:00
< a href = "https://opencollective.com/pokeapi#backers" target = "_blank" > < img src = "https://opencollective.com/pokeapi/backers.svg?width=890" > < / a >
2016-07-07 12:23:59 +00:00
2021-03-23 19:01:28 +00:00
## Join Us On Slack!
2023-07-05 08:45:53 +00:00
> **Warning**
> Currently no maintainer has enough free time to support the community on Slack. Our Slack is in an unmaintained status.
Have a question or just want to discuss new ideas and improvements? Hit us up on Slack. ~~Consider talking with us here before creating a new issue.~~
2021-03-23 19:01:28 +00:00
This way we can keep issues here a bit more organized and helpful in the long run. Be excellent to each other :smile:
2024-01-15 20:03:04 +00:00
[Sign up ](https://join.slack.com/t/pokeapi/shared_invite/zt-2ampo6her-_tHSI3uOS65WzGypt7Y96w ) easily!
2021-03-23 19:01:28 +00:00
Once you've signed up visit [PokéAPI on Slack ](https://pokeapi.slack.com )
2014-12-05 12:31:49 +00:00
## Contributing
2019-12-11 09:08:39 +00:00
This project exists thanks to all the people who [contribute ](https://github.com/PokeAPI/pokeapi/blob/master/CONTRIBUTING.md )
2017-06-19 09:10:34 +00:00
< a href = "graphs/contributors" > < img src = "https://opencollective.com/pokeapi/contributors.svg?width=890" / > < / a >
2019-12-11 09:08:39 +00:00
2024-01-21 20:59:02 +00:00
All contributions are welcome: bug fixes, data contributions, and recommendations.
2014-12-05 12:31:49 +00:00
2016-06-02 08:42:48 +00:00
Please see the [issues on GitHub ](https://github.com/PokeAPI/pokeapi/issues ) before you submit a pull request or raise an issue, someone else might have beat you to it.
2014-12-05 12:31:49 +00:00
To contribute to this repository:
- [Fork the project to your own GitHub profile ](https://help.github.com/articles/fork-a-repo/ )
2019-12-11 09:08:39 +00:00
- Download the forked project using git clone:
2019-01-04 14:37:59 +00:00
```sh
2020-07-10 13:05:53 +00:00
git clone --recurse-submodules git@github.com:< YOUR_USERNAME > /pokeapi.git
2019-01-04 14:37:59 +00:00
```
2014-12-05 12:31:49 +00:00
- Create a new branch with a descriptive name:
2019-01-04 14:37:59 +00:00
```sh
git checkout -b my_new_branch
```
- Write some code, fix something, and add a test to prove that it works. *No pull request will be accepted without tests passing, or without new tests if new features are added.*
2014-12-05 12:31:49 +00:00
- Commit your code and push it to GitHub
- [Open a new pull request ](https://help.github.com/articles/creating-a-pull-request/ ) and describe the changes you have made.
- We'll accept your changes after review.
Simple!
2019-01-04 14:37:59 +00:00
2019-12-11 09:08:39 +00:00
## Deprecation
2019-01-04 14:37:59 +00:00
2019-01-07 18:59:05 +00:00
As of October 2018, the v1 API has been removed from PokéAPI. For more information, see [pokeapi.co/docs/v1.html ](https://pokeapi.co/docs/v1.html ).