Purpose
The purpose of this project is to recreate the AirBnB site, from the back-end data management to the front-end user interface.
In the fourth phase, the website was redesigned to make dynamic webpages using jQuery. Now as the user selects places in the browser using the checkboxes, the selected places are loaded on the client side. Build an API. To implement, run the API module. Current implmentation requires an existing database in mysql.Run at the root of the folder
>>> HBNB_MYSQL_USER=hbnb_dev HBNB_MYSQL_PWD=hbnb_dev_pwd HBNB_MYSQL_HOST=localhost HBNB_MYSQL_DB=hbnb_dev_db HBNB_TYPE_STORAGE=db HBNB_API_HOST=0.0.0.0 HBNB_API_PORT=5000 python3 -m api.v1.app
Expected response:
* Running on http://0.0.0.0:5000/ (Press CTRL+C to quit)
...
A list of all the possible routes and their respective routes are available on Flasgger's application, here.
Input route for specific api request and available route below.
http://0.0.0.0:5000/api/v1/{Route}
Route | Request |
---|---|
states | [GET, POST] |
states/<state_id> | [GET, DELETE, PUT] |
states/<state_id>/cities | [GET, POST] |
cities/<city_id> | [GET, DELETE. PUT] |
amenities | [GET, POST] |
amenities/<amenity_ids> | [GET, DELETE, PUT] |
users | [GET, POST] |
users/<user_id> | [GET, DELETE, PUT |
cities/<city_id>/places | [GET, POST] |
places/<place_id> | [GET, DELETE, PUT] |
places/<place_id>/amenities | [GET, DELETE] |
places/<place_id>/amenities/<amenity_id> | [POST] |
places/<place_id>/reviews | [GET, POST] |
reviews/<review_id> | [GET, DELETE, PUT] |
places | [POST] |
- MySQL user = <HBNB_MYSQL_USER>
- MySQL password = <HBNB_MYSQL_PWD>
- MySQL host = <HBNB_MYSQL_HOST> (typically = localhost)
- MySQL database = HBNB_MYSQL_DB
- HBNB_TYPE_STORAGE = db
Authors
- Philip Yoo, <[email protected]>, @philipYoo10
- Jianqin Wang, <[email protected]>, @jianqinwang94
- Anne Cognet, <[email protected]>, @1million40
- Richard Sim, <[email protected]>, @rdsim8589
- Swati Gupta, <[email protected]>, @gupta1505
In order to begin the console, you can run either 'python3 console.py' or './console.py' in the command line.
Classes that are currently supported include BaseModel, User, City, State, Amenity, Review, and Place.
The console currently supports the following commands:
- create <class name>, which will create an object of the class declared by user;
- show <class name> <id>, which will display the object information if it exists;
- destroy <class name> <id>, which will delete the object if it exists;
- all <class name>, where the class name input is optional and the console will display all instances, or all instances of a specified object;
- update <class name> <id> <attribute name> <attribute value>, whilch will update an instance attribute of a previously declared object.
Additionally, the console also supports the following command formats:
- <class name>.all(), which will display all instances of the specified class;
- <class name>.count(), whilch will display the number of instances of the specified class;
- <class name>.show(<id>), whilch will display the instance with correct id and class;
- <class name>.destroy(<id>), which will delete the instance with correct id and class;
- <class name>.update(<id>, <attribute name>, <attribute value>), which will update an instance of the given class and id with the new attribute;
- <class name>.update(<id>, <dictionary representation>), which will update an instance of the given class and id with a dictionary of key value pairs that will be new attributes for the objects.
- **<class name>.create(=) create an instance of the class