Skip to content

Commit b45e5d6

Browse files
committed
Log objects rather than JSON stringified objects
1 parent 2561987 commit b45e5d6

File tree

3 files changed

+14
-10
lines changed

3 files changed

+14
-10
lines changed

spec/FileLoggerAdapter.spec.js

+3-3
Original file line numberDiff line numberDiff line change
@@ -62,7 +62,7 @@ describe('verbose logs', () => {
6262
level: 'verbose'
6363
});
6464
}).then((results) => {
65-
expect(results[1].message.includes('"password": "********"')).toEqual(true);
65+
expect(results[1].body.password).toEqual("********");
6666
var headers = {
6767
'X-Parse-Application-Id': 'test',
6868
'X-Parse-REST-API-Key': 'rest'
@@ -77,7 +77,7 @@ describe('verbose logs', () => {
7777
size: 100,
7878
level: 'verbose'
7979
}).then((results) => {
80-
expect(results[1].message.includes('password=********')).toEqual(true);
80+
expect(results[1].url.includes('password=********')).toEqual(true);
8181
done();
8282
});
8383
});
@@ -95,7 +95,7 @@ describe('verbose logs', () => {
9595
level: 'verbose'
9696
});
9797
}).then((results) => {
98-
expect(results[1].message.includes('"password": "pw"')).toEqual(true);
98+
expect(results[1].body.password).toEqual("pw");
9999
done();
100100
});
101101
});

src/PromiseRouter.js

+9-5
Original file line numberDiff line numberDiff line change
@@ -155,14 +155,18 @@ export default class PromiseRouter {
155155
function makeExpressHandler(promiseHandler) {
156156
return function(req, res, next) {
157157
try {
158-
log.verbose(req.method, maskSensitiveUrl(req), req.headers,
159-
JSON.stringify(maskSensitiveBody(req), null, 2));
158+
log.verbose('Got request', {
159+
method: req.method,
160+
url: maskSensitiveUrl(req),
161+
headers: req.headers,
162+
body: maskSensitiveBody(req)
163+
});
160164
promiseHandler(req).then((result) => {
161165
if (!result.response && !result.location && !result.text) {
162166
log.error('the handler did not include a "response" or a "location" field');
163167
throw 'control should not get here';
164168
}
165-
log.verbose(JSON.stringify(result, null, 2));
169+
log.verbose('Generated response', {result: result});
166170

167171
var status = result.status || 200;
168172
res.status(status);
@@ -186,11 +190,11 @@ function makeExpressHandler(promiseHandler) {
186190
}
187191
res.json(result.response);
188192
}, (e) => {
189-
log.verbose('error:', e);
193+
log.verbose('Error generating response', {error: e});
190194
next(e);
191195
});
192196
} catch (e) {
193-
log.verbose('exception:', e);
197+
log.verbose('Error handling request', {error: e});
194198
next(e);
195199
}
196200
}

src/index.js

+2-2
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
1-
import winston from 'winston';
21
import ParseServer from './ParseServer';
2+
import logger from './logger';
33
import S3Adapter from 'parse-server-s3-adapter'
44
import FileSystemAdapter from 'parse-server-fs-adapter'
55
import TestUtils from './TestUtils';
@@ -16,4 +16,4 @@ _ParseServer.createLiveQueryServer = ParseServer.createLiveQueryServer;
1616
let GCSAdapter = useExternal('GCSAdapter', 'parse-server-gcs-adapter');
1717

1818
export default ParseServer;
19-
export { S3Adapter, GCSAdapter, FileSystemAdapter, TestUtils, _ParseServer as ParseServer };
19+
export { S3Adapter, GCSAdapter, FileSystemAdapter, TestUtils, _ParseServer as ParseServer, logger };

0 commit comments

Comments
 (0)