#!/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.4.4_SendInfoReq.seq,v 1.5 2006/03/22 05:49: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";
my $timeout = 30;
#-------------------------------------------------------------------
vLogHTML('Sending Information-Request message with Authentication Option
');
#-------------------------------------------------------------------
#--------------------------------------------------------------#
# 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!");
}
#--------------------------------------------------------------#
#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;
}
#--------------------------------------------------------------#
#5. Wait until Information-request arrives
#--------------------------------------------------------------#
# XXXX
# This test is depend on implementation.
# If the device support sending Information-request after client initiated exchange finished,
# then this test will be perfomed.
#
my ($retinf,%inf) = wait_for_information_request($IF0, $timeout) ;
if($retinf != 0){
dhcpExitFail("Can't receive correct DHCPv6 Information-request message");
}
vClear($IF0);
# check options in Information-request Message
if (0 != options_exist(\%inf, ($CMP_ORO|$CMP_AUTH))){
dhcpExitError("Do not include necessary options!");
}
#--------------------------------------------------------------#
#6. send Reply message
#--------------------------------------------------------------#
$auth_counter = '0000000000000003';
$SID_OPTION = "opt_SID_LLT_server1";
$DNS_SVR_OPTION = "opt_DNS_Name_Server1";
$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;
}
#--------------------------------------------------------------#
#7. Whether information-request is recevied or not
#--------------------------------------------------------------#
my ($retinf,%inf) = wait_for_information_request($IF0, $timeout) ;
if($retinf == 0){
dhcpExitFail("Received DHCPv6 Information-request message");
}
vClear($IF0);
#-------------------------------------------------------------------
vLogHTML('Sending Information-Request message is correct
');
#-------------------------------------------------------------------
dhcpExitPass;
###############################################################################
__END__
=head1 NAME
C_RFC3315_21.4.4.4_SendInfoReq.seq - Sending Information-Request message
=head1 TARGET
Client
=head1 SYNOPSIS
=begin html
C_RFC3315_21.4.4.4_SendInfoReq.seq [-tooloption...] -pkt C_RFC3315_21.4.4.4_SendInfoReq.def -tooloption : v6eval tool option=end html =head1 INITIALIZATION =begin html
See Also DHCPv6.def
NUT(Client)
|
|
Link0 --+--------+------------------------ 3ffe:501:ffff:100::/64
|
|
TN(Server)
If the server has selected a key for the client in a previous message exchange, the client MUST use the same key to generate the authentication information throughout the session.
| Device Name | Device Type | Interface | Address | Link Local Addr | MAC Addr |
| Client | NUT | Link0 | NUT's Linklocal address | NUT's MAC address | |
| Server | TN | Link0 | 3ffe:501:ffff:100:200:ff:fe00:a1a1 | fe80::200:ff:fe00:a1a1 | 00:00:00:00:a1:a1 |
NUT TN
| |
| |Initialize NUT (as a DHCPv6 client)
| |
| ----> |Solicit w/ Authentication Option
| <---- |Advertise w/ Authentication Option
| ----> |Request w/ Authentication Option
| <---- |Reply w/ Authentication Option
| |
| ----> |Information-Request w/ Authentication Option (1*)
| <---- |Reply w/ Authentication Option
| |
| --X-> |No Information-Request (2*)
| |
=end html
=head1 JUDGEMENT
=begin html
(1*)PASS: TN receives Information-Request w/ Authentication Option from NUT. (1*)PASS: TN doesn't receive Information-Request w/ Authentication Option from NUT.=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 21.4.4.4. Sending Information-request Messages 22.11 Authentication Option=end html =head1 SEE ALSO =begin html
=end html
perldoc V6evalTool