summaryrefslogtreecommitdiff
path: root/tempest_lib/services/compute/security_group_default_rules_client.py
blob: 74a99b3f53b187e3730531e26f6496daf3c2d581 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
# Copyright 2014 NEC Corporation.
# 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.

from oslo_serialization import jsonutils as json

from tempest_lib.api_schema.response.compute.v2_1 import \
    security_group_default_rule as schema
from tempest_lib.common import rest_client


class SecurityGroupDefaultRulesClient(rest_client.RestClient):

    def create_security_default_group_rule(self, **kwargs):
        """Create security group default rule.

        Available params: see http://developer.openstack.org/
                              api-ref-compute-v2.1.html
                              #createSecGroupDefaultRule
        """
        post_body = json.dumps({'security_group_default_rule': kwargs})
        url = 'os-security-group-default-rules'
        resp, body = self.post(url, post_body)
        body = json.loads(body)
        self.validate_response(schema.create_get_security_group_default_rule,
                               resp, body)
        return rest_client.ResponseBody(resp, body)

    def delete_security_group_default_rule(self,
                                           security_group_default_rule_id):
        """Delete the provided Security Group default rule."""
        resp, body = self.delete('os-security-group-default-rules/%s' % (
            security_group_default_rule_id))
        self.validate_response(schema.delete_security_group_default_rule,
                               resp, body)
        return rest_client.ResponseBody(resp, body)

    def list_security_group_default_rules(self):
        """List all Security Group default rules."""
        resp, body = self.get('os-security-group-default-rules')
        body = json.loads(body)
        self.validate_response(schema.list_security_group_default_rules,
                               resp, body)
        return rest_client.ResponseBody(resp, body)

    def show_security_group_default_rule(self, security_group_default_rule_id):
        """Return the details of provided Security Group default rule."""
        resp, body = self.get('os-security-group-default-rules/%s' %
                              security_group_default_rule_id)
        body = json.loads(body)
        self.validate_response(schema.create_get_security_group_default_rule,
                               resp, body)
        return rest_client.ResponseBody(resp, body)