dhcp_conf.py
author Tero Marttila <terom@fixme.fi>
Thu, 02 Apr 2009 20:54:37 +0300
changeset 2 e66102ab7048
parent 1 2223ade4f259
child 3 ff98fa9b84ce
permissions -rw-r--r--
fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
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
2
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
     9
class Comment (conf.ConfObject) :
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    10
    """
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    11
        A comment, is, well, a comment :)
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    12
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    13
        Currently, comments are only one line, and look like the following:
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    14
            "#" <comment>
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    15
    """
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    16
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    17
    def __init__ (self, comment) :
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    18
        """
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    19
            @param comment the comment string
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    20
        """
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    21
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    22
        self.comment = comment
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    23
    
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    24
    def fmt_lines (self) :
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    25
        """
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    26
            Yield a single line with the comment
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    27
        """
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    28
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    29
        yield "# %s" % (self.comment, )
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    30
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    31
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
    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
        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
    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
2
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    36
    def __init__ (self, params=None, decls=None, comment=None) :
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    37
        """
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    38
            If params/decls are given, those are the used as the initial contents of this section
2
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    39
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    40
            If a comment is given, then it will be formatted before the section's stuff
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    41
        """
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
    42
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    43
        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
    44
        self.decls = decls or []
2
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    45
        self.comment = comment
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    46
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    47
    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
    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
            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
    50
        """
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    51
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    52
        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
    53
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    54
    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
    55
        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
    56
            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
    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
    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
    59
        """
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    60
            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
    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
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    63
        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
    64
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    65
    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
    66
        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
    67
            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
    68
2
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    69
    def _fmt_comment (self) :
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    70
        """
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    71
            Format our comment line 
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    72
        """
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    73
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    74
        return "# %s" % (self.comment, )
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    75
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    76
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    77
    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
    78
        """
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    79
            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
    80
        """
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    81
2
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    82
        # comment?
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    83
        if self.comment :
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    84
            yield self._fmt_comment()
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
    85
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    86
        # 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
    87
        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
    88
            # 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
    89
            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
    90
                continue
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    91
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    92
            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
    93
                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
    94
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    95
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
    96
    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
    97
    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
    98
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
    99
    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
   100
        """
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   101
            Initialize the dhcpd config file, but don't open it yet.
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   102
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   103
        
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   104
        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
   105
        Section.__init__(self, params, decls)
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   106
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   107
class Statement (conf.ConfObject) :
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   108
    """
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   109
        A statement is a single line in the config file
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   110
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   111
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   112
    def __init__ (self, name, *args) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   113
        """
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   114
            Arguments given as None will be ignored.
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   115
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   116
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   117
        self.name = name
2
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
   118
        self.args = [arg for arg in args if arg is not None]
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   119
    
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   120
    def _fmt_arg (self, arg) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   121
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   122
            Formats a arg for use in output, the following types are supported:
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   123
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   124
                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
   125
                unicode:            results in an encoded str
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   126
                str:                results in the string itself, quoted if needed
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   127
                other:              attempt to convert to a str, and then format that
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   128
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   129
        
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   130
        # format lists specially
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   131
        # XXX: iterators?
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   132
        if isinstance(arg, (list, tuple)) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   133
            # recurse as a comma-and-space separated list
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   134
            return ', '.join(self._fmt_arg(a) for a in arg)
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   135
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   136
        elif isinstance(arg, Literal) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   137
            # use what it specifies
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   138
            return arg.fmt_arg()
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   139
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   140
        elif isinstance(arg, unicode) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   141
            # recurse with the str version
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   142
            # XXX: what encoding to use?
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   143
            return self._fmt_arg(arg.encode('utf8'))
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   144
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   145
        elif isinstance(arg, str) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   146
            # XXX: quoting
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   147
            return arg
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   148
        
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   149
        else :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   150
            # try and use it as a string
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   151
            return self._fmt_arg(str(arg))
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   152
    
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   153
    def _fmt_data (self) :
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
            Formats the statement name/params as a single line, ignoring None
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   156
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   157
2
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
   158
        return "%s%s" % (self.name, (' ' + ' '.join(self._fmt_arg(a) for a in self.args)) if self.args else '')
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
class Literal (Statement) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   161
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   162
        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
   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
    def __init__ (self, literal) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   166
        self.literal = literal
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   167
    
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   168
    def fmt_arg (self) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   169
        return self.literal
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   170
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   171
    def fmt_lines (self) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   172
        yield self.literal
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   173
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   174
class Parameter (Statement) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   175
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   176
        A parameter is a single statement that configures the behaviour of something.
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   177
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   178
        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
   179
        a semicolon. For convenience, params/decls that are None are ignored.
2
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
   180
            
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
   181
        The parameter will be formatted like this:
e66102ab7048 fix up data.load_py, and make conf.File be a ConfObject itself - implement this for dhcp_conf
Tero Marttila <terom@fixme.fi>
parents: 1
diff changeset
   182
            <name> [ <arg> [ ... ] ] ";"
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   183
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   184
    
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   185
    def fmt_lines (self) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   186
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   187
            Yields a single ;-terminated line
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   188
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   189
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   190
        yield "%s;" % self._fmt_data()
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   191
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   192
class Declaration (Section, Statement) :
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   193
    """
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   194
        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
   195
        that acts like a Section.
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   196
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   197
        <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
   198
            [ <Section> ]
0
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
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   203
    def __init__ (self, name, args=[], params=None, decls=None) :
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   204
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   205
            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
   206
            an iterable of Declarations.
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
        # 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
   210
        Section.__init__(self, params, decls)
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   211
        Statement.__init__(self, name, *args)
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   212
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   213
    def fmt_lines (self) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   214
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   215
            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
   216
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   217
        
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   218
        # the header to open the block
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   219
        yield "%s {" % self._fmt_data()
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   220
        
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   221
        # 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
   222
        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
   223
            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
   224
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   225
        # and then close the block
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   226
        yield "}"
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   227
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   228
class SharedNetwork (Declaration) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   229
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   230
        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
   231
        optionally with some shared params.
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   232
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   233
        shared-network <name> {
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   234
            [ parameters ]
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   235
            [ declarations ]
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   236
        }
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   237
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   238
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   239
    def __init__ (self, name, params=[], decls=[]) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   240
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   241
            @param name the name of the shared-subnet
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   242
            @param params optional parameters
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   243
            @param decls the iterable of subnets or other declarations in the shared network
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   244
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   245
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   246
        super(SharedNetwork, self).__init__("shared-network", [name], params, decls)
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   247
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   248
class Subnet (Declaration) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   249
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   250
        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
   251
        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
   252
        
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   253
        subnet <subnet-number> netmask <netmask> {
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   254
            [ parameters ]
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   255
            [ declarations ]
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   256
        }
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   257
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   258
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   259
    def __init__ (self, network, params=None, decls=None) :
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   260
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   261
            @param network the addr.Network for the subnet
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   262
            @param params optional parameters
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   263
            @param decls optional decls, e.g. subnets
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   264
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   265
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   266
        super(Subnet, self).__init__("subnet", [network.net(), "netmask", network.netmask()], params, decls)
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   267
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   268
class Group (Declaration) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   269
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   270
        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
   271
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   272
        group {
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   273
            [ parameters ]
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   274
            [ declarations ]
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   275
        }
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   276
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   277
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   278
    def __init__ (self, params=None, decls=None) :
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   279
        super(Group, self).__init__("group", [], params, decls)
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   280
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   281
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   282
class Host (Declaration) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   283
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   284
        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
   285
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   286
        The "hostname" is the DHCP name to identify the host. 
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   287
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   288
        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
   289
        "hardware" parameter.
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   290
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   291
        host <hostname> {
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   292
            [ parameters ]
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   293
            [ declarations ]
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   294
        }
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   295
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   296
1
2223ade4f259 continue the overengineering effort, we are now able to generate dhcpd.conf files
Tero Marttila <terom@fixme.fi>
parents: 0
diff changeset
   297
    def __init__ (self, hostname, params=None, decls=None) :
0
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   298
        super(Host, self).__init__("host", [hostname], params, decls)
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   299
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   300
class Option (Parameter) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   301
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   302
        A generic 'option' parameter for a dhcpd.conf file
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   303
    """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   304
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   305
    def __init__ (self, name, *args) :
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   306
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   307
            Formatted as a Satement with a name of "option <name>".
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   308
        """
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   309
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   310
        super(Option, self).__init__("option %s" % name, *args)
257003279747 initial code
Tero Marttila <terom@fixme.fi>
parents:
diff changeset
   311