Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
S
scapy
Manage
Activity
Members
Plan
Wiki
Code
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Deploy
Releases
Package Registry
Model registry
Operate
Terraform modules
Analyze
Contributor analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
CodeLinaro
public-release-test-restored
platform
external
scapy
Commits
2ac53bbd
Commit
2ac53bbd
authored
10 years ago
by
Guillaume Valadon
Browse files
Options
Downloads
Patches
Plain Diff
More GTP messages
--HG-- branch : GTP support
parent
0c79572b
No related branches found
No related tags found
No related merge requests found
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
scapy/contrib/gtp.py
+35
-0
35 additions, 0 deletions
scapy/contrib/gtp.py
with
35 additions
and
0 deletions
scapy/contrib/gtp.py
+
35
−
0
View file @
2ac53bbd
...
@@ -19,9 +19,11 @@ from scapy.all import *
...
@@ -19,9 +19,11 @@ from scapy.all import *
GTPmessageType
=
{
1
:
"
echo_request
"
,
GTPmessageType
=
{
1
:
"
echo_request
"
,
2
:
"
echo_response
"
,
2
:
"
echo_response
"
,
16
:
"
create_pdp_context_req
"
,
16
:
"
create_pdp_context_req
"
,
17
:
"
create_pdp_context_res
"
,
20
:
"
delete_pdp_context_req
"
,
20
:
"
delete_pdp_context_req
"
,
21
:
"
delete_pdp_context_res
"
,
21
:
"
delete_pdp_context_res
"
,
26
:
"
error_indication
"
,
26
:
"
error_indication
"
,
27
:
"
pdu_notification_req
"
,
255
:
"
gtp_u_header
"
}
255
:
"
gtp_u_header
"
}
IEType
=
{
1
:
"
Cause
"
,
IEType
=
{
1
:
"
Cause
"
,
...
@@ -316,6 +318,7 @@ class APNStrLenField(StrLenField):
...
@@ -316,6 +318,7 @@ class APNStrLenField(StrLenField):
s
=
""
.
join
(
map
(
lambda
x
:
chr
(
len
(
x
))
+
x
,
s
.
split
(
"
.
"
)))
s
=
""
.
join
(
map
(
lambda
x
:
chr
(
len
(
x
))
+
x
,
s
.
split
(
"
.
"
)))
return
s
return
s
class
IE_AccessPointName
(
Packet
):
class
IE_AccessPointName
(
Packet
):
# Sent by SGSN or by GGSN as defined in 3GPP TS 23.060
# Sent by SGSN or by GGSN as defined in 3GPP TS 23.060
name
=
"
Access Point Name
"
name
=
"
Access Point Name
"
...
@@ -421,6 +424,7 @@ class GTPEchoResponse(Packet):
...
@@ -421,6 +424,7 @@ class GTPEchoResponse(Packet):
def
answers
(
self
,
other
):
def
answers
(
self
,
other
):
return
self
.
seq
==
other
.
seq
return
self
.
seq
==
other
.
seq
class
GTPCreatePDPContextRequest
(
Packet
):
class
GTPCreatePDPContextRequest
(
Packet
):
# 3GPP TS 29.060 V9.1.0 (2009-12)
# 3GPP TS 29.060 V9.1.0 (2009-12)
name
=
"
GTP Create PDP Context Request
"
name
=
"
GTP Create PDP Context Request
"
...
@@ -431,6 +435,22 @@ class GTPCreatePDPContextRequest(Packet):
...
@@ -431,6 +435,22 @@ class GTPCreatePDPContextRequest(Packet):
IE_GSNAddress
(),
IE_GSNAddress
(),
IE_NotImplementedTLV
(
ietype
=
135
,
length
=
15
,
data
=
RandString
(
15
))
],
IE_NotImplementedTLV
(
ietype
=
135
,
length
=
15
,
data
=
RandString
(
15
))
],
IE_Dispatcher
)
]
IE_Dispatcher
)
]
def
hashret
(
self
):
return
struct
.
pack
(
"
H
"
,
self
.
seq
)
class
GTPCreatePDPContextResponse
(
Packet
):
# 3GPP TS 29.060 V9.1.0 (2009-12)
name
=
"
GTP Create PDP Context Response
"
fields_desc
=
[
ShortField
(
"
seq
"
,
RandShort
()),
ByteField
(
"
npdu
"
,
0
),
ByteField
(
"
next_ex
"
,
0
),
PacketListField
(
"
IE_list
"
,
[],
IE_Dispatcher
)
]
def
hashret
(
self
):
return
struct
.
pack
(
"
H
"
,
self
.
seq
)
def
answers
(
self
,
other
):
return
self
.
seq
==
other
.
seq
class
GTPErrorIndication
(
Packet
):
class
GTPErrorIndication
(
Packet
):
# 3GPP TS 29.060 V9.1.0 (2009-12)
# 3GPP TS 29.060 V9.1.0 (2009-12)
...
@@ -456,6 +476,19 @@ class GTPDeletePDPContextResponse(Packet):
...
@@ -456,6 +476,19 @@ class GTPDeletePDPContextResponse(Packet):
ByteField
(
"
next_ex
"
,
0
),
ByteField
(
"
next_ex
"
,
0
),
PacketListField
(
"
IE_list
"
,
[],
IE_Dispatcher
)
]
PacketListField
(
"
IE_list
"
,
[],
IE_Dispatcher
)
]
class
GTPPDUNotificationRequest
(
Packet
):
# 3GPP TS 29.060 V9.1.0 (2009-12)
name
=
"
GTP PDU Notification Request
"
fields_desc
=
[
XBitField
(
"
seq
"
,
0
,
16
),
ByteField
(
"
npdu
"
,
0
),
ByteField
(
"
next_ex
"
,
0
),
PacketListField
(
"
IE_list
"
,
[
IE_IMSI
(),
IE_TEICP
(
TEICI
=
RandInt
()),
IE_EndUserAddress
(
PDPTypeNumber
=
0x21
),
IE_AccessPointName
(),
IE_GSNAddress
(
address
=
"
127.0.0.1
"
),
],
IE_Dispatcher
)
]
class
GTP_U_Header
(
Packet
):
class
GTP_U_Header
(
Packet
):
# 3GPP TS 29.060 V9.1.0 (2009-12)
# 3GPP TS 29.060 V9.1.0 (2009-12)
name
=
"
GTP-U Header
"
name
=
"
GTP-U Header
"
...
@@ -494,8 +527,10 @@ bind_layers(UDP, GTPHeader, dport = 2123)
...
@@ -494,8 +527,10 @@ bind_layers(UDP, GTPHeader, dport = 2123)
bind_layers
(
GTPHeader
,
GTPEchoRequest
,
gtp_type
=
1
)
bind_layers
(
GTPHeader
,
GTPEchoRequest
,
gtp_type
=
1
)
bind_layers
(
GTPHeader
,
GTPEchoResponse
,
gtp_type
=
2
)
bind_layers
(
GTPHeader
,
GTPEchoResponse
,
gtp_type
=
2
)
bind_layers
(
GTPHeader
,
GTPCreatePDPContextRequest
,
gtp_type
=
16
)
bind_layers
(
GTPHeader
,
GTPCreatePDPContextRequest
,
gtp_type
=
16
)
bind_layers
(
GTPHeader
,
GTPCreatePDPContextResponse
,
gtp_type
=
17
)
bind_layers
(
GTPHeader
,
GTPDeletePDPContextRequest
,
gtp_type
=
20
)
bind_layers
(
GTPHeader
,
GTPDeletePDPContextRequest
,
gtp_type
=
20
)
bind_layers
(
GTPHeader
,
GTPDeletePDPContextResponse
,
gtp_type
=
21
)
bind_layers
(
GTPHeader
,
GTPDeletePDPContextResponse
,
gtp_type
=
21
)
bind_layers
(
GTPHeader
,
GTPPDUNotificationRequest
,
gtp_type
=
27
)
# Bind GTP-U
# Bind GTP-U
bind_layers
(
UDP
,
GTP_U_Header
)
bind_layers
(
UDP
,
GTP_U_Header
)
bind_layers
(
GTP_U_Header
,
IP
,
gtp_type
=
255
)
bind_layers
(
GTP_U_Header
,
IP
,
gtp_type
=
255
)
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment