Source code for oneview_redfish_toolkit.api.subscription_collection

# -*- coding: utf-8 -*-

# Copyright (2017) Hewlett Packard Enterprise Development LP
#
# 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 collections

from oneview_redfish_toolkit.api.redfish_json_validator \
    import RedfishJsonValidator


[docs]class SubscriptionCollection(RedfishJsonValidator): """Creates a Subscription Collection Redfish dict Populates self.redfish with some hardcoded SubscriptionCollection values """ SCHEMA_NAME = 'EventDestinationCollection' def __init__(self, all_subscriptions): """SubscriptionCollection constructor. Populates self.redfish with hardcoded SubscriptionCollection values. all_subscriptions: Dictionary with all subscriptions. """ super().__init__(self.SCHEMA_NAME) self.redfish["@odata.type"] = \ "#EventDestinationCollection.EventDestinationCollection" self.redfish["Name"] = "Event Subscriptions Collection" self.redfish["Members@odata.count"] = len(all_subscriptions) self.redfish["Members"] = list() for subscription_id in all_subscriptions: member = collections.OrderedDict() member["@odata.id"] = \ "/redfish/v1/EventService" \ "/EventSubscriptions/{}".format( all_subscriptions[subscription_id].get_id()) self.redfish["Members"].append(member) self.redfish["@odata.context"] = \ "/redfish/v1/$metadata#EventDestinationCollection" \ ".EventDestinationCollection" self.redfish["@odata.id"] = \ "/redfish/v1/EventService/EventSubscriptions/" self._validate()