Laravel Lumen is a stunningly fast PHP micro-framework for building web applications with expressive, elegant syntax. We believe development must be an enjoyable, creative experience to be truly fulfilling. Lumen attempts to take the pain out of development by easing common tasks used in the majority of web projects, such as routing, database abstraction, queueing, and caching.
Documentation for the framework can be found on the Lumen website.
If you discover a security vulnerability within Laravel, please send an e-mail to Taylor Otwell at taylor@laravel.com. All security vulnerabilities will be promptly addressed.
The Lumen framework is open-sourced software licensed under the MIT license
Lumen Car Rental is example API application of car rental which built by Lumen (micro-framework of laravel) click for demo https://lumen-car-rental.herokuapp.com/
API to get client / car / rental data
Method : GET
[CLIENT]
URL : /api/v1/client
Response : ['name','gender']
[CAR]
URL : /api/v1/car
Response : ['brand','type','year','color','plate']
[RENTAL]
URL : /api/v1/rental
Response : ['name','brand','type','plate','date-from','date-to']
API to create client / car / rental data
Method : POST
[CLIENT]
URL : /api/v1/client
Parameter : ['name','gender:male,female']
Validation :
* All field is required
* Gender must be “male” or “female”
[CAR]
URL : /api/v1/car
Parameter : ['brand','type','year:2016','color','plate']
Validation :
* All field is required
* Year cannot be future
* Plate is unique
[RENTAL]
URL : /api/v1/rental
Parameter : ['car-id','client-id','date-from:2011-11-11','date-to:2011-11-11']
Validation :
* car-id and client-id must be exists.
* Client is not rent another car at selected rent date.
* All field is required
* Car is not rented at selected rent date.
* Rented duration max 3 days
* Rent date only between current day + 1 days until current date +7 days.
API to update client / car /rental data
Method : PUT
[CLIENT]
URL : /api/v1/client/{id}
Parameter : ['name','gender:male,female']
Validation :
* All fields are required.
* Gender must be “male” or “female”
* The ID must be exists on the database
[CAR]
URL : /api/v1/car/{id}
Parameter : ['brand','type','year','color','plate']
Validation :
* All field required
* Plate cannot be duplicated.
* Year cannot be future
[RENTAL]
URL : /api/v1/rental/{id}
Parameter : ['car-id','client-id','date-from:2011-11-11','date-to:2011-11-11']
Validation :
* Car id and client id must be exists.
* Client is not rent another car at selected rent date.
* Car is not rented at selected rent date.
* Rented duration max 3 days
* Rent date only between current day + 1 days until current date +7 days.
API to delete client / car / rental data
Method : DELETE
[CLIENT]
URL : /api/v1/client/{id}
Validation : id must be exist in database
[CAR]
URL : /api/v1/car/{id}
Validation : id must be exist in database
[RENTAL]
URL : /api/v1/rental/{id}
Validation : id must be exist in database
API to get rental histories for specific client and within specified month for car histories
Method : GET
[CLIENT]
URL : /api/v1/histories/client/{id}
Validation : id must be exist in database
[CAR]
URL : /api/v1/histories/car/{id}
Parameter : ['month:"12-2016"']
Validation :
* The car ID must be exists on the database
* Month format must be `MM-YYYY`
API to get rented car in specified date
Method : GET
URL : /api/v1/car/rented
Parameter : ['month:"22-12-2016"']
Validation :
* date format must be `DD-MM-YYYY`
API to get available car in specified date
Method : GET
URL : /api/v1/car/free
Parameter : ['month:"22-12-2016"']
Validation :
* date format must be `DD-MM-YYYY`
all test : phpunit
specified : phpunit tests/{filename}