Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vyahello/async-weather-api
⛓️ Asynchronous weather REST API (asyncio, quart, pytest, docker)
https://github.com/vyahello/async-weather-api
asyncio rest-api
Last synced: 3 months ago
JSON representation
⛓️ Asynchronous weather REST API (asyncio, quart, pytest, docker)
- Host: GitHub
- URL: https://github.com/vyahello/async-weather-api
- Owner: vyahello
- License: mit
- Created: 2020-01-05T12:33:20.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2022-12-27T15:37:54.000Z (about 2 years ago)
- Last Synced: 2024-10-31T13:52:35.442Z (4 months ago)
- Topics: asyncio, rest-api
- Language: Python
- Homepage: https://pypi.org/project/async-weather-api/
- Size: 88.9 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.md
Awesome Lists containing this project
README
data:image/s3,"s3://crabby-images/a151b/a151bd3c3274fd94b050fb6cb0bb5394cc824296" alt="Screenshot"
[data:image/s3,"s3://crabby-images/53b98/53b981d4ad2e22fc4a1a55aaa7dd262dfcb61285" alt="made-with-python"](https://www.python.org/)
[data:image/s3,"s3://crabby-images/98647/986475842f2907062b79c4bb27fdd075d638e5b9" alt="Code style: black"](https://github.com/psf/black)
[data:image/s3,"s3://crabby-images/ae90a/ae90a1b17cdb458fe3d891a0e5eca828a68a1e69" alt="Checked with mypy"](http://mypy-lang.org/)
[data:image/s3,"s3://crabby-images/8b0c1/8b0c1c0fc4b3bd277a66c365d1f7feb620508f79" alt="PyPI version shields.io"](https://pypi.python.org/pypi/async-weather-api/)
[data:image/s3,"s3://crabby-images/73ab5/73ab57dbeee7ce857b42241541cefe919b5908bd" alt="PyPI pyversions"](https://pypi.python.org/pypi/async-weather-api/)
[data:image/s3,"s3://crabby-images/625dd/625dd28dd88307e6699c6a7b5c11368aba12c116" alt="Downloads"](https://pepy.tech/project/async-weather-api)
[data:image/s3,"s3://crabby-images/88243/8824349e8a262a928b31f61bd0755006e0b0a005" alt="Build Status"](https://travis-ci.org/vyahello/async-weather-api)
[data:image/s3,"s3://crabby-images/98643/986432ffd306b7165c41c84033307ce945606eb6" alt="Coverage Status"](https://coveralls.io/github/vyahello/async-weather-api?branch=master)
[data:image/s3,"s3://crabby-images/e369f/e369f6eaac3cd359cb46351ac6983544d5c0f586" alt="Docker pulls"](https://hub.docker.com/repository/docker/vyahello/async-weather-api)
[data:image/s3,"s3://crabby-images/a6d36/a6d36c750f205f1b0294ad766af3fb3737f99c6f" alt="License"](LICENSE.md)# Async weather API
> This project represents sample of asynchronous weather REST API that is build using **quart** (flask compatible API) python web microframework based on Asyncio.
>
> It uses https://openweathermap.org to obtain weather data.## Tools
### Production
- python 3.6, 3.7, 3.8
- [asyncio](https://docs.python.org/3/library/asyncio.html)
- [quart](https://pgjones.gitlab.io/quart/)### Development
- [pytest](https://pypi.org/project/pytest/)
- [mypy](http://mypy.readthedocs.io/en/latest)
- [black](https://black.readthedocs.io/en/stable/)
- [pylint](https://www.pylint.org/)
- [flake8](http://flake8.pycqa.org/en/latest/)
- [pydocstyle](http://www.pydocstyle.org/)## Usage
### Quick start
Please run following script to obtain the latest package from PYPI:
```bash
pip install async-weather-api
```Then please execute steps below to launch API from your environment:
```python
import weatherweather.run(key="your-secret-key", bind="0.0.0.0:5001", debug=False)
```
> Note: `key` stands for API key from https://openweathermap.org### Docker image
Please run next command to start async weather api via docker:
```bash
docker run -it -p 3000:5001 vyahello/async-weather-api:0.5.0 \
weather run \
--bind 0.0.0.0:5001 \
--mode prod \
--key
```> Note: please use `3000` port to access application via docker
### Source code
To be able to run source code please execute command below:
```bash
python -m weather run --bind 0.0.0.0:5001 --mode prod --key your-secret-key
```### Endpoints
- **/** - home page
```bash
curl -X GET http://0.0.0.0:5001/
curl -X GET http://0.0.0.0:5001/index
```
_Response_: html page
- **/api/weather/{city}/{state}/{country}** - current weather event
```bash
curl -X GET http://0.0.0.0:5001/api/events/London/GB/GreatBritain
```
_Response_: json object
```json
{"city":"London","country":"GreatBritain","name":"Jeff the player","state":"GB"}
```
- **/api/weather/{zip_code}/{country}** - current weather in city
```bash
curl -X GET http://0.0.0.0:5001/api/weather/97002/us
```
_Response_: json object
```json
{"base":"stations","clouds":{"all":90},"cod":200,"coord":{"lat":45.23,"lon":-122.8}}
```
- **/api/sun/{zip_code}/{country}** - current sunset/sunrise in city
```bash
curl -X GET http://0.0.0.0:5001/sun/weather/97002/us
```
_Response_: json object
```json
{"astronomical_twilight_begin":"04:03:49 PM","astronomical_twilight_end":"04:29:50 AM"}
```## Development notes
### CI/CD
Project has Travis CI integration using [.travis.yml](.travis.yml) file thus code analysis (`black`, `mypy`, `pydocstyle`, `pylint`, `flake8`) and unittests (`pytest`) will be run automatically
after every made change to the repository.To be able to run code analysis, please execute command below:
```bash
./analyse-code.sh
```Other than that, a fresh versioned package will be delivered on PYPI after new tag is created using [pythonpublish.yml](.github/workflows/pythonpublish.yml) file.
### Release notes
Please check [changelog](CHANGELOG.md) file to get more details about actual versions and it's release notes.
### Meta
Author – _Volodymyr Yahello_.
Distributed under the `MIT` license. See [LICENSE](LICENSE.md) for more information.
You can reach out me at:
* [[email protected]]([email protected])
* [https://twitter.com/vyahello](https://twitter.com/vyahello)
* [https://www.linkedin.com/in/volodymyr-yahello-821746127](https://www.linkedin.com/in/volodymyr-yahello-821746127)### Contributing
I would highly appreciate any contribution and support. If you are interested to add your ideas into project please follow next simple steps:1. Clone the repository
2. Configure `git` for the first time after cloning with your `name` and `email`
3. `pip install -r requirements.txt` to install all project dependencies
4. `pip install -r requirements-dev.txt` to install all development project dependencies
5. Create your feature branch (`git checkout -b feature/fooBar`)
6. Commit your changes (`git commit -am 'Add some fooBar'`)
7. Push to the branch (`git push origin feature/fooBar`)
8. Create a new Pull Request