ghost-storage
is a Ghost Blog plugin used to store static files in other cloud storage services like Amazon S3 instead of local file system storage.
- Amazon S3 Storage
- Google Cloud Storage
- Generate Security Credentials in AWS console with
Access Key ID
andSecret Access Key
, credentials should be keep safe, otherwise can be used to access all AWS services by other users. - Create a bucket with a unique name and assign permission to yourself in order to upload, delete and view assets in bucket.
- Enable static site hosting and add policy below, so your bucket can be served as static site with read access to all users. For example, you can access your static files in browser with URL
example-bucket.s3-website-us-east-1.amazonaws.com
{
"Version":"2012-10-17",
"Statement":[{
"Sid":"PublicReadForGetBucketObjects",
"Effect":"Allow",
"Principal": "*",
"Action":["s3:GetObject"],
"Resource":["arn:aws:s3:::example-bucket/*"
]
}
]
}
In order to replace the storage module, the basic requirements are:
- Create a new folder inside
/content
called/storage
- Inside of
/storage
you need to create your new module - Your
config.js
file will need to be updated to provide config for your new storage module and set it as active.
- Get the name of bucket, subdomains of aws host path from AWS S3 console to update config file.
- In your
config.js
file, you'll need to add a new storage block to whichever environment you want to change:
production: {
"others": {},
"storage": {
"active": "ghost-storage",
"ghost-storage": {
"accessKeyId": "",
"secretAccessKey": "",
"bucket": "example_bucket",
"awsPath": "s3-website-us-east-1.amazonaws.com"
}
},
}
development: {
}
- Create
index.js
file with folder pathcontent/storage/ghost-storage/index.js
(manually create folder if not exist) and fill this file with content below
'use strict';
module.exports = require('ghost-storage').S3;
- Generate Security Credentials in Google API console with
Project ID
and downloadJSON key
file, credentials should be keep safe. - Create a new bucket with domain unique name and make it public to be readable to all visitors. Write down
bucket name
to be used later.
- Repeat most steps as the same in Amazon S3 Storage configuration.
- Put
key.json
file under the same directory asconfig.js
to be imported in Ghost configuration. - Update your
config.js
file, you'll need to add a new storage block to whichever environment you want to change:
production: {
"others": {},
"storage": {
"active": "ghost-storage",
"ghost-storage": {
projectId: '',
keyFilename: path.join(__dirname, './key.json'),
bucket: 'bucket name',
gcloudPath: 'storage.googleapis.com'
}
},
}
development: {
}
- Create
index.js
file with folder pathcontent/storage/ghost-storage/index.js
(manually create folder if not exist) and fill this file with content below.
'use strict';
module.exports = require('ghost-storage').Google;
If you are interested in this project and want to be collaborators to implement other cloud storage plugins, please send pull requests or shoot me a email.