2020-08-31 16:43:58 -05:00
# imgupload
2020-09-06 11:26:13 -05:00
2020-09-07 02:07:36 -05:00
<!-- - ![CodeFactor Grade](https://img.shields.io/codefactor/grade/github/BBaoVanC/imgupload/master?color=purple)
2020-09-06 11:26:13 -05:00
![GitHub repo size ](https://img.shields.io/github/repo-size/bbaovanc/imgupload?color=purple )
![GitHub All Releases ](https://img.shields.io/github/downloads/bbaovanc/imgupload/total?color=purple )
![GitHub issues ](https://img.shields.io/github/issues/bbaovanc/imgupload?color=purple )
![GitHub closed issues ](https://img.shields.io/github/issues-closed/bbaovanc/imgupload?color=purple )
2020-09-07 02:07:36 -05:00
![GitHub ](https://img.shields.io/github/license/bbaovanc/imgupload?color=purple )-->
2020-08-31 17:19:08 -05:00
2020-09-06 12:43:44 -05:00
## What is imgupload?
2020-08-31 19:12:39 -05:00
imgupload is a Flask + uWSGI application to serve as an all-purpose image/file uploader over POST requests.
2020-09-06 11:26:13 -05:00
---
2020-09-06 12:43:44 -05:00
## FAQ
**Where can I send bug reports and feature requests?**
2020-09-07 02:07:36 -05:00
You can create an issue [here ](https://git.bbaovanc.com/bbaovanc/imgupload/issues ).
2020-09-06 12:43:44 -05:00
**How do I use this program?**
See [Installation ](#installation )
**I want to make a pull request. Where should I do that?**
2020-09-07 02:07:36 -05:00
First, fork [this repository ](https://git.bbaovanc.com/bbaovanc/imgupload ). If you don't have an account on my Gitea site yet, you can either create one, or sign in using your GitHub account. Commit your changes to your fork, and then create a pull request.
2020-09-06 12:43:44 -05:00
---
## Installation
2020-09-08 00:39:48 -05:00
### Using uWSGI
2020-09-02 21:43:31 -05:00
2020-09-08 00:39:48 -05:00
Note: replace `www-data` with whatever user your webserver runs as.
1. Make /srv/imgupload: `sudo mkdir /srv/imgupload`
2. Change ownership of /srv/imgupload: `sudo chown www-data:www-data /srv/imgupload`
3. Enter www-data user: `sudo su www-data`
4. Change directories to /srv/imgupload: `cd /srv/imgupload`
5. Clone the repository: `git clone https://git.bbaovanc.com/bbaovanc/imgupload.git`
6. Enter the imgupload directory: `cd imgupload`
7. Create a virtualenv: `python3 -m venv env`
8. Enter the virtualenv: `source env/bin/activate`
9. Install dependencies: `python3 -m pip install -r requirements.txt`
10. Leave the www-data user: `exit`
11. Copy the default uWSGI configuration: `sudo cp /srv/imgupload/uwsgi.ini.default /etc/uwsgi/apps-available/imgupload.ini`
12. Modify `/etc/uwsgi/apps-available/imgupload.ini` to your preferences
13. Enable imgupload: `sudo ln -s /etc/uwsgi/apps-available/imgupload.ini /etc/uwsgi/apps-enabled/`
14. Restart uWSGI: `sudo systemctl restart uwsgi`
15. Set up your webserver to proxy the uwsgi.sock
Example NGINX location block:
```nginx
location /upload {
include uwsgi_params;
uwsgi_pass unix:/srv/imgupload/uwsgi.sock;
client_max_body_size 25M;
}
```
2020-09-06 11:26:13 -05:00
2020-09-08 00:39:48 -05:00
### Using Flask development server
2020-09-06 11:26:13 -05:00
2020-09-06 12:43:44 -05:00
2020-09-08 00:39:48 -05:00
#### Setup
2020-09-02 21:52:13 -05:00
2020-09-08 00:39:48 -05:00
```shell
$ git clone https://git.bbaovanc.com/bbaovanc/imgupload.git
$ cd imgupload
$ python3 -m venv env
$ source env/bin/activate
$ pip3 install -r requirements.txt
```
2020-09-02 21:43:31 -05:00
2020-09-08 00:39:48 -05:00
#### Run
2020-09-06 11:26:13 -05:00
2020-09-02 21:43:31 -05:00
```shell
$ export FLASK_APP=imgupload.py
$ flask run
```
2020-09-06 11:26:13 -05:00
---
## License
2020-09-07 02:07:36 -05:00
_imgupload_ is licensed under the GPLv3 license. For more information, please refer to [`LICENSE` ](https://git.bbaovanc.com/bbaovanc/imgupload/src/branch/master/LICENSE )