Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/eashish93/imgsquash

Simple image compression full website code written in node, react and next.js framework. Easy to deploy as a microservice.
https://github.com/eashish93/imgsquash

compression image-compressor image-processing nextjs nodejs react

Last synced: 3 months ago
JSON representation

Simple image compression full website code written in node, react and next.js framework. Easy to deploy as a microservice.

Awesome Lists containing this project

README

        

## SUMMARY
Image compression full stack website code. Contains both api service and frontend written in node, react and next.js framework.

### SCREENSHOTS
screen-one
screen-two
screen-three

### SETTING UP GOOGLE CLOUD STORAGE
1. Create a project on google cloud and add a free cloud storage bucket via this quickstart guide:
-
2. Authenticate using either `gcloud` command line tool ([download here](https://cloud.google.com/sdk/docs/downloads-interactive)) or set `GOOGLE_APPLICATION_CREDENTIALS` env variable with the service account file.
- Guide here:

### STARTING THE API SERVICE
1. Create `.env` file in the root of the folder with the following variables. See [dotenv](https://www.npmjs.com/package/dotenv) on how to add env variables.
- __API_VERSION__ : `1` (optional).
- __GC_STORAGE__ : `your-google-cloud-bucket-name`
- __DL_BASE_URL__ : `[YOUR-API-URL]/1/dl`
2. Do `npm install` to install all node modules for api.
3. Do `npm run dev` to start the dev server on `3000` port.
4. Do `npm start` for production

### STARTING THE FRONTEND
1. Do `npm install` to install all node modules for frontend.
2. Do `npm run dev` will start the webpack server on `3001` port.
3. Do `npm run build` and `npm start` to build and use the code in production.

### NOTES

1. Following programs are used for optimization
- mozjpeg (lossy jpeg compression)
- jpegtran (lossless jpeg compression)
- pngquant (lossy png compression)
- optipng (lossless png compression)
3. Current file size upload limit is 10MB.
4. API Routes.
[POST]
- `/image`: upload image(s) via file, URL, base64 or Binary.
- file: `file` or `base64` or `binary`.
- lossy: `Boolean` (default: false)
- `/url`: Compression direct image url.
- url: valid image url.
- `/zip`: Accepts list of files object as an array with (`id`, `size` and `name`) and send the zipped result.
- files: list of files object as an array.

[GET]
- `/dl/:id`: Generate download url of compressed image. Accept optional query `name`.


### LICENSE
MIT