SVN: security: cve_reader.py generate.sh index.php

shadzik shadzik at pld-linux.org
Sat Oct 6 13:06:11 CEST 2007


Author: shadzik
Date: Sat Oct  6 13:06:11 2007
New Revision: 8794

Added:
   security/cve_reader.py   (contents, props changed)
   security/generate.sh   (contents, props changed)
   security/index.php
Log:
- scripts for security.pld-linux.org


Added: security/cve_reader.py
==============================================================================
--- (empty file)
+++ security/cve_reader.py	Sat Oct  6 13:06:11 2007
@@ -0,0 +1,164 @@
+#!/usr/bin/python
+#
+# CVE security reader for pld-linux.org purpose
+# Basicly it parses commits.log and searches for "CVE" keyword, then it generates a .html file with simple table structure
+#
+# TODO
+# - display all auto-ac, auto-th and auto-ti tags if they resolve the same CVE
+#
+import os
+import sys
+import re
+import readline
+import time
+import datetime
+
+# Changes go here
+log = '/cvsroot/SPECS/commits.log'
+cvsroot = "/cvsroot/"
+cvsmodule = "SPECS/"
+h_page = "header.html"
+table_page = "security.html"
+f_page = "footer.html"
+size_f = "size.txt"
+
+# Don't change anything below unless you know what you're doing
+specs =  []
+cves = []
+lines = []
+revs = []
+date = []
+
+# Main parse function
+def parse():
+	# seek where we last ended parsing
+	f2 = open(size_f, 'r')
+	old_size = f2.read().split("L")
+	old_size = long(old_size[0])
+	f2.close()
+	f = open(log)
+	f.seek(old_size) # end seeking
+	read = f.xreadlines()
+	for l in read:
+		l = l.strip()
+		lines.append(l)
+	lines_len = len(lines)
+	for i in range(lines_len):
+		if lines[i] == "Modified files:":
+			spec = lines[i+1]
+		if lines[i] == "Log message:":
+			cvslog = 1
+			cve = ""
+			while(lines[i+cvslog] != ""):
+				cve_match = re.match('.*(CVE-[0-9\-]+)', lines[i+cvslog])
+				if cve_match:
+					cve += "<a href=\"http://cve.mitre.org/cgi-bin/cvename.cgi?name=%s\">%s</a> " % (cve_match.group(1), cve_match.group(1))
+				cvslog = cvslog+1
+		if lines[i] == "$Log$":
+			p = lines[i+1].split(" ")
+			if cve != "":
+				specs.append(spec)
+				cves.append(cve)
+				revs.append(p[1])
+				date.append(p[3])
+	f1 = open(table_page, 'w')
+	x = len(cves)-1
+	# LIFO - means, reverse the array
+	while x!=-1:
+		resolved = getCVSentry(specs[x], revs[x])
+		if resolved == 0:
+			f1.write("<tr><td>%s</td>\n" % (date[x]))
+			f1.write("<td><a href=\"http://cvs.pld-linux.org/cgi-bin/cvsweb.cgi/SPECS/%s?rev=%s\">%s</a></td>\n" % (specs[x], revs[x], specs[x]))
+			f1.write("<td>%s</td>\n" % (cves[x]))
+			f1.write("<td>%s</td>\n" % (revs[x]))
+			f1.write("<td>%s</td></tr>\n" % (revs[x]))
+		else:
+			rev_tag = resolved.split(":")
+			f1.write("<tr><td>%s</td>\n" % (date[x]))
+			f1.write("<td><a href=\"http://cvs.pld-linux.org/cgi-bin/cvsweb.cgi/SPECS/%s?logsort=rev;only_with_tag=%s\">%s</a></td>\n" % (specs[x], rev_tag[0], specs[x]))
+			f1.write("<td>%s</td>\n" % (cves[x]))
+			f1.write("<td>%s</td>\n" % (revs[x]))
+			f1.write("<td>%s</td></tr>\n" % (resolved))
+		x = x-1
+	f1.close()
+	# write new file size
+	size = os.fstat(f.fileno())
+	size = str(size).split(", ")
+	fs = open(size_f, "w")
+	fs.write(size[6])
+	fs.close()
+
+# get cvs log entries (auto-tags) for specs
+def getCVSentry(spec, revision):
+	tags = []
+	autotag = os.popen("cvs -d %s log -tr%s: %s%s |grep -A300 symbolic |grep auto" % (cvsroot, revision, cvsmodule, spec))
+	for l in autotag.xreadlines():
+		l = l.strip()
+		tags.append(l)
+	try:
+		tag_rev = tags[0].split(" ")
+		if compRevs(tag_rev[1], revision)==0:
+			return tags[0]
+		else:
+			return 0
+	except(IndexError):
+		return 0
+		pass
+
+# get commits.log file
+def rsync():
+	os.system("rsync rsync://cvs.pld-linux.org/cvs/SPECS/commits.log .")
+
+# do I need to explain this function?
+def genPageHeader():
+	t = datetime.datetime.now()
+	EpochSeconds = time.mktime(t.timetuple())
+	now = datetime.datetime.fromtimestamp(EpochSeconds)
+	f = open(h_page, 'w')
+	f.write("<p align=\"center\">Generated on: %s</p>" % now.ctime())
+	f.write("<table><tr>\n")
+	f.write("<td><b>Date</b></td>\n")
+	f.write("<td><b>SPEC</b></td>\n")
+	f.write("<td><b>CVE Entry</b></td>\n")
+	f.write("<td><b>Revision</b></td>\n")
+	f.write("<td><b>Resolved with</b></td>\n")
+	f.write("</tr><tr>\n")
+	f.close()
+
+# ...or this one?
+def genPageFooter():
+	f = open(f_page, 'w')
+	f.write("</tr></table>\n")
+	f.write("<p align=\"right\">\n")
+	f.write("<img src=\"http://pl.docs.pld-linux.org/zrzuty_ekr/logo_03.png\" alt=\"PLD\" /></p>\n")
+	f.close()
+
+#compares whether rev1 is greater than rev2 and return 0 if true, 1 if false
+def compRevs(rev1, rev2):
+	rev1 = rev1.split(".")
+	rev2 = rev2.split(".")
+	if len(rev1) >= len(rev2):
+		for x in range(len(rev2)):
+			if (rev1[x]!=rev2[x]): 
+				if (rev1[x]>rev2[x]):
+					return 0
+					break
+				else:
+					return 1
+					break
+	elif len(rev1) < len(rev2):
+		for x in range(len(rev1)):
+			if (rev1[x]!=rev2[x]):
+				if (rev1[x]>rev2[x]):
+					return 0
+					break
+				else:
+					return 1
+					break
+	return 0	
+
+# now call them
+genPageHeader()
+#rsync()
+parse()
+genPageFooter()

Added: security/generate.sh
==============================================================================
--- (empty file)
+++ security/generate.sh	Sat Oct  6 13:06:11 2007
@@ -0,0 +1,8 @@
+#!/bin/sh
+
+mv security.html temp
+./cve_reader.py
+cat temp >> security.html
+rm temp
+cp /home/users/security/*.html /home/users/security/www/
+chmod a+r /home/users/security/www/*.html

Added: security/index.php
==============================================================================
--- (empty file)
+++ security/index.php	Sat Oct  6 13:06:11 2007
@@ -0,0 +1,99 @@
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="pl">
+<head>
+<title>PLD Security Logs</title>
+<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
+
+<style type="text/css">
+h2 { text-align: center; }
+body, td { font-family: Verdana; font-size: 9pt; }
+table { border-collapse: collapse; width: 100%; }
+td { padding: 6px 15px; }
+tr.entry { padding: 6px 15px; border-top: 3px solid #ebebe4; border-bottom: 1px solid #ebebe4 }
+tr.branch { padding: 6px 15px; width: 150px; color: red; } 
+.thead td, thead td, tfoot td { background-color: #ebebe4 }
+.thead td, thead td { border-bottom: 1px solid #c0c0c0; border-top: 1px solid #c0c0c0; padding: 5px 15px }
+.thead td a, thead td a { color: #000000 }
+tfoot td { border-top: 2px solid #c0c0c0; border-bottom: 1px solid #c0c0c0 }
+tfoot td a { display: block; padding: 2px 5px; border: 1px outset; float: left; border: 1px solid #c0c0c0; background-color: #ffffff; color: #000000; text-decoration: none; margin-left: 5px }
+#phonebookTable thead tr td div {
+	text-align: center;
+	font-weight: bold;
+}
+.status {
+	width: 200px;
+}
+.builder, .spec, .status {
+	width: 100px;
+}
+.recip {
+	width: 80px;
+}
+
+.date { 
+	width: 80px;
+	text-align: center;
+}
+.sender {
+	width: 80px;
+}
+.appInfoHead td {
+	text-decoration: underline;
+}
+tr.application:hover td {
+	background: #f2f2f2;
+}
+div#logoPLD {
+	text-align: right;
+}
+
+a, a:visited {
+	color: blue;
+}
+a:hover, a:visited:hover {
+	color: red;
+}
+
+a.mailto, a.mailto:visited {
+	background: url() right center no-repeat;
+	padding-right: 18px;
+}
+a.mailto:hover, a.mailto:visited:hover {
+	background-image: url();
+}
+#Popup {
+	display: none;
+	position: absolute;
+	padding: 2px;
+	border: 2px solid #c0c0c0;
+	background-color: #ebebe4;
+	color: #000;
+	z-index: 1000;
+	right: auto;
+	bottom: auto;
+	width: auto;
+	max-width: 490px;
+	height: auto;
+	left: 10px;
+	top: 10px;
+}
+.ok { color: green; }
+.fail { color: red; }
+#bottomlink {
+	padding: 15px 15px 15px 15px;
+	text-align: right;
+}
+
+</style>
+
+</head>
+<body>
+
+<h2>PLD Security Logs</h2>
+<?
+include("header.html");
+include("security.html");
+include("footer.html");
+?>
+</body>
+</html>


More information about the pld-cvs-commit mailing list