#!/usr/bin/perl # #Copyright (C) 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006 Yokogawa Electric Corporation. #All rights reserved. # #Redistribution and use of this software in source and binary #forms, with or without modification, are permitted provided that #the following conditions and disclaimer are agreed and accepted #by the user: # #1. Redistributions of source code must retain the above copyright # notice, this list of conditions and the following disclaimer. # #2. Redistributions in binary form must reproduce the above copyright # notice, this list of conditions and the following disclaimer in # the documentation and/or other materials provided with # the distribution. # #3. Neither the names of the copyrighters, the name of the project # which is related to this software (hereinafter referred to as # "project") nor the names of the contributors may be used to # endorse or promote products derived from this software without # specific prior written permission. # #4. No merchantable use may be permitted without prior written # notification to the copyrighters. # #5. The copyrighters, the project and the contributors may prohibit # the use of this software at any time. # #THIS SOFTWARE IS PROVIDED BY THE COPYRIGHTERS, THE PROJECT AND #CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING #BUT NOT LIMITED THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS #FOR A PARTICULAR PURPOSE, ARE DISCLAIMED. IN NO EVENT SHALL THE #COPYRIGHTERS, THE PROJECT OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, #INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES #(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR #SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) #HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, #STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING #IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE #POSSIBILITY OF SUCH DAMAGE. # #$Id: C_RFC3315_21.4.1_DelayedAuthProto.seq,v 1.11 2006/03/14 01:16:30 mnaoki Exp $ ############################################################################### BEGIN { $V6evalTool::TestVersion = '$Name: DHCPv6_1_0 $'; push(@INC, '..'); } use strict; use V6evalTool; use DHCPv6_common; use Client_pktdesc; dhcpExitNS if ChkFuncSupport('AUTHENTICATION'); #--------------------------------------------------------------# # Initialization variables #--------------------------------------------------------------# vLogHTML('==== NUT Initialization ====
'); # Configure authentication parametor vLogHTML("Authentication Information
"); my $auth_realm = "DHCPv6.TEST.EXAMPLE.COM"; my $hex_auth_realm = Ascii2Hex($auth_realm); my $auth_key_id = "1"; my $auth_sharedsecretkey = "TAHITEST_VALID12"; vLogHTML("  REALM: $auth_realm
"); vLogHTML("  Key ID: $auth_key_id
"); vLogHTML("  Shared Secret Key: $auth_sharedsecretkey"); my $SHARED_SECRET_KEY_TYPE = ChkConfig('SHARED_SECRET_KEY_TYPE'); my $enc_auth_sharedsecretkey = SharedSecretKeyCheck($SHARED_SECRET_KEY_TYPE, $auth_sharedsecretkey); vLogHTML("  Device's Key Type: $SHARED_SECRET_KEY_TYPE, Encoded value: $enc_auth_sharedsecretkey
"); my $IF0_NUT = $V6evalTool::NutDef{"Link0_device"}; my $IF0 = "Link0"; #------------------------------------------------------------------- vLogHTML('DHCP Client-Initiated Configuration Exchange using Delayed Authentication Protocol
'); #------------------------------------------------------------------- #--------------------------------------------------------------# # Initialize DHCPv6 Client #--------------------------------------------------------------# my $ret = vRemote("dhcp6c.rmt", "start", "authentication=delayed", "auth_realm=$auth_realm", "auth_keyid=$auth_key_id", "auth_sharedsecretkey=$enc_auth_sharedsecretkey", "link0=$IF0_NUT"); if($ret != 0){ vLogHTML('Cannot Initialize DHCPv6 Client program.
'); dhcpExitFail; }; vCapture($IF0); my $cpp = undef; #--------------------------------------------------------------# #1. Wait until Solicit arrives #--------------------------------------------------------------# # This is requried when Authentication option is used, otherwise not required. $AUTH_OPTION_REQUIRED = $TRUE; my ($retsol,%sol) = wait_for_solicit($IF0,30) ; if($retsol != 0){ dhcpExitFail("Can't receive correct DHCPv6 Solicit message"); } vClear($IF0); # check options in Solicit Message if (0 != options_exist(\%sol, ($CMP_CID|$CMP_AUTH))){ dhcpExitError("Do not include necessary options!"); } if ($sol{'Recv_ReplayDetection'} ne '0000000000000000') { dhcpExitError("Must include 0 in Replay Detection field"); } #--------------------------------------------------------------# # 2. send Advertise message #--------------------------------------------------------------# # Increment replay detection field (64bit) my $auth_counter = undef; $auth_counter = '0000000000000001'; #$CID_OPTION = "opt_CID_LLT_nut"; $SID_OPTION = "opt_SID_LLT_server1"; $IA_NA_OPTION = "opt_IA_NA_Addr_woStatus"; $Authentication_OPTION = "opt_Auth"; $cpp = "-DAUTH_COUNTER=hexstr\\\(\\\"$auth_counter\\\",8\\\) "; $cpp .= "-DAUTH_REALM=hexstr\\\(\\\"$hex_auth_realm\\\"\\\) "; $cpp .= "-DAUTH_KEY_ID=$auth_key_id "; $cpp .= "-DAUTH_KEY_VALUE=\\\"$auth_sharedsecretkey\\\" "; my ($retadv, %adv) = send_advertise($IF0, "advertise_server1_to_nut", \%sol, $cpp); if($retadv != 0){ dhcpExitFail; } #--------------------------------------------------------------# #3. Wait until Request arrives #--------------------------------------------------------------# my ($retreq,%req) = wait_for_request($IF0,30); if($retreq != 0){ dhcpExitFail("Can't receive correct DHCPv6 Request message"); } vClear($IF0); # check options in Request Message #if (0 != options_exist(\%req, ($CMP_IA_NA|$CMP_CID|$CMP_SID|$CMP_AUTH))){ if (0 != options_exist(\%req, ($CMP_CID|$CMP_SID|$CMP_AUTH))){ dhcpExitError("Do not include necessary options!"); } if (0 != compare_options(\%adv, \%req, ( $CMP_SID|$CMP_CID))){ dhcpExitError("The server ID option in Request Msg is error!"); } #check Authenticator my $retauth = check_Auth_MD5(\%req,$auth_sharedsecretkey); if($retauth != 0){ dhcpExitFail("Authenticator does not match"); } #--------------------------------------------------------------# #4. send Reply message #--------------------------------------------------------------# $auth_counter = '0000000000000002'; $StatusCode_OPTION = "opt_StatusCode"; $Authentication_OPTION = "opt_Auth"; $cpp = "-DAUTH_COUNTER=hexstr\\\(\\\"$auth_counter\\\",8\\\) "; $cpp .= "-DAUTH_REALM=hexstr\\\(\\\"$hex_auth_realm\\\"\\\) "; $cpp .= "-DAUTH_KEY_ID=$auth_key_id "; $cpp .= "-DAUTH_KEY_VALUE=\\\"$auth_sharedsecretkey\\\" "; my ($retrep, %rep) = send_reply($IF0, "reply_server1_to_nut", \%req, $cpp); if($retrep !=0){ dhcpExitFail; } ## wait for DAD completion vRecv($IF0, 3, 0, 0, 'dadns_nutga'); vSleep(3); my $ret = ping_test($IF0); if($ret != 0){ dhcpExitFail; } #------------------------------------------------------------------- vLogHTML('DHCP Client-Initiated Configuration Exchange using Delayed Authentication Protocol is correct
'); #------------------------------------------------------------------- dhcpExitPass; ############################################################################### __END__ =head1 NAME C_RFC3315_21.4.1_DelayedAuthProto.seq - Checking Delayed Authentication Protocol for Client =head1 TARGET Client =head1 SYNOPSIS =begin html
   C_RFC3315_21.4.1_DelayedAuthProto.seq [-tooloption...]
  -pkt   C_RFC3315_21.4.1_DelayedAuthProto.def
  -tooloption : v6eval tool option

See Also DHCPv6.def
=end html =head1 INITIALIZATION =begin html =end html =head1 TEST PROCEDURE =begin html
       NUT      TN
        |       |
        |       |Initialize NUT (as a DHCPv6 client)
        |       |
        | ----> |Solicit w/ Authentication Option (1*)
        | <---- |Advertise w/ Authentication Option
        | ----> |Request w/ Authentication Option (3*)
        | <---- |Reply w/ Authentication Option
        |       |
        | <---- |Echo Request
        | ----> |Echo Reply (6*)
        |       |
=end html =head1 JUDGEMENT =begin html
  (1*)PASS: TN receives Solicit w/ Authentication Option from NUT.
  (3*)PASS: TN receives Request w/ Authentication Option from NUT.
  (6*)PASS: NUT should send Echo Reply to TN.
=end html =head1 TERMINATION =begin html
  N/A
=end html =head1 REFERENCE =begin html
   see also RFC3315
   21.4.4 Client Considerations for Delayed Authentication protocol
   22.11 Authentication Option
=end html =head1 SEE ALSO =begin html

perldoc V6evalTool
=end html