Commit cfff9b09 authored by Ad Schellevis's avatar Ad Schellevis Committed by Franco Fichtner

(captiveportal, new) style fixes

(cherry picked from commit 9dbf4dda)
parent 2d2864ee
...@@ -35,7 +35,7 @@ from lib.arp import ARP ...@@ -35,7 +35,7 @@ from lib.arp import ARP
from lib.ipfw import IPFW from lib.ipfw import IPFW
# parse input parameters # parse input parameters
parameters = {'username': '', 'ip_address': None, 'zoneid': None,'authenticated_via': None, 'output_type':'plain'} parameters = {'username': '', 'ip_address': None, 'zoneid': None, 'authenticated_via': None, 'output_type': 'plain'}
current_param = None current_param = None
for param in sys.argv[1:]: for param in sys.argv[1:]:
if len(param) > 1 and param[0] == '/': if len(param) > 1 and param[0] == '/':
......
...@@ -31,11 +31,10 @@ ...@@ -31,11 +31,10 @@
import sys import sys
import ujson import ujson
from lib.db import DB from lib.db import DB
from lib.arp import ARP
from lib.ipfw import IPFW from lib.ipfw import IPFW
# parse input parameters # parse input parameters
parameters = {'sessionid': None, 'zoneid': None, 'output_type':'plain'} parameters = {'sessionid': None, 'zoneid': None, 'output_type': 'plain'}
current_param = None current_param = None
for param in sys.argv[1:]: for param in sys.argv[1:]:
if len(param) > 1 and param[0] == '/': if len(param) > 1 and param[0] == '/':
...@@ -47,7 +46,7 @@ for param in sys.argv[1:]: ...@@ -47,7 +46,7 @@ for param in sys.argv[1:]:
# disconnect client # disconnect client
response = {'terminateCause': 'UNKNOWN'} response = {'terminateCause': 'UNKNOWN'}
if parameters['sessionid'] is not None and parameters['zoneid'] is not None: if parameters['sessionid'] is not None and parameters['zoneid'] is not None:
cp_db = DB() cp_db = DB()
# remove client # remove client
client_session_info = cp_db.del_client(parameters['zoneid'], parameters['sessionid']) client_session_info = cp_db.del_client(parameters['zoneid'], parameters['sessionid'])
......
...@@ -29,7 +29,7 @@ ...@@ -29,7 +29,7 @@
// try to login // try to login
$.ajax({ $.ajax({
type: "POST", type: "POST",
url: "http://127.0.0.1:8888/api/captiveportal/access/logon", url: "https://10.211.55.100/api/captiveportal/access/logon/0/",
dataType:"json", dataType:"json",
data:{ user: $("#inputUsername").val(), password: $("#inputPassword").val() } data:{ user: $("#inputUsername").val(), password: $("#inputPassword").val() }
}).done(function(data) { }).done(function(data) {
......
...@@ -77,15 +77,15 @@ class DB(object): ...@@ -77,15 +77,15 @@ class DB(object):
cur = self._connection.cursor() cur = self._connection.cursor()
# set cp_client as deleted in case there's already a user logged-in at this ip address. # set cp_client as deleted in case there's already a user logged-in at this ip address.
cur.execute("""update cp_clients cur.execute("""UPDATE cp_clients
set deleted = 1 SET deleted = 1
where zoneid = :zoneid WHERE zoneid = :zoneid
and ip_address = :ipAddress AND ip_address = :ipAddress
""", response) """, response)
# add new session # add new session
cur.execute("""insert into cp_clients(zoneid, authenticated_via, sessionid, username, ip_address, mac_address, created) cur.execute("""INSERT INTO cp_clients(zoneid, authenticated_via, sessionid, username, ip_address, mac_address, created)
values (:zoneid, :authenticated_via, :sessionId, :userName, :ipAddress, :macAddress, :startTime) VALUES (:zoneid, :authenticated_via, :sessionId, :userName, :ipAddress, :macAddress, :startTime)
""", response) """, response)
self._connection.commit() self._connection.commit()
...@@ -98,11 +98,11 @@ class DB(object): ...@@ -98,11 +98,11 @@ class DB(object):
:return: client info before removal or None if client not found :return: client info before removal or None if client not found
""" """
cur = self._connection.cursor() cur = self._connection.cursor()
cur.execute(""" select * cur.execute(""" SELECT *
from cp_clients FROM cp_clients
where sessionid = :sessionid WHERE sessionid = :sessionid
and zoneid = :zoneid AND zoneid = :zoneid
and deleted = 0 AND deleted = 0
""", {'zoneid': zoneid, 'sessionid': sessionid}) """, {'zoneid': zoneid, 'sessionid': sessionid})
data = cur.fetchall() data = cur.fetchall()
if len(data) > 0: if len(data) > 0:
...@@ -110,7 +110,7 @@ class DB(object): ...@@ -110,7 +110,7 @@ class DB(object):
for fields in cur.description: for fields in cur.description:
session_info[fields[0]] = data[0][len(session_info)] session_info[fields[0]] = data[0][len(session_info)]
# remove client # remove client
cur.execute("update cp_clients set deleted = 1 where sessionid = :sessionid and zoneid = :zoneid", cur.execute("UPDATE cp_clients SET deleted = 1 WHERE sessionid = :sessionid AND zoneid = :zoneid",
{'zoneid': zoneid, 'sessionid': sessionid}) {'zoneid': zoneid, 'sessionid': sessionid})
self._connection.commit() self._connection.commit()
...@@ -118,7 +118,6 @@ class DB(object): ...@@ -118,7 +118,6 @@ class DB(object):
else: else:
return None return None
def list_clients(self, zoneid): def list_clients(self, zoneid):
""" return list of (administrative) connected clients and usage statistics """ return list of (administrative) connected clients and usage statistics
:param zoneid: zone id :param zoneid: zone id
...@@ -128,22 +127,22 @@ class DB(object): ...@@ -128,22 +127,22 @@ class DB(object):
fieldnames = list() fieldnames = list()
cur = self._connection.cursor() cur = self._connection.cursor()
# rename fields for API # rename fields for API
cur.execute(""" select cc.zoneid cur.execute(""" SELECT cc.zoneid
, cc.sessionid sessionId , cc.sessionid sessionId
, cc.authenticated_via authenticated_via , cc.authenticated_via authenticated_via
, cc.username userName , cc.username userName
, cc.created startTime , cc.created startTime
, cc.ip_address ipAddress , cc.ip_address ipAddress
, cc.mac_address macAddress , cc.mac_address macAddress
, case when si.packets_in is null then 0 else si.packets_in end packets_in , CASE WHEN si.packets_in IS NULL THEN 0 ELSE si.packets_in END packets_in
, case when si.packets_out is null then 0 else si.packets_out end packets_out , CASE WHEN si.packets_out IS NULL THEN 0 ELSE si.packets_out END packets_out
, case when si.bytes_in is null then 0 else si.bytes_in end bytes_in , CASE WHEN si.bytes_in IS NULL THEN 0 ELSE si.bytes_in END bytes_in
, case when si.bytes_out is null then 0 else si.bytes_out end bytes_out , CASE WHEN si.bytes_out IS NULL THEN 0 ELSE si.bytes_out END bytes_out
, case when si.last_accessed is null then 0 else si.last_accessed end last_accessed , CASE WHEN si.last_accessed IS NULL THEN 0 ELSE si.last_accessed END last_accessed
from cp_clients cc FROM cp_clients cc
left join session_info si on si.zoneid = cc.zoneid and si.sessionid = cc.sessionid LEFT JOIN session_info si ON si.zoneid = cc.zoneid AND si.sessionid = cc.sessionid
where cc.zoneid = :zoneid WHERE cc.zoneid = :zoneid
and cc.deleted = 0 AND cc.deleted = 0
""", {'zoneid': zoneid}) """, {'zoneid': zoneid})
while True: while True:
# fetch field names # fetch field names
...@@ -218,12 +217,15 @@ class DB(object): ...@@ -218,12 +217,15 @@ class DB(object):
# add usage to session # add usage to session
record['last_accessed'] = details[record['ip_address']]['last_accessed'] record['last_accessed'] = details[record['ip_address']]['last_accessed']
if record['prev_packets_in'] <= details[record['ip_address']]['in_pkts'] and \ if record['prev_packets_in'] <= details[record['ip_address']]['in_pkts'] and \
record['prev_packets_out'] <= details[record['ip_address']]['out_pkts']: record['prev_packets_out'] <= details[record['ip_address']]['out_pkts']:
# ipfw data is still valid, add difference to use # ipfw data is still valid, add difference to use
record['packets_in'] = (details[record['ip_address']]['in_pkts'] - record['prev_packets_in']) record['packets_in'] = (
record['packets_out'] = (details[record['ip_address']]['out_pkts'] - record['prev_packets_out']) details[record['ip_address']]['in_pkts'] - record['prev_packets_in'])
record['bytes_in'] = (details[record['ip_address']]['in_bytes'] - record['prev_bytes_in']) record['packets_out'] = (
record['bytes_out'] = (details[record['ip_address']]['out_bytes'] - record['prev_bytes_out']) details[record['ip_address']]['out_pkts'] - record['prev_packets_out'])
record['bytes_in'] = (details[record['ip_address']]['in_bytes'] - record['prev_bytes_in'])
record['bytes_out'] = (
details[record['ip_address']]['out_bytes'] - record['prev_bytes_out'])
else: else:
# the data has been reset (reloading rules), add current packet count # the data has been reset (reloading rules), add current packet count
record['packets_in'] = details[record['ip_address']]['in_pkts'] record['packets_in'] = details[record['ip_address']]['in_pkts']
......
...@@ -114,10 +114,10 @@ class IPFW(object): ...@@ -114,10 +114,10 @@ class IPFW(object):
if ip_address not in result: if ip_address not in result:
result[ip_address] = {'rule': int(parts[0]), result[ip_address] = {'rule': int(parts[0]),
'last_accessed': 0, 'last_accessed': 0,
'in_pkts' : 0, 'in_pkts': 0,
'in_bytes' : 0, 'in_bytes': 0,
'out_pkts' : 0, 'out_pkts': 0,
'out_bytes' : 0 'out_bytes': 0
} }
result[ip_address]['last_accessed'] = max(result[ip_address]['last_accessed'], result[ip_address]['last_accessed'] = max(result[ip_address]['last_accessed'],
last_accessed) last_accessed)
......
...@@ -33,7 +33,7 @@ import ujson ...@@ -33,7 +33,7 @@ import ujson
from lib.db import DB from lib.db import DB
# parse input parameters # parse input parameters
parameters = {'zoneid': None, 'output_type':'plain'} parameters = {'zoneid': None, 'output_type': 'plain'}
current_param = None current_param = None
for param in sys.argv[1:]: for param in sys.argv[1:]:
if len(param) > 1 and param[0] == '/': if len(param) > 1 and param[0] == '/':
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment