summaryrefslogtreecommitdiff
path: root/designateclient/cli/sync.py
blob: 96d8a9df1d2f704d599dfecf383eef29506d5768 (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
# Copyright 2012 Managed I.T.
#
# Author: Kiall Mac Innes <kiall@managedit.ie>
#
# 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

from designateclient.cli import base

LOG = logging.getLogger(__name__)


class SyncAllCommand(base.Command):
    """Sync Everything"""

    def execute(self, parsed_args):
        self.client.sync.sync_all()

        LOG.info('Synchronization of all domains scheduled')


class SyncDomainCommand(base.Command):
    """Sync a single Domain"""

    def get_parser(self, prog_name):
        parser = super(SyncDomainCommand, self).get_parser(prog_name)

        parser.add_argument('domain_id', help="Domain ID")

        return parser

    def execute(self, parsed_args):
        self.client.sync.sync_domain(parsed_args.domain_id)

        LOG.info('Synchronization of domain scheduled')


class SyncRecordCommand(base.Command):
    """Sync a single Record"""

    def get_parser(self, prog_name):
        parser = super(SyncRecordCommand, self).get_parser(prog_name)

        parser.add_argument('domain_id', help="Domain ID")
        parser.add_argument('record_id', help="Record ID")

        return parser

    def execute(self, parsed_args):
        self.client.sync.sync_record(parsed_args.domain_id,
                                     parsed_args.record_id)

        LOG.info('Synchronization of record scheduled')