def __parse_line(self, line): if not self.boot_succeeded: if re.search("Starting\storctl\sprogram\son\shost", line) is not None: parts = line.strip().split() if len(parts) < 11: return True self.name = parts[10] if re.search("Bootstrapped\s100", line) is not None: self.boot_succeeded = True elif re.search("BOOTSTRAP", line) is not None and re.search( "PROGRESS=100", line) is not None: self.boot_succeeded = True # parse with stem timestamps, sep, raw_event_str = line.partition(" 650 ") if sep == '': return True # event.arrived_at is also available but at worse granularity unix_ts = float(timestamps.strip().split()[2]) # check if we should ignore the line line_date = datetime.datetime.utcfromtimestamp(unix_ts).date() if not self.__is_date_valid(line_date): return True event = ControlMessage.from_str("{0} {1}".format( sep.strip(), raw_event_str)) convert('EVENT', event) self.__handle_event(event, unix_ts) return True
def __parse_line(self, line): if not self.boot_succeeded: if re.search("Starting\storctl\sprogram\son\shost", line) is not None: parts = line.strip().split() if len(parts) < 11: return True self.name = parts[10] if re.search("Bootstrapped\s100", line) is not None: self.boot_succeeded = True elif re.search("BOOTSTRAP", line) is not None and re.search("PROGRESS=100", line) is not None: self.boot_succeeded = True if self.do_simple is False or (self.do_simple is True and re.search("650\sBW", line) is not None): # parse with stem timestamps, sep, raw_event_str = line.partition(" 650 ") if sep == '': return True # event.arrived_at is also available but at worse granularity unix_ts = float(timestamps.strip().split()[2]) # check if we should ignore the line line_date = datetime.datetime.utcfromtimestamp(unix_ts).date() if not self.__is_date_valid(line_date): return True event = ControlMessage.from_str("{0} {1}".format(sep.strip(), raw_event_str)) convert('EVENT', event) self.__handle_event(event, unix_ts) return True