2017-09-29 16:37:30 +00:00
|
|
|
#!/usr/bin/env python
|
|
|
|
# Python helper tool to purge expired clients from DB and iptables. Requires
|
|
|
|
# root privileges for iptc to work.
|
|
|
|
|
|
|
|
from sys import exit
|
|
|
|
from argparse import ArgumentParser, FileType
|
|
|
|
from pprint import pprint as pp
|
|
|
|
from configparser import RawConfigParser
|
|
|
|
from datetime import datetime, timedelta
|
|
|
|
|
|
|
|
import errors
|
|
|
|
from storage import StoragePostgres
|
|
|
|
from client import Client
|
|
|
|
|
|
|
|
|
|
|
|
parser = ArgumentParser((
|
|
|
|
'Purge expired clients by disabling them.'
|
|
|
|
))
|
|
|
|
|
|
|
|
parser.add_argument(
|
|
|
|
'--config',
|
|
|
|
type=FileType('r'),
|
|
|
|
required=True,
|
|
|
|
help='Configuration file'
|
|
|
|
)
|
|
|
|
|
|
|
|
args = parser.parse_args()
|
|
|
|
|
|
|
|
config = RawConfigParser()
|
|
|
|
config.readfp(args.config)
|
|
|
|
|
|
|
|
sr = StoragePostgres(config=config)
|
|
|
|
|
2017-09-29 17:07:32 +00:00
|
|
|
for client_id in sr.client_ids():
|
2017-09-29 16:37:30 +00:00
|
|
|
client = Client(
|
|
|
|
storage=sr,
|
|
|
|
chain=config.get('iptables', 'chain'),
|
2017-09-29 17:07:32 +00:00
|
|
|
client_id=client_id[0]
|
2017-09-29 16:37:30 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
if datetime.now() > client.expires:
|
|
|
|
client.enabled = False
|
|
|
|
client.commit()
|
|
|
|
else:
|
|
|
|
# Simply commit whatever was loaded during Client.__init__(), like
|
|
|
|
# up-to-date packet count stats for example.
|
|
|
|
client.commit()
|