Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/brendon45/airbnb_clone
This is the AirBnB clone - The console (hbnb) repository from ALX
https://github.com/brendon45/airbnb_clone
Last synced: about 2 months ago
JSON representation
This is the AirBnB clone - The console (hbnb) repository from ALX
- Host: GitHub
- URL: https://github.com/brendon45/airbnb_clone
- Owner: Brendon45
- Created: 2024-02-06T20:27:21.000Z (11 months ago)
- Default Branch: main
- Last Pushed: 2024-02-19T21:13:52.000Z (11 months ago)
- Last Synced: 2024-02-20T21:54:35.040Z (11 months ago)
- Language: Python
- Size: 96.7 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Authors: AUTHORS
Awesome Lists containing this project
README
# 0x00. AirBnB clone - The console
## Welcome to the AirBnB clone project!
Before starting, please read the AirBnB concept page.## First step: Write a command interpreter to manage your AirBnB objects.
This is the first step towards building your first full web application: the AirBnB clone. This first step is very important because you will use what you build during this project with all other following projects: HTML/CSS templating, database storage, API, front-end integration…## Each task is linked and will help you to:
- put in place a parent class (called BaseModel) to take care of the initialization, serialization and deserialization of your future instances
- create a simple flow of serialization/deserialization: Instance <-> Dictionary <-> JSON string <-> file
- create all classes used for AirBnB (User, State, City, Place…) that inherit from BaseModel
- create the first abstracted storage engine of the project: File storage.
- create all unittests to validate all our classes and storage engine![AIRBNB!](https://s3.amazonaws.com/alx-intranet.hbtn.io/uploads/medias/2018/6/65f4a1dd9c51265f49d0.png?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Credential=AKIARDDGGGOUSBVO6H7D%2F20240206%2Fus-east-1%2Fs3%2Faws4_request&X-Amz-Date=20240206T193524Z&X-Amz-Expires=86400&X-Amz-SignedHeaders=host&X-Amz-Signature=67432a4202eff52e372532c801cf0e2d532b9a14d8309fe5b2463a4e74634a29)
## What’s a command interpreter?
## Do you remember the Shell? It’s exactly the same but limited to a specific use-case. In our case, we want to be able to manage the objects of our project:- Create a new object (ex: a new User or a new Place)
- Retrieve an object from a file, a database etc…
- Do operations on objects (count, compute stats, etc…)
- Update attributes of an object
- Destroy an object## Execution
## Your shell should work like this in interactive mode:$ ./console.py
(hbnb) helpDocumented commands (type help ):
========================================
EOF help quit(hbnb)
(hbnb)
(hbnb) quit
$## But also in non-interactive mode: (like the Shell project in C)
$ echo "help" | ./console.py
(hbnb)## Documented commands (type help ):
========================================
EOF help quit
(hbnb)
$
$ cat test_help
help
$
$ cat test_help | ./console.py
(hbnb)## Documented commands (type help ):
========================================
EOF help quit
(hbnb)
$All tests should also pass in non-interactive mode: $ echo "python3 -m unittest discover tests" | bash
![CHEESE!](https://s3.amazonaws.com/alx-intranet.hbtn.io/uploads/medias/2018/6/815046647d23428a14ca.png?X-Amz-Algorithm=AWS4-HMAC-SHA256&X-Amz-Credential=AKIARDDGGGOUSBVO6H7D%2F20240206%2Fus-east-1%2Fs3%2Faws4_request&X-Amz-Date=20240206T211943Z&X-Amz-Expires=86400&X-Amz-SignedHeaders=host&X-Amz-Signature=ea727ba4aaff1301048c1d1fd51b72319caca67f05c837af4f07bca6f19bc8ab)
## AUTHORS
Brendon Jeje![AKUREK](https://www.codester.com/static/uploads/items/000/021/21656/preview.jpg)