mirror of https://github.com/OpenKMIP/PyKMIP.git
Merge pull request #67 from OpenKMIP/feat/add-pie-client-secrets
Adding secret data examples for the ProxyKmipClient
This commit is contained in:
commit
ea1b453cff
|
@ -0,0 +1,48 @@
|
||||||
|
# Copyright (c) 2015 The Johns Hopkins University/Applied Physics Laboratory
|
||||||
|
# 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.
|
||||||
|
|
||||||
|
|
||||||
|
import logging
|
||||||
|
import sys
|
||||||
|
|
||||||
|
from kmip.core import enums
|
||||||
|
from kmip.demos import utils
|
||||||
|
|
||||||
|
from kmip.pie import client
|
||||||
|
from kmip.pie import objects
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
parser = utils.build_cli_parser()
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
opts, args = parser.parse_args(sys.argv[1:])
|
||||||
|
|
||||||
|
config = opts.config
|
||||||
|
|
||||||
|
value = (b'\x53\x65\x63\x72\x65\x74\x50\x61\x73\x73\x77\x6F\x72\x64')
|
||||||
|
data_type = enums.SecretDataType.PASSWORD
|
||||||
|
usage_mask = [enums.CryptographicUsageMask.VERIFY]
|
||||||
|
name = 'Demo Secret Data'
|
||||||
|
|
||||||
|
secret = objects.SecretData(value, data_type, usage_mask, name)
|
||||||
|
|
||||||
|
# Build the client and connect to the server
|
||||||
|
with client.ProxyKmipClient(config=config) as client:
|
||||||
|
try:
|
||||||
|
uid = client.register(secret)
|
||||||
|
logger.info(
|
||||||
|
"Successfully registered secret data with ID: {0}".format(uid))
|
||||||
|
except Exception as e:
|
||||||
|
logger.error(e)
|
|
@ -352,3 +352,30 @@ class TestProxyKmipClientIntegration(testtools.TestCase):
|
||||||
exceptions.KmipOperationFailure, self.client.get, uid)
|
exceptions.KmipOperationFailure, self.client.get, uid)
|
||||||
self.assertRaises(
|
self.assertRaises(
|
||||||
exceptions.KmipOperationFailure, self.client.destroy, uid)
|
exceptions.KmipOperationFailure, self.client.destroy, uid)
|
||||||
|
|
||||||
|
def test_secret_data_register_get_destroy(self):
|
||||||
|
"""
|
||||||
|
Test that the ProxyKmipClient can register, retrieve, and destroy a
|
||||||
|
secret.
|
||||||
|
"""
|
||||||
|
# Secret encoding obtained from Section 3.1.5 of the KMIP 1.1 test
|
||||||
|
# documentation.
|
||||||
|
secret = objects.SecretData(
|
||||||
|
(b'\x53\x65\x63\x72\x65\x74\x50\x61\x73\x73\x77\x6F\x72\x64'),
|
||||||
|
enums.SecretDataType.PASSWORD)
|
||||||
|
|
||||||
|
uid = self.client.register(secret)
|
||||||
|
self.assertIsInstance(uid, six.string_types)
|
||||||
|
|
||||||
|
try:
|
||||||
|
result = self.client.get(uid)
|
||||||
|
self.assertIsInstance(result, objects.SecretData)
|
||||||
|
self.assertEqual(
|
||||||
|
result, secret, "expected {0}\nobserved {1}".format(
|
||||||
|
result, secret))
|
||||||
|
finally:
|
||||||
|
self.client.destroy(uid)
|
||||||
|
self.assertRaises(
|
||||||
|
exceptions.KmipOperationFailure, self.client.get, uid)
|
||||||
|
self.assertRaises(
|
||||||
|
exceptions.KmipOperationFailure, self.client.destroy, uid)
|
||||||
|
|
Loading…
Reference in New Issue