- 18 Dec 2023
- 2 Minutes to read
- Print
- PDF
How do I use Django with Wasabi S3 ?
- Updated on 18 Dec 2023
- 2 Minutes to read
- Print
- PDF
Django is validated to use with Wasabi S3 storage. It is a web framework designed to create websites using python.
Here's how you can design a basic web framework in Django:
Start by installing Django and set up a project
$ pip install django
To confirm your installation was successful, run the following command and you should see available sub-commands
$ django-admin
Type 'django-admin help ' for help on a specific subcommand.
Available subcommands:
[django]
check
compilemessages
createcachetable
dbshell
diffsettings
dumpdata
flush
inspectdb
loaddata
makemessages
makemigrations
migrate
runserver
sendtestemail
shell
showmigrations
sqlflush
sqlmigrate
sqlsequencereset
squashmigrations
startapp
startproject
test
testserver
To create a new project, you can use "startproject" command
$ django-admin startproject
This will automatically create the basic Django framework. Navigate inside your project where "manage.py" file has been created and use the following command to run the server
$ python manage.py runserver
You will see the below output which indicates your server is now running on port 8000
data:image/s3,"s3://crabby-images/672b1/672b153201e7499edb559573405d9df11d49805e" alt="Screen_Shot_2020-08-09_at_9.56.14_PM.png"
If you go to port 8000 on your web browser, you will see Django server running on your system
data:image/s3,"s3://crabby-images/b2d69/b2d69394f110661169a06b125da3e3b683ef8163" alt="Screen_Shot_2020-08-09_at_9.59.19_PM.png".png)
Here's how you can allow your Django project to communicate with Wasabi S3 storage
Install django-storages
$ pip install django-storages
Install boto3 library
$ pip install boto3
Add "storages" to your INSTALLED_APPS inside the "settings.py" module as shown below:
data:image/s3,"s3://crabby-images/eff1e/eff1e8e8488b2793914be9e550f47e98d7dbdfd7" alt="Screen_Shot_2020-08-11_at_11.39.43_PM.png"
Configure "settings.py" module to support S3 backend as documented here
Below is an example of a config that would allow your Django web application to communicate with Wasabi, please make sure to use your own details
AWS_ACCESS_KEY_ID = 'Wasabi-Access-Key'
AWS_SECRET_ACCESS_KEY = 'Wasabi-Secret-Key'
AWS_STORAGE_BUCKET_NAME = 'Wasabi-Bucket-Name'
AWS_S3_ENDPOINT_URL = 'https://s3.us-east-2.wasabisys.com'
This code example discusses the use of Wasabi's us-east-2 storage region. To use other Wasabi storage regions, please use the appropriate Wasabi service URL as described here.
data:image/s3,"s3://crabby-images/e127b/e127bdbc2cb18716afc5cd809be3d908e9637816" alt="Screen_Shot_2020-08-11_at_11.41.06_PM.png".png)
You can design and let Django put your static assets in your Wasabi bucket so that you can connect it directly to your deployment script
$ python manage.py collectstatic
data:image/s3,"s3://crabby-images/dccda/dccdab0c37f90bbc1fe554cc41b3eec9a51cbf8b" alt="Screen_Shot_2020-08-11_at_11.25.47_PM.png".png)
You can see that those files are now on Wasabi Bucket and can be interacted with your framework from there directly
data:image/s3,"s3://crabby-images/e2543/e2543d29dff4f3f4c98edd9a3552980c6b2ea54b" alt="Screen_Shot_2020-08-12_at_12.21.26_AM.png"
NOTE:
The above example is only a sample to illustrate what settings need to be done to communicate with Wasabi Storage. We expect users to build & develop their own Django framework application as per their requirement(s) and use the above settings to configure the S3 storage library
If you are deploying your application on a server that would require cross-origin resource sharing (CORS) ability, it will not work with Wasabi S3 as we currently do not support this feature. Please refer to this document for more information.