mirror of
https://github.com/OpenKMIP/PyKMIP.git
synced 2025-10-24 17:14:33 +02:00
This change adds support for the GetAttributeList operation to the ProxyKmipClient. It updates the Pie client API and provides a demo showing how to use the operation. All relevant test suites are updated accordingly.
54 lines
1.8 KiB
Python
54 lines
1.8 KiB
Python
# 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 os
|
|
import sys
|
|
|
|
from kmip.core import enums
|
|
from kmip.demos import utils
|
|
from kmip.pie import client
|
|
|
|
|
|
if __name__ == '__main__':
|
|
# Build and parse arguments
|
|
parser = utils.build_cli_parser(enums.Operation.GET_ATTRIBUTE_LIST)
|
|
opts, args = parser.parse_args(sys.argv[1:])
|
|
|
|
config = opts.config
|
|
uid = opts.uuid
|
|
|
|
# Exit early if the UUID is not specified
|
|
if uid is None:
|
|
logging.debug('No ID provided, exiting early from demo')
|
|
sys.exit()
|
|
|
|
# Build and setup logging and needed factories
|
|
f_log = os.path.join(os.path.dirname(__file__), os.pardir, os.pardir,
|
|
'logconfig.ini')
|
|
logging.config.fileConfig(f_log)
|
|
logger = logging.getLogger(__name__)
|
|
|
|
# Build the client and connect to the server
|
|
with client.ProxyKmipClient(config=config) as client:
|
|
try:
|
|
attribute_names = client.get_attribute_list(uid)
|
|
logger.info("Successfully retrieved {0} attribute names:".format(
|
|
len(attribute_names)))
|
|
for attribute_name in attribute_names:
|
|
logger.info("Attribute name: {0}".format(attribute_name))
|
|
except Exception as e:
|
|
logger.error(e)
|