filters-maker/maker_domains.py

38 lines
1.3 KiB
Python
Raw Normal View History

2021-08-01 11:05:44 +00:00
import os
import sys
import datetime
import pytz
UTC = pytz.utc
date = datetime.datetime.now(UTC)
def linecounter(incoming):
with open(incoming) as f:
2021-08-01 11:05:44 +00:00
for i, l in enumerate(f):
pass
return i + 1
2021-08-02 14:00:05 +00:00
def domainsbuilding(excluded ,incoming):
2021-08-01 11:05:44 +00:00
with open(excluded ,'r') as f:
exclude = f.read().split()
2021-08-02 14:00:05 +00:00
with open(incoming ,'r') as f:
2021-08-01 11:05:44 +00:00
lines = f.read().splitlines() # read lines
2021-08-02 14:00:05 +00:00
with open(incoming ,'w') as f:
2021-08-01 11:05:44 +00:00
f.write('# Title : Minoplhy Personal Blocklist\n')
f.write('# Description : My Very Personal DNS Blocklist plus crawling from the source\n')
2021-08-01 11:07:39 +00:00
f.write('# Source : Resources/Source.txt\n')
2021-08-02 14:29:04 +00:00
f.write('# Rule Counter : ' + str(linecounter(incoming)) +' Rules\n')
2021-08-01 11:05:44 +00:00
f.write('# Format : Domains\n')
f.write('# Licenses : MIT\n')
f.write('# Compiled Date : ' + str(date) +'\n\n')
for line in lines:
if line.strip() and not line in exclude and not line.startswith('#'):
f.write('\n'.join([line + '\n']))
if line.startswith((';','$','@',' IN')):
f.write('\n'.join([line + '\n']))
if not line.strip():
f.write('\n'.join([line + '\n']))
f.close()
2021-08-02 14:00:05 +00:00
if __name__ == "__main__":
domainsbuilding(None,'test.txt')