An API Gateway to multiple Cloud Providers.
The projects has been designed to create a common gateway for interating with multiple infrastructures(clouds).
- Applications need not maintain/secure access keys to different environments. They can use 1 request format for interacting with different infrastructures
- A similar response structure for all requests makes it easier for consumers to focus on data without concerning about parse logics in multi-cloud environments
- Access tokens/keys can be maintained at 1 location for cloud/non-cloud inter cloud applications thus providing greater control over access
- Features like request throttling help you control the hits any consumer makes to the cloud. (Unbounded requests can lead to request throttling at cloud end as well which can certainly cause production issues)
Some small but significant additions include -
- Support for adding default tags for resources
- Instant Audit Log for resource creation or deletion
- Notification can be given to stakeholder for infra changes (support for filtering events)
- Restrict creation of certain resources directly via API. Only whitelisted users can create resource without approval
-
Install pipenv
-
Create a virtualenv or let pipenv manage that for you. Install dependencies !!
-
Configure any local settings in
settings/local.py
-
Ready to launch django's runserver by hitting
python manage.py runserver
The project contains Containerfile. You can use any tool (like docker or buildah) to compile this file and make a container image
The Containerfile contains multiple targets for production and debug builds
buildah bud --squash --target=prod -t cloud-explorer .
buildah bud --target=debug -t cloud-explorer-debug .
Run the image using podman (or docker)
podman run cloud-explorer