ip: 44.220.247.152
import os
from pathlib import Path
import sys
########################################################################
#Classes
class filek:
path = ''
size = 0
def __init__(self, _path, _size):
self.path = _path
self.size = _size
########################################################################
# Main
########################################################################
lista = []
b = len(sys.argv)
if b != 2 and b != 3:
print ("directory must be specified, min file size is optional")
print ("findLargestFiles . 1024")
print ("findLargestFiles /var")
exit()
#if not defined set min length to 1 byte
if b == 2:
limit = 1
else:
limit = int(sys.argv[2])
if limit<1: limit = 1
#create list with all files
if int(limit) > 0:
import os
for path, dirs, files in os.walk(sys.argv[1]):
for f in files:
size=os.path.getsize( os.path.join( path, f ))
if size>limit:
lista.append(filek(path + f, size))
#print (path, f, size)
lista.sort(key=lambda x: x.size, reverse=True)
for x in lista:
print ("%10d %s" % (x.size, x.path))
import os
LogFile = "f:\\Logs\\W3SVC44\\u_ex201227_x.log" #file to be parsed
pattern = set(['SELECT%','%27%20OR%201%3d','UPDATEXML','EXTRACTVALUE','GTID_SUBSET','%20and%20']) #string for search
saveDirtyLog = "output.txt" #set up file for CERT report
saveIPs = "IPs.txt" #list of IP that are flagged for CERT report
toFile=1 #0-print to console, 1-print to file
fields = {} #column definition
fieldsLoaded = False #are fields defined
IpList = set([]) #IP list
useProxy = 0 #is reversed proxy used (X-Forwarded-For instead od c-ip)
Lines = [] # line of log text
#tranform all search string to lower
for i in pattern:
i = i.lower()
#open file for parsing
with open(LogFile,'r',encoding='utf8',errors='ignore') as f:
Lines = f.readlines()
count = 0
# Strips the newline character
for line in Lines:
#header
if (line.startswith("#Fields:")):
brojac = -1
for l in line.split(' '):
if (l != "#Fields:"):
l = l.lower().strip()
fields[l] = brojac
if (l == "x-forwarded-for"):
useProxy = 1
brojac += 1
fieldsLoaded = True
continue
if (line.startswith("#")):
continue
if (fieldsLoaded):
#Log parsing
s = line.split(' ')
#print ("cs-uri-query: ")
#print (s[fields["cs-uri-query"]])
try:
q = s[fields["cs-uri-query"]].lower()
except:
continue
#print ("q: ",q,", column: ", fields["cs-uri-query"])
if (q == '-'):
continue
if any(p.lower() in q for p in pattern):
#print ("q: ", q, ", stupac: ", fields["cs-uri-query"], ", BREAK")
#ignore white listed IP address
if (s[fields["c-ip"]].strip() != "1.1.1.1" ):
if (useProxy == 1):
if (s[fields["x-forwarded-for"]].strip() != "1.1.1.1"):
IpList.add(s[fields["x-forwarded-for"]].strip())
else:
IpList.add(s[fields["c-ip"]].strip())
#break
#if (line.find(pattern)!= -1):
count += 1
# debug
# print ("\nfieldsLoaded: ", fieldsLoaded)
# print ("\nfields: " , fields)
# print ("\ncount: ", count)
# print ("\nuseProxy: " , useProxy)
# print ("\npattern: ", pattern)
if (toFile == 1):
#write IPs to file
with open(saveIPs, 'w') as f:
for line in sorted(IpList):
f.write(line + "\n") # set of numbers & a tuple
if os.path.exists(saveDirtyLog):
os.remove(saveDirtyLog)
br = 0
with open(saveDirtyLog, 'a') as app:
#CERT report
for line in Lines:
if (line.startswith("#")):
if (br<6):
app.write (line)
continue
if IpList & set(line.split()):
app.write(line)
br += 1
else:
print ("\nIPs:" , sorted(IpList) )
print ("\nLog:")
br=0
for line in Lines:
if (not line.startswith("#")):
s = line.split(' ')
q = s[fields["cs-uri-query"]].lower()
if any(p.lower() in q for p in pattern):
#if (q.find(pattern) != -1):
print(line.strip())
br+=1
print ("\nnumber of lines matching searched strings: ", br)
import os
from pathlib import Path
import sys
########################################################################
# Classes
class filek:
path = ''
size = 0
def __init__(self, _path, _size):
self.path = _path
self.size = _size
########################################################################
# Main
########################################################################
lista = []
b = len(sys.argv)
if b != 2 and b != 3:
print ("Directory is mandatory, min file size is optional)")
print ("findLargestFiles . 1024")
print ("findLargestFiles .")
exit()
if b == 2:
limit = 1
else:
limit = int(sys.argv[2])
if limit<1: limit = 1
if int(limit) > 0:
for path, dirs, files in os.walk(sys.argv[1]):
for f in files:
size=os.path.getsize(os.path.join( path, f ))
if size>limit:
lista.append(filek(path + f, size))
#print (path, f, size)
lista.sort(key=lambda x: x.size, reverse=True)
for x in lista:
print ("%10d %s" % (x.size, x.path))
import os
import sys
import dns.resolver
from netaddr import *
from termcolor import colored
lista = [
'damir.globaldizajn.hr',
'google.com',
'gmail.com'
]
IP = ""
for x in lista:
try:
a = dns.resolver.resolve(x, 'A')
for r in a:
IP = str(r)
print (IP, colored(x,"green"))
except:
print ("000.000.000.000", x, "non existing domain")
continue
import os
import sys
import dns.resolver
from netaddr import *
from termcolor import colored
import requests
lista = [
'https://damir.globaldizajn.hr',
'httsp://google.com',
'https://gmail.com'
]
boja = "white"
for x in lista:
try:
r = requests.get(x)
if str(r.history) == "[]":
boja = "white"
else:
boja = "yellow"
if r.status_code == 200:
print (str(x) + " - " + colored(str(r.history),boja) + " * " + colored (str(r.status_code), "green" ))
else:
#print (str(x) + " - " + colored(str(r.history),boja) + " * " + colored (str(r.status_code),"red"))
except:
print (x, " ERROR " + str(sys.exc_info()[0]))
continue
import glob
for filename in glob.iglob("./" + '**/*.txt', recursive=True):
print(filename)
import re
#list of all IPs
lista = []
#open file in which are IPs all around
file1 = open('file.txt','r',encoding='utf8',errors='ignore')
Lines = file1.readlines()
for line in Lines:
#find all IPs in one line of text in file
x = re.findall("\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}", line, flags=re.IGNORECASE)
for i in x:
lista.append(i)
#remove duplicates
l = list(set(lista))
#sort it
l.sort()
#display all
for i in l:
print (i)
How to monitor UPS for you PC with python, this script can be executed every minute and if UPS looses grid power send email to alert someone
import psutil
import smtplib
from email.mime.text import MIMEText
def sendMail(onPower, percent):
sender = 'UPS@example.com'
receiver = 'receiver@example.com'
msg = MIMEText("UPS status onPower: " + onPower + ", battery percent: " + percent + "\n" )
msg['From'] = sender
msg['To'] = receiver
msg['Subject'] = 'UPS alert PC on battery power'
s = smtplib.SMTP('localhost')
s.sendmail(sender, [receiver], msg.as_string())
s.quit()
battery = psutil.sensors_battery()
if battery.power_plugged == True:
print("UPS is connected to grid")
else:
print("UPS not connected to grid, send alert email")
sendMail( str(battery.power_plugged), str(battery.percent))
import subprocess
result = subprocess.run(['ls', '-l'], stdout=subprocess.PIPE)
print (str(result.stdout))
cmd = "ls -al | grep aaa"
ps = subprocess.Popen(cmd,shell=True,stdout=subprocess.PIPE,stderr=subprocess.STDOUT)
output = str(ps.communicate()[0]).replace("\\n","\n")
import re
z = re.findall("FROM:(<[^>]+>)", next_line, flags=re.IGNORECASE)
if z:
From = z[0]
with open('filename.txt','r',encoding='utf8',errors='ignore') as fRead:
for line in fRead:
print(line)
if str.find("substr") != -1:
print("true")
or
if "substr" in str:
print("true")
How to access MS SQL Server with python
import pyodbc
conn_str = 'Driver={SQL Server};SERVER=sqlServer;DATABASE=DBName;UID=login;PWD=password'
conn = pyodbc.connect(conn_str)
cursor = conn.cursor()
sql = "SELECT * FROM myTable"
cursor.execute(sql)
records = cursor.fetchall()
for row in records:
ID = row.ID
UserName = row.UserName
print("ID: " + str(ID) + ", user: " + UserName)