From 26ecf7b02377b860b4412aa554ed2392f42f8d40 Mon Sep 17 00:00:00 2001 From: Aditi Raveesh Date: Fri, 17 May 2013 10:32:38 +0530 Subject: [PATCH] Importing correlation_id middleware from oslo-incubator Including 'correlation_id' middleware from oslo-incubator. Adding this to openstack-common.conf to copy over the middleware to the location nova/openstack/common/middleware Change-Id: I21b27e8dae585345d03d59c125d9e1bbea95f830 Implements: blueprint cross-service-request-id --- nova/openstack/common/middleware/__init__.py | 0 .../common/middleware/correlation_id.py | 29 +++++++++++++++++++ openstack-common.conf | 1 + 3 files changed, 30 insertions(+) create mode 100644 nova/openstack/common/middleware/__init__.py create mode 100644 nova/openstack/common/middleware/correlation_id.py diff --git a/nova/openstack/common/middleware/__init__.py b/nova/openstack/common/middleware/__init__.py new file mode 100644 index 000000000000..e69de29bb2d1 diff --git a/nova/openstack/common/middleware/correlation_id.py b/nova/openstack/common/middleware/correlation_id.py new file mode 100644 index 000000000000..b04f81922043 --- /dev/null +++ b/nova/openstack/common/middleware/correlation_id.py @@ -0,0 +1,29 @@ +# vim: tabstop=4 shiftwidth=4 softtabstop=4 + +# Copyright (c) 2013 Rackspace Hosting +# All Rights Reserved. +# +# Licensed under the Apache License, Version 2.0 (the "License"); you may +# not use this file except in compliance with the License. You may obtain +# a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT +# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the +# License for the specific language governing permissions and limitations +# under the License. + +"""Middleware that attaches a correlation id to WSGI request""" + +from nova.openstack.common import uuidutils +from nova import wsgi + + +class CorrelationIdMiddleware(wsgi.Middleware): + + def process_request(self, req): + correlation_id = (req.headers.get("X_CORRELATION_ID") or + uuidutils.generate_uuid()) + req.headers['X_CORRELATION_ID'] = correlation_id diff --git a/openstack-common.conf b/openstack-common.conf index 086796b12e21..297029dc1000 100644 --- a/openstack-common.conf +++ b/openstack-common.conf @@ -18,6 +18,7 @@ module=lockutils module=log module=loopingcall module=memorycache +module=middleware.correlation_id module=network_utils module=notifier module=patch_tox_venv