in skywalking/plugins/sw_falcon.py [0:0]
def install():
from falcon import API, request, RequestOptions
_original_falcon_api = API.__call__
def _sw_falcon_api(this: API, env, start_response):
context = get_context()
carrier = Carrier()
req = request.Request(env, RequestOptions())
headers = req.headers
method = req.method
for item in carrier:
key = item.key.upper()
if key in headers:
item.val = headers[key]
span = NoopSpan(NoopContext()) if config.ignore_http_method_check(method) \
else context.new_entry_span(op=req.path, carrier=carrier)
with span:
span.layer = Layer.Http
span.component = Component.Falcon
span.peer = req.remote_addr
span.tag(TagHttpMethod(method))
span.tag(TagHttpURL(str(req.url)))
if req.params:
span.tag(TagHttpParams(','.join([f'{k}={v}' for k, v in req.params.items()])))
def _start_response(resp_status, headers):
try:
code, msg = resp_status.split(' ', 1)
code = int(code)
except Exception:
code, msg = 500, 'Internal Server Error'
if code >= 400:
span.error_occurred = True
span.tag(TagHttpStatusCode(code))
span.tag(TagHttpStatusMsg(msg))
return start_response(resp_status, headers)
try:
return _original_falcon_api(this, env, _start_response)
except Exception:
span.raised()
raise
API.__call__ = _sw_falcon_api