1
0
mirror of https://github.com/r4sas/py-i2phosts synced 2025-01-09 22:38:08 +00:00
py-i2phosts/py-i2phosts-injector
Hidden Z 584d113a06 py-i2phosts-injector: add extra newline for error message
This improves output readability significantly.
2010-10-22 18:51:13 +00:00

65 lines
2.1 KiB
Python
Executable File

#!/usr/bin/python
import os
import sys
import argparse
from django.core.exceptions import ValidationError
# django setup
DJANGO_SETTINGS_MODULE = 'settings'
DJANGO_PROJECT_PATH = os.path.dirname(sys.argv[0]) + '/web'
sys.path.insert(1, DJANGO_PROJECT_PATH)
os.environ['DJANGO_SETTINGS_MODULE'] = DJANGO_SETTINGS_MODULE
from web.postkey.models import i2phost
from web.lib.validation import validate_hostname
from web.lib.validation import validate_b64hash
# parse command line options
parser = argparse.ArgumentParser(
description='Hosts injector for py-i2phosts.',
epilog='Report bugs to http://zzz.i2p/topics/733')
parser.add_argument('-f', '--file', default=os.environ['HOME'] + '/.i2p/hosts.txt', dest='hostsfile',
help='hosts.txt for parsing')
parser.add_argument('-d', '--description', default='Auto-added from external hosts.txt',
help='provide custom description message')
parser.add_argument('-s', '--supress', action='store_true',
help='supress warnings about already existed hostnames'),
parser.add_argument('-q', '--quiet', action='store_true',
help='be completely quiet, print only errors')
args = parser.parse_args()
if args.quiet:
args.supress = True
f = open(args.hostsfile, 'r')
for line in f:
# ignore comments and empty lines
if line.startswith('#') or line.isspace():
continue
if line.find('=') == -1:
sys.stderr.write('Invalid line: %s\n' % line)
continue
# strip trailing '\n'
line = line.rstrip('\n')
entry = line.split('=')
try:
hostname = validate_hostname(entry[0])
base64 = validate_b64hash(entry[1], check_uniq=False) # don't require uniqueness
except ValidationError, e:
sys.stderr.write('validation error: %s: %s\n\n' % (e, line))
else:
# Check for already existed hosts in database to avoid unneeded INSERTs
# beacuse they will fail anyway.
qs = i2phost.objects.filter(name=hostname)
if qs.exists():
if not args.supress:
print 'Host %s already exists' % hostname
else:
if not args.quiet:
print 'Adding %s' % hostname
host = i2phost(name=hostname, b64hash=base64,
description=args.description,
activated=True, external=True)
host.save()
f.close()