powr-sdk-api 1.3.3 → 1.3.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/middleware/request.js +55 -20
- package/package.json +1 -1
|
@@ -40,38 +40,73 @@ const requestHandler = (req, res, next) => {
|
|
|
40
40
|
res.error = (message, statusCode = 500, error = null) => {
|
|
41
41
|
// Extract error details for logging and response
|
|
42
42
|
let errorDetails = null;
|
|
43
|
+
let userFriendlyMessage = message;
|
|
43
44
|
if (error) {
|
|
44
45
|
// If error is an Error object, extract relevant properties
|
|
45
46
|
if (error instanceof Error) {
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
47
|
+
// For logging, include the stack trace
|
|
48
|
+
logger.error(message, {
|
|
49
|
+
statusCode,
|
|
50
|
+
requestId: req.requestId,
|
|
51
|
+
error: {
|
|
52
|
+
message: error.message,
|
|
53
|
+
stack: error.stack
|
|
54
|
+
}
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
// For response, only include the error message without stack
|
|
58
|
+
errorDetails = error.message;
|
|
59
|
+
|
|
60
|
+
// If no user-friendly message was provided, use a generic one
|
|
61
|
+
if (message === error.message || !message || message === '{}') {
|
|
62
|
+
userFriendlyMessage = 'An error occurred while processing your request';
|
|
63
|
+
}
|
|
50
64
|
} else if (typeof error === 'object') {
|
|
51
|
-
//
|
|
52
|
-
|
|
65
|
+
// Log the full error object
|
|
66
|
+
logger.error(message, {
|
|
67
|
+
statusCode,
|
|
68
|
+
requestId: req.requestId,
|
|
69
|
+
error
|
|
70
|
+
});
|
|
71
|
+
|
|
72
|
+
// For response, use the error message or a stringified version
|
|
73
|
+
errorDetails = error.message || JSON.stringify(error);
|
|
74
|
+
|
|
75
|
+
// If no user-friendly message was provided, use a generic one
|
|
76
|
+
if (!message || message === '{}') {
|
|
77
|
+
userFriendlyMessage = 'An error occurred while processing your request';
|
|
78
|
+
}
|
|
53
79
|
} else {
|
|
54
80
|
// If error is a primitive, convert to string
|
|
55
|
-
errorDetails =
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
81
|
+
errorDetails = String(error);
|
|
82
|
+
logger.error(message, {
|
|
83
|
+
statusCode,
|
|
84
|
+
requestId: req.requestId,
|
|
85
|
+
error: errorDetails
|
|
86
|
+
});
|
|
60
87
|
|
|
61
|
-
|
|
62
|
-
|
|
88
|
+
// If no user-friendly message was provided, use a generic one
|
|
89
|
+
if (!message || message === '{}') {
|
|
90
|
+
userFriendlyMessage = 'An error occurred while processing your request';
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
} else {
|
|
94
|
+
// Log without error details
|
|
95
|
+
logger.error(message, {
|
|
96
|
+
statusCode,
|
|
97
|
+
requestId: req.requestId
|
|
98
|
+
});
|
|
63
99
|
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
});
|
|
100
|
+
// If no user-friendly message was provided, use a generic one
|
|
101
|
+
if (!message || message === '{}') {
|
|
102
|
+
userFriendlyMessage = 'An error occurred while processing your request';
|
|
103
|
+
}
|
|
104
|
+
}
|
|
70
105
|
|
|
71
106
|
// Create response object
|
|
72
107
|
const response = {
|
|
73
108
|
success: false,
|
|
74
|
-
message:
|
|
109
|
+
message: userFriendlyMessage,
|
|
75
110
|
requestId: req.requestId
|
|
76
111
|
};
|
|
77
112
|
|