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
2cdd660f
Commit
2cdd660f
authored
Feb 25, 2016
by
Ad Schellevis
Committed by
Franco Fichtner
Mar 03, 2016
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
(legacy) spaces in IPv6.inc
(cherry picked from commit
dab86324
)
parent
7a353276
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
40 additions
and
241 deletions
+40
-241
IPv6.inc
src/etc/inc/IPv6.inc
+40
-241
No files found.
src/etc/inc/IPv6.inc
View file @
2cdd660f
...
@@ -150,23 +150,17 @@ class Net_IPv6
...
@@ -150,23 +150,17 @@ class Net_IPv6
$addr
=
$ip
;
$addr
=
$ip
;
$spec
=
''
;
$spec
=
''
;
if
(
false
===
strrpos
(
$ip
,
'/'
))
{
if
(
false
===
strrpos
(
$ip
,
'/'
))
{
return
array
(
$addr
,
$spec
);
return
array
(
$addr
,
$spec
);
}
}
$elements
=
explode
(
'/'
,
$ip
);
$elements
=
explode
(
'/'
,
$ip
);
if
(
2
==
count
(
$elements
))
{
if
(
2
==
count
(
$elements
))
{
$addr
=
$elements
[
0
];
$addr
=
$elements
[
0
];
$spec
=
$elements
[
1
];
$spec
=
$elements
[
1
];
}
}
return
array
(
$addr
,
$spec
);
return
array
(
$addr
,
$spec
);
}
}
// }}}
// }}}
...
@@ -184,11 +178,8 @@ class Net_IPv6
...
@@ -184,11 +178,8 @@ class Net_IPv6
*/
*/
public
static
function
removeNetmaskSpec
(
$ip
)
public
static
function
removeNetmaskSpec
(
$ip
)
{
{
$elements
=
Net_IPv6
::
separate
(
$ip
);
$elements
=
Net_IPv6
::
separate
(
$ip
);
return
$elements
[
0
];
return
$elements
[
0
];
}
}
// }}}
// }}}
// {{{ removePrefixLength()
// {{{ removePrefixLength()
...
@@ -211,13 +202,9 @@ class Net_IPv6
...
@@ -211,13 +202,9 @@ class Net_IPv6
public
static
function
removePrefixLength
(
$ip
)
public
static
function
removePrefixLength
(
$ip
)
{
{
$pos
=
strrpos
(
$ip
,
'/'
);
$pos
=
strrpos
(
$ip
,
'/'
);
if
(
false
!==
$pos
)
{
if
(
false
!==
$pos
)
{
return
substr
(
$ip
,
0
,
$pos
);
return
substr
(
$ip
,
0
,
$pos
);
}
}
return
$ip
;
return
$ip
;
}
}
...
@@ -236,11 +223,8 @@ class Net_IPv6
...
@@ -236,11 +223,8 @@ class Net_IPv6
*/
*/
public
static
function
getNetmaskSpec
(
$ip
)
public
static
function
getNetmaskSpec
(
$ip
)
{
{
$elements
=
Net_IPv6
::
separate
(
$ip
);
$elements
=
Net_IPv6
::
separate
(
$ip
);
return
$elements
[
1
];
return
$elements
[
1
];
}
}
// }}}
// }}}
...
@@ -262,17 +246,11 @@ class Net_IPv6
...
@@ -262,17 +246,11 @@ class Net_IPv6
*/
*/
public
static
function
getPrefixLength
(
$ip
)
public
static
function
getPrefixLength
(
$ip
)
{
{
if
(
preg_match
(
"/^([0-9a-fA-F:]
{
2,39})\/(\d{1,3
}
)*$/"
,
if
(
preg_match
(
"/^([0-9a-fA-F:]
{
2,39})\/(\d{1,3
}
)*$/"
,
$ip
,
$matches
))
{
$ip
,
$matches
))
{
return
$matches
[
2
];
return
$matches
[
2
];
}
else
{
}
else
{
return
false
;
return
false
;
}
}
}
}
// }}}
// }}}
...
@@ -293,31 +271,21 @@ class Net_IPv6
...
@@ -293,31 +271,21 @@ class Net_IPv6
public
static
function
getNetmask
(
$ip
,
$bits
=
null
)
public
static
function
getNetmask
(
$ip
,
$bits
=
null
)
{
{
if
(
null
==
$bits
)
{
if
(
null
==
$bits
)
{
$elements
=
explode
(
'/'
,
$ip
);
$elements
=
explode
(
'/'
,
$ip
);
if
(
2
==
count
(
$elements
))
{
if
(
2
==
count
(
$elements
))
{
$addr
=
$elements
[
0
];
$addr
=
$elements
[
0
];
$bits
=
$elements
[
1
];
$bits
=
$elements
[
1
];
}
else
{
}
else
{
include_once
'PEAR.inc'
;
include_once
'PEAR.inc'
;
return
PEAR
::
raiseError
(
NET_IPV6_NO_NETMASK_MSG
,
return
PEAR
::
raiseError
(
NET_IPV6_NO_NETMASK_MSG
,
NET_IPV6_NO_NETMASK
);
NET_IPV6_NO_NETMASK
);
}
}
}
else
{
}
else
{
$addr
=
$ip
;
$addr
=
$ip
;
}
}
$addr
=
Net_IPv6
::
uncompress
(
$addr
);
$addr
=
Net_IPv6
::
uncompress
(
$addr
);
$binNetmask
=
str_repeat
(
'1'
,
$bits
)
.
str_repeat
(
'0'
,
128
-
$bits
);
$binNetmask
=
str_repeat
(
'1'
,
$bits
)
.
str_repeat
(
'0'
,
128
-
$bits
);
return
Net_IPv6
::
_bin2Ip
(
Net_IPv6
::
_ip2Bin
(
$addr
)
&
$binNetmask
);
return
Net_IPv6
::
_bin2Ip
(
Net_IPv6
::
_ip2Bin
(
$addr
)
&
$binNetmask
);
}
}
...
@@ -345,46 +313,31 @@ class Net_IPv6
...
@@ -345,46 +313,31 @@ class Net_IPv6
// try to get the bit count
// try to get the bit count
if
(
null
==
$bits
)
{
if
(
null
==
$bits
)
{
$elements
=
explode
(
'/'
,
$ip
);
$elements
=
explode
(
'/'
,
$ip
);
if
(
2
==
count
(
$elements
))
{
if
(
2
==
count
(
$elements
))
{
$ip
=
$elements
[
0
];
$ip
=
$elements
[
0
];
$bits
=
$elements
[
1
];
$bits
=
$elements
[
1
];
}
elseif
(
null
==
$bits
)
{
}
else
if
(
null
==
$bits
)
{
$elements
=
explode
(
'/'
,
$netmask
);
$elements
=
explode
(
'/'
,
$netmask
);
if
(
2
==
count
(
$elements
))
{
if
(
2
==
count
(
$elements
))
{
$netmask
=
$elements
[
0
];
$netmask
=
$elements
[
0
];
$bits
=
$elements
[
1
];
$bits
=
$elements
[
1
];
}
}
if
(
null
==
$bits
)
{
if
(
null
==
$bits
)
{
include_once
'PEAR.inc'
;
include_once
'PEAR.inc'
;
return
PEAR
::
raiseError
(
NET_IPV6_NO_NETMASK_MSG
,
return
PEAR
::
raiseError
(
NET_IPV6_NO_NETMASK_MSG
,
NET_IPV6_NO_NETMASK
);
NET_IPV6_NO_NETMASK
);
}
}
}
}
}
}
$binIp
=
Net_IPv6
::
_ip2Bin
(
Net_IPv6
::
removeNetmaskSpec
(
$ip
));
$binIp
=
Net_IPv6
::
_ip2Bin
(
Net_IPv6
::
removeNetmaskSpec
(
$ip
));
$binNetmask
=
Net_IPv6
::
_ip2Bin
(
Net_IPv6
::
removeNetmaskSpec
(
$netmask
));
$binNetmask
=
Net_IPv6
::
_ip2Bin
(
Net_IPv6
::
removeNetmaskSpec
(
$netmask
));
if
(
null
!=
$bits
if
(
null
!=
$bits
&&
""
!=
$bits
&&
""
!=
$bits
&&
0
==
strncmp
(
$binNetmask
,
$binIp
,
$bits
))
{
&&
0
==
strncmp
(
$binNetmask
,
$binIp
,
$bits
))
{
return
true
;
return
true
;
}
}
return
false
;
return
false
;
...
@@ -428,52 +381,30 @@ class Net_IPv6
...
@@ -428,52 +381,30 @@ class Net_IPv6
$ip
=
Net_IPv6
::
removeNetmaskSpec
(
$ip
);
$ip
=
Net_IPv6
::
removeNetmaskSpec
(
$ip
);
$binip
=
Net_IPv6
::
_ip2Bin
(
$ip
);
$binip
=
Net_IPv6
::
_ip2Bin
(
$ip
);
if
(
0
==
strncmp
(
str_repeat
(
'0'
,
128
),
$binip
,
128
))
{
// ::/128
if
(
0
==
strncmp
(
str_repeat
(
'0'
,
128
),
$binip
,
128
))
{
// ::/128
return
NET_IPV6_UNSPECIFIED
;
return
NET_IPV6_UNSPECIFIED
;
}
elseif
(
0
==
strncmp
(
str_repeat
(
'0'
,
127
)
.
'1'
,
$binip
,
128
))
{
// ::/128
}
else
if
(
0
==
strncmp
(
str_repeat
(
'0'
,
127
)
.
'1'
,
$binip
,
128
))
{
// ::/128
return
NET_IPV6_LOOPBACK
;
return
NET_IPV6_LOOPBACK
;
}
elseif
(
0
==
strncmp
(
str_repeat
(
'0'
,
80
)
.
str_repeat
(
'1'
,
16
),
$binip
,
96
))
{
// ::ffff/96
}
else
if
(
0
==
strncmp
(
str_repeat
(
'0'
,
80
)
.
str_repeat
(
'1'
,
16
),
$binip
,
96
))
{
// ::ffff/96
return
NET_IPV6_IPV4MAPPING
;
return
NET_IPV6_IPV4MAPPING
;
}
elseif
(
0
==
strncmp
(
'1111111010'
,
$binip
,
10
))
{
}
else
if
(
0
==
strncmp
(
'1111111010'
,
$binip
,
10
))
{
return
NET_IPV6_LOCAL_LINK
;
return
NET_IPV6_LOCAL_LINK
;
}
elseif
(
0
==
strncmp
(
'1111111011'
,
$binip
,
10
))
{
}
else
if
(
0
==
strncmp
(
'1111111011'
,
$binip
,
10
))
{
return
NET_IPV6_LOCAL_SITE
;
return
NET_IPV6_LOCAL_SITE
;
}
elseif
(
0
==
strncmp
(
'111111100'
,
$binip
,
9
))
{
}
else
if
(
0
==
strncmp
(
'111111100'
,
$binip
,
9
))
{
return
NET_IPV6_UNASSIGNED
;
return
NET_IPV6_UNASSIGNED
;
}
elseif
(
0
==
strncmp
(
'11111111'
,
$binip
,
8
))
{
}
else
if
(
0
==
strncmp
(
'11111111'
,
$binip
,
8
))
{
return
NET_IPV6_MULTICAST
;
return
NET_IPV6_MULTICAST
;
}
elseif
(
0
==
strncmp
(
'00000000'
,
$binip
,
8
))
{
}
else
if
(
0
==
strncmp
(
'00000000'
,
$binip
,
8
))
{
return
NET_IPV6_RESERVED
;
return
NET_IPV6_RESERVED
;
}
elseif
(
0
==
strncmp
(
'00000001'
,
$binip
,
8
)
}
else
if
(
0
==
strncmp
(
'00000001'
,
$binip
,
8
)
||
0
==
strncmp
(
'1111110'
,
$binip
,
7
))
{
||
0
==
strncmp
(
'1111110'
,
$binip
,
7
))
{
return
NET_IPV6_UNASSIGNED
;
return
NET_IPV6_UNASSIGNED
;
}
elseif
(
0
==
strncmp
(
'0000001'
,
$binip
,
7
))
{
}
else
if
(
0
==
strncmp
(
'0000001'
,
$binip
,
7
))
{
return
NET_IPV6_RESERVED_NSAP
;
return
NET_IPV6_RESERVED_NSAP
;
}
elseif
(
0
==
strncmp
(
'0000010'
,
$binip
,
7
))
{
}
else
if
(
0
==
strncmp
(
'0000010'
,
$binip
,
7
))
{
return
NET_IPV6_RESERVED_IPX
;
return
NET_IPV6_RESERVED_IPX
;
}
elseif
(
0
==
strncmp
(
'0000011'
,
$binip
,
7
)
||
}
else
if
(
0
==
strncmp
(
'0000011'
,
$binip
,
7
)
||
0
==
strncmp
(
'111110'
,
$binip
,
6
)
||
0
==
strncmp
(
'111110'
,
$binip
,
6
)
||
0
==
strncmp
(
'11110'
,
$binip
,
5
)
||
0
==
strncmp
(
'11110'
,
$binip
,
5
)
||
0
==
strncmp
(
'00001'
,
$binip
,
5
)
||
0
==
strncmp
(
'00001'
,
$binip
,
5
)
||
...
@@ -483,19 +414,12 @@ class Net_IPv6
...
@@ -483,19 +414,12 @@ class Net_IPv6
0
==
strncmp
(
'011'
,
$binip
,
3
)
||
0
==
strncmp
(
'011'
,
$binip
,
3
)
||
0
==
strncmp
(
'101'
,
$binip
,
3
)
||
0
==
strncmp
(
'101'
,
$binip
,
3
)
||
0
==
strncmp
(
'110'
,
$binip
,
3
))
{
0
==
strncmp
(
'110'
,
$binip
,
3
))
{
return
NET_IPV6_UNASSIGNED
;
return
NET_IPV6_UNASSIGNED
;
}
elseif
(
0
==
strncmp
(
'010'
,
$binip
,
3
))
{
}
else
if
(
0
==
strncmp
(
'010'
,
$binip
,
3
))
{
return
NET_IPV6_UNICAST_PROVIDER
;
return
NET_IPV6_UNICAST_PROVIDER
;
}
elseif
(
0
==
strncmp
(
'100'
,
$binip
,
3
))
{
}
else
if
(
0
==
strncmp
(
'100'
,
$binip
,
3
))
{
return
NET_IPV6_RESERVED_UNICAST_GEOGRAPHIC
;
return
NET_IPV6_RESERVED_UNICAST_GEOGRAPHIC
;
}
}
return
NET_IPV6_UNKNOWN_TYPE
;
return
NET_IPV6_UNKNOWN_TYPE
;
}
}
...
@@ -533,18 +457,12 @@ class Net_IPv6
...
@@ -533,18 +457,12 @@ class Net_IPv6
*/
*/
public
static
function
uncompress
(
$ip
,
$leadingZeros
=
false
)
public
static
function
uncompress
(
$ip
,
$leadingZeros
=
false
)
{
{
$prefix
=
Net_IPv6
::
getPrefixLength
(
$ip
);
$prefix
=
Net_IPv6
::
getPrefixLength
(
$ip
);
if
(
false
===
$prefix
)
{
if
(
false
===
$prefix
)
{
$prefix
=
''
;
$prefix
=
''
;
}
else
{
}
else
{
$ip
=
Net_IPv6
::
removePrefixLength
(
$ip
);
$ip
=
Net_IPv6
::
removePrefixLength
(
$ip
);
$prefix
=
'/'
.
$prefix
;
$prefix
=
'/'
.
$prefix
;
}
}
$netmask
=
Net_IPv6
::
getNetmaskSpec
(
$ip
);
$netmask
=
Net_IPv6
::
getNetmaskSpec
(
$ip
);
...
@@ -554,93 +472,57 @@ class Net_IPv6
...
@@ -554,93 +472,57 @@ class Net_IPv6
$c2
=
-
1
;
$c2
=
-
1
;
if
(
false
!==
strpos
(
$uip
,
'::'
)
)
{
if
(
false
!==
strpos
(
$uip
,
'::'
)
)
{
list
(
$ip1
,
$ip2
)
=
explode
(
'::'
,
$uip
);
list
(
$ip1
,
$ip2
)
=
explode
(
'::'
,
$uip
);
if
(
""
==
$ip1
)
{
if
(
""
==
$ip1
)
{
$c1
=
-
1
;
$c1
=
-
1
;
}
else
{
}
else
{
$pos
=
0
;
$pos
=
0
;
if
(
0
<
(
$pos
=
substr_count
(
$ip1
,
':'
)))
{
if
(
0
<
(
$pos
=
substr_count
(
$ip1
,
':'
)))
{
$c1
=
$pos
;
$c1
=
$pos
;
}
else
{
}
else
{
$c1
=
0
;
$c1
=
0
;
}
}
}
}
if
(
""
==
$ip2
)
{
if
(
""
==
$ip2
)
{
$c2
=
-
1
;
$c2
=
-
1
;
}
else
{
}
else
{
$pos
=
0
;
$pos
=
0
;
if
(
0
<
(
$pos
=
substr_count
(
$ip2
,
':'
)))
{
if
(
0
<
(
$pos
=
substr_count
(
$ip2
,
':'
)))
{
$c2
=
$pos
;
$c2
=
$pos
;
}
else
{
}
else
{
$c2
=
0
;
$c2
=
0
;
}
}
}
}
if
(
strstr
(
$ip2
,
'.'
))
{
if
(
strstr
(
$ip2
,
'.'
))
{
$c2
++
;
$c2
++
;
}
}
if
(
-
1
==
$c1
&&
-
1
==
$c2
)
{
// ::
if
(
-
1
==
$c1
&&
-
1
==
$c2
)
{
// ::
$uip
=
"0:0:0:0:0:0:0:0"
;
$uip
=
"0:0:0:0:0:0:0:0"
;
}
elseif
(
-
1
==
$c1
)
{
// ::xxx
}
else
if
(
-
1
==
$c1
)
{
// ::xxx
$fill
=
str_repeat
(
'0:'
,
7
-
$c2
);
$fill
=
str_repeat
(
'0:'
,
7
-
$c2
);
$uip
=
str_replace
(
'::'
,
$fill
,
$uip
);
$uip
=
str_replace
(
'::'
,
$fill
,
$uip
);
}
elseif
(
-
1
==
$c2
)
{
// xxx::
}
else
if
(
-
1
==
$c2
)
{
// xxx::
$fill
=
str_repeat
(
':0'
,
7
-
$c1
);
$fill
=
str_repeat
(
':0'
,
7
-
$c1
);
$uip
=
str_replace
(
'::'
,
$fill
,
$uip
);
$uip
=
str_replace
(
'::'
,
$fill
,
$uip
);
}
else
{
// xxx::xxx
}
else
{
// xxx::xxx
$fill
=
str_repeat
(
':0:'
,
max
(
1
,
6
-
$c2
-
$c1
));
$fill
=
str_repeat
(
':0:'
,
max
(
1
,
6
-
$c2
-
$c1
));
$uip
=
str_replace
(
'::'
,
$fill
,
$uip
);
$uip
=
str_replace
(
'::'
,
$fill
,
$uip
);
$uip
=
str_replace
(
'::'
,
':'
,
$uip
);
$uip
=
str_replace
(
'::'
,
':'
,
$uip
);
}
}
}
}
if
(
true
==
$leadingZeros
)
{
if
(
true
==
$leadingZeros
)
{
$uipT
=
array
();
$uipT
=
array
();
$uiparts
=
explode
(
':'
,
$uip
);
$uiparts
=
explode
(
':'
,
$uip
);
foreach
(
$uiparts
as
$p
)
{
foreach
(
$uiparts
as
$p
)
{
$uipT
[]
=
sprintf
(
'%04s'
,
$p
);
$uipT
[]
=
sprintf
(
'%04s'
,
$p
);
}
}
$uip
=
implode
(
':'
,
$uipT
);
$uip
=
implode
(
':'
,
$uipT
);
}
}
if
(
''
!=
$netmask
)
{
if
(
''
!=
$netmask
)
{
$uip
=
$uip
.
'/'
.
$netmask
;
$uip
=
$uip
.
'/'
.
$netmask
;
}
}
return
$uip
.
$prefix
;
return
$uip
.
$prefix
;
...
@@ -680,31 +562,21 @@ class Net_IPv6
...
@@ -680,31 +562,21 @@ class Net_IPv6
public
static
function
compress
(
$ip
,
$force
=
false
)
public
static
function
compress
(
$ip
,
$force
=
false
)
{
{
if
(
false
!==
strpos
(
$ip
,
'::'
))
{
// its already compressed
if
(
false
!==
strpos
(
$ip
,
'::'
))
{
// its already compressed
if
(
true
==
$force
)
{
if
(
true
==
$force
)
{
$ip
=
Net_IPv6
::
uncompress
(
$ip
);
$ip
=
Net_IPv6
::
uncompress
(
$ip
);
}
else
{
}
else
{
return
$ip
;
return
$ip
;
}
}
}
}
$prefix
=
Net_IPv6
::
getPrefixLength
(
$ip
);
$prefix
=
Net_IPv6
::
getPrefixLength
(
$ip
);
if
(
false
===
$prefix
)
{
if
(
false
===
$prefix
)
{
$prefix
=
''
;
$prefix
=
''
;
}
else
{
}
else
{
$ip
=
Net_IPv6
::
removePrefixLength
(
$ip
);
$ip
=
Net_IPv6
::
removePrefixLength
(
$ip
);
$prefix
=
'/'
.
$prefix
;
$prefix
=
'/'
.
$prefix
;
}
}
$netmask
=
Net_IPv6
::
getNetmaskSpec
(
$ip
);
$netmask
=
Net_IPv6
::
getNetmaskSpec
(
$ip
);
...
@@ -713,9 +585,7 @@ class Net_IPv6
...
@@ -713,9 +585,7 @@ class Net_IPv6
$ipp
=
explode
(
':'
,
$ip
);
$ipp
=
explode
(
':'
,
$ip
);
for
(
$i
=
0
;
$i
<
count
(
$ipp
);
$i
++
)
{
for
(
$i
=
0
;
$i
<
count
(
$ipp
);
$i
++
)
{
$ipp
[
$i
]
=
dechex
(
hexdec
(
$ipp
[
$i
]));
$ipp
[
$i
]
=
dechex
(
hexdec
(
$ipp
[
$i
]));
}
}
$cip
=
':'
.
join
(
':'
,
$ipp
)
.
':'
;
$cip
=
':'
.
join
(
':'
,
$ipp
)
.
':'
;
...
@@ -723,29 +593,20 @@ class Net_IPv6
...
@@ -723,29 +593,20 @@ class Net_IPv6
preg_match_all
(
"/(:0)(:0)+/"
,
$cip
,
$zeros
);
preg_match_all
(
"/(:0)(:0)+/"
,
$cip
,
$zeros
);
if
(
count
(
$zeros
[
0
])
>
0
)
{
if
(
count
(
$zeros
[
0
])
>
0
)
{
$match
=
''
;
$match
=
''
;
foreach
(
$zeros
[
0
]
as
$zero
)
{
foreach
(
$zeros
[
0
]
as
$zero
)
{
if
(
strlen
(
$zero
)
>
strlen
(
$match
))
{
if
(
strlen
(
$zero
)
>
strlen
(
$match
))
{
$match
=
$zero
;
$match
=
$zero
;
}
}
}
}
$cip
=
preg_replace
(
'/'
.
$match
.
'/'
,
':'
,
$cip
,
1
);
$cip
=
preg_replace
(
'/'
.
$match
.
'/'
,
':'
,
$cip
,
1
);
}
}
$cip
=
preg_replace
(
'/((^:)|(:$))/'
,
''
,
$cip
);
$cip
=
preg_replace
(
'/((^:)|(:$))/'
,
''
,
$cip
);
$cip
=
preg_replace
(
'/((^:)|(:$))/'
,
'::'
,
$cip
);
$cip
=
preg_replace
(
'/((^:)|(:$))/'
,
'::'
,
$cip
);
if
(
''
!=
$netmask
)
{
if
(
''
!=
$netmask
)
{
$cip
=
$cip
.
'/'
.
$netmask
;
$cip
=
$cip
.
'/'
.
$netmask
;
}
}
return
$cip
.
$prefix
;
return
$cip
.
$prefix
;
...
@@ -796,9 +657,7 @@ class Net_IPv6
...
@@ -796,9 +657,7 @@ class Net_IPv6
*/
*/
function
isCompressible
(
$ip
)
function
isCompressible
(
$ip
)
{
{
return
(
bool
)(
$ip
!=
Net_IPv6
::
compress
(
$address
));
return
(
bool
)(
$ip
!=
Net_IPv6
::
compress
(
$address
));
}
}
// }}}
// }}}
...
@@ -827,23 +686,16 @@ class Net_IPv6
...
@@ -827,23 +686,16 @@ class Net_IPv6
$ip
=
Net_IPv6
::
removeNetmaskSpec
(
$ip
);
$ip
=
Net_IPv6
::
removeNetmaskSpec
(
$ip
);
if
(
$uncompress
)
{
if
(
$uncompress
)
{
$ip
=
Net_IPv6
::
Uncompress
(
$ip
);
$ip
=
Net_IPv6
::
Uncompress
(
$ip
);
}
}
if
(
strstr
(
$ip
,
'.'
))
{
if
(
strstr
(
$ip
,
'.'
))
{
$pos
=
strrpos
(
$ip
,
':'
);
$pos
=
strrpos
(
$ip
,
':'
);
$ip
{
$pos
}
=
'_'
;
$ip
{
$pos
}
=
'_'
;
$ipPart
=
explode
(
'_'
,
$ip
);
$ipPart
=
explode
(
'_'
,
$ip
);
return
$ipPart
;
return
$ipPart
;
}
else
{
}
else
{
return
array
(
$ip
,
""
);
return
array
(
$ip
,
""
);
}
}
}
}
...
@@ -863,15 +715,10 @@ class Net_IPv6
...
@@ -863,15 +715,10 @@ class Net_IPv6
*/
*/
public
static
function
checkIPv6
(
$ip
)
public
static
function
checkIPv6
(
$ip
)
{
{
$elements
=
Net_IPv6
::
separate
(
$ip
);
$elements
=
Net_IPv6
::
separate
(
$ip
);
$ip
=
$elements
[
0
];
$ip
=
$elements
[
0
];
if
(
''
!=
$elements
[
1
]
&&
(
!
is_numeric
(
$elements
[
1
])
||
0
>
$elements
[
1
]
||
128
<
$elements
[
1
]))
{
if
(
''
!=
$elements
[
1
]
&&
(
!
is_numeric
(
$elements
[
1
])
||
0
>
$elements
[
1
]
||
128
<
$elements
[
1
]))
{
return
false
;
return
false
;
}
}
$ipPart
=
Net_IPv6
::
SplitV64
(
$ip
);
$ipPart
=
Net_IPv6
::
SplitV64
(
$ip
);
...
@@ -879,73 +726,46 @@ class Net_IPv6
...
@@ -879,73 +726,46 @@ class Net_IPv6
if
(
!
empty
(
$ipPart
[
0
]))
{
if
(
!
empty
(
$ipPart
[
0
]))
{
$ipv6
=
explode
(
':'
,
$ipPart
[
0
]);
$ipv6
=
explode
(
':'
,
$ipPart
[
0
]);
foreach
(
$ipv6
as
$element
)
{
// made a validate precheck
foreach
(
$ipv6
as
$element
)
{
// made a validate precheck
if
(
!
preg_match
(
'/[0-9a-fA-F]*/'
,
$element
))
{
if
(
!
preg_match
(
'/[0-9a-fA-F]*/'
,
$element
))
{
return
false
;
return
false
;
}
}
}
}
for
(
$i
=
0
;
$i
<
count
(
$ipv6
);
$i
++
)
{
for
(
$i
=
0
;
$i
<
count
(
$ipv6
);
$i
++
)
{
if
(
4
<
strlen
(
$ipv6
[
$i
]))
{
if
(
4
<
strlen
(
$ipv6
[
$i
]))
{
return
false
;
return
false
;
}
}
$dec
=
hexdec
(
$ipv6
[
$i
]);
$dec
=
hexdec
(
$ipv6
[
$i
]);
$hex
=
strtoupper
(
preg_replace
(
"/^[0]
{
1,3
}
(.*[0-9a-fA-F])$/"
,
$hex
=
strtoupper
(
preg_replace
(
"/^[0]
{
1,3
}
(.*[0-9a-fA-F])$/"
,
"
\\
1"
,
$ipv6
[
$i
]));
"
\\
1"
,
$ipv6
[
$i
]));
if
(
$ipv6
[
$i
]
>=
0
&&
$dec
<=
65535
if
(
$ipv6
[
$i
]
>=
0
&&
$dec
<=
65535
&&
$hex
==
strtoupper
(
dechex
(
$dec
)))
{
&&
$hex
==
strtoupper
(
dechex
(
$dec
)))
{
$count
++
;
$count
++
;
}
}
}
}
if
(
8
==
$count
)
{
if
(
8
==
$count
)
{
return
true
;
return
true
;
}
elseif
(
6
==
$count
and
!
empty
(
$ipPart
[
1
]))
{
}
else
if
(
6
==
$count
and
!
empty
(
$ipPart
[
1
]))
{
$ipv4
=
explode
(
'.'
,
$ipPart
[
1
]);
$ipv4
=
explode
(
'.'
,
$ipPart
[
1
]);
$count
=
0
;
$count
=
0
;
for
(
$i
=
0
;
$i
<
count
(
$ipv4
);
$i
++
)
{
for
(
$i
=
0
;
$i
<
count
(
$ipv4
);
$i
++
)
{
if
(
$ipv4
[
$i
]
>=
0
&&
(
integer
)
$ipv4
[
$i
]
<=
255
if
(
$ipv4
[
$i
]
>=
0
&&
(
integer
)
$ipv4
[
$i
]
<=
255
&&
preg_match
(
"/^\d
{
1,3
}
$/"
,
$ipv4
[
$i
]))
{
&&
preg_match
(
"/^\d
{
1,3
}
$/"
,
$ipv4
[
$i
]))
{
$count
++
;
$count
++
;
}
}
}
}
if
(
4
==
$count
)
{
if
(
4
==
$count
)
{
return
true
;
return
true
;
}
}
}
else
{
}
else
{
return
false
;
return
false
;
}
}
}
else
{
}
else
{
return
false
;
return
false
;
}
}
}
}
// }}}
// }}}
...
@@ -974,31 +794,21 @@ class Net_IPv6
...
@@ -974,31 +794,21 @@ class Net_IPv6
public
static
function
parseAddress
(
$ipToParse
,
$bits
=
null
)
public
static
function
parseAddress
(
$ipToParse
,
$bits
=
null
)
{
{
$ip
=
null
;
$ip
=
null
;
$bitmask
=
null
;
$bitmask
=
null
;
if
(
null
==
$bits
)
{
if
(
null
==
$bits
)
{
$elements
=
explode
(
'/'
,
$ipToParse
);
$elements
=
explode
(
'/'
,
$ipToParse
);
if
(
2
==
count
(
$elements
)
)
{
if
(
2
==
count
(
$elements
)
)
{
$ip
=
Net_IPv6
::
uncompress
(
$elements
[
0
]);
$ip
=
Net_IPv6
::
uncompress
(
$elements
[
0
]);
$bitmask
=
$elements
[
1
];
$bitmask
=
$elements
[
1
];
}
else
{
}
else
{
include_once
'PEAR.inc'
;
include_once
'PEAR.inc'
;
return
PEAR
::
raiseError
(
NET_IPV6_NO_NETMASK_MSG
,
return
PEAR
::
raiseError
(
NET_IPV6_NO_NETMASK_MSG
,
NET_IPV6_NO_NETMASK
);
NET_IPV6_NO_NETMASK
);
}
}
}
else
{
}
else
{
$ip
=
Net_IPv6
::
uncompress
(
$ipToParse
);
$ip
=
Net_IPv6
::
uncompress
(
$ipToParse
);
$bitmask
=
$bits
;
$bitmask
=
$bits
;
}
}
$binNetmask
=
str_repeat
(
'1'
,
$bitmask
)
.
$binNetmask
=
str_repeat
(
'1'
,
$bitmask
)
.
...
@@ -1026,7 +836,7 @@ class Net_IPv6
...
@@ -1026,7 +836,7 @@ class Net_IPv6
*
*
* @return String the binary representation
* @return String the binary representation
* @access private
* @access private
@
@since 1.1.0
*
@since 1.1.0
*/
*/
protected
static
function
_ip2Bin
(
$ip
)
protected
static
function
_ip2Bin
(
$ip
)
{
{
...
@@ -1038,10 +848,8 @@ class Net_IPv6
...
@@ -1038,10 +848,8 @@ class Net_IPv6
$parts
=
explode
(
':'
,
$ip
);
$parts
=
explode
(
':'
,
$ip
);
foreach
(
$parts
as
$v
)
{
foreach
(
$parts
as
$v
)
{
$str
=
base_convert
(
$v
,
16
,
2
);
$str
=
base_convert
(
$v
,
16
,
2
);
$binstr
.=
str_pad
(
$str
,
16
,
'0'
,
STR_PAD_LEFT
);
$binstr
.=
str_pad
(
$str
,
16
,
'0'
,
STR_PAD_LEFT
);
}
}
return
$binstr
;
return
$binstr
;
...
@@ -1057,29 +865,22 @@ class Net_IPv6
...
@@ -1057,29 +865,22 @@ class Net_IPv6
*
*
* @return String the uncompressed Hex representation
* @return String the uncompressed Hex representation
* @access private
* @access private
@
@since 1.1.0
*
@since 1.1.0
*/
*/
protected
static
function
_bin2Ip
(
$bin
)
protected
static
function
_bin2Ip
(
$bin
)
{
{
$ip
=
""
;
$ip
=
""
;
if
(
strlen
(
$bin
)
<
128
)
{
if
(
strlen
(
$bin
)
<
128
)
{
$bin
=
str_pad
(
$bin
,
128
,
'0'
,
STR_PAD_LEFT
);
$bin
=
str_pad
(
$bin
,
128
,
'0'
,
STR_PAD_LEFT
);
}
}
$parts
=
str_split
(
$bin
,
"16"
);
$parts
=
str_split
(
$bin
,
"16"
);
foreach
(
$parts
as
$v
)
{
foreach
(
$parts
as
$v
)
{
$str
=
base_convert
(
$v
,
2
,
16
);
$str
=
base_convert
(
$v
,
2
,
16
);
$ip
.=
$str
.
":"
;
$ip
.=
$str
.
":"
;
}
}
$ip
=
substr
(
$ip
,
0
,
-
1
);
$ip
=
substr
(
$ip
,
0
,
-
1
);
return
$ip
;
return
$ip
;
}
}
...
@@ -1094,5 +895,3 @@ class Net_IPv6
...
@@ -1094,5 +895,3 @@ class Net_IPv6
* c-hanging-comment-ender-p: nil
* c-hanging-comment-ender-p: nil
* End:
* End:
*/
*/
?>
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