GoogleCloudPlatform / stackdriver-errors-js

Client-side JavaScript exception reporting library for Cloud Error Reporting
https://cloud.google.com/error-reporting/
Apache License 2.0
362 stars 54 forks source link

AppEngine Standard - Report API #62

Open patelnav opened 5 years ago

patelnav commented 5 years ago

Hello there,

As other issues have mentioned, there are some security considerations with regards to hitting the stackdriver API with an API Key. I opted to implement a backend service to forward messages along to the Report API.

AppEngine standard is configured to automatically send log messages to stackdriver, which is super convenient. Unfortunately it's fairly limited to using the logging API. It works, but records get merged with all the other server side logs, the function name ends up being the endpoint, and httpContext doesn't get captured.

I tried lots of shenanigans with building my own LogRecord object and sending it to the logger, but to no avail.

I could setup API keys and use the google.cloud libbrary to hit the Report API directly, but that defeats the purpose/benefit of using AppEngine standard!

Is there advice on a better API/route to create StackDriver logs from AppEngine standard?

---- EDIT --- So far this is the best solution I have for an AppEngine Standard + Python 2.7 + Flask blueprint.

I pull out the URL from the context and stuff it into the message.

from flask import Blueprint, request
import logging

ERR = Blueprint('Stackdriver', __name__)

@ERR.route('/client_error', methods=['POST'])
def client_error():
    json = request.get_json()
    msg = "Page: {page}\n{message}".format(
        page=json['context']['httpRequest']['url'], message=json['message'])

    logging.error(msg)

    return ""