mirror of
https://github.com/NodeBB/NodeBB.git
synced 2025-10-26 16:46:12 +01:00
refactor: remove jshint, remove async.parallel
This commit is contained in:
@@ -1,84 +0,0 @@
|
|||||||
{
|
|
||||||
"maxerr" : 50, // {int} Maximum error before stopping
|
|
||||||
|
|
||||||
"esversion": 9,
|
|
||||||
|
|
||||||
// Enforcing
|
|
||||||
"bitwise" : true, // true: Prohibit bitwise operators (&, |, ^, etc.)
|
|
||||||
"camelcase" : false, // true: Identifiers must be in camelCase
|
|
||||||
"curly" : true, // true: Require {} for every new block or scope
|
|
||||||
"eqeqeq" : true, // true: Require triple equals (===) for comparison
|
|
||||||
"forin" : true, // true: Require filtering for..in loops with obj.hasOwnProperty()
|
|
||||||
"immed" : false, // true: Require immediate invocations to be wrapped in parens e.g. `(function () { } ());`
|
|
||||||
"indent" : 4, // {int} Number of spaces to use for indentation
|
|
||||||
"latedef" : false, // true: Require variables/functions to be defined before being used
|
|
||||||
"newcap" : false, // true: Require capitalization of all constructor functions e.g. `new F()`
|
|
||||||
"noarg" : true, // true: Prohibit use of `arguments.caller` and `arguments.callee`
|
|
||||||
"noempty" : true, // true: Prohibit use of empty blocks
|
|
||||||
"nonew" : false, // true: Prohibit use of constructors for side-effects (without assignment)
|
|
||||||
"plusplus" : false, // true: Prohibit use of `++` & `--`
|
|
||||||
"quotmark" : false, // Quotation mark consistency:
|
|
||||||
// false : do nothing (default)
|
|
||||||
// true : ensure whatever is used is consistent
|
|
||||||
// "single" : require single quotes
|
|
||||||
// "double" : require double quotes
|
|
||||||
"undef" : true, // true: Require all non-global variables to be declared (prevents global leaks)
|
|
||||||
"unused" : true, // true: Require all defined variables be used
|
|
||||||
"strict" : true, // true: Requires all functions run in ES5 Strict Mode
|
|
||||||
"trailing" : false, // true: Prohibit trailing whitespaces
|
|
||||||
"maxparams" : false, // {int} Max number of formal params allowed per function
|
|
||||||
"maxdepth" : false, // {int} Max depth of nested blocks (within functions)
|
|
||||||
"maxstatements" : false, // {int} Max number statements per function
|
|
||||||
"maxcomplexity" : false, // {int} Max cyclomatic complexity per function
|
|
||||||
"maxlen" : false, // {int} Max number of characters per line
|
|
||||||
|
|
||||||
// Relaxing
|
|
||||||
"asi" : false, // true: Tolerate Automatic Semicolon Insertion (no semicolons)
|
|
||||||
"boss" : false, // true: Tolerate assignments where comparisons would be expected
|
|
||||||
"debug" : false, // true: Allow debugger statements e.g. browser breakpoints.
|
|
||||||
"eqnull" : false, // true: Tolerate use of `== null`
|
|
||||||
"es5" : false, // true: Allow ES5 syntax (ex: getters and setters)
|
|
||||||
"esnext" : false, // true: Allow ES.next (ES6) syntax (ex: `const`)
|
|
||||||
"moz" : false, // true: Allow Mozilla specific syntax (extends and overrides esnext features)
|
|
||||||
// (ex: `for each`, multiple try/catch, function expression…)
|
|
||||||
"evil" : false, // true: Tolerate use of `eval` and `new Function()`
|
|
||||||
"expr" : false, // true: Tolerate `ExpressionStatement` as Programs
|
|
||||||
"funcscope" : false, // true: Tolerate defining variables inside control statements"
|
|
||||||
"globalstrict" : true, // true: Allow global "use strict" (also enables 'strict')
|
|
||||||
"iterator" : false, // true: Tolerate using the `__iterator__` property
|
|
||||||
"lastsemic" : false, // true: Tolerate omitting a semicolon for the last statement of a 1-line block
|
|
||||||
"laxbreak" : false, // true: Tolerate possibly unsafe line breakings
|
|
||||||
"laxcomma" : false, // true: Tolerate comma-first style coding
|
|
||||||
"loopfunc" : false, // true: Tolerate functions being defined in loops
|
|
||||||
"multistr" : false, // true: Tolerate multi-line strings
|
|
||||||
"proto" : false, // true: Tolerate using the `__proto__` property
|
|
||||||
"scripturl" : false, // true: Tolerate script-targeted URLs
|
|
||||||
"smarttabs" : false, // true: Tolerate mixed tabs/spaces when used for alignment
|
|
||||||
"shadow" : false, // true: Allows re-define variables later in code e.g. `var x=1; x=2;`
|
|
||||||
"sub" : false, // true: Tolerate using `[]` notation when it can still be expressed in dot notation
|
|
||||||
"supernew" : false, // true: Tolerate `new function () { ... };` and `new Object;`
|
|
||||||
"validthis" : false, // true: Tolerate using this in a non-constructor function
|
|
||||||
|
|
||||||
"globals": {
|
|
||||||
"app": true,
|
|
||||||
"io": true,
|
|
||||||
"socket": true,
|
|
||||||
"ajaxify": true,
|
|
||||||
"config": true,
|
|
||||||
"utils": true,
|
|
||||||
"overrides": true,
|
|
||||||
"componentHandler": true,
|
|
||||||
"templates": true,
|
|
||||||
"Visibility": true,
|
|
||||||
"Tinycon": true,
|
|
||||||
"require": true,
|
|
||||||
"define": true,
|
|
||||||
"ace": true,
|
|
||||||
"Sortable": true,
|
|
||||||
"Slideout": true,
|
|
||||||
"NProgress": true
|
|
||||||
},
|
|
||||||
|
|
||||||
"jquery": true,
|
|
||||||
"browser": true
|
|
||||||
}
|
|
||||||
@@ -1,13 +1,13 @@
|
|||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
const async = require('async');
|
|
||||||
const analytics = require('../../analytics');
|
const analytics = require('../../analytics');
|
||||||
|
const utils = require('../../utils');
|
||||||
|
|
||||||
const Analytics = module.exports;
|
const Analytics = module.exports;
|
||||||
|
|
||||||
Analytics.get = function (socket, data, callback) {
|
Analytics.get = async function (socket, data) {
|
||||||
if (!data || !data.graph || !data.units) {
|
if (!data || !data.graph || !data.units) {
|
||||||
return callback(new Error('[[error:invalid-data]]'));
|
throw new Error('[[error:invalid-data]]');
|
||||||
}
|
}
|
||||||
|
|
||||||
// Default returns views from past 24 hours, by hour
|
// Default returns views from past 24 hours, by hour
|
||||||
@@ -20,30 +20,17 @@ Analytics.get = function (socket, data, callback) {
|
|||||||
}
|
}
|
||||||
const getStats = data.units === 'days' ? analytics.getDailyStatsForSet : analytics.getHourlyStatsForSet;
|
const getStats = data.units === 'days' ? analytics.getDailyStatsForSet : analytics.getHourlyStatsForSet;
|
||||||
if (data.graph === 'traffic') {
|
if (data.graph === 'traffic') {
|
||||||
async.parallel({
|
const result = await utils.promiseParallel({
|
||||||
uniqueVisitors: function (next) {
|
uniqueVisitors: getStats('analytics:uniquevisitors', data.until || Date.now(), data.amount),
|
||||||
getStats('analytics:uniquevisitors', data.until || Date.now(), data.amount, next);
|
pageviews: getStats('analytics:pageviews', data.until || Date.now(), data.amount),
|
||||||
},
|
pageviewsRegistered: getStats('analytics:pageviews:registered', data.until || Date.now(), data.amount),
|
||||||
pageviews: function (next) {
|
pageviewsGuest: getStats('analytics:pageviews:guest', data.until || Date.now(), data.amount),
|
||||||
getStats('analytics:pageviews', data.until || Date.now(), data.amount, next);
|
pageviewsBot: getStats('analytics:pageviews:bot', data.until || Date.now(), data.amount),
|
||||||
},
|
summary: analytics.getSummary(),
|
||||||
pageviewsRegistered: function (next) {
|
|
||||||
getStats('analytics:pageviews:registered', data.until || Date.now(), data.amount, next);
|
|
||||||
},
|
|
||||||
pageviewsGuest: function (next) {
|
|
||||||
getStats('analytics:pageviews:guest', data.until || Date.now(), data.amount, next);
|
|
||||||
},
|
|
||||||
pageviewsBot: function (next) {
|
|
||||||
getStats('analytics:pageviews:bot', data.until || Date.now(), data.amount, next);
|
|
||||||
},
|
|
||||||
summary: function (next) {
|
|
||||||
analytics.getSummary(next);
|
|
||||||
},
|
|
||||||
}, (err, data) => {
|
|
||||||
data.pastDay = data.pageviews.reduce((a, b) => parseInt(a, 10) + parseInt(b, 10));
|
|
||||||
const last = data.pageviews.length - 1;
|
|
||||||
data.pageviews[last] = parseInt(data.pageviews[last], 10) + analytics.getUnwrittenPageviews();
|
|
||||||
callback(err, data);
|
|
||||||
});
|
});
|
||||||
|
result.pastDay = result.pageviews.reduce((a, b) => parseInt(a, 10) + parseInt(b, 10));
|
||||||
|
const last = result.pageviews.length - 1;
|
||||||
|
result.pageviews[last] = parseInt(result.pageviews[last], 10) + analytics.getUnwrittenPageviews();
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user