Create an API for an online Bucket List service using Flask.
Bucket list
can also be refered to as things/something to do before you die
. It is possibly derived from the English idiom to kick the bucket. It is used as an informal way or as a slang and it is believed that the idiom comes from method of execution such as hanging. The origin of the word remains unclear. Read more here. 🤔
This App exposes endpoints that allows clients/Users
to manage a bucketlist of their choise.
Method | Endpoint | Usage |
---|---|---|
POST | /api/v1.0/register |
Register a user. |
POST | /api/v1.0/login |
Login user. |
POST | /api/v1.0/bucketlists/ |
Create a new bucket list. |
GET | /api/v1.0/bucketlists/ |
Get all the created bucket lists. |
GET | /api/v1.0/bucketlists/<bucket_id> |
Get a single bucket list. |
PUT | /api/v1.0/bucketlists/<bucket_id> |
Update a single bucket list. |
DELETE | /api/v1.0/bucketlists/<bucket_id> |
Delete single bucket list. |
POST | /api/v1.0/bucketlists/<bucket_id>/items |
Add a new item to this bucket list. |
GET | /api/v1.0/bucketlists/<bucket_id>/items/<item_id> |
Get an item from this bucket list. |
PUT | /api/v1.0/bucketlists/<bucket_id>/items/<item_id> |
Update an item in this bucket list. |
PATCH | /api/v1.0/bucketlists/<bucket_id>/items/<item_id> |
Patch an item in this bucket list. |
DELETE | /api/v1.0/bucketlists/<bucket_id>/items/<item_id> |
Delete this single bucket list. |
GET | /api/v1.0/bucketlists?limit=10&page=1 |
Pagination to get 10 bucket list records. |
GET | /api/v1.0/bucketlists?q=travelling bucket |
Search for bucket lists with name like travelling bucket. |
- To run on local machine git clone this project :
$ git clone https://github.com/georgreen/CP2A-BucketList-Application.git
Copy and paste the above command in your terminal, the project will be downloaded to your local machine.
- To consume API in client of choice navigate to:
https://cp2-bucketlist-prd.herokuapp.com/api/
This link will open up a running version of the project on heroku, a detailed documentation is provided on the site.
The application is built using python: flask framework.
Flask is a microframework for the Python programming language.
To Install python checkout:
https://www.python.org/
For this section I will assume you have python3 and it's configured on your machine.
Navigate to the folder you cloned and run:
- Install Requirements
$ pip install -r requirements.txt
- Configure Environment.
$ export APP_SETTINGS="default"
$ export DEV_DATABASE="path to your database"
$ export SECRET="Secret Key Here"
Note replace the value for DEV_DATABASE with real database path and SECRET with a strong string value
- Configure database
$ python manage.py database init
$ python manage.py database migrate
$ python manage.py database upgrade
- Run App 🏃🏃
$ python manage.py runserver
The app should be accessiable via : http://127.0.0.1:5000/
To Follow along with this examples get postman : A powerful GUI platform to make your API requests. READ MORE HERE
-
- Post data in the format below to the register endpoint:
/api/v1.0/register
{ "username":"geogreen ngunga", "email":"demoenail@gmail.com", "password":"demoPassword12#" }
- Post data in the format below to the register endpoint:
-
- Post data in the format below to the login endpoint :
/api/v1.0/login
{ "email":"demoenail@gmail.com", "password":"demoPassword12#" }
- Post data in the format below to the login endpoint :
-
Copy the token returned and add it into the headers as a key pair value of
Authorization : Bearer [put token here]
-
- Post data in the format below to the bucketlist endpoint:
/api/v1.0/bucketlists/
{ "name":"new bucketlist name" }
- Post data in the format below to the bucketlist endpoint:
-
- Get data from the bucketlist endpoint:
/api/v1.0/bucketlists/
- Get data from the bucketlist endpoint:
-
- Get data from the bucketlist endpoint:
/api/v1.0/bucketlists/bucket_id
- Get data from the bucketlist endpoint:
-
- Put data to the endpoint :
/api/v1.0/bucketlists/bucket_id
{ "name":"new name" }
- Put data to the endpoint :
-
- Delete data at an endpoint:
/api/v1.0/bucketlists/bucket_id
- Delete data at an endpoint:
-
- Post data to
/api/v1.0/bucketlists/<bucket_id>/items
in the format:
{ "name":"Item name", "description":"Item description" }
- Post data to
-
- Get data from the endpoint:
/api/v1.0/bucketlists/<bucket_id>/items/<item_id>
- Get data from the endpoint:
-
- Put data to
/api/v1.0/bucketlists/<bucket_id>/items/<item_id>
in the format:
{ "name":"This will update name", "description":"This will update description" }
- Put data to
-
- Patch item endpoint
/api/v1.0/bucketlists/<bucket_id>/items/<item_id>
data format:
{ "done":"True" }
- Patch item endpoint
-
- Delete item at the endpoint
/api/v1.0/bucketlists/<bucket_id>/items/<item_id>
- Delete item at the endpoint
-
- Get bucketlist by searching
/api/v1.0/bucketlists/<bucket_id>/?q=search
Search can be any sub string to be queried from the resource
- Get bucketlist by searching
-
- Get paginated buckets
/api/v1.0/bucketlists/<bucket_id>/?limit=2&page=1
This will get two bucketlists per page, limit can be set to any number of bucketlist required per page; page is the required page 1st, 2nd , 3rd ....etc
- Get paginated buckets
$ python manage.py test
- With Coverage
$ nosetests --rednose --with-coverage --cover-package=app -v
- Coding style tests
Pep8 standards are followed in project.
$ pep8 app --count
- Flask - The web framework used
- Flaskrestplus - Extension for Flask that adds support for quickly building REST APIs.
- webargs - webargs is a Python library for parsing HTTP request arguments
- Flask JWT Extended - Extension for Flask that adds support for tokken authentication
- Please Fork me! :-)
- Georgreen Mamboleo - Initial work - Dojo
- This project is licensed under the MIT License - see the LICENSE.md file for details
- Andela - We are hiring !
- Taracha Roger - Cool Human being.🤓🤓
- Motivation - BEST RESOURCE EVER!!!