Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
P
pim_dm
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
pim_dm
Commits
ee35f93e
Commit
ee35f93e
authored
Jul 25, 2017
by
Pedro Oliveira
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
fix ipv6 support in address encoding
parent
506bb655
Changes
7
Show whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
108 additions
and
52 deletions
+108
-52
Main.py
Main.py
+11
-7
Packet/PacketPimEncodedGroupAddress.py
Packet/PacketPimEncodedGroupAddress.py
+21
-11
Packet/PacketPimEncodedSourceAddress.py
Packet/PacketPimEncodedSourceAddress.py
+24
-12
Packet/PacketPimEncodedUnicastAddress.py
Packet/PacketPimEncodedUnicastAddress.py
+17
-9
Packet/PacketPimJoinPrune.py
Packet/PacketPimJoinPrune.py
+13
-4
Packet/PacketPimJoinPruneMulticastGroup.py
Packet/PacketPimJoinPruneMulticastGroup.py
+19
-8
Run.py
Run.py
+3
-1
No files found.
Main.py
View file @
ee35f93e
...
@@ -17,9 +17,8 @@ def add_interface(interface_name):
...
@@ -17,9 +17,8 @@ def add_interface(interface_name):
interfaces
[
interface_name
]
=
interface
interfaces
[
interface_name
]
=
interface
protocols
[
0
].
force_send
(
interface
)
protocols
[
0
].
force_send
(
interface
)
# TODO: verificar melhor este metodo:
def
remove_interface
(
interface_name
):
def
remove_interface
(
interface_name
):
# TODO remover neighbors desta interface
global
interfaces
global
interfaces
global
neighbors
global
neighbors
if
(
interface_name
in
interfaces
)
or
interface_name
==
"*"
:
if
(
interface_name
in
interfaces
)
or
interface_name
==
"*"
:
...
@@ -34,12 +33,10 @@ def remove_interface(interface_name):
...
@@ -34,12 +33,10 @@ def remove_interface(interface_name):
print
(
"removido interface"
)
print
(
"removido interface"
)
for
(
ip_neighbor
,
neighbor
)
in
list
(
neighbors
.
items
()):
for
(
ip_neighbor
,
neighbor
)
in
list
(
neighbors
.
items
()):
# TODO ver melhor este algoritmo
if
neighbor
.
contact_interface
not
in
interfaces
:
if
neighbor
.
contact_interface
not
in
interfaces
or
interface_name
==
"*"
:
neighbor
.
remove
()
neighbor
.
remove
()
def
add_neighbor
(
contact_interface
,
ip
,
random_number
,
hello_hold_time
):
def
add_neighbor
(
contact_interface
,
ip
,
random_number
,
hello_hold_time
):
global
neighbors
global
neighbors
if
ip
not
in
neighbors
:
if
ip
not
in
neighbors
:
...
@@ -77,7 +74,7 @@ def list_neighbors():
...
@@ -77,7 +74,7 @@ def list_neighbors():
def
list_enabled_interfaces
():
def
list_enabled_interfaces
():
global
interfaces
global
interfaces
# TESTE DE PIM JOIN/PRUNE
for
interface
in
interfaces
:
for
interface
in
interfaces
:
from
Packet.Packet
import
Packet
from
Packet.Packet
import
Packet
from
Packet.PacketPimHeader
import
PacketPimHeader
from
Packet.PacketPimHeader
import
PacketPimHeader
...
@@ -85,7 +82,14 @@ def list_enabled_interfaces():
...
@@ -85,7 +82,14 @@ def list_enabled_interfaces():
from
Packet.PacketPimJoinPruneMulticastGroup
import
PacketPimJoinPruneMulticastGroup
from
Packet.PacketPimJoinPruneMulticastGroup
import
PacketPimJoinPruneMulticastGroup
ph
=
PacketPimJoinPrune
(
"10.0.0.13"
,
210
)
ph
=
PacketPimJoinPrune
(
"10.0.0.13"
,
210
)
ph
.
add_multicast_group
(
PacketPimJoinPruneMulticastGroup
(
"239.123.123.123"
,
[
"1.1.1.1"
],
[]))
ph
.
add_multicast_group
(
PacketPimJoinPruneMulticastGroup
(
"239.123.123.123"
,
[
"1.1.1.1"
,
"10.1.1.1"
],
[]))
ph
.
add_multicast_group
(
PacketPimJoinPruneMulticastGroup
(
"239.123.123.124"
,
[
"1.1.1.2"
,
"10.1.1.2"
],
[]))
pckt
=
Packet
(
pim_header
=
PacketPimHeader
(
ph
))
interfaces
[
interface
].
send
(
pckt
.
bytes
())
ph
=
PacketPimJoinPrune
(
"ff08::1"
,
210
)
ph
.
add_multicast_group
(
PacketPimJoinPruneMulticastGroup
(
"2001:1:a:b:c::1"
,
[
"1.1.1.1"
,
"2001:1:a:b:c::2"
],
[]))
ph
.
add_multicast_group
(
PacketPimJoinPruneMulticastGroup
(
"239.123.123.123"
,
[
"1.1.1.1"
],
[
"2001:1:a:b:c::3"
]))
pckt
=
Packet
(
pim_header
=
PacketPimHeader
(
ph
))
pckt
=
Packet
(
pim_header
=
PacketPimHeader
(
ph
))
interfaces
[
interface
].
send
(
pckt
.
bytes
())
interfaces
[
interface
].
send
(
pckt
.
bytes
())
...
...
Packet/PacketPimEncodedGroupAddress.py
View file @
ee35f93e
...
@@ -11,8 +11,15 @@ import socket
...
@@ -11,8 +11,15 @@ import socket
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+...
'''
'''
class
PacketPimEncodedGroupAddress
:
class
PacketPimEncodedGroupAddress
:
PIM_ENCODED_GROUP_ADDRESS_HDR
=
"! BBBB 4s"
PIM_ENCODED_GROUP_ADDRESS_HDR
=
"! BBBB %s"
PIM_ENCODED_GROUP_ADDRESS_HDR_LEN
=
struct
.
calcsize
(
PIM_ENCODED_GROUP_ADDRESS_HDR
)
PIM_ENCODED_GROUP_ADDRESS_HDR_WITHOUT_GROUP_MULTICAST_ADDRESS
=
"! BBBB"
IPV4_HDR
=
"4s"
IPV6_HDR
=
"16s"
# TODO ver melhor versao ip
PIM_ENCODED_GROUP_ADDRESS_HDR_LEN
=
struct
.
calcsize
(
PIM_ENCODED_GROUP_ADDRESS_HDR
%
IPV4_HDR
)
PIM_ENCODED_GROUP_ADDRESS_HDR_LEN_IPv6
=
struct
.
calcsize
(
PIM_ENCODED_GROUP_ADDRESS_HDR
%
IPV6_HDR
)
FAMILY_RESERVED
=
0
FAMILY_RESERVED
=
0
FAMILY_IPV4
=
1
FAMILY_IPV4
=
1
...
@@ -20,7 +27,7 @@ class PacketPimEncodedGroupAddress:
...
@@ -20,7 +27,7 @@ class PacketPimEncodedGroupAddress:
RESERVED
=
0
RESERVED
=
0
def
__init__
(
self
,
group_address
,
mask_len
=
32
):
def
__init__
(
self
,
group_address
,
mask_len
=
None
):
if
type
(
group_address
)
not
in
(
str
,
bytes
):
if
type
(
group_address
)
not
in
(
str
,
bytes
):
raise
Exception
raise
Exception
if
type
(
group_address
)
is
bytes
:
if
type
(
group_address
)
is
bytes
:
...
@@ -29,18 +36,21 @@ class PacketPimEncodedGroupAddress:
...
@@ -29,18 +36,21 @@ class PacketPimEncodedGroupAddress:
self
.
mask_len
=
mask_len
self
.
mask_len
=
mask_len
def
bytes
(
self
)
->
bytes
:
def
bytes
(
self
)
->
bytes
:
addr_family
=
self
.
get_addr_family
(
self
.
group_address
)
(
string_ip_hdr
,
hdr_addr_family
,
socket_family
)
=
PacketPimEncodedGroupAddress
.
get_ip_info
(
self
.
group_address
)
ip
=
socket
.
inet_aton
(
self
.
group_address
)
if
self
.
mask_len
is
None
:
msg
=
struct
.
pack
(
PacketPimEncodedGroupAddress
.
PIM_ENCODED_GROUP_ADDRESS_HDR
,
addr_family
,
0
,
mask_len
=
8
*
struct
.
calcsize
(
string_ip_hdr
)
PacketPimEncodedGroupAddress
.
RESERVED
,
self
.
mask_len
,
ip
)
ip
=
socket
.
inet_pton
(
socket_family
,
self
.
group_address
)
msg
=
struct
.
pack
(
PacketPimEncodedGroupAddress
.
PIM_ENCODED_GROUP_ADDRESS_HDR
%
string_ip_hdr
,
hdr_addr_family
,
0
,
PacketPimEncodedGroupAddress
.
RESERVED
,
mask_len
,
ip
)
return
msg
return
msg
def
get_addr_family
(
self
,
ip
):
@
staticmethod
def
get_ip_info
(
ip
):
version
=
ipaddress
.
ip_address
(
ip
).
version
version
=
ipaddress
.
ip_address
(
ip
).
version
if
version
==
4
:
if
version
==
4
:
return
PacketPimEncodedGroupAddress
.
FAMILY_IPV4
return
(
PacketPimEncodedGroupAddress
.
IPV4_HDR
,
PacketPimEncodedGroupAddress
.
FAMILY_IPV4
,
socket
.
AF_INET
)
elif
version
==
6
:
elif
version
==
6
:
return
PacketPimEncodedGroupAddress
.
FAMILY_IPV6
return
(
PacketPimEncodedGroupAddress
.
IPV6_HDR
,
PacketPimEncodedGroupAddress
.
FAMILY_IPV6
,
socket
.
AF_INET6
)
else
:
else
:
raise
Exception
raise
Exception
Packet/PacketPimEncodedSourceAddress.py
View file @
ee35f93e
...
@@ -11,8 +11,16 @@ import socket
...
@@ -11,8 +11,16 @@ import socket
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+...
'''
'''
class
PacketPimEncodedSourceAddress
:
class
PacketPimEncodedSourceAddress
:
PIM_ENCODED_SOURCE_ADDRESS_HDR
=
"! BBBB 4s"
PIM_ENCODED_SOURCE_ADDRESS_HDR
=
"! BBBB %s"
PIM_ENCODED_SOURCE_ADDRESS_HDR_LEN
=
struct
.
calcsize
(
PIM_ENCODED_SOURCE_ADDRESS_HDR
)
PIM_ENCODED_SOURCE_ADDRESS_HDR_WITHOUT_SOURCE_ADDRESS
=
"! BBBB"
IPV4_HDR
=
"4s"
IPV6_HDR
=
"16s"
# TODO ver melhor versao ip
PIM_ENCODED_SOURCE_ADDRESS_HDR_LEN
=
struct
.
calcsize
(
PIM_ENCODED_SOURCE_ADDRESS_HDR
%
IPV4_HDR
)
PIM_ENCODED_SOURCE_ADDRESS_HDR_LEN_IPV6
=
struct
.
calcsize
(
PIM_ENCODED_SOURCE_ADDRESS_HDR
%
IPV6_HDR
)
FAMILY_RESERVED
=
0
FAMILY_RESERVED
=
0
FAMILY_IPV4
=
1
FAMILY_IPV4
=
1
...
@@ -20,7 +28,7 @@ class PacketPimEncodedSourceAddress:
...
@@ -20,7 +28,7 @@ class PacketPimEncodedSourceAddress:
RESERVED_AND_SWR_BITS
=
0
RESERVED_AND_SWR_BITS
=
0
def
__init__
(
self
,
source_address
,
mask_len
=
32
):
def
__init__
(
self
,
source_address
,
mask_len
=
None
):
if
type
(
source_address
)
not
in
(
str
,
bytes
):
if
type
(
source_address
)
not
in
(
str
,
bytes
):
raise
Exception
raise
Exception
if
type
(
source_address
)
is
bytes
:
if
type
(
source_address
)
is
bytes
:
...
@@ -29,18 +37,22 @@ class PacketPimEncodedSourceAddress:
...
@@ -29,18 +37,22 @@ class PacketPimEncodedSourceAddress:
self
.
mask_len
=
mask_len
self
.
mask_len
=
mask_len
def
bytes
(
self
)
->
bytes
:
def
bytes
(
self
)
->
bytes
:
addr_family
=
self
.
get_addr_family
(
self
.
source_address
)
(
string_ip_hdr
,
hdr_addr_family
,
socket_family
)
=
PacketPimEncodedSourceAddress
.
get_ip_info
(
self
.
source_address
)
ip
=
socket
.
inet_aton
(
self
.
source_address
)
msg
=
struct
.
pack
(
PacketPimEncodedSourceAddress
.
PIM_ENCODED_SOURCE_ADDRESS_HDR
,
addr_family
,
0
,
if
self
.
mask_len
is
None
:
PacketPimEncodedSourceAddress
.
RESERVED_AND_SWR_BITS
,
self
.
mask_len
,
ip
)
mask_len
=
8
*
struct
.
calcsize
(
string_ip_hdr
)
ip
=
socket
.
inet_pton
(
socket_family
,
self
.
source_address
)
msg
=
struct
.
pack
(
PacketPimEncodedSourceAddress
.
PIM_ENCODED_SOURCE_ADDRESS_HDR
%
string_ip_hdr
,
hdr_addr_family
,
0
,
PacketPimEncodedSourceAddress
.
RESERVED_AND_SWR_BITS
,
mask_len
,
ip
)
return
msg
return
msg
def
get_addr_family
(
self
,
ip
):
@
staticmethod
def
get_ip_info
(
ip
):
version
=
ipaddress
.
ip_address
(
ip
).
version
version
=
ipaddress
.
ip_address
(
ip
).
version
if
version
==
4
:
if
version
==
4
:
return
PacketPimEncodedSourceAddress
.
FAMILY_IPV4
return
(
PacketPimEncodedSourceAddress
.
IPV4_HDR
,
PacketPimEncodedSourceAddress
.
FAMILY_IPV4
,
socket
.
AF_INET
)
elif
version
==
6
:
elif
version
==
6
:
return
PacketPimEncodedSourceAddress
.
FAMILY_IPV6
return
(
PacketPimEncodedSourceAddress
.
IPV6_HDR
,
PacketPimEncodedSourceAddress
.
FAMILY_IPV6
,
socket
.
AF_INET6
)
else
:
else
:
raise
Exception
raise
Exception
\ No newline at end of file
Packet/PacketPimEncodedUnicastAddress.py
View file @
ee35f93e
...
@@ -9,8 +9,15 @@ import socket
...
@@ -9,8 +9,15 @@ import socket
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+...
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+...
'''
'''
class
PacketPimEncodedUnicastAddress
:
class
PacketPimEncodedUnicastAddress
:
PIM_ENCODED_UNICAST_ADDRESS_HDR
=
"! BB 4s"
PIM_ENCODED_UNICAST_ADDRESS_HDR
=
"! BB %s"
PIM_ENCODED_UNICAST_ADDRESS_HDR_LEN
=
struct
.
calcsize
(
PIM_ENCODED_UNICAST_ADDRESS_HDR
)
PIM_ENCODED_UNICAST_ADDRESS_HDR_WITHOUT_UNICAST_ADDRESS
=
"! BB"
IPV4_HDR
=
"4s"
IPV6_HDR
=
"16s"
# TODO ver melhor versao ip
PIM_ENCODED_UNICAST_ADDRESS_HDR_LEN
=
struct
.
calcsize
(
PIM_ENCODED_UNICAST_ADDRESS_HDR
%
IPV4_HDR
)
PIM_ENCODED_UNICAST_ADDRESS_HDR_LEN_IPV6
=
struct
.
calcsize
(
PIM_ENCODED_UNICAST_ADDRESS_HDR
%
IPV6_HDR
)
FAMILY_RESERVED
=
0
FAMILY_RESERVED
=
0
FAMILY_IPV4
=
1
FAMILY_IPV4
=
1
...
@@ -24,17 +31,18 @@ class PacketPimEncodedUnicastAddress:
...
@@ -24,17 +31,18 @@ class PacketPimEncodedUnicastAddress:
self
.
unicast_address
=
unicast_address
self
.
unicast_address
=
unicast_address
def
bytes
(
self
)
->
bytes
:
def
bytes
(
self
)
->
bytes
:
addr_family
=
self
.
get_addr_family
(
self
.
unicast_address
)
(
string_ip_hdr
,
hdr_addr_family
,
socket_family
)
=
PacketPimEncodedUnicastAddress
.
get_ip_info
(
self
.
unicast_address
)
ip
=
socket
.
inet_aton
(
self
.
unicast_address
)
msg
=
struct
.
pack
(
PacketPimEncodedUnicastAddress
.
PIM_ENCODED_UNICAST_ADDRESS_HDR
,
addr_family
,
0
,
ip
)
ip
=
socket
.
inet_pton
(
socket_family
,
self
.
unicast_address
)
msg
=
struct
.
pack
(
PacketPimEncodedUnicastAddress
.
PIM_ENCODED_UNICAST_ADDRESS_HDR
%
string_ip_hdr
,
hdr_addr_family
,
0
,
ip
)
return
msg
return
msg
def
get_addr_family
(
self
,
ip
):
@
staticmethod
def
get_ip_info
(
ip
):
version
=
ipaddress
.
ip_address
(
ip
).
version
version
=
ipaddress
.
ip_address
(
ip
).
version
if
version
==
4
:
if
version
==
4
:
return
PacketPimEncodedUnicastAddress
.
FAMILY_IPV4
return
(
PacketPimEncodedUnicastAddress
.
IPV4_HDR
,
PacketPimEncodedUnicastAddress
.
FAMILY_IPV4
,
socket
.
AF_INET
)
elif
version
==
6
:
elif
version
==
6
:
return
PacketPimEncodedUnicastAddress
.
FAMILY_IPV6
return
(
PacketPimEncodedUnicastAddress
.
IPV6_HDR
,
PacketPimEncodedUnicastAddress
.
FAMILY_IPV6
,
socket
.
AF_INET6
)
else
:
else
:
raise
Exception
raise
Exception
Packet/PacketPimJoinPrune.py
View file @
ee35f93e
import
struct
import
struct
import
socket
import
socket
from
Packet.PacketPimEncodedUnicastAddress
import
PacketPimEncodedUnicastAddress
from
Packet.PacketPimEncodedUnicastAddress
import
PacketPimEncodedUnicastAddress
from
Packet.PacketPimJoinPruneMulticastGroup
import
PacketPimJoinPruneMulticastGroup
'''
'''
0 1 2 3
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
...
@@ -12,8 +13,15 @@ from Packet.PacketPimEncodedUnicastAddress import PacketPimEncodedUnicastAddress
...
@@ -12,8 +13,15 @@ from Packet.PacketPimEncodedUnicastAddress import PacketPimEncodedUnicastAddress
'''
'''
class
PacketPimJoinPrune
:
class
PacketPimJoinPrune
:
PIM_TYPE
=
3
PIM_TYPE
=
3
PIM_HDR_JOIN_PRUNE
=
"! "
+
str
(
PacketPimEncodedUnicastAddress
.
PIM_ENCODED_UNICAST_ADDRESS_HDR_LEN
)
+
"s BBH"
PIM_HDR_JOIN_PRUNE_LEN
=
struct
.
calcsize
(
PIM_HDR_JOIN_PRUNE
)
PIM_HDR_JOIN_PRUNE
=
"! %ss BBH"
PIM_HDR_JOIN_PRUNE_WITHOUT_ADDRESS
=
"! BBH"
PIM_HDR_JOIN_PRUNE_v4
=
PIM_HDR_JOIN_PRUNE
%
PacketPimEncodedUnicastAddress
.
PIM_ENCODED_UNICAST_ADDRESS_HDR_LEN
PIM_HDR_JOIN_PRUNE_v6
=
PIM_HDR_JOIN_PRUNE
%
PacketPimEncodedUnicastAddress
.
PIM_ENCODED_UNICAST_ADDRESS_HDR_LEN_IPV6
PIM_HDR_JOIN_PRUNE_WITHOUT_ADDRESS_LEN
=
struct
.
calcsize
(
PIM_HDR_JOIN_PRUNE_WITHOUT_ADDRESS
)
PIM_HDR_JOIN_PRUNE_v4_LEN
=
struct
.
calcsize
(
PIM_HDR_JOIN_PRUNE_v4
)
PIM_HDR_JOIN_PRUNE_v6_LEN
=
struct
.
calcsize
(
PIM_HDR_JOIN_PRUNE_v6
)
def
__init__
(
self
,
upstream_neighbor_address
,
hold_time
):
def
__init__
(
self
,
upstream_neighbor_address
,
hold_time
):
if
type
(
upstream_neighbor_address
)
not
in
(
str
,
bytes
):
if
type
(
upstream_neighbor_address
)
not
in
(
str
,
bytes
):
...
@@ -24,13 +32,14 @@ class PacketPimJoinPrune:
...
@@ -24,13 +32,14 @@ class PacketPimJoinPrune:
self
.
upstream_neighbor_address
=
upstream_neighbor_address
self
.
upstream_neighbor_address
=
upstream_neighbor_address
self
.
hold_time
=
hold_time
self
.
hold_time
=
hold_time
def
add_multicast_group
(
self
,
group
):
def
add_multicast_group
(
self
,
group
:
PacketPimJoinPruneMulticastGroup
):
# TODO verificar se grupo ja esta na msg
# TODO verificar se grupo ja esta na msg
self
.
groups
.
append
(
group
)
self
.
groups
.
append
(
group
)
def
bytes
(
self
)
->
bytes
:
def
bytes
(
self
)
->
bytes
:
upstream_neighbor_address
=
PacketPimEncodedUnicastAddress
(
self
.
upstream_neighbor_address
).
bytes
()
upstream_neighbor_address
=
PacketPimEncodedUnicastAddress
(
self
.
upstream_neighbor_address
).
bytes
()
msg
=
struct
.
pack
(
PacketPimJoinPrune
.
PIM_HDR_JOIN_PRUNE
,
upstream_neighbor_address
,
0
,
len
(
self
.
groups
),
self
.
hold_time
)
msg
=
upstream_neighbor_address
+
struct
.
pack
(
PacketPimJoinPrune
.
PIM_HDR_JOIN_PRUNE_WITHOUT_ADDRESS
,
0
,
len
(
self
.
groups
),
self
.
hold_time
)
for
multicast_group
in
self
.
groups
:
for
multicast_group
in
self
.
groups
:
msg
+=
multicast_group
.
bytes
()
msg
+=
multicast_group
.
bytes
()
...
...
Packet/PacketPimJoinPruneMulticastGroup.py
View file @
ee35f93e
...
@@ -2,6 +2,7 @@ import struct
...
@@ -2,6 +2,7 @@ import struct
import
socket
import
socket
from
Packet.PacketPimEncodedGroupAddress
import
PacketPimEncodedGroupAddress
from
Packet.PacketPimEncodedGroupAddress
import
PacketPimEncodedGroupAddress
from
Packet.PacketPimEncodedSourceAddress
import
PacketPimEncodedSourceAddress
from
Packet.PacketPimEncodedSourceAddress
import
PacketPimEncodedSourceAddress
'''
'''
0 1 2 3
0 1 2 3
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1
...
@@ -25,15 +26,24 @@ from Packet.PacketPimEncodedSourceAddress import PacketPimEncodedSourceAddress
...
@@ -25,15 +26,24 @@ from Packet.PacketPimEncodedSourceAddress import PacketPimEncodedSourceAddress
| Pruned Source Address n (Encoded Source Format) |
| Pruned Source Address n (Encoded Source Format) |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
'''
'''
class
PacketPimJoinPruneMulticastGroup
:
class
PacketPimJoinPruneMulticastGroup
:
PIM_HDR_JOIN_PRUNE_MULTICAST_GROUP
=
"!
"
+
str
(
PacketPimEncodedGroupAddress
.
PIM_ENCODED_GROUP_ADDRESS_HDR_LEN
)
+
"
s HH"
PIM_HDR_JOIN_PRUNE_MULTICAST_GROUP
=
"!
%s
s HH"
PIM_HDR_JOIN_PRUNE_MULTICAST_GROUP_
LEN
=
struct
.
calcsize
(
PIM_HDR_JOIN_PRUNE_MULTICAST_GROUP
)
PIM_HDR_JOIN_PRUNE_MULTICAST_GROUP_
WITHOUT_GROUP_ADDRESS
=
"! HH"
PIM_HDR_JOINED_PRUNED_SOURCE
=
"! "
+
str
(
PacketPimEncodedSourceAddress
.
PIM_ENCODED_SOURCE_ADDRESS_HDR_LEN
)
+
"s"
PIM_HDR_JOIN_PRUNE_MULTICAST_GROUP_v4_LEN_
=
struct
.
calcsize
(
PIM_HDR_JOINED_PRUNED_SOURCE_LEN
=
struct
.
calcsize
(
PIM_HDR_JOINED_PRUNED_SOURCE
)
PIM_HDR_JOIN_PRUNE_MULTICAST_GROUP
%
PacketPimEncodedGroupAddress
.
PIM_ENCODED_GROUP_ADDRESS_HDR_LEN
)
PIM_HDR_JOIN_PRUNE_MULTICAST_GROUP_v6_LEN_
=
struct
.
calcsize
(
PIM_HDR_JOIN_PRUNE_MULTICAST_GROUP
%
PacketPimEncodedGroupAddress
.
PIM_ENCODED_GROUP_ADDRESS_HDR_LEN_IPv6
)
PIM_HDR_JOIN_PRUNE_MULTICAST_GROUP_WITHOUT_GROUP_ADDRESS_LEN
=
struct
.
calcsize
(
PIM_HDR_JOIN_PRUNE_MULTICAST_GROUP_WITHOUT_GROUP_ADDRESS
)
PIM_HDR_JOINED_PRUNED_SOURCE
=
"! %ss"
PIM_HDR_JOINED_PRUNED_SOURCE_v4_LEN
=
PacketPimEncodedSourceAddress
.
PIM_ENCODED_SOURCE_ADDRESS_HDR_LEN
PIM_HDR_JOINED_PRUNED_SOURCE_v6_LEN
=
PacketPimEncodedSourceAddress
.
PIM_ENCODED_SOURCE_ADDRESS_HDR_LEN_IPV6
def
__init__
(
self
,
multicast_group
,
joined_src_addresses
:
list
,
pruned_src_addresses
:
list
):
def
__init__
(
self
,
multicast_group
,
joined_src_addresses
:
list
,
pruned_src_addresses
:
list
):
if
type
(
multicast_group
)
not
in
(
str
,
bytes
):
if
type
(
multicast_group
)
not
in
(
str
,
bytes
):
raise
Exception
raise
Exception
elif
type
(
multicast_group
)
is
bytes
:
elif
type
(
multicast_group
)
is
bytes
:
...
@@ -50,13 +60,14 @@ class PacketPimJoinPruneMulticastGroup:
...
@@ -50,13 +60,14 @@ class PacketPimJoinPruneMulticastGroup:
def
bytes
(
self
)
->
bytes
:
def
bytes
(
self
)
->
bytes
:
multicast_group_address
=
PacketPimEncodedGroupAddress
(
self
.
multicast_group
).
bytes
()
multicast_group_address
=
PacketPimEncodedGroupAddress
(
self
.
multicast_group
).
bytes
()
msg
=
struct
.
pack
(
self
.
PIM_HDR_JOIN_PRUNE_MULTICAST_GROUP
,
multicast_group_address
,
len
(
self
.
joined_src_addresses
),
len
(
self
.
pruned_src_addresses
))
msg
=
multicast_group_address
+
struct
.
pack
(
self
.
PIM_HDR_JOIN_PRUNE_MULTICAST_GROUP_WITHOUT_GROUP_ADDRESS
,
len
(
self
.
joined_src_addresses
),
len
(
self
.
pruned_src_addresses
))
for
joined_src_address
in
self
.
joined_src_addresses
:
for
joined_src_address
in
self
.
joined_src_addresses
:
joined_src_address_bytes
=
PacketPimEncodedSourceAddress
(
joined_src_address
).
bytes
()
joined_src_address_bytes
=
PacketPimEncodedSourceAddress
(
joined_src_address
).
bytes
()
msg
+=
struct
.
pack
(
self
.
PIM_HDR_JOINED_PRUNED_SOURCE
,
joined_src_address_bytes
)
msg
+=
joined_src_address_bytes
for
pruned_src_address
in
self
.
pruned_src_addresses
:
for
pruned_src_address
in
self
.
pruned_src_addresses
:
pruned_src_address_bytes
=
PacketPimEncodedSourceAddress
(
pruned_src_address
).
bytes
()
pruned_src_address_bytes
=
PacketPimEncodedSourceAddress
(
pruned_src_address
).
bytes
()
msg
+=
struct
.
pack
(
self
.
PIM_HDR_JOINED_PRUNED_SOURCE
,
pruned_src_address_bytes
)
msg
+=
pruned_src_address_bytes
return
msg
return
msg
Run.py
View file @
ee35f93e
...
@@ -7,7 +7,8 @@ import socket
...
@@ -7,7 +7,8 @@ import socket
import
sys
import
sys
import
os
import
os
import
argparse
import
argparse
from
argparse
import
Namespace
import
traceback
def
client_socket
(
data_to_send
):
def
client_socket
(
data_to_send
):
# Create a UDS socket
# Create a UDS socket
...
@@ -71,6 +72,7 @@ class MyDaemon(Daemon):
...
@@ -71,6 +72,7 @@ class MyDaemon(Daemon):
connection
.
shutdown
(
socket
.
SHUT_RDWR
)
connection
.
shutdown
(
socket
.
SHUT_RDWR
)
except
Exception
:
except
Exception
:
connection
.
shutdown
(
socket
.
SHUT_RDWR
)
connection
.
shutdown
(
socket
.
SHUT_RDWR
)
traceback
.
print_exc
()
finally
:
finally
:
# Clean up the connection
# Clean up the connection
connection
.
close
()
connection
.
close
()
...
...
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