Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jpmckinney/image-proxy
An image proxy using the Express Node.js framework
https://github.com/jpmckinney/image-proxy
Last synced: about 2 months ago
JSON representation
An image proxy using the Express Node.js framework
- Host: GitHub
- URL: https://github.com/jpmckinney/image-proxy
- Owner: jpmckinney
- License: mit
- Created: 2013-02-16T19:44:17.000Z (almost 12 years ago)
- Default Branch: master
- Last Pushed: 2018-07-12T18:37:36.000Z (over 6 years ago)
- Last Synced: 2024-10-14T12:16:42.448Z (2 months ago)
- Language: JavaScript
- Size: 3.58 MB
- Stars: 59
- Watchers: 6
- Forks: 29
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# Image Proxy
[![NPM version](https://badge.fury.io/js/image-proxy.svg)](https://badge.fury.io/js/image-proxy)
[![Build Status](https://secure.travis-ci.org/jpmckinney/image-proxy.png)](https://travis-ci.org/jpmckinney/image-proxy)
[![Dependency Status](https://david-dm.org/jpmckinney/image-proxy.svg)](https://david-dm.org/jpmckinney/image-proxy)
[![Coverage Status](https://coveralls.io/repos/jpmckinney/image-proxy/badge.png)](https://coveralls.io/r/jpmckinney/image-proxy)A simple Express app for proxying and manipulating images, specifically headshots.
The code is just over 100 lines, making it easy to tailor to your needs.
## Getting Started
First, [install the dependencies](https://github.com/aheckmann/gm#getting-started) for the `gm` package.
npm install
npm start
curl -I http://localhost:5000/http%3A%2F%2F1.gravatar.com%2Favatar%2F60f641dfbb4215f1f6d6c059eebf1848/240/80.jpgThe URL structure is `/:url/:width/:height.:extension?`. The `:url` parameter must be escaped/encoded. If the remote image's width or height is greater than the given `:width` or `:height`, it will be resized, maintaining aspect ratio, and cropped. If smaller, it will be padded with white pixels. If an optional `:extension` parameter is provided, the image will be transcoded to the corresponding file format. The equivalent ImageMagick command for the example URL above is:
convert input.jpg -thumbnail 240x80^> -gravity center -extent 240x80 output.jpg
The `Cache-Control` header sets a `max-age` of one year.
## Features
Image proxy:
* Supports HTTP and HTTPS
* Follows 301 and 302 redirects
* Sets a maximum timeout for the remote server
* Handles complex MIME types like `image/jpeg; charset=utf-8`
* Optional whitelisting using regular expressionsImage manipulation:
* Accepts a custom width and height, up to 1000x1000
* Resizes, centers and crops the image
* Optionally transcodes to another file formatHTTP server:
* No query string parameters (preferred by CloudFront)
* Adds a Cache-Control headerIf you need more features, see [node-imageable](https://github.com/sdepold/node-imageable) and [node-imageable-server](https://github.com/dawanda/node-imageable-server).
### Environment variables
* `DELAY`: The timeout delay in milliseconds, after which the proxy will respond with a HTTP 504 Gateway Timeout server error. Default: `5000`
* `WHITELIST`: A comma-separated list of domains to whitelist, e.g. `.gov,facebook.com`, which will be transformed into the regular expressions `/\.gov$/` and `/facebook\.com$/`.
* `PORT`: If running the server, changes the port on which it listens. Default: `5000`## Deployment
### Heroku
[![Deploy](https://www.herokucdn.com/deploy/button.png)](https://heroku.com/deploy)
git clone https://github.com/jpmckinney/image-proxy.git
heroku apps:create
heroku config:set NODE_ENV=production
git push heroku master
heroku apps:open### AWS CloudFront
Create a distribution and set the "Origin Domain Name" to the domain name of your Heroku app.
## Testing
npm test
## Acknowledgements
This project is inspired by [node-connect-image-proxy](https://github.com/mysociety/node-connect-image-proxy).
Copyright (c) 2013 James McKinney, released under the MIT license