backend logging
This commit is contained in:
@@ -3,6 +3,7 @@ const router = express.Router();
|
||||
const { authenticateToken } = require("../middleware/auth");
|
||||
const rateLimiter = require("../middleware/rateLimiter");
|
||||
const googleMapsService = require("../services/googleMapsService");
|
||||
const logger = require("../utils/logger");
|
||||
|
||||
// Input validation middleware
|
||||
const validateInput = (req, res, next) => {
|
||||
@@ -34,8 +35,12 @@ const validateInput = (req, res, next) => {
|
||||
};
|
||||
|
||||
// Error handling middleware
|
||||
const handleServiceError = (error, res) => {
|
||||
console.error("Maps service error:", error.message);
|
||||
const handleServiceError = (error, res, req) => {
|
||||
const reqLogger = logger.withRequestId(req?.id);
|
||||
reqLogger.error("Maps service error", {
|
||||
error: error.message,
|
||||
stack: error.stack
|
||||
});
|
||||
|
||||
if (error.message.includes("API key not configured")) {
|
||||
return res.status(503).json({
|
||||
@@ -87,17 +92,16 @@ router.post(
|
||||
);
|
||||
|
||||
// Log request for monitoring (without sensitive data)
|
||||
console.log(
|
||||
`Places Autocomplete: user=${
|
||||
req.user?.id || "anonymous"
|
||||
}, query_length=${input.length}, results=${
|
||||
result.predictions?.length || 0
|
||||
}`
|
||||
);
|
||||
const reqLogger = logger.withRequestId(req.id);
|
||||
reqLogger.info("Places Autocomplete request", {
|
||||
userId: req.user?.id || "anonymous",
|
||||
queryLength: input.length,
|
||||
resultsCount: result.predictions?.length || 0
|
||||
});
|
||||
|
||||
res.json(result);
|
||||
} catch (error) {
|
||||
handleServiceError(error, res);
|
||||
handleServiceError(error, res, req);
|
||||
}
|
||||
}
|
||||
);
|
||||
@@ -127,15 +131,15 @@ router.post(
|
||||
const result = await googleMapsService.getPlaceDetails(placeId, options);
|
||||
|
||||
// Log request for monitoring
|
||||
console.log(
|
||||
`Place Details: user=${
|
||||
req.user?.id || "anonymous"
|
||||
}, placeId=${placeId.substring(0, 10)}...`
|
||||
);
|
||||
const reqLogger = logger.withRequestId(req.id);
|
||||
reqLogger.info("Place Details request", {
|
||||
userId: req.user?.id || "anonymous",
|
||||
placeIdPrefix: placeId.substring(0, 10) + "..."
|
||||
});
|
||||
|
||||
res.json(result);
|
||||
} catch (error) {
|
||||
handleServiceError(error, res);
|
||||
handleServiceError(error, res, req);
|
||||
}
|
||||
}
|
||||
);
|
||||
@@ -165,15 +169,15 @@ router.post(
|
||||
const result = await googleMapsService.geocodeAddress(address, options);
|
||||
|
||||
// Log request for monitoring
|
||||
console.log(
|
||||
`Geocoding: user=${req.user?.id || "anonymous"}, address_length=${
|
||||
address.length
|
||||
}`
|
||||
);
|
||||
const reqLogger = logger.withRequestId(req.id);
|
||||
reqLogger.info("Geocoding request", {
|
||||
userId: req.user?.id || "anonymous",
|
||||
addressLength: address.length
|
||||
});
|
||||
|
||||
res.json(result);
|
||||
} catch (error) {
|
||||
handleServiceError(error, res);
|
||||
handleServiceError(error, res, req);
|
||||
}
|
||||
}
|
||||
);
|
||||
|
||||
Reference in New Issue
Block a user