/mandos/trunk

To get this branch, use:
bzr branch http://bzr.recompile.se/loggerhead/mandos/trunk

« back to all changes in this revision

Viewing changes to mandos

  • Committer: Teddy Hogeborn
  • Date: 2008-08-20 03:22:45 UTC
  • Revision ID: teddy@fukt.bsnet.se-20080820032245-ue341vdvzqdsg68l
* mandos (string_to_delta): Accept a whitespace-separated sequence of
                            intervals and return the sum.  This allows
                            "5m 30s" to be valid.
  (main): Provide an empty default value for the "host" option for
          "clients.conf", making it no longer a required option.

* mandos-clients.conf.xml: Removed <?xml-stylesheet>.
  (DESCRIPTION): Improved text.
  (DEFAULTS): Renamed to "OPTIONS".  Improved text for "timeout" and
              "interval".
  (CLIENTS): Removed; content moved to "OPTIONS".
  (EXPANSION): New section; document %(foo)s and %%(foo)s expansion.
  (FILES): Moved to before "EXAMPLES".
  (BUGS): New section.
  (EXAMPLES): Renamed to "EXAMPLE", as per man-pages(7).  Renamed
              example section "example_client" to "foo".  Changed
              example "host" setting to a more reasonable example host
              name.  Added additional example client "bar".

* mandos-conf.xml: Removed OVERVIEW entity.

Show diffs side-by-side

added added

removed removed

Lines of Context:
563
563
    datetime.timedelta(1)
564
564
    >>> string_to_delta(u'1w')
565
565
    datetime.timedelta(7)
 
566
    >>> string_to_delta('5m 30s')
 
567
    datetime.timedelta(0, 330)
566
568
    """
567
 
    try:
568
 
        suffix=unicode(interval[-1])
569
 
        value=int(interval[:-1])
570
 
        if suffix == u"d":
571
 
            delta = datetime.timedelta(value)
572
 
        elif suffix == u"s":
573
 
            delta = datetime.timedelta(0, value)
574
 
        elif suffix == u"m":
575
 
            delta = datetime.timedelta(0, 0, 0, 0, value)
576
 
        elif suffix == u"h":
577
 
            delta = datetime.timedelta(0, 0, 0, 0, 0, value)
578
 
        elif suffix == u"w":
579
 
            delta = datetime.timedelta(0, 0, 0, 0, 0, 0, value)
580
 
        else:
 
569
    timevalue = datetime.timedelta(0)
 
570
    for s in interval.split():
 
571
        try:
 
572
            suffix=unicode(s[-1])
 
573
            value=int(s[:-1])
 
574
            if suffix == u"d":
 
575
                delta = datetime.timedelta(value)
 
576
            elif suffix == u"s":
 
577
                delta = datetime.timedelta(0, value)
 
578
            elif suffix == u"m":
 
579
                delta = datetime.timedelta(0, 0, 0, 0, value)
 
580
            elif suffix == u"h":
 
581
                delta = datetime.timedelta(0, 0, 0, 0, 0, value)
 
582
            elif suffix == u"w":
 
583
                delta = datetime.timedelta(0, 0, 0, 0, 0, 0, value)
 
584
            else:
 
585
                raise ValueError
 
586
        except (ValueError, IndexError):
581
587
            raise ValueError
582
 
    except (ValueError, IndexError):
583
 
        raise ValueError
584
 
    return delta
 
588
        timevalue += delta
 
589
    return timevalue
585
590
 
586
591
 
587
592
def server_state_changed(state):
733
738
    client_defaults = { "timeout": "1h",
734
739
                        "interval": "5m",
735
740
                        "checker": "fping -q -- %%(host)s",
 
741
                        "host": "",
736
742
                        }
737
743
    client_config = ConfigParser.SafeConfigParser(client_defaults)
738
744
    client_config.read(os.path.join(server_settings["configdir"],