Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
O
OpnSense
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Kulya
OpnSense
Commits
7e9c0dde
Commit
7e9c0dde
authored
Sep 28, 2015
by
Ad Schellevis
Committed by
Franco Fichtner
Sep 29, 2015
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
(captiveportal, new) work in progress script base
(cherry picked from commit
518f6cc1
)
parent
0fb6b319
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
76 additions
and
1 deletion
+76
-1
allow.py
src/opnsense/scripts/OPNsense/CaptivePortal/allow.py
+3
-0
ipfw.py
src/opnsense/scripts/OPNsense/CaptivePortal/lib/ipfw.py
+73
-1
No files found.
src/opnsense/scripts/OPNsense/CaptivePortal/allow.py
View file @
7e9c0dde
...
@@ -63,6 +63,9 @@ if parameters['ip_address'] is not None and parameters['zoneid'] is not None:
...
@@ -63,6 +63,9 @@ if parameters['ip_address'] is not None and parameters['zoneid'] is not None:
# check if address is not already registered before adding it to the ipfw table
# check if address is not already registered before adding it to the ipfw table
if
not
cpIPFW
.
ip_or_net_in_table
(
table_number
=
parameters
[
'zoneid'
],
address
=
parameters
[
'ip_address'
]):
if
not
cpIPFW
.
ip_or_net_in_table
(
table_number
=
parameters
[
'zoneid'
],
address
=
parameters
[
'ip_address'
]):
cpIPFW
.
add_to_table
(
table_number
=
parameters
[
'zoneid'
],
address
=
parameters
[
'ip_address'
])
cpIPFW
.
add_to_table
(
table_number
=
parameters
[
'zoneid'
],
address
=
parameters
[
'ip_address'
])
# add accounting for this ip address
cpIPFW
.
add_accounting
(
parameters
[
'ip_address'
])
response
[
'state'
]
=
'AUTHORIZED'
response
[
'state'
]
=
'AUTHORIZED'
else
:
else
:
response
=
{
'state'
:
'UNKNOWN'
}
response
=
{
'state'
:
'UNKNOWN'
}
...
...
src/opnsense/scripts/OPNsense/CaptivePortal/lib/ipfw.py
View file @
7e9c0dde
...
@@ -74,7 +74,6 @@ class IPFW(object):
...
@@ -74,7 +74,6 @@ class IPFW(object):
DEVNULL
=
open
(
os
.
devnull
,
'w'
)
DEVNULL
=
open
(
os
.
devnull
,
'w'
)
subprocess
.
call
([
'/sbin/ipfw'
,
'table'
,
table_number
,
'add'
,
address
],
stdout
=
DEVNULL
,
stderr
=
DEVNULL
)
subprocess
.
call
([
'/sbin/ipfw'
,
'table'
,
table_number
,
'add'
,
address
],
stdout
=
DEVNULL
,
stderr
=
DEVNULL
)
def
delete_from_table
(
self
,
table_number
,
address
):
def
delete_from_table
(
self
,
table_number
,
address
):
""" remove entry from ipfw table
""" remove entry from ipfw table
:param table_number: ipfw table number
:param table_number: ipfw table number
...
@@ -83,3 +82,76 @@ class IPFW(object):
...
@@ -83,3 +82,76 @@ class IPFW(object):
"""
"""
DEVNULL
=
open
(
os
.
devnull
,
'w'
)
DEVNULL
=
open
(
os
.
devnull
,
'w'
)
subprocess
.
call
([
'/sbin/ipfw'
,
'table'
,
table_number
,
'delete'
,
address
],
stdout
=
DEVNULL
,
stderr
=
DEVNULL
)
subprocess
.
call
([
'/sbin/ipfw'
,
'table'
,
table_number
,
'delete'
,
address
],
stdout
=
DEVNULL
,
stderr
=
DEVNULL
)
def
list_accounting_info
(
self
):
""" list accounting info per ip addres, addresses can't overlap in zone's so we just output all we know here
instead of trying to map addresses back to zones.
:return: list accounting info per ip address
"""
DEVNULL
=
open
(
os
.
devnull
,
'w'
)
result
=
dict
()
with
tempfile
.
NamedTemporaryFile
()
as
output_stream
:
subprocess
.
check_call
([
'/sbin/ipfw'
,
'-aT'
,
'list'
],
stdout
=
output_stream
,
stderr
=
DEVNULL
)
output_stream
.
seek
(
0
)
for
line
in
output_stream
.
read
()
.
split
(
'
\n
'
):
parts
=
line
.
split
()
if
len
(
parts
)
>
5
:
if
30001
<=
int
(
parts
[
0
])
<=
50000
and
parts
[
4
]
==
'count'
:
in_pkts
=
int
(
parts
[
1
])
out_pkts
=
int
(
parts
[
2
])
last_accessed
=
int
(
parts
[
3
])
if
parts
[
7
]
!=
'any'
:
ip_address
=
parts
[
7
]
else
:
ip_address
=
parts
[
9
]
if
ip_address
not
in
result
:
result
[
ip_address
]
=
{
'rule'
:
int
(
parts
[
0
]),
'last_accessed'
:
last_accessed
,
'in_pkts'
:
in_pkts
,
'out_pkts'
:
out_pkts
}
else
:
result
[
ip_address
][
'in_pkts'
]
+=
in_pkts
result
[
ip_address
][
'out_pkts'
]
+=
out_pkts
result
[
ip_address
][
'last_accessed'
]
=
max
(
result
[
ip_address
][
'last_accessed'
],
last_accessed
)
return
result
def
add_accounting
(
self
,
address
):
""" add ip address for accounting
:param address: ip address
:return: None
"""
# search for unused rule number
acc_info
=
self
.
list_accounting_info
()
if
address
not
in
acc_info
:
rule_ids
=
list
()
for
ip_address
in
acc_info
:
if
acc_info
[
ip_address
][
'rule'
]
not
in
rule_ids
:
rule_ids
.
append
(
acc_info
[
ip_address
][
'rule'
])
newRuleid
=
-
1
for
ruleId
in
range
(
30001
,
50000
):
if
ruleId
not
in
rule_ids
:
newRuleid
=
ruleId
break
# add accounting rule
DEVNULL
=
open
(
os
.
devnull
,
'w'
)
subprocess
.
call
([
'/sbin/ipfw'
,
'add'
,
'count'
,
'ip'
,
'from'
,
address
,
'to'
,
'any'
],
stdout
=
DEVNULL
,
stderr
=
DEVNULL
)
subprocess
.
call
([
'/sbin/ipfw'
,
'add'
,
'count'
,
'ip'
,
'from'
,
'any'
,
'to'
,
address
],
stdout
=
DEVNULL
,
stderr
=
DEVNULL
)
def
del_accounting
(
self
,
address
):
""" remove ip address from accounting rules
:param address: ip address
:return: None
"""
acc_info
=
self
.
list_accounting_info
()
if
address
in
acc_info
:
DEVNULL
=
open
(
os
.
devnull
,
'w'
)
subprocess
.
call
([
'/sbin/ipfw'
,
'delete'
,
acc_info
[
address
][
'rule'
]],
stdout
=
DEVNULL
,
stderr
=
DEVNULL
)
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment