A lightweight Node.js client for the Tinify API, used for tinypng API and TinyJPG. This library lets you intelligently compress, resize, convert, and store images (AVIF, WebP, JPEG, PNG) with minimal effort. Read more at http://tinify.com.
- Compress and optimize images in AVIF, WebP, JPEG, and PNG formats
- Resize with intelligent cropping
- Convert between formats
- Preserve metadata (copyright, GPS, creation time)
- Upload directly to Amazon S3, Google Cloud Storage, or custom S3/Azure storage
Go to the full documentation for the Node.js client.
Install the API client via NPM:
npm install tinify
Or add this to your package.json
:
{
"dependencies": {
"tinify": "*"
}
}
const tinify = require("tinify");
tinify.key = "YOUR_API_KEY";
// Basic from file system
tinify.fromFile("unoptimized.png").toFile("optimized.png");
// From URL
tinify.fromUrl("https://tinypng.com/images/panda-happy.png")
.toFile("optimized.png");
// Resize
tinify.fromFile("unoptimized.png").resize({
method: "cover",
width: 150,
height: 100
}).toFile("thumbnail.jpg");
// Convert format
tinify.fromFile("photo.jpg").convert({ type: ["image/webp", "image/png"] })
.result().extension().then(ext => {
return tinify.fromFile("photo.jpg").toFile("photo." + ext);
});
// Preserve metadata
tinify.fromFile("original.jpg")
.preserve("copyright", "location", "creation")
.toFile("with-meta.jpg");
// Store to Amazon S3
tinify.fromFile("upload.jpg").store({
service: "s3",
aws_access_key_id: "KEY",
aws_secret_access_key: "SECRET",
region: "us-west-1",
path: "bucket-name/images/upload.jpg"
});
npm install
npm test
npm install
TINIFY_KEY=$YOUR_API_KEY npm run integration
$ docker run --rm -it -v ~/.mitmproxy:/home/mitmproxy/.mitmproxy -p 8080:8080 mitmproxy/mitmproxy mitmproxy --listen-host 0.0.0.0
$ TINIFY_PROXY=http://172.17.0.3:8080 npm run integration
This software is licensed under the MIT License. View the license.