forked from cms-sw/cms-bot
-
Notifications
You must be signed in to change notification settings - Fork 0
/
es_cmsrep_apache.py
executable file
·67 lines (64 loc) · 2.67 KB
/
es_cmsrep_apache.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
#!/usr/bin/env python
from sys import exit
from datetime import datetime
from time import mktime
from es_utils import send_payload
from hashlib import sha1
from json import dumps
from logwatch import logwatch, run_cmd, LOGWATCH_APACHE_IGNORE_AGENTS
def process (line, count):
for agent in LOGWATCH_APACHE_IGNORE_AGENTS:
if agent in line: return True
payload = {}
items = line.split(" ")
if len(items)<12: return True
if not (items[3][0]=='[' and items[4][-1]==']'): return True
payload["ip"]=items[0]
payload["ident"]=items[1]
payload["auth"]=items[2]
payload["verb"]=items[5][1:]
payload["request"]=items[6]
payload["httpversion"]=items[7][:-1]
payload["response"]=items[8]
try:
payload["bytes"]=int(items[9])
except:
payload["bytes"]=0
payload["referrer"]=items[10][1:-1]
agent = " ".join(items[11:]).replace('"','')
if "CMSPKG-v" in agent: agent = agent.replace("-v","/")
payload["agent"]=agent
payload["agent_type"]=agent.replace(" ","-").split("/",1)[0].upper()
payload["@timestamp"]=int(mktime(datetime.strptime(items[3][1:],'%d/%b/%Y:%H:%M:%S').timetuple())*1000)
id = sha1(line).hexdigest()
if (count%1000)==0: print "Processed entries",count
if not send_payload("apache-cmsrep","access_log", id, dumps(payload), passwd_file="/data/es/es_secret"):
return False
if payload["verb"] != "GET": return True
items = payload["request"].replace("/cms/cpt/Software/download/","/cmssw/",1).split("/")
if len(items)<6: return True
if items[3] == "apt": items[3]="PRMS"
if items[3] != "RPMS": return True
pkg, cmspkg, arch, repo, dev = items[-1], "apt", "" , "", 0
if "?" in pkg:
pkg, pkgopts = pkg.split("?",1)
if "version=" in pkgopts: cmspkg = pkgopts.split("version=",1)[1].split("&",1)[0]
if not pkg.endswith(".rpm"): return True
if (items[1] == "cgi-bin") and items[2].startswith("cmspkg"):
if len(items)<8: return True
if items[2].endswith('-dev'): dev=1
repo, arch = items[4], items[5]
elif items[1] == "cmssw":
repo, arch = items[2], items[4]
else:
return True
from urllib import unquote
xpayload = {'dev' : dev, 'repository' : unquote(repo), 'architecture' : unquote(arch), 'package' : unquote(pkg).split("-1-",1)[0], 'cmspkg' : unquote(cmspkg)}
for x in ["@timestamp","ip"]: xpayload[x] = payload[x]
return send_payload("cmspkg-access","rpm-packages", id, dumps(xpayload), passwd_file="/data/es/es_secret")
count=run_cmd("pgrep -l -x -f '^python .*/es_cmsrep_apache.py$' | wc -l",False)
if int(count)>1: exit(0)
logs = run_cmd("ls -rt /var/log/httpd/access_log* | grep -v '[.]gz$'").split("\n")
log = logwatch("httpd",log_dir="/data/es")
s,c=log.process(logs, process)
print "Total entries processed",c