#UPDATE Update version 0.2.2 for Ghost 0.6.0
This module allows you to store media file at Amazon S3 instead of storing at local machine, especially helpful for ghost blog hosted at heroku (no local storage). Work with latest version 0.6.0 of Ghost! (Use module version 0.1.7 for Ghost version < 0.6.0)
npm install --save ghost-s3-storage
Create index.js file with folder path 'content/storage/ghost-s3/index.js' (manually create folder if not exist)
'use strict';
module.exports = require('ghost-s3-storage');
Create new Amazon S3 bucket and new IAM User with permissions allowed to put and get object from that bucket. Remember saving ACCESS_KEY and ACCESS_SECRET_KEY.
Add storage
block to file config.js
in each environment as below:
storage: {
active: 'ghost-s3',
'ghost-s3': {
accessKeyId: 'Put_your_access_key_here',
secretAccessKey: 'Put_your_secret_key_here',
bucket: 'Put_your_bucket_name',
region: 'Put_your_bucket_region',
assetHost: 'Put_your_cdn_url*'
}
},
Note 1 You can use assetHost config to specify S3 bucket full-url in virtual host style, path style or custom domain (http://docs.aws.amazon.com/AmazonS3/latest/dev/VirtualHosting.html)
-
Virtual-host style example: 'https://blogthucdon24bucket.s3.amazonaws.com/2015/Feb/follow_your_dreams1-1424940431463.jpg'
-
Path style example: 'https://s3-ap-southeast-1.amazonaws.com/blogthucdon24bucket/2015/Feb/follow_your_dreams1-1424940431463.jpg'
Restart app then test upload new image in blog post. Image will be store at newly S3 bucket.
Copyright (c) 2015 Hoang Pham Huu phamhuuhoang@gmail.com
Released under the MIT license.