Files
keystone/keystone/token/providers/pki.py
David Stanek e709b98201 Adds missing log hints for level E/I/W
This patch adds logging hints for the remaining logging statements.

bp more-code-style-automation

Change-Id: I78801d9d3187df6470b51b3ecb0f182440112d13
2014-11-21 14:56:51 +00:00

50 lines
1.8 KiB
Python

# Copyright 2013 OpenStack Foundation
#
# 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.
"""Keystone PKI Token Provider"""
from keystoneclient.common import cms
from oslo.serialization import jsonutils
from keystone.common import environment
from keystone.common import utils
from keystone import config
from keystone import exception
from keystone.i18n import _, _LE
from keystone.openstack.common import log
from keystone.token.providers import common
CONF = config.CONF
LOG = log.getLogger(__name__)
class Provider(common.BaseProvider):
def _get_token_id(self, token_data):
try:
# force conversion to a string as the keystone client cms code
# produces unicode. This can be removed if the client returns
# str()
# TODO(ayoung): Make to a byte_str for Python3
token_json = jsonutils.dumps(token_data, cls=utils.PKIEncoder)
token_id = str(cms.cms_sign_token(token_json,
CONF.signing.certfile,
CONF.signing.keyfile))
return token_id
except environment.subprocess.CalledProcessError:
LOG.exception(_LE('Unable to sign token'))
raise exception.UnexpectedError(_(
'Unable to sign token.'))