Files
trove/reddwarf/common/context.py
Craig Vyvial 4b67e70886 checks before deleting kwargs from the context
Make sure to check if the kwarg is there before deleting it.

bug 1074422

Change-Id: I66f5338b100f3c16f7e0ca0382ecfea22b099726
2012-11-06 16:09:38 -06:00

59 lines
1.9 KiB
Python

# vim: tabstop=4 shiftwidth=4 softtabstop=4
# Copyright 2011 OpenStack LLC.
# 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.
"""
Simple class that stores security context information in the web request.
Projects should subclass this class if they wish to enhance the request
context or provide additional information in their specific WSGI pipeline.
"""
from reddwarf.openstack.common import context
from reddwarf.common import utils
class ReddwarfContext(context.RequestContext):
"""
Stores information about the security context under which the user
accesses the system, as well as additional request information.
"""
def __init__(self, **kwargs):
self.limit = kwargs.get('limit')
if 'limit' in kwargs:
del kwargs['limit']
self.marker = kwargs.get('marker')
if 'marker' in kwargs:
del kwargs['marker']
super(ReddwarfContext, self).__init__(**kwargs)
def to_dict(self):
return {'user': self.user,
'tenant': self.tenant,
'is_admin': self.is_admin,
'show_deleted': self.show_deleted,
'read_only': self.read_only,
'auth_tok': self.auth_tok,
'limit': self.limit,
'marker': self.marker
}
@classmethod
def from_dict(cls, values):
return cls(**values)