This API provides a range of endpoints designed for the management of various hotel-related tasks, including booking handling, hotel and city information management, and offering guest services.
- User Registration: Allows new users to create accounts by providing necessary information.
- User Login: Enables registered users to log in securely to access booking features.
- Search by Various Criteria: Users can search for hotels using criteria such as hotel name, room type, room capacities, price range, and other properties through text fields.
- Comprehensive Search Results: Provides users with detailed information about hotels matching their search criteria.
- Management of Images and Thumbnails: Allows for the addition, deletion, and updating of images associated with cities and hotels.
- Display Most Visited Cities: Showcases popular cities based on user traffic, allowing users to explore trending destinations easily.
- Invoice Requests via Email: Users can effortlessly request detailed invoices anytime. the email service promptly delivers comprehensive invoices, including total price, hotel location, and relevant details, ensuring ease and transparency for the guests.
- Enhanced User Communication: Facilitates effective communication with users, keeping them informed about their bookings.
- Search, Add, Update, and Delete Entities: Provides administrators with full control over system entities, enabling efficient management of cities, hotels, rooms, and other components.
- Streamlined Administrative Tasks: Simplifies administrative tasks through a user-friendly interface, enhancing system maintenance.
HTTP Method | Endpoint | Description |
---|---|---|
GET | /api/room-amenities | Retrieve a page of room amenities |
POST | /api/room-amenities | Create a new room amenity |
GET | /api/room-amenities/{id} | Get a room amenity specified by ID |
DELETE | /api/room-amenities/{id} | Delete room amenity specified by ID |
PUT | /api/room-amenities/{id} | Update an existing room amenity |
PATCH | /ap/room-amenities/{id} | Partially Update an existing room amenity |
HTTP Method | Endpoint | Description |
---|---|---|
POST | /api/authentication/sign-in | Processes a login request |
POST | /api/authentication/register | Processes registering a guest request |
HTTP Method | Endpoint | Description |
---|---|---|
GET | /api/home/destinations/trending | Retrieves the top 5 trending cities |
GET | /api/home/search | Searches for hotels based on the search query |
GET | /api/home/featured-deals | Retrieves the top 5 featured hotel deals |
HTTP Method | Endpoint | Description |
---|---|---|
GET | /api/cities | Retrieve a page of cities |
POST | /api/cities | Creates a new city |
GET | /api/cities/{cityId} | Retrieves details for a specific city |
DELETE | /api/cities/{cityId} | Deletes a city by ID |
PUT | /api/cities/{cityId} | Updates an existing city |
PATCH | /api/cities/{cityId} | Partially updates a city |
GET | /api/cities/{cityId}/photos | Retrieves all photos for a city |
POST | /api/cities/{cityId}/gallery | Uploads an image for a city |
PUT | /api/cities/{cityId}/thumbnail | Uploads a thumbnail for a city |
DELETE | /api/cities/{cityId}/photos/{photoId} | Deletes an image associated with a city |
HTTP Method | Endpoint | Description |
---|---|---|
GET | /api/room-types/{roomTypeId}/discounts | Retrieves discounts for a room type |
GET | /api/room-types/discounts/{discountId} | Retrieves a discount by its ID |
DELETE | /api/room-types/discounts/{discountId} | Deletes a discount by its ID |
POST | /api/room-types/discounts | Creates a new discount |
HTTP Method | Endpoint | Description |
---|---|---|
GET | /api/guests/{guestId}/recently-visited-hotels | Retrieves recent 5 distinct hotels for a guest |
GET | /api/guests/recently-visited-hotels | Fetches 5 recent unique hotels for the authenticated guest |
GET | /api/guests/bookings | Retrieves bookings for the authenticated guest |
POST | /api/guests/bookings | Reserve a room |
DELETE | /api/guests/bookings/{bookingId} | Cancels a booking for the guest |
GET | /api/guests/bookings/{bookingId}/invoice | Retrieves invoice for a booking |
HTTP Method | Endpoint | Description |
---|---|---|
GET | /api/hotels | Retrieves all hotels |
POST | /api/hotels | Creates a new hotel |
GET | /api/hotels/{hotelId} | Retrieves information about a hotel |
DELETE | /api/hotels/{hotelId} | Deletes a hotel |
PUT | /api/hotels/{hotelId} | Updates information about a hotel |
GET | /api/hotels/{hotelId}/available-rooms | Retrieves available rooms for a hotel |
GET | /api/hotels/{hotelId}/photos | Retrieves all photos associated with a hotel |
POST | /api/hotels/{hotelId}/gallery | Uploads an image for a hotel |
PUT | /api/hotels/{hotelId}/thumbnail | Uploads a thumbnail for a hotel |
DELETE | /api/hotels/{hotelId}/photos/{photoId} | Deletes an image associated with a hotel |
GET | /api/hotels/{hotelId}/rooms | Retrieves all rooms available for a hotel |
POST | /api/hotels/{hotelId}/rooms | Creates a new room for a hotel |
GET | /api/hotels/{hotelId}/rooms/{roomId} | Retrieves a room from a hotel |
GET | /api/hotels/{hotelId}/room-types | Retrieves all room categories available for a hotel |
GET | /api/hotels/{hotelId}/bookings | Retrieves all bookings associated with a hotel |
HTTP Method | Endpoint | Description |
---|---|---|
GET | /api/reviews/hotels/{hotelId} | Retrieves reviews for a specific hotel |
POST | /api/reviews | Creates a new review |
- C#: Main programming language.
- ASP.NET Core: Framework for building high-performance, cross-platform web APIs.
- Entity Framework Core: Employing Entity Framework Core for streamlined object-relational mapping (ORM) within the .NET ecosystem, simplifying database interactions.
- SQL Server: Utilizing SQL Server for reliable and scalable backend database management, ensuring efficient storage and retrieval of application data.
- Firebase Storage: Part of Google's Firebase platform, offers cloud-based storage for images in this hotel booking system. It provides scalability, reliability, and seamless API integration.
- Swagger/OpenAPI: For API specification and documentation.
- Swagger UI: Provides a user-friendly interface for API interaction.
- JWT (JSON Web Tokens): For secure transmission of information between parties.
- Serilog: Logging library for .NET applications.
- RESTful Principles: Adhering to RESTful design principles to ensure that APIs are designed for simplicity, scalability, and ease of use.
- CQRS (Command Query Responsibility Segregation) Pattern: CQRS separates the responsibility for handling read and write operations into separate components. It can improve scalability and performance by allowing optimized data access paths for read and write operations.
- Clean Architecture
- External Layers:
- Web: Controllers for handling requests and managing client-server communication.
- Infrastructure: Manages external resources such as databases, email services, PDF generation, and identity management.
- Core Layers:
- Application Layer: Implements business logic and orchestrates interactions between components.
- Domain Layer: Contains fundamental business rules and entities, independent of external concerns like databases or user interfaces.
- External Layers:
- HTTPS: Ensures secure communication over the network.
- Data Encryption: Password hashing using
Isopoh.Cryptography.Argon2
.
This API leverages the Asp.Versioning.Mvc library to implement a streamlined header-based versioning mechanism. This approach facilitates seamless client access to different API versions without requiring adjustments to the base URL or path. By utilizing headers, the versioning process is standardized and offers improved clarity and maintainability. This method also enhances flexibility and ease of integration for users while ensuring optimal compatibility with various client applications. curl? This API uses Asp.Versioning.Mvc for header-based versioning, allowing seamless access to different versions without changing the URL. It standardizes versioning via headers, improving clarity and flexibility for users and compatibility with client apps.
Users can effortlessly specify their preferred API version by including the x-api-version header in their requests. In instances where no version is explicitly specified, the API seamlessly defaults to the latest available version. For instance:
To explicitly request version 1.0:
curl -X GET "localhost:5231/api/cities" -H "x-api-version: 1.0"
To utilize the latest version by default:
curl -X GET "localhost:5231/api/cities"
This guide provides instructions on setting up an existing ASP.NET API project. Follow these steps to clone the repository, configure the appsettings.json
file, and run the API locally.
- .NET 7 SDK installed on your system.
- Running SQL Server instance with a database.
Clone the repository of your existing ASP.NET API project to your local machine:
git clone https://github.com/obada-yahya/Travel-And-Accommodation-Booking-Platform.git
Change your current directory to the root directory of your ASP.NET API project:
cd TAABP\TAABP.API
Open the appsettings.json
file located in your project directory and configure the connection string for SQL Server. Replace the <connection_string>
placeholder with your SQL Server connection string:
{
"ConnectionStrings": {
"TAABPCoreDb": "<connection_string>"
}
}
Start the ASP.NET API project using the following command:
dotnet run
The API will be accessable using https://localhost:7022.
The swagger UI will open automatically where you can try and explore the endpoints or you can open it using https://localhost:7022/swagger.
Your Feedback and Contributions are Welcome!
- Feedback: Share your thoughts and ideas.
- Issue Reporting: Help us by reporting any bugs or issues on GitHub.
- Code Contributions: Contribute to the codebase.
Email: obadayahya.an@gmail.com.
GitHub: Obada Yahya.
Thank you for your interest. I look forward to hearing from you!