2019-09-26 06:03:56 -04:00
|
|
|
#!/usr/bin/env node
|
|
|
|
// Ghost Configuration for Heroku
|
|
|
|
|
|
|
|
var fs = require('fs');
|
|
|
|
var path = require('path');
|
|
|
|
var url = require('url');
|
|
|
|
|
|
|
|
var envValues = require('./common/env-values');
|
|
|
|
var appRoot = path.join(__dirname, '..');
|
|
|
|
|
|
|
|
function createConfig() {
|
|
|
|
var fileStorage, storage;
|
|
|
|
|
|
|
|
if (!!process.env.S3_ACCESS_KEY_ID) {
|
|
|
|
fileStorage = true
|
|
|
|
storage = {
|
|
|
|
active: 's3',
|
|
|
|
's3': {
|
|
|
|
accessKeyId: process.env.S3_ACCESS_KEY_ID,
|
|
|
|
secretAccessKey: process.env.S3_ACCESS_SECRET_KEY,
|
|
|
|
bucket: process.env.S3_BUCKET_NAME,
|
|
|
|
region: process.env.S3_BUCKET_REGION,
|
|
|
|
assetHost: process.env.S3_ASSET_HOST_URL
|
|
|
|
}
|
|
|
|
}
|
2019-09-26 08:38:10 -04:00
|
|
|
} else if (!!process.env.WEBDAV_SERVER_URL){
|
|
|
|
fileStorage = true
|
|
|
|
storage = {
|
|
|
|
'active': 'webdav',
|
|
|
|
'webdav': {
|
|
|
|
'url': process.env.WEBDAV_SERVER_URL,
|
|
|
|
'username': process.env.WEBDAV_USERNAME,
|
|
|
|
'password': process.env.WEBDAV_PASSWORD,
|
|
|
|
'pathPrefix': process.env.WEBDAV_PATH_PREFIX,
|
|
|
|
'storagePathPrefix': process.env.WEBDAV_STORAGE_PATH_PREFIX
|
|
|
|
}
|
|
|
|
}
|
2019-09-26 06:03:56 -04:00
|
|
|
} else if (!!process.env.BUCKETEER_AWS_ACCESS_KEY_ID) {
|
|
|
|
fileStorage = true
|
|
|
|
storage = {
|
|
|
|
active: 's3',
|
|
|
|
's3': {
|
|
|
|
accessKeyId: process.env.BUCKETEER_AWS_ACCESS_KEY_ID,
|
|
|
|
secretAccessKey: process.env.BUCKETEER_AWS_SECRET_ACCESS_KEY,
|
|
|
|
bucket: process.env.BUCKETEER_BUCKET_NAME,
|
|
|
|
region: process.env.S3_BUCKET_REGION,
|
|
|
|
assetHost: process.env.S3_ASSET_HOST_URL
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else if (!!process.env.CLOUDINARY_URL) {
|
|
|
|
fileStorage = true
|
|
|
|
storage = {
|
|
|
|
active: 'ghost-storage-cloudinary',
|
|
|
|
'ghost-storage-cloudinary': {
|
|
|
|
useDatedFolder: false,
|
|
|
|
upload: {
|
|
|
|
use_filename: true,
|
|
|
|
unique_filename: false,
|
|
|
|
overwrite: false,
|
|
|
|
folder: "ghost-blog-images",
|
|
|
|
tags: ["blog"]
|
|
|
|
},
|
|
|
|
fetch: {
|
|
|
|
quality: "auto",
|
|
|
|
secure: true,
|
|
|
|
cdn_subdomain: true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
fileStorage = false
|
|
|
|
storage = {}
|
|
|
|
}
|
|
|
|
|
|
|
|
config = {
|
|
|
|
url: process.env.APP_PUBLIC_URL,
|
|
|
|
logging: {
|
|
|
|
level: "info",
|
|
|
|
transports: ["stdout"]
|
|
|
|
},
|
|
|
|
mail: {
|
|
|
|
transport: 'SMTP',
|
|
|
|
options: {
|
|
|
|
service: 'Mailgun',
|
|
|
|
auth: {
|
|
|
|
user: process.env.MAILGUN_SMTP_LOGIN,
|
|
|
|
pass: process.env.MAILGUN_SMTP_PASSWORD
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
fileStorage: fileStorage,
|
|
|
|
storage: storage,
|
|
|
|
database: {
|
|
|
|
client: 'mysql',
|
2019-09-26 12:01:19 -04:00
|
|
|
// connection: getMysqlConfig(envValues.mysqlDatabaseUrl),
|
2019-09-26 12:02:30 -04:00
|
|
|
connection: getMysqlConfig(process.env.JAWSDB_URL),
|
2019-09-26 06:03:56 -04:00
|
|
|
pool: { min: 0, max: 5 },
|
|
|
|
debug: false
|
|
|
|
},
|
|
|
|
server: {
|
|
|
|
host: '0.0.0.0',
|
|
|
|
port: process.env.PORT
|
|
|
|
},
|
|
|
|
paths: {
|
|
|
|
contentPath: path.join(appRoot, '/content/')
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
return config;
|
|
|
|
}
|
|
|
|
|
|
|
|
function getMysqlConfig(connectionUrl) {
|
2019-09-26 12:10:34 -04:00
|
|
|
|
2019-09-26 06:03:56 -04:00
|
|
|
if (connectionUrl == null) {
|
|
|
|
return {};
|
|
|
|
}
|
|
|
|
|
2019-09-26 12:10:34 -04:00
|
|
|
/*
|
2019-09-26 06:03:56 -04:00
|
|
|
var dbConfig = url.parse(connectionUrl);
|
|
|
|
if (dbConfig == null) {
|
|
|
|
return {};
|
|
|
|
}
|
|
|
|
|
|
|
|
var dbAuth = dbConfig.auth ? dbConfig.auth.split(':') : [];
|
|
|
|
var dbUser = dbAuth[0];
|
|
|
|
var dbPassword = dbAuth[1];
|
|
|
|
|
|
|
|
if (dbConfig.pathname == null) {
|
|
|
|
var dbName = 'ghost';
|
|
|
|
} else {
|
|
|
|
var dbName = dbConfig.pathname.split('/')[1];
|
|
|
|
}
|
|
|
|
|
|
|
|
var dbConnection = {
|
|
|
|
host: dbConfig.hostname,
|
|
|
|
port: dbConfig.port || '3306',
|
|
|
|
user: dbUser,
|
|
|
|
password: dbPassword,
|
|
|
|
database: dbName
|
|
|
|
};
|
|
|
|
return dbConnection;
|
2019-09-26 12:10:34 -04:00
|
|
|
*/
|
|
|
|
|
|
|
|
var dbConnection = {
|
|
|
|
host: process.env.DB_URL,
|
|
|
|
user: process.env.DB_USERNAME,
|
|
|
|
password: process.env.DB_PASSWORD,
|
|
|
|
database: process.env.DB_NAME,
|
|
|
|
charset: 'utf8'
|
|
|
|
};
|
|
|
|
|
|
|
|
return dbConnection;
|
|
|
|
|
2019-09-26 06:03:56 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
var configContents = JSON.stringify(createConfig(), null, 2);
|
|
|
|
fs.writeFileSync(path.join(appRoot, 'config.production.json'), configContents);
|