dhcp_conf.py
author Tero Marttila <terom@fixme.fi>
Thu, 02 Apr 2009 20:19:18 +0300
changeset 1 2223ade4f259
parent 0 conf_dhcp.py@257003279747
child 2 e66102ab7048
permissions -rw-r--r--
continue the overengineering effort, we are now able to generate dhcpd.conf files
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     1
"""
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     2
    Configuration file output for the ISC DHCP server
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     3
"""
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     4
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     5
import conf
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     6
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     7
import itertools
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
     8
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
     9
class Section (conf.ConfObject) :
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    10
    """
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    11
        A section holds a list of params and a list of decls
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    12
    """
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    13
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    14
    def __init__ (self, params=None, decls=None) :
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    15
        """
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    16
            If params/decls are given, those are the used as the initial contents of this section
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    17
        """
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    18
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    19
        self.params = params or []
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    20
        self.decls = decls or []
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    21
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    22
    def add_param (self, param) :
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    23
        """
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    24
            Add the given Parameter to the end of this section's params
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    25
        """
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    26
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    27
        self.params.append(param)
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    28
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    29
    def add_params (self, params) :
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    30
        for param in params :
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    31
            self.add_param(param)
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    32
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    33
    def add_decl (self, decl) :
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    34
        """
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    35
            Add the given Declaration to the end of this section's decls
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    36
        """
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    37
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    38
        self.decls.append(decl)
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    39
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    40
    def add_decls (self, decls) :
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    41
        for decl in decls :
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    42
            self.add_decl(decl)
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    43
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    44
    def fmt_lines (self) :
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    45
        """
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    46
            Format all of our params and decls, in that order
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    47
        """
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    48
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    49
        # then output each content line
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    50
        for stmt in itertools.chain(self.params, self.decls) :
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    51
            # skip Nones
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    52
            if stmt is None :
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    53
                continue
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    54
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    55
            for line in stmt.fmt_lines() :
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    56
                yield line
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    57
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    58
class ConfFile (Section, conf.File) :
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    59
    DEFAULT_NAME = "dhcpd.conf"
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    60
    DEFAULT_PATH = "/etc/dhcp3/dhcpd.conf"
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    61
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    62
    def __init__ (self, name=DEFAULT_NAME, path=DEFAULT_PATH, params=None, decls=None) :
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    63
        """
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    64
            Initialize the dhcpd config file, but don't open it yet.
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    65
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    66
        
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    67
        conf.File.__init__(self, name, path)
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    68
        Section.__init__(self, params, decls)
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    69
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    70
class Statement (conf.ConfObject) :
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    71
    """
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    72
        A statement is a single line in the config file
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    73
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    74
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    75
    def __init__ (self, name, *args) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    76
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    77
            The statement will be formatted like this:
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    78
                <name> [ <arg> [ ... ] ] ";"
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    79
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    80
            Arguments given as None will be ignored.
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    81
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    82
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    83
        self.name = name
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    84
        self.args = args
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    85
    
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    86
    def _fmt_arg (self, arg) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    87
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    88
            Formats a arg for use in output, the following types are supported:
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    89
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    90
                list/tuple/iter:    results in a comma-and-space separated list of formatted values
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    91
                unicode:            results in an encoded str
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    92
                str:                results in the string itself, quoted if needed
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    93
                other:              attempt to convert to a str, and then format that
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    94
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    95
        
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    96
        # format lists specially
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    97
        # XXX: iterators?
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    98
        if isinstance(arg, (list, tuple)) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    99
            # recurse as a comma-and-space separated list
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   100
            return ', '.join(self._fmt_arg(a) for a in arg)
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   101
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   102
        elif isinstance(arg, Literal) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   103
            # use what it specifies
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   104
            return arg.fmt_arg()
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   105
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   106
        elif isinstance(arg, unicode) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   107
            # recurse with the str version
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   108
            # XXX: what encoding to use?
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   109
            return self._fmt_arg(arg.encode('utf8'))
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   110
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   111
        elif isinstance(arg, str) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   112
            # XXX: quoting
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   113
            return arg
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   114
        
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   115
        else :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   116
            # try and use it as a string
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   117
            return self._fmt_arg(str(arg))
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   118
    
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   119
    def _fmt_data (self) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   120
        """
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   121
            Formats the statement name/params as a single line, ignoring None
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   122
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   123
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   124
        return "%s%s" % (self.name, (' ' + ' '.join(self._fmt_arg(a) for a in self.args if a is not None)) if self.args else '')
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   125
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   126
class Literal (Statement) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   127
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   128
        A literal is something that goes into the config file as-is, with no formatting or escaping applied.
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   129
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   130
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   131
    def __init__ (self, literal) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   132
        self.literal = literal
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   133
    
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   134
    def fmt_arg (self) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   135
        return self.literal
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   136
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   137
    def fmt_lines (self) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   138
        yield self.literal
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   139
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   140
class Parameter (Statement) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   141
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   142
        A parameter is a single statement that configures the behaviour of something.
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   143
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   144
        Parameters have a name, and optionally, a number of arguments, and are formatted as statements terminated with
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   145
        a semicolon. For convenience, params/decls that are None are ignored.
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   146
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   147
    
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   148
    def fmt_lines (self) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   149
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   150
            Yields a single ;-terminated line
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   151
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   152
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   153
        yield "%s;" % self._fmt_data()
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   154
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   155
class Declaration (Section, Statement) :
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   156
    """
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   157
        A declaration begins like a statement (with name and args), but then contains a curly-braces-delimited block
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   158
        that acts like a Section.
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   159
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   160
        <name> [ <args> [ ... ] ] {
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   161
            [ <Section> ]
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   162
        }
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   163
        
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   164
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   165
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   166
    def __init__ (self, name, args=[], params=None, decls=None) :
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   167
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   168
            The name/args will be formatted as in Statement, but params should be an iterable of Parameters, and decls
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   169
            an iterable of Declarations.
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   170
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   171
        
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   172
        # init the statement bit
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   173
        Section.__init__(self, params, decls)
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   174
        Statement.__init__(self, name, *args)
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   175
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   176
    def fmt_lines (self) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   177
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   178
            Yields a header line, a series of indented body lines, and the footer line
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   179
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   180
        
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   181
        # the header to open the block
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   182
        yield "%s {" % self._fmt_data()
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   183
        
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   184
        # then output the section stuff, indented
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   185
        for line in Section.fmt_lines(self) :
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   186
            yield "\t%s" % line
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   187
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   188
        # and then close the block
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   189
        yield "}"
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   190
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   191
class SharedNetwork (Declaration) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   192
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   193
        A shared-network declaration is used to define a set of subnets that share the same physical network,
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   194
        optionally with some shared params.
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   195
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   196
        shared-network <name> {
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   197
            [ parameters ]
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   198
            [ declarations ]
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   199
        }
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   200
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   201
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   202
    def __init__ (self, name, params=[], decls=[]) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   203
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   204
            @param name the name of the shared-subnet
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   205
            @param params optional parameters
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   206
            @param decls the iterable of subnets or other declarations in the shared network
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   207
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   208
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   209
        super(SharedNetwork, self).__init__("shared-network", [name], params, decls)
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   210
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   211
class Subnet (Declaration) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   212
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   213
        A subnet is used to provide the information about a subnet required to identify whether or not an IP address is
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   214
        on that subnet, and may also be used to specify parameters/declarations for that subnet.
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   215
        
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   216
        subnet <subnet-number> netmask <netmask> {
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   217
            [ parameters ]
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   218
            [ declarations ]
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   219
        }
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   220
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   221
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   222
    def __init__ (self, network, params=None, decls=None) :
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   223
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   224
            @param network the addr.Network for the subnet
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   225
            @param params optional parameters
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   226
            @param decls optional decls, e.g. subnets
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   227
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   228
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   229
        super(Subnet, self).__init__("subnet", [network.net(), "netmask", network.netmask()], params, decls)
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   230
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   231
class Group (Declaration) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   232
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   233
        A group is simply used to apply a set of parameters to a set of declarations.
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   234
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   235
        group {
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   236
            [ parameters ]
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   237
            [ declarations ]
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   238
        }
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   239
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   240
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   241
    def __init__ (self, params=None, decls=None) :
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   242
        super(Group, self).__init__("group", [], params, decls)
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   243
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   244
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   245
class Host (Declaration) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   246
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   247
        A host is used to match a request against specific host, and then apply settings for that host.
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   248
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   249
        The "hostname" is the DHCP name to identify the host. 
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   250
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   251
        If no dhcp-client-identifier option is specified in the parameters, then the host is matched using the
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   252
        "hardware" parameter.
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   253
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   254
        host <hostname> {
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   255
            [ parameters ]
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   256
            [ declarations ]
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   257
        }
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   258
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   259
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   260
    def __init__ (self, hostname, params=None, decls=None) :
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   261
        super(Host, self).__init__("host", [hostname], params, decls)
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   262
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   263
class Option (Parameter) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   264
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   265
        A generic 'option' parameter for a dhcpd.conf file
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   266
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   267
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   268
    def __init__ (self, name, *args) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   269
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   270
            Formatted as a Satement with a name of "option <name>".
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   271
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   272
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   273
        super(Option, self).__init__("option %s" % name, *args)
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   274