Skip to content

Commit f4f7458

Browse files
committed
Expose controller instead of adapter, reduces method requirements for adapter
1 parent c09bcf4 commit f4f7458

File tree

8 files changed

+38
-48
lines changed

8 files changed

+38
-48
lines changed

spec/WinstonLoggerAdapter.spec.js

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -8,7 +8,7 @@ describe('info logs', () => {
88

99
it("Verify INFO logs", (done) => {
1010
var winstonLoggerAdapter = new WinstonLoggerAdapter();
11-
winstonLoggerAdapter.info('testing info logs', () => {
11+
winstonLoggerAdapter.log('info', 'testing info logs', () => {
1212
winstonLoggerAdapter.query({
1313
from: new Date(Date.now() - 500),
1414
size: 100,
@@ -29,7 +29,7 @@ describe('info logs', () => {
2929
describe('error logs', () => {
3030
it("Verify ERROR logs", (done) => {
3131
var winstonLoggerAdapter = new WinstonLoggerAdapter();
32-
winstonLoggerAdapter.error('testing error logs', () => {
32+
winstonLoggerAdapter.log('error', 'testing error logs', () => {
3333
winstonLoggerAdapter.query({
3434
from: new Date(Date.now() - 500),
3535
size: 100,

src/Adapters/Logger/LoggerAdapter.js

Lines changed: 1 addition & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -4,25 +4,12 @@
44
//
55
// Adapter classes must implement the following functions:
66
// * log() {}
7-
// * error() {}
8-
// * warn() {}
9-
// * info() {}
10-
// * verbose() {}
11-
// * debug() {}
12-
// * silly() {}
137
// * query(options, callback) /* optional */
14-
// * configureLogger(options)
158
// Default is WinstonLoggerAdapter.js
169

1710
export class LoggerAdapter {
1811
constructor(options) {}
19-
log() {}
20-
error() {}
21-
warn() {}
22-
info() {}
23-
verbose() {}
24-
debug() {}
25-
silly() {}
12+
log(level, message, /* meta */) {}
2613
}
2714

2815
export default LoggerAdapter;

src/Adapters/Logger/WinstonLoggerAdapter.js

Lines changed: 1 addition & 25 deletions
Original file line numberDiff line numberDiff line change
@@ -15,33 +15,9 @@ export class WinstonLoggerAdapter extends LoggerAdapter {
1515
configureLogger(options);
1616
}
1717
}
18-
19-
error() {
20-
return logger.error.apply(undefined, arguments);
21-
}
22-
23-
warn() {
24-
return logger.warn.apply(undefined, arguments);
25-
}
26-
27-
info() {
28-
return logger.info.apply(undefined, arguments);
29-
}
30-
31-
verbose() {
32-
return logger.verbose.apply(undefined, arguments);
33-
}
34-
35-
debug() {
36-
return logger.debug.apply(undefined, arguments);
37-
}
38-
39-
silly() {
40-
return logger.silly.apply(undefined, arguments);
41-
}
4218

4319
log() {
44-
return logger.log.apply(undefined, arguments);
20+
return logger.log.apply(logger, arguments);
4521
}
4622

4723
addTransport(transport) {

src/Controllers/DatabaseController.js

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -878,6 +878,8 @@ DatabaseController.prototype.addPointerPermissions = function(schema, className,
878878
}
879879
}
880880

881+
// TODO: create indexes on first creation of a _User object. Otherwise it's impossible to
882+
// have a Parse app without it having a _User collection.
881883
DatabaseController.prototype.performInitizalization = function() {
882884
const requiredUserFields = { fields: { ...SchemaController.defaultColumns._Default, ...SchemaController.defaultColumns._User } };
883885

src/Controllers/LoggerController.js

Lines changed: 28 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -16,7 +16,35 @@ export const LogOrder = {
1616
}
1717

1818
export class LoggerController extends AdaptableController {
19+
20+
log(level, args) {
21+
args = [].concat(level, [...args]);
22+
this.adapter.log.apply(this.adapter, args);
23+
}
24+
25+
info() {
26+
return this.log('info', arguments);
27+
}
28+
29+
error() {
30+
return this.log('error', arguments);
31+
}
32+
33+
warn() {
34+
return this.log('warn', arguments);
35+
}
1936

37+
verbose() {
38+
return this.log('verbose', arguments);
39+
}
40+
41+
debug() {
42+
return this.log('debug', arguments);
43+
}
44+
45+
silly() {
46+
return this.log('silly', arguments);
47+
}
2048
// check that date input is valid
2149
static validDateTime(date) {
2250
if (!date) {

src/ParseServer.js

Lines changed: 2 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -175,9 +175,6 @@ class ParseServer {
175175
const pushControllerAdapter = loadAdapter(push && push.adapter, ParsePushAdapter, push || {});
176176

177177
const loggerControllerAdapter = loadAdapter(loggerAdapter, WinstonLoggerAdapter, { jsonLogs, logsFolder, verbose, logLevel, silent });
178-
179-
logging.setLogger(loggerControllerAdapter);
180-
181178
const emailControllerAdapter = loadAdapter(emailAdapter);
182179
const cacheControllerAdapter = loadAdapter(cacheAdapter, InMemoryCacheAdapter, {appId: appId});
183180
const analyticsControllerAdapter = loadAdapter(analyticsAdapter, AnalyticsAdapter);
@@ -194,8 +191,8 @@ class ParseServer {
194191
const hooksController = new HooksController(appId, databaseController, webhookKey);
195192
const analyticsController = new AnalyticsController(analyticsControllerAdapter);
196193

197-
// TODO: create indexes on first creation of a _User object. Otherwise it's impossible to
198-
// have a Parse app without it having a _User collection.
194+
logging.setLogger(loggerController);
195+
199196
const dbInitPromise = databaseController.performInitizalization();
200197

201198
AppCache.put(appId, {

src/Routers/FunctionsRouter.js

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -65,7 +65,7 @@ export class FunctionsRouter extends PromiseRouter {
6565
master: req.auth && req.auth.isMaster,
6666
user: req.auth && req.auth.user,
6767
installationId: req.info.installationId,
68-
log: req.config.loggerController && req.config.loggerController.adapter,
68+
log: req.config.loggerController,
6969
headers: req.headers
7070
};
7171

src/triggers.js

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -102,7 +102,7 @@ export function getRequestObject(triggerType, auth, parseObject, originalParseOb
102102
triggerName: triggerType,
103103
object: parseObject,
104104
master: false,
105-
log: config.loggerController && config.loggerController.adapter
105+
log: config.loggerController
106106
};
107107

108108
if (originalParseObject) {

0 commit comments

Comments
 (0)