Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/struckchure/file-storage-api
File Storage API acts as a simple version of any cloud storage bucket.
https://github.com/struckchure/file-storage-api
buckets django django-rest-framework docker python storage-api
Last synced: 3 months ago
JSON representation
File Storage API acts as a simple version of any cloud storage bucket.
- Host: GitHub
- URL: https://github.com/struckchure/file-storage-api
- Owner: struckchure
- Created: 2022-11-08T15:21:04.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2023-07-20T11:53:20.000Z (over 1 year ago)
- Last Synced: 2024-10-07T19:46:40.447Z (3 months ago)
- Topics: buckets, django, django-rest-framework, docker, python, storage-api
- Language: Python
- Homepage: https://file-storage-api.readthedocs.io/en/latest
- Size: 60.5 KB
- Stars: 9
- Watchers: 2
- Forks: 3
- Open Issues: 8
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# File Storage API
[![Docker Image CI](https://github.com/struckchure/file_storage_api/actions/workflows/docker-image.yml/badge.svg)](https://github.com/struckchure/file_storage_api/actions/workflows/docker-image.yml)
Rome wasn't built in a day, but `file_storage_api` was 😅
This is a simple API for storing files. It is designed to be used with the [File Storage Client](https://github.com/struckchure/file-storage-client).
It can also be used as a standalone API on RESTFul communications over HTTP/HTTPS. By default it runs on port `1276`
# Running image
To run the container, using `docker`. Pull from any registry, DockerHub or GitHub, both registries are linked to this repository and work exactly the same.
- DockerHub
```sh
$ docker pull struckchure/file_storage
$ docker run -p 1276:1276 -it struckchure/file_storage
```- GitHub
```sh
$ docker pull ghcr.io/struckchure/file_storage
$ docker run -p 1276:1276 -it ghcr.io/struckchure/file_storage
```# Running from source
To run the API from source, you need to have `python3` and `pip3` installed. Then you can install the dependencies and run the API.
```sh
$ git clone [email protected]:struckchure/file_storage_api.git
$ cd file_storage_api
$ pip3 install -r requirements.txt
$ python3 manage.py runserver 1276
```# Using the API
- `POST api/v1/files/` - Upload a file
Upload file using the key `file` in the request body.\
Example (using `curl`):```sh
$ curl -F "file=@/path/to/file" -X POST http://localhost:1276/api/v1/files/
```- `GET api/v1/files/` - Get a list of all files
List all files in the database (not sure if you want to do this, but it's there).\
Example (using `curl`):```sh
$ curl http://localhost:1276/api/v1/files/
```- `GET api/v1/files/` - Get a file by ID
Get a file by ID.\
Example (using `curl`):```sh
$ curl http://localhost:1276/api/v1/files/c678409202e12677e2c4/
```- `PUT api/v1/files/` - Update a file by ID
Update a file by ID.\
Example (using `curl`):```sh
$ curl -F "file=@/path/to/file" -X PUT http://localhost:1276/api/v1/files/c678409202e12677e2c4/
```- `DELETE api/v1/files/` - Delete a file by ID
Delete a file by ID.\
Example (using `curl`):```sh
$ curl -X DELETE http://localhost:1276/api/v1/files/c678409202e12677e2c4/
```