mirror of
https://github.com/xcat2/xcat-core.git
synced 2025-10-23 23:45:33 +00:00
Merge pull request #4371 from xuweibj/T4196
rspconfig admin_password for OpenBMC
This commit is contained in:
@@ -310,9 +310,17 @@ my %status_info = (
|
||||
RSPCONFIG_GET_RESPONSE => {
|
||||
process => \&rspconfig_response,
|
||||
},
|
||||
RSPCONFIG_SET_REQUEST => {
|
||||
RSPCONFIG_SET_PASSWD_REQUEST => {
|
||||
method => "POST",
|
||||
init_url => "/xyz/openbmc_project/user/root/action/SetPassword",
|
||||
data => "",
|
||||
},
|
||||
"RSPCONFIG_PASSWD_VERIFY" => {
|
||||
process => \&rspconfig_response,
|
||||
},
|
||||
RSPCONFIG_SET_HOSTNAME_REQUEST => {
|
||||
method => "PUT",
|
||||
init_url => "$openbmc_project_url/network",
|
||||
init_url => "$openbmc_project_url/network/config/attr/HostName",
|
||||
data => "[]",
|
||||
},
|
||||
RSPCONFIG_SET_RESPONSE => {
|
||||
@@ -839,8 +847,12 @@ sub parse_args {
|
||||
my $key = $1;
|
||||
my $value = $2;
|
||||
return ([ 1, "Changing ipsrc value is currently not supported." ]) if ($key eq "ipsrc");
|
||||
return ([ 1, "Unsupported command: $command $key" ]) unless ($key =~ /^ip$|^netmask$|^gateway$|^hostname$|^vlan$/);
|
||||
return ([ 1, "The option 'hostname' can not work with other options." ]) if ($key eq "hostname" and $num_subcommand > 1);
|
||||
return ([ 1, "Unsupported command: $command $key" ]) unless ($key =~ /^ip$|^netmask$|^gateway$|^hostname$|^vlan$|^admin_passwd$/);
|
||||
return ([ 1, "The option '$key' can not work with other options." ]) if ($key =~ /^hostname$|^admin_passwd$/ and $num_subcommand > 1);
|
||||
if ($key eq "admin_passwd") {
|
||||
my $comma_num = $value =~ tr/,/,/;
|
||||
return ([ 1, "Invalid parameter for option $key: $value" ]) if ($comma_num != 1);
|
||||
}
|
||||
|
||||
my $nodes_num = @$noderange;
|
||||
return ([ 1, "Invalid parameter for option $key" ]) unless ($value);
|
||||
@@ -1170,13 +1182,14 @@ sub parse_command_status {
|
||||
return 0;
|
||||
}
|
||||
if ($subcommand =~ /^hostname=(.+)/) {
|
||||
$next_status{LOGIN_RESPONSE} = "RSPCONFIG_SET_REQUEST";
|
||||
$next_status{RSPCONFIG_SET_REQUEST} = "RSPCONFIG_SET_RESPONSE";
|
||||
$next_status{LOGIN_RESPONSE} = "RSPCONFIG_SET_HOSTNAME_REQUEST";
|
||||
$next_status{RSPCONFIG_SET_HOSTNAME_REQUEST} = "RSPCONFIG_SET_RESPONSE";
|
||||
$next_status{RSPCONFIG_SET_RESPONSE} = "RSPCONFIG_GET_REQUEST";
|
||||
$next_status{RSPCONFIG_GET_REQUEST} = "RSPCONFIG_GET_RESPONSE";
|
||||
|
||||
$status_info{RSPCONFIG_SET_REQUEST}{data} = $1;
|
||||
$status_info{RSPCONFIG_SET_REQUEST}{init_url} .= "/config/attr/HostName";
|
||||
$status_info{RSPCONFIG_SET_HOSTNAME_REQUEST}{data} = $1;
|
||||
$status_info{RSPCONFIG_SET_RESPONSE}{argv} = "Hostname";
|
||||
$status_info{RSPCONFIG_GET_RESPONSE}{argv} = "hostname";
|
||||
return 0;
|
||||
}
|
||||
}
|
||||
@@ -1209,6 +1222,19 @@ sub parse_command_status {
|
||||
return 0;
|
||||
}
|
||||
|
||||
if ($subcommand =~ /^admin_passwd=(.+),(.+)/) {
|
||||
my $currentpasswd = $1;
|
||||
my $newpasswd = $2;
|
||||
$next_status{LOGIN_RESPONSE} = "RSPCONFIG_PASSWD_VERIFY";
|
||||
$next_status{RSPCONFIG_PASSWD_VERIFY} = "RSPCONFIG_SET_PASSWD_REQUEST";
|
||||
$next_status{RSPCONFIG_SET_PASSWD_REQUEST} = "RSPCONFIG_SET_RESPONSE";
|
||||
|
||||
$status_info{RSPCONFIG_PASSWD_VERIFY}{argv} = "$currentpasswd";
|
||||
$status_info{RSPCONFIG_SET_PASSWD_REQUEST}{data} = "[\"$newpasswd\"]";
|
||||
$status_info{RSPCONFIG_SET_RESPONSE}{argv} = "Password";
|
||||
return 0;
|
||||
}
|
||||
|
||||
my $type = "obj";
|
||||
my %tmp_hash = ();
|
||||
foreach $subcommand (@$subcommands) {
|
||||
@@ -2483,9 +2509,18 @@ sub rspconfig_response {
|
||||
}
|
||||
}
|
||||
|
||||
if ($node_info{$node}{cur_status} eq "RSPCONFIG_PASSWD_VERIFY") {
|
||||
if ($status_info{RSPCONFIG_PASSWD_VERIFY}{argv} ne $node_info{$node}{password}) {
|
||||
xCAT::SvrUtils::sendmsg("Current BMC password is incorrect, cannot set the new password.", $callback, $node);
|
||||
$next_status{ $node_info{$node}{cur_status} } = "";
|
||||
}
|
||||
}
|
||||
|
||||
if ($node_info{$node}{cur_status} eq "RSPCONFIG_SET_RESPONSE") {
|
||||
if ($response_info->{'message'} eq $::RESPONSE_OK) {
|
||||
xCAT::SvrUtils::sendmsg("BMC Setting Hostname...", $callback, $node);
|
||||
if (defined $status_info{RSPCONFIG_SET_RESPONSE}{argv}) {
|
||||
xCAT::SvrUtils::sendmsg("BMC Setting $status_info{RSPCONFIG_SET_RESPONSE}{argv}...", $callback, $node);
|
||||
}
|
||||
}
|
||||
}
|
||||
if ($node_info{$node}{cur_status} eq "RSPCONFIG_DHCP_RESPONSE") {
|
||||
|
Reference in New Issue
Block a user