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)
[![License ](https://img.shields.io/github/license/PokeAPI/pokeapi.svg )](https://github.com/PokeAPI/pokeapi/blob/master/LICENSE.rst)
[![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
2016-04-20 09:46:35 +00:00
## Join Us On Slack!
2019-01-04 14:37:59 +00:00
2016-04-20 09:46:35 +00:00
Have a question or just want to discuss new ideas and improvements? Hit us up on slack. Consider talking with us here before creating new issue.
2019-01-04 14:37:59 +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:
2016-04-20 09:46:35 +00:00
2019-12-11 09:08:39 +00:00
[Sign up ](https://pokeapi-slack-invite.herokuapp.com/ ) easily!
2016-04-20 09:46:35 +00:00
2019-01-04 14:37:59 +00:00
Once you've signed up visit [PokéAPI on Slack ](https://pokeapi.slack.com )
2016-04-20 09:46:35 +00:00
2017-10-21 13:21:23 +00:00
## Official Wrappers
2017-06-19 09:10:34 +00:00
2017-10-21 13:21:23 +00:00
* 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_
* Java/Kotlin [PokeAPI/pokekotlin ](https://github.com/PokeAPI/pokekotlin )
2019-01-04 14:37:59 +00:00
* Python 3 [GregHilmes/pokebase ](https://github.com/GregHilmes/pokebase ) | _Auto caching_
2019-04-01 01:08:11 +00:00
* Python 2/3 [PokeAPI/pokepy ](https://github.com/PokeAPI/pokepy ) | _Auto caching_
2019-12-11 09:08:39 +00:00
* PHP [lmerotta/phpokeapi ](https://github.com/lmerotta/phpokeapi ) | _Auto caching, lazy loading_
2019-05-07 18:23:09 +00:00
* Ruby [rdavid1099/poke-api-v2 ](https://github.com/rdavid1099/poke-api-v2 )
2019-05-09 02:07:26 +00:00
* .Net Standard [mtrdp642/PokeApiNet ](https://github.com/mtrdp642/PokeApiNet ) | _Auto caching_
2019-06-24 05:33:09 +00:00
* Go [mtslzr/pokeapi-go ](https://github.com/mtslzr/pokeapi-go ) | _Auto caching_
2020-04-15 03:19:55 +00:00
* Dart [prathanbomb/pokedart ](https://github.com/prathanbomb/pokedart )
2020-02-17 12:58:27 +00:00
* Rust [lunik1/pokerust ](https://gitlab.com/lunik1/pokerust ) | _Auto caching_
2020-06-01 22:43:26 +00:00
* Spring Boot [dlfigueira/spring-pokeapi ](https://github.com/dlfigueira/spring-pokeapi ) | _Auto caching_
2020-06-28 00:29:25 +00:00
* Swift [kinkofer/PokemonAPI ](https://github.com/kinkofer/PokemonAPI )
2014-12-04 11:11:46 +00:00
2018-10-19 15:30:11 +00:00
## Setup [![pyVersion37](https://img.shields.io/badge/python-3.7-blue.svg)](https://www.python.org/download/releases/3.7/)
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
- Run the server using the following command:
2019-12-11 09:08:39 +00:00
```sh
make serve
```
2014-12-05 12:31:49 +00:00
2018-10-18 18:14:54 +00:00
## Database setup
2015-12-07 20:42:07 +00:00
2019-12-11 09:08:39 +00:00
Start the Django shell by
2019-01-04 14:37:59 +00:00
```sh
python manage.py shell --settings=config.local
2015-12-07 20:42:07 +00:00
```
2018-09-08 22:42:24 +00:00
Run the build script with
2019-01-04 14:37:59 +00:00
```py
from data.v2.build import build_all
build_all()
2015-12-07 20:42:07 +00:00
```
2019-01-04 14:37:59 +00:00
2019-12-11 09:08:39 +00:00
Visit [localhost:8000/api/v2/ ](localhost:8000/api/v2/ ) to see the running API!
2018-09-08 22:42:24 +00:00
Each time the build 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.
In informal tests on a Windows PC with a SSD and a 2.50 GHz processor, building against a PostgresQL database took approximately 6 minutes, and building against a SQLite database took about 7.5 minutes or longer, with some varying results.
2018-09-07 19:18:33 +00:00
The option to build individual portions of the database was removed in order to increase performance of the build script.
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
make wipe_db
```
2019-01-04 14:37:59 +00:00
## Docker Compose
2015-04-21 03:31:59 +00:00
2019-01-04 14:37:59 +00:00
There is also a multi-container setup, managed by [Docker Compose ](https://docs.docker.com/compose/ ). This setup allow you to deploy a production-like environment, with separate containers for each services.
2015-11-12 02:17:20 +00:00
2019-01-04 14:37:59 +00:00
Start the process using
2015-11-12 02:17:20 +00:00
2019-01-04 14:37:59 +00:00
```sh
docker-compose up --build
2015-11-12 02:17:20 +00:00
```
2019-01-04 14:37:59 +00:00
You can specify the `-d` switch to start in detached mode.
This will bind port 80 and 443. Unfortunately, unlike the `docker` command, there is no command line arguments to specify ports. If you want to change them, edit the `docker-compose.yml` file.
After that, start the migration process
```sh
2019-01-07 19:12:01 +00:00
docker-compose exec app python manage.py migrate --settings=config.docker-compose
2015-11-12 02:17:20 +00:00
```
2019-01-04 14:37:59 +00:00
And then, import the data using the shell
```sh
2019-01-07 19:12:01 +00:00
docker-compose exec app python manage.py shell --settings=config.docker-compose
2015-11-12 02:17:20 +00:00
```
2019-01-04 14:37:59 +00:00
2019-01-07 18:59:05 +00:00
Then use the `build_all()` method in the shell to populate the database.
2019-01-04 14:37:59 +00:00
```py
from data.v2.build import build_all
build_all()
2015-11-12 02:17:20 +00:00
```
2019-01-04 14:37:59 +00:00
Browse [localhost/api/v2/ ](http://localhost/api/v2/ ) or [localhost/api/v2/pokemon/bulbasaur/ ](http://localhost/api/v2/pokemon/bulbasaur/ )
2016-07-07 12:23:59 +00:00
2019-12-11 09:08:39 +00:00
This setup doesn't allow you to use the `scale` command.
2016-07-07 12:23:59 +00:00
2019-12-11 09:08:39 +00:00
## Donations
2016-07-07 12:23:59 +00:00
2019-12-11 09:08:39 +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 almost 20 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
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
2014-12-05 12:31:49 +00:00
All contributions are welcome: bug fixes, data contributions, recommendations.
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 ).