mirror of
https://github.com/webmin/webmin.git
synced 2026-02-07 07:52:13 +00:00
51 lines
1.3 KiB
Perl
Executable File
51 lines
1.3 KiB
Perl
Executable File
|
|
do 'sshd-lib.pl';
|
|
|
|
# useradmin_create_user(&details)
|
|
# Setup SSH and GNUPG for new users
|
|
sub useradmin_create_user
|
|
{
|
|
if ($config{'sync_create'} && &has_command($config{'keygen_path'}) &&
|
|
-d $_[0]->{'home'} && !-d "$_[0]->{'home'}/.ssh") {
|
|
local $cmd;
|
|
local $type = $config{'sync_type'} ? "-t $config{'sync_type'}" :
|
|
$version{'type'} eq 'openssh' &&
|
|
$version{'number'} >= 3.2 ? "-t rsa1" : "";
|
|
if ($config{'sync_pass'} && $_[0]->{'passmode'} == 3) {
|
|
$cmd = "$config{'keygen_path'} $type -P \"$_[0]->{'plainpass'}\"";
|
|
}
|
|
else {
|
|
$cmd = "$config{'keygen_path'} $type -P \"\"";
|
|
}
|
|
&system_logged("echo '' | su $_[0]->{'user'} -c '$cmd' >/dev/null 2>&1");
|
|
if ($config{'sync_auth'}) {
|
|
my $akeys = "$_[0]->{'home'}/.ssh/authorized_keys";
|
|
&lock_file($akeys);
|
|
if (-r "$_[0]->{'home'}/.ssh/identity.pub") {
|
|
©_source_dest("$_[0]->{'home'}/.ssh/identity.pub", $akeys);
|
|
}
|
|
elsif (-r "$_[0]->{'home'}/.ssh/id_rsa.pub") {
|
|
©_source_dest("$_[0]->{'home'}/.ssh/id_rsa.pub", $akeys);
|
|
}
|
|
else {
|
|
©_source_dest("$_[0]->{'home'}/.ssh/id_dsa.pub", $akeys);
|
|
}
|
|
&set_ownership_permissions($_[0]->{'uid'}, $_[0]->{'gid'}, undef, $akeys);
|
|
&unlock_file($akeys);
|
|
}
|
|
}
|
|
}
|
|
|
|
# useradmin_delete_user(&details)
|
|
sub useradmin_delete_user
|
|
{
|
|
}
|
|
|
|
# useradmin_modify_user(&details)
|
|
sub useradmin_modify_user
|
|
{
|
|
}
|
|
|
|
1;
|
|
|