Files
offline_kubespray/collection/community/dns/plugins/module_utils/provider.py
ByeonJungHun 360c6eef4a offline 작업
2024-02-19 16:02:29 +09:00

70 lines
2.0 KiB
Python

# -*- coding: utf-8 -*-
#
# Copyright (c) 2017-2021 Felix Fontein
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
from __future__ import (absolute_import, division, print_function)
__metaclass__ = type
import abc
from ansible.module_utils import six
@six.add_metaclass(abc.ABCMeta)
class ProviderInformation(object):
@abc.abstractmethod
def get_zone_id_type(self):
"""
Return the (short) type for zone IDs, like ``'int'`` or ``'str'``.
"""
@abc.abstractmethod
def get_record_id_type(self):
"""
Return the (short) type for record IDs, like ``'int'`` or ``'str'``.
"""
@abc.abstractmethod
def get_record_default_ttl(self):
"""
Return the default TTL for records, like 300, 3600 or None.
None means that some other TTL (usually from the zone) will be used.
"""
@abc.abstractmethod
def get_supported_record_types(self):
"""
Return a list of supported record types.
"""
def normalize_prefix(self, prefix):
"""
Given a prefix (string or None), return its normalized form.
The result should always be None for the trivial prefix, and a non-zero length DNS name
for a non-trivial prefix.
If a provider supports other identifiers for the trivial prefix, such as '@', this
function needs to convert them to None as well.
"""
return prefix or None
def supports_bulk_actions(self):
"""
Return whether the API supports some kind of bulk actions.
"""
return False
@abc.abstractmethod
def txt_record_handling(self):
"""
Return how the API handles TXT records.
Returns one of the following strings:
* 'decoded' - the API works with unencoded values
* 'encoded' - the API works with encoded values
* 'encoded-no-octal' - the API works with encoded values, but without octal encoding
"""