mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 22:40:14 -05:00
adding config flags to control all items mentioned in PRIVACY.md
closes #3241 - in config.js, the `privacy` attribute holds all privacy-related flags - `privacy.userTinfoil: true` disables everything (equivalent to setting all flags to false) - added helper function to core/server/config/index.js to checking privacy flags - added helper function to core/server/config/index.js to show warning about deprecated items
This commit is contained in:
parent
0a96351274
commit
3583515e44
8 changed files with 55 additions and 4 deletions
|
@ -19,6 +19,7 @@ config = {
|
|||
},
|
||||
debug: false
|
||||
},
|
||||
|
||||
server: {
|
||||
// Host to be passed to node's `net.Server#listen()`
|
||||
host: '127.0.0.1',
|
||||
|
|
|
@ -290,6 +290,43 @@ ConfigManager.prototype.validate = function () {
|
|||
return Promise.resolve(config);
|
||||
};
|
||||
|
||||
/**
|
||||
* Helper method for checking the state of a particular privacy flag
|
||||
* @param privacyFlag The flag to check
|
||||
* @returns {boolean}
|
||||
*/
|
||||
ConfigManager.prototype.isPrivacyDisabled = function (privacyFlag) {
|
||||
if (!this.privacy) {
|
||||
return false;
|
||||
}
|
||||
|
||||
if (this.privacy.useTinfoil === true) {
|
||||
return true;
|
||||
}
|
||||
|
||||
return this.privacy[privacyFlag] === false;
|
||||
};
|
||||
|
||||
/**
|
||||
* Check if any of the currently set config items are deprecated, and issues a warning.
|
||||
*/
|
||||
ConfigManager.prototype.checkDeprecated = function () {
|
||||
var deprecatedItems = ['updateCheck'],
|
||||
self = this;
|
||||
|
||||
_.each(deprecatedItems, function (item) {
|
||||
if (self.hasOwnProperty(item)) {
|
||||
var errorText = 'The configuration property [' + item.toString().bold + '] has been deprecated.',
|
||||
explinationText = 'This will be removed in a future version, please update your config.js file.',
|
||||
helpText = 'Please check http://support.ghost.org/config for the most up-to-date example.';
|
||||
|
||||
errors.logWarn(errorText, explinationText, helpText);
|
||||
}
|
||||
|
||||
});
|
||||
};
|
||||
|
||||
|
||||
if (testingEnvs.indexOf(process.env.NODE_ENV) > -1) {
|
||||
defaultConfig = require('../../../config.example')[process.env.NODE_ENV];
|
||||
}
|
||||
|
|
|
@ -2,6 +2,7 @@ var _ = require('lodash'),
|
|||
api = require('../api'),
|
||||
errors = require('../errors'),
|
||||
updateCheck = require('../update-check'),
|
||||
config = require('../config'),
|
||||
adminControllers;
|
||||
|
||||
adminControllers = {
|
||||
|
@ -12,7 +13,9 @@ adminControllers = {
|
|||
/*jslint unparam:true*/
|
||||
|
||||
function renderIndex() {
|
||||
res.render('default');
|
||||
res.render('default', {
|
||||
skip_google_fonts: config.isPrivacyDisabled('useGoogleFonts')
|
||||
});
|
||||
}
|
||||
|
||||
updateCheck().then(function () {
|
||||
|
|
|
@ -142,6 +142,8 @@ function init(options) {
|
|||
|
||||
// Load our config.js file from the local file system.
|
||||
return config.load(options.config).then(function () {
|
||||
return config.checkDeprecated();
|
||||
}).then(function () {
|
||||
// Make sure javascript files have been built via grunt concat
|
||||
return builtFilesExist();
|
||||
}).then(function () {
|
||||
|
|
|
@ -7,6 +7,7 @@ var _ = require('lodash'),
|
|||
crypto = require('crypto'),
|
||||
validator = require('validator'),
|
||||
validation = require('../data/validation'),
|
||||
config = require('../config'),
|
||||
|
||||
bcryptGenSalt = Promise.promisify(bcrypt.genSalt),
|
||||
bcryptHash = Promise.promisify(bcrypt.hash),
|
||||
|
@ -844,6 +845,10 @@ User = ghostBookshelf.Model.extend({
|
|||
'?d=404&s=250';
|
||||
|
||||
return new Promise(function (resolve) {
|
||||
if (config.isPrivacyDisabled('useGravatar')) {
|
||||
resolve(userData);
|
||||
}
|
||||
|
||||
http.get('http:' + gravatarUrl, function (res) {
|
||||
if (res.statusCode !== 404) {
|
||||
userData.image = gravatarUrl;
|
||||
|
|
|
@ -168,7 +168,8 @@ function updateCheck() {
|
|||
// 1. updateCheck is defined as false in config.js
|
||||
// 2. we've already done a check this session
|
||||
// 3. we're not in production or development mode
|
||||
if (config.updateCheck === false || _.indexOf(allowedCheckEnvironments, process.env.NODE_ENV) === -1) {
|
||||
//TODO: need to remove config.updateCheck in favor of config.privacy.updateCheck in future version (it is now deprecated)
|
||||
if (config.updateCheck === false || config.isPrivacyDisabled('useUpdateCheck') || _.indexOf(allowedCheckEnvironments, process.env.NODE_ENV) === -1) {
|
||||
// No update check
|
||||
return Promise.resolve();
|
||||
} else {
|
||||
|
|
|
@ -29,7 +29,9 @@
|
|||
<meta name="msapplication-square150x150logo" content="{{asset "img/medium.png" ghost="true"}}" />
|
||||
<meta name="msapplication-square310x310logo" content="{{asset "img/large.png" ghost="true"}}" />
|
||||
|
||||
<link rel="stylesheet" type="text/css" href="//fonts.googleapis.com/css?family=Open+Sans:400,300,700" />
|
||||
{{#unless skip_google_fonts}}
|
||||
<link rel="stylesheet" type="text/css" href="//fonts.googleapis.com/css?family=Open+Sans:400,300,700" />
|
||||
{{/unless}}
|
||||
<link rel="stylesheet" href="{{asset "css/ghost.min.css" ghost="true"}}" />
|
||||
</head>
|
||||
<body class="{{bodyClass}}" data-apps="{{apps}}" data-filestorage="{{file_storage}}" data-blogurl="{{blog_url}}">
|
||||
|
|
|
@ -17,7 +17,7 @@ function ping(post) {
|
|||
title = post.title;
|
||||
|
||||
// Only ping when in production and not a page
|
||||
if (process.env.NODE_ENV !== 'production' || post.page) {
|
||||
if (process.env.NODE_ENV !== 'production' || post.page || config.isPrivacyDisabled('useRpcPing')) {
|
||||
return;
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue