A RESTFul API for managing assets such as satellites, antennas etc
- Python (3.5.0 or higher)
- pip (18.1 or higher)
- Django (2.1.4 or higher)
- Django REST Framework (3.9.0 or higher)
- Clone this repository locally
- The permissions on the bash shell scripts need to changed to 755 with command
chmod 755 *.sh
- Execute the script
install.sh
- Python is expected to be installed by the user
- OPTIONAL: if pip is not up-to-date, upgrade pip with command
pip install --upgrade pip
- This script installs all the dependencies except python and pip, using pip
- This script installs the missing required packages, if your system already has the required package installed, it skips the installation of that package
The API is only tested with JSON input and output. XML as input is NOT tested.
GET /api/v1/assets/
: This request with the specified URL retrieves ALL the assets in the asset store. Make a note of the '/' at the end of URL, it's required.GET /api/v1/assets/<asset_name>
: This request with the specified URL retrieves a single asset with the asset_name specified in the URLPOST /api/v1/assets/
: This request with the specified URL attempts to create ALL of the assets from the JSON payload or nothing in case of one or more errors in the payload. Make a note of the '/' at the end of the URL, it's required.PUT and DELETE
: These types of requests are NOT allowed. Attempting these request will yield a response of405 Method Not Allowed
- The API is designed such that it allows for multiple versions that may or may not be backwards compatible. Hence the version number in the path. This design choice is made to make clients of the API aware of different versions and potential compatibility issues.
- POST request handler is implemented following an ALL or Nothing paradigm. If all the assets in the payload are valid, the handler performs a BULK creation of all of the assets from the payload. But if even one asset in the payload is not valid, the entire payload is rejected.
- Response for the POST method contains one to one mapping from the request payload. The response payload indicates the asset_name and errors (a list of errors) for each of the asset from the request. If there are valid assets in the request payload, the validity is indicated in the errors field for asset_name, but the asset is not created in the system because of other assets in the request being invalid.
- Also the order errors in the response payload for POST request preserves the order of assets given in the request payload, this choice is made to make it easier for the clients to process the errors.
- The paradigm used for requests is to allow for different HTTP methods to dictate which one of (Create, Read, Update, and Delete) methods on the asset resource in the asset store. Because of this different class based views are defined for different HTTP methods. A single base view class each for URLs
/api/v1/assets/
and/api/v1/assets/<asset_name>
is defined. Each of these base view class redirects the request to class based view defined for the corresponding HTTP method. PUT
(update) andDELETE
methods are implemented but the handlers for these methods just return a405 Method Not Allowed
response. This is because the asset resource currently only has immutable attributes defined and resource should not be deleted as per the specification of the problem.
The database used for this API is the Django provided SQLite database.
The script runserver.sh
is provided as a convenience to run the server for this API application. This script attempts to create and migrate the necessary database schema for the API before starting up the server.
- To verify the basic correctness of the implementation, some tests are provided in
tests.py
inside theassets
application. To sanity check the installation of the API, you can run the commandpython manage.py test
. - A postman collection (
Asset_Store_API.postman_collection
) is provided at the root of this repository to easily verify the API. This collection expects the API to be deployed on port 8000 on your local server (127.0.0.1). The collection contains requests for CRUD HTTP methods (POST, GET, PUT, DELETE).
- On windows OS, the first time a PUT request is made with any body content, the server does not respond. If you make this request again, the reponse received is the expected
405 Method Not Allowed
. This is a known bug and will be resolved at a future time. Note that if the PUT request does NOT contain any body this problem does not arise.