[RADIATOR] EAP-SIM Authentication Issue
Rajesh Thota
rajesh.thota at prontonetworks.com
Fri Jun 25 03:20:34 CDT 2010
Hi Mike,
Appreciate your quick response. I modified the code to pull 3 triplets from
the HTTP server and pass it like this. I also modified the radius.cfg
(NumTriplets 3).
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
sub sim_request_triplets
{
my ($self, $context, $p, $n) = @_;
my $ua = new LWP::UserAgent;
$ua->agent("AgentName/0.1 " . $ua->agent);
# Create a request
my $req = new HTTP::Request GET => '
http://192.168.1.127:8080/cgi-bin/hlr_hex_cgi?TRANS_ID=102&IMSI=405803190032618
';
$req->content_type('application/x-www-form-urlencoded');
$req->content('match=www&errors=0');
# Pass request to the user agent and get a response back
my $res = $ua->request($req);
my $webOut;
# Check the outcome of the response
if ($res->is_success) {
$webOut = $res->content;
} else {
print "Bad luck this time\n";
}
my $row;
@$row = split( /\n/, $webOut);
my $ua1 = new LWP::UserAgent;
$ua1->agent("AgentName/0.1 " . $ua1->agent);
# Create a request
my $req1 = new HTTP::Request GET => '
http://192.168.1.127:8080/cgi-bin/hlr_hex_cgi?TRANS_ID=103&IMSI=405803190032618
';
$req1->content_type('application/x-www-form-urlencoded');
$req1->content('match=www&errors=0');
# Pass request to the user agent and get a response back
my $res1 = $ua1->request($req1);
my $webOut1;
# Check the outcome of the response
if ($res1->is_success) {
$webOut1 = $res1->content;
} else {
print "Bad luck this time\n";
}
my $row1;
@$row1 = split( /\n/, $webOut1);
my $ua2 = new LWP::UserAgent;
$ua2->agent("AgentName/0.1 " . $ua2->agent);
# Create a request
my $req2 = new HTTP::Request GET => '
http://192.168.1.127:8080/cgi-bin/hlr_hex_cgi?TRANS_ID=104&IMSI=405803190032618
';
$req2->content_type('application/x-www-form-urlencoded');
$req2->content('match=www&errors=0');
# Pass request to the user agent and get a response back
my $res2 = $ua1->request($req2);
my $webOut2;
# Check the outcome of the response
if ($res2->is_success) {
$webOut2 = $res2->content;
} else {
print "Bad luck this time\n";
}
my $row2;
@$row2 = split( /\n/, $webOut2);
my $myARand;
my $myARand1;
my $myARand2;
my $myASres;
my $myASres1;
my $myASres2;
my $myAKc;
my $myAKc1;
my $myAKc2;
@$myARand=split(/\=/, @$row[6]);
@$myASres=split(/\=/, @$row[7]);
@$myAKc=split(/\=/, @$row[8]);
@$myARand1=split(/\=/, @$row1[6]);
@$myASres1=split(/\=/, @$row1[7]);
@$myAKc1=split(/\=/, @$row1[8]);
@$myARand2=split(/\=/, @$row2[6]);
@$myASres2=split(/\=/, @$row2[7]);
@$myAKc2=split(/\=/, @$row2[8]);
my $myKc = @$myAKc[1];
my $mySres = @$myASres[1];
my $myRand = @$myARand[1];
my $myKc1 = @$myAKc1[1];
my $mySres1 = @$myASres1[1];
my $myRand1 = @$myARand1[1];
my $myKc2 = @$myAKc2[1];
my $mySres2 = @$myASres2[1];
my $myRand2 = @$myARand2[1];
$self->log($main::LOG_DEBUG, ".......................... $myRand |
$mySres | $myKc ...................");
$self->log($main::LOG_DEBUG, ".......................... $myRand1 |
$mySres1 | $myKc1 ...................");
$self->log($main::LOG_DEBUG, ".......................... $myRand2 |
$mySres2 | $myKc2 ...................");
return (
pack('H*', $myKc), pack('H*', $mySres), pack('H*', $myRand),
pack('H*', $myKc1), pack('H*', $mySres1), pack('H*', $myRand1),
pack('H*', $myKc2), pack('H*', $mySres2), pack('H*', $myRand2),
);
}
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
The Client seems to still send the same ERROR. The IMSI which I am passing
to the CGI is the same I am testing with. I have just removed the leading
'1' and anything after @ in the identity attribute of the EAP Message.
Somehow it is not going into SIM_CHALLENGE sub. Any help would be much
appreciated.
Thanks
Rajesh.
On Fri, Jun 25, 2010 at 1:53 AM, Mike McCauley <mikem at open.com.au> wrote:
> HEllo,
>
> On Thursday 24 June 2010 11:55:12 pm Rajesh Thota wrote:
> > Hello All,
> >
> > I am in the process of evaluating Radiator. 2 Main features I would be
> > needing is EAP-SIM and EAP-PEAP.
> >
> > I have been working on modifying the EAP-SIM.pm file I have just
> modified
> > the sim_request_triplets subroutine to pull the GSM triplets using a HTTP
> > GET request to a server. The HTTP Server talks to the MAP gateway
> passing
> > the IMSI. For the time being I have hard-coded the IMSI onto the URL.
> > The IMSI on the URL and the request is same. I am passing the RAND, SRES
> &
> > Kc from this routine as shown in the sample code(comment).
>
> That looks OK, although I see you are passing the same triplet back 3
> times.
>
> The last message indicates the client found a problem with the triplets
> sent
> to it. Suggest you look at the client side logs to determine why it did not
> like the triplets. May be related to the above point?
>
> Or may through some error, the triplets are not for the IMSI you are
> requesting.
>
> Cheers.
>
> >
> > Any help is appreciated on this front.
> >
> > Thanks & Regards
> >
> > Rajesh
> >
> >
> ---------------------------------------------------------------------------
>
> >----------------------------------------------------------------------------
> >----------------------
> >
> > sub sim_request_triplets
> > {
> > my ($self, $context, $p, $n) = @_;
> >
> > my $ua1 = new LWP::UserAgent;
> > $ua1->agent("AgentName/0.1 " . $ua1->agent);
> >
> > # Create a request
> > my $req = new HTTP::Request GET => '
> >
> http://192.168.1.127:8080/cgi-bin/hlr_hex_cgi?TRANS_ID=102&IMSI=40580319003
> >2618 ';
> > $req->content_type('application/x-www-form-urlencoded');
> > $req->content('match=www&errors=0');
> >
> > # Pass request to the user agent and get a response back
> > my $res = $ua1->request($req);
> > my $webOut;
> >
> > # Check the outcome of the response
> > if ($res->is_success) {
> > $webOut = $res->content;
> > } else {
> > print "Bad luck this time\n";
> > }
> >
> > my $row;
> > @$row = split( /\n/, $webOut);
> >
> > my $myARand;
> > my $myASres;
> > my $myAKc;
> >
> > @$myARand=split(/\=/, @$row[6]);
> > @$myASres=split(/\=/, @$row[7]);
> > @$myAKc=split(/\=/, @$row[8]);
> >
> > my $myKc = @$myAKc[1];
> > my $mySres = @$myASres[1];
> > my $myRand = @$myARand[1];
> >
> > $self->log($main::LOG_DEBUG, "$myRand | $mySres | $myKc
> > ...................");
> >
> > return (
> > pack('H*', $myKc), pack('H*', $mySres), pack('H*', $myRand),
> > pack('H*', $myKc), pack('H*', $mySres), pack('H*', $myRand),
> > pack('H*', $myKc), pack('H*', $mySres), pack('H*', $myRand),
> > );
> >
> > return;
> > }
> >
> >
> ---------------------------------------------------------------------------
>
> >----------------------------------------------------------------------------
> >----------------------
> >
> > The Radius LOG file prints the following :
> >
> > *** Received from 192.168.1.152 port 2049 ....
> > Code: Access-Request
> > Identifier: 9
> > Authentic: <145>BZ<135><209><1>Qi<214><11>r<248>e<174><141><224>
> > Attributes:
> > User-Name = "1405803190032618 at wlan.mnc080.mcc405.3gppnetwork.org
> "
> > NAS-IP-Address = 192.168.1.152
> > NAS-Identifier = "Wireless LAN Access Point"
> > NAS-Port = 0
> > Called-Station-Id = "00-80-48-67-43-25:SIM-Test"
> > Calling-Station-Id = "00-24-7D-4A-52-87"
> > Framed-MTU = 1400
> > NAS-Port-Type = Wireless-IEEE-802-11
> > Connect-Info = "CONNECT 11Mbps 802.11b"
> > EAP-Message = <2><0><0>8<1>
> > 1405803190032618 at wlan.mnc080.mcc405.3gppnetwork.org
> > Message-Authenticator = <212>I<163>k?gNAGu<5><228><7><200>"<197>
> >
> > Thu Jun 24 19:02:13 2010: DEBUG: Handling request with Handler
> > 'Realm=DEFAULT'
> > Thu Jun 24 19:02:13 2010: DEBUG: Deleting session for
> > 1405803190032618 at wlan.mnc080.mcc405.3gppnetwork.org, 192.168.1.152, 0
> > Thu Jun 24 19:02:13 2010: DEBUG: Handling with Radius::AuthSIM:
> > Thu Jun 24 19:02:13 2010: DEBUG: Handling with EAP: code 2, 0, 56, 1
> > Thu Jun 24 19:02:13 2010: DEBUG: Response type 1
> > Thu Jun 24 19:02:13 2010: DEBUG: EAP result: 3, EAP SIM/Start
> > Thu Jun 24 19:02:13 2010: DEBUG: AuthBy SIM result: CHALLENGE, EAP
> > SIM/Start Thu Jun 24 19:02:13 2010: DEBUG: Access challenged for
> > 1405803190032618 at wlan.mnc080.mcc405.3gppnetwork.org: EAP SIM/Start
> > Thu Jun 24 19:02:13 2010: DEBUG: Packet dump:
> > *** Sending to 192.168.1.152 port 2049 ....
> > Code: Access-Challenge
> > Identifier: 9
> > Authentic:
> <179><251><218><160><134><176><0><241>m'<240><216><136><188>kF
> > Attributes:
> > EAP-Message =
> <1><1><0><16><18><10><0><0><15><2><0><4><0><0><0><1>
> > Message-Authenticator =
> > <0><0><0><0><0><0><0><0><0><0><0><0><0><0><0><0>
> >
> > Thu Jun 24 19:02:13 2010: DEBUG: Packet dump:
> > *** Received from 192.168.1.152 port 2049 ....
> > Code: Access-Request
> > Identifier: 10
> > Authentic:
> > <205><19><175><222><132><4>#<7><128><206><241><232><144><169><205>2
> > Attributes:
> > User-Name = "1405803190032618 at wlan.mnc080.mcc405.3gppnetwork.org
> "
> > NAS-IP-Address = 192.168.1.152
> > NAS-Identifier = "Wireless LAN Access Point"
> > NAS-Port = 0
> > Called-Station-Id = "00-80-48-67-43-25:SIM-Test"
> > Calling-Station-Id = "00-24-7D-4A-52-87"
> > Framed-MTU = 1400
> > NAS-Port-Type = Wireless-IEEE-802-11
> > Connect-Info = "CONNECT 11Mbps 802.11b"
> > EAP-Message = <2><1><0>
> >
> <18><10><0><0><7><5><0><0><4><171><176><171><217>[$<216><231><10><135>|<181
> >><172><167><245><16><1><0><1> Message-Authenticator =
> > i<26>=/<243><153>,<192><215><237>~<157><240><163><S
> >
> > Thu Jun 24 19:02:13 2010: DEBUG: Handling request with Handler
> > 'Realm=DEFAULT'
> > Thu Jun 24 19:02:13 2010: DEBUG: Deleting session for
> > 1405803190032618 at wlan.mnc080.mcc405.3gppnetwork.org, 192.168.1.152, 0
> > Thu Jun 24 19:02:13 2010: DEBUG: Handling with Radius::AuthSIM:
> > Thu Jun 24 19:02:13 2010: DEBUG: Handling with EAP: code 2, 1, 32, 18
> > Thu Jun 24 19:02:13 2010: DEBUG: Response type 18
> > Thu Jun 24 19:02:13 2010: DEBUG: ..........................
> > 2c191a3d8f1a2fd2553ff272433f142 | c56c879a | 2098f32fbf3e86b1
> > ...................
> > Thu Jun 24 19:02:13 2010: DEBUG: EAP result: 3, EAP SIM/Challenge
> > Thu Jun 24 19:02:13 2010: DEBUG: AuthBy SIM result: CHALLENGE, EAP
> > SIM/Challenge
> > Thu Jun 24 19:02:13 2010: DEBUG: Access challenged for
> > 1405803190032618 at wlan.mnc080.mcc405.3gppnetwork.org: EAP SIM/Challenge
> > Thu Jun 24 19:02:13 2010: DEBUG: Packet dump:
> > *** Sending to 192.168.1.152 port 2049 ....
> > Code: Access-Challenge
> > Identifier: 10
> > Authentic: g<141><12><241>Bt<201>zf<202>lG<216>W<166>}
> > Attributes:
> > EAP-Message =
> >
> <1><2><0>P<18><11><0><0><1><13><0><0>,<25><26>=<143><26>/<210>U?<242>rC?<20
> >> ,<25><26>=<143><26>/<210>U?<242>rC?<20>
> > ,<25><26>=<143><26>/<210>U?<242>rC?<20>
> > <11><5><0><0><234><197>L'<152><227><237><153><164>^<200><152>P<239><10>h
> > Message-Authenticator =
> > <0><0><0><0><0><0><0><0><0><0><0><0><0><0><0><0>
> >
> > Thu Jun 24 19:02:17 2010: DEBUG: Packet dump:
> > *** Received from 192.168.1.152 port 2049 ....
> > Code: Access-Request
> > Identifier: 11
> > Authentic: <238>H<203><145><189><211><135>g<230><145><233><234>R<170>+5
> > Attributes:
> > User-Name = "1405803190032618 at wlan.mnc080.mcc405.3gppnetwork.org
> "
> > NAS-IP-Address = 192.168.1.152
> > NAS-Identifier = "Wireless LAN Access Point"
> > NAS-Port = 0
> > Called-Station-Id = "00-80-48-67-43-25:SIM-Test"
> > Calling-Station-Id = "00-24-7D-4A-52-87"
> > Framed-MTU = 1400
> > NAS-Port-Type = Wireless-IEEE-802-11
> > Connect-Info = "CONNECT 11Mbps 802.11b"
> > EAP-Message = <2><2><0><12><18><14><0><0><22><1><0><0>
> > Message-Authenticator =
> > <164>.n<14><227><19>szL<200><175><193><221><21>#'
> >
> > Thu Jun 24 19:02:17 2010: DEBUG: Handling request with Handler
> > 'Realm=DEFAULT'
> > Thu Jun 24 19:02:17 2010: DEBUG: Deleting session for
> > 1405803190032618 at wlan.mnc080.mcc405.3gppnetwork.org, 192.168.1.152, 0
> > Thu Jun 24 19:02:17 2010: DEBUG: Handling with Radius::AuthSIM:
> > Thu Jun 24 19:02:17 2010: DEBUG: Handling with EAP: code 2, 2, 12, 18
> > Thu Jun 24 19:02:17 2010: DEBUG: Response type 18
> > Thu Jun 24 19:02:17 2010: WARNING: EAP SIM Client Error code 0: Unable to
> > Process
> > Thu Jun 24 19:02:17 2010: DEBUG: EAP result: 1, EAP SIM Client Error
> > Thu Jun 24 19:02:17 2010: DEBUG: AuthBy SIM result: REJECT, EAP SIM
> Client
> > Error
> > Thu Jun 24 19:02:17 2010: INFO: Access rejected for
> > 1405803190032618 at wlan.mnc080.mcc405.3gppnetwork.org: EAP SIM Client
> Error
> > Thu Jun 24 19:02:17 2010: DEBUG: Packet dump:
> > *** Sending to 192.168.1.152 port 2049 ....
> > Code: Access-Reject
> > Identifier: 11
> > Authentic:
> > #<145><185><187><185>y<216><180><140><26>B<217><176><210><146><224>
> > Attributes:
> > EAP-Message = <4><2><0><4>
> > Message-Authenticator =
> > <0><0><0><0><0><0><0><0><0><0><0><0><0><0><0><0>
> > Reply-Message = "Request Denied"
> >
> >
> ---------------------------------------------------------------------------
>
> >----------------------------------------------------------------------------
> >----------------------
> >
> > The CGI program I am invoking returns the following
> >
> > TRANS_ID=102
> > PRIM_ID=56242
> > IMSI=405803190032618
> > RESPONSE_CODE=0
> > VECTOR_COUNT=1
> > VECTOR_TYPE=2G
> > RAND=c2de1c1ec4d73dc1e6ece5ce624e85
> > SRES=84566be
> > KC=bb2a2c1388718b99
> > ;
> >
> >
> >
> ---------------------------------------------------------------------------
>
> >----------------------------------------------------------------------------
> >----------------------
> >
> >
> > Wondering What is going Wrong ? Any help is much appreciated.
>
>
>
> --
> Mike McCauley mikem at open.com.au
> Open System Consultants Pty. Ltd
> 9 Bulbul Place Currumbin Waters QLD 4223 Australia
> http://www.open.com.au
> Phone +61 7 5598-7474 Fax +61 7 5598-7070
>
> Radiator: the most portable, flexible and configurable RADIUS server
> anywhere. SQL, proxy, DBM, files, LDAP, NIS+, password, NT, Emerald,
> Platypus, Freeside, TACACS+, PAM, external, Active Directory, EAP, TLS,
> TTLS, PEAP, TNC, WiMAX, RSA, Vasco, Yubikey, MOTP, HOTP, TOTP,
> DIAMETER etc. Full source on Unix, Windows, MacOSX, Solaris, VMS, NetWare
> etc.
>
-------------- next part --------------
An HTML attachment was scrubbed...
URL: http://www.open.com.au/pipermail/radiator/attachments/20100625/58b23751/attachment-0001.html
More information about the radiator
mailing list