Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

AppEngine Standard - Report API #62

Open
patelnav opened this issue Dec 21, 2018 · 0 comments
Open

AppEngine Standard - Report API #62

patelnav opened this issue Dec 21, 2018 · 0 comments

Comments

@patelnav
Copy link

patelnav commented Dec 21, 2018

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 ""
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant