Server IP : 195.201.23.43 / Your IP : 18.216.103.219 Web Server : Apache System : Linux webserver2.vercom.be 5.4.0-192-generic #212-Ubuntu SMP Fri Jul 5 09:47:39 UTC 2024 x86_64 User : kdecoratie ( 1041) PHP Version : 7.1.33-63+ubuntu20.04.1+deb.sury.org+1 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals, MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /usr/share/webmin/useradmin/ |
Upload File : |
#!/usr/bin/perl # Execute create/modify/delete group commands in a batch file require './user-lib.pl'; $access{'batch'} || &error($text{'gbatch_ecannot'}); if ($ENV{'REQUEST_METHOD'} eq 'GET') { &ReadParse(); } else { &ReadParseMime(); } if ($in{'source'} == 0) { $data = $in{'file'}; $data =~ /\S/ || &error($text{'batch_efile'}); } elsif ($in{'source'} == 1) { open(LOCAL, "<$in{'local'}") || &error($text{'batch_elocal'}); while(<LOCAL>) { $data .= $_; } close(LOCAL); } elsif ($in{'source'} == 2) { $data = $in{'text'}; $data =~ /\S/ || &error($text{'batch_etext'}); } &ui_print_unbuffered_header(undef, $text{'gbatch_title'}, ""); # Force defaults for save options $in{'chgid'} = 1 if (!$access{'chgid'}); # Work out a good base GID for new groups &build_group_used(\%gused, \%gtaken); $newgid = int($config{'base_gid'} > $access{'lowgid'} ? $config{'base_gid'} : $access{'lowgid'}); # Process the file &batch_start() if ($in{'batch'}); &lock_user_files(); $lnum = $created = $modified = $deleted = 0; print "<pre>\n"; $pft = &passfiles_type(); foreach $line (split(/[\r\n]+/, $data)) { $lnum++; $line =~ s/^\s*#.*$//; next if ($line !~ /\S/); local @line = split(/:/, $line, -1); local %group; if ($line[0] eq 'create') { # Creating a new group # Validate line if (!$line[1]) { print &text('batch_eline', $lnum),"\n"; next; } if (@line != 5) { print &text('batch_elen', $lnum, 5),"\n"; next; } if ($line[1] !~ /^[^:\t]+$/) { print &text('gbatch_egroupname', $lnum),"\n"; next; } $group{'group'} = $line[1]; if ($gtaken{$group{'group'}}) { print &text('gbatch_egroup', $lnum, $group{'group'}),"\n"; next; } if ($line[3] !~ /^\d+$/) { # make up a GID while($gused{$newgid}) { $newgid++; } $group{'gid'} = $newgid; } else { # use the given UID if ($gused{$line[3]} && !$access{'gmultiple'}) { print &text('gbatch_ecaccess', $lnum, $text{'gsave_egidused2'}),"\n"; next; } $group{'gid'} = $line[3]; } $gused{$group{'gid'}}++; $group{'members'} = $line[4]; # Check access control restrictions if (!$access{'gcreate'}) { print &text('gbatch_ecaccess', $lnum, $text{'gsave_ecreate'}); next; } local $ch = &check_group(\%group); if ($ch) { print &text('gbatch_ecaccess', $lnum, $ch),"\n"; next; } if ($line[2] eq '') { # No password needed $group{'pass'} = ''; $group{'passmode'} = 0; } else { # Normal password $group{'pass'} = &encrypt_password($line[2]); $group{'passmode'} = 3; $group{'plainpass'} = $line[2]; } # Run the before command &set_user_envs(\%group, 'CREATE_GROUP'); $merr = &making_changes(); &error(&text('gsave_emaking', "<tt>$merr</tt>")) if (defined($merr)); # Create the group! &create_group(\%group); # All done &made_changes(); # Call other modules, ignoring any failures $error_must_die = 1; eval { &other_modules("useradmin_create_group", \%group) if ($access{'cothers'} == 1 && $in{'others'} || $access{'cothers'} == 0); }; $other_err = $@; $error_must_die = 0; print "<b>",&text('gbatch_created', $group{'group'}),"</b>\n"; print "<b><i>",&text('batch_eother', $other_err),"</i></b>\n" if ($other_err); $created++; } elsif ($line[0] eq 'delete') { # Deleting an existing group if (@line != 2) { print &text('batch_elen', $lnum, 2),"\n"; next; } local @glist = &list_groups(); local ($group) = grep { $_->{'group'} eq $line[1] } @glist; if (!$group) { print &text('gbatch_enogroup', $lnum, $line[1]),"\n"; next; } # Check if deletion is allowed if (!&can_edit_group(\%access, $group)) { print &text('gbatch_edaccess', $lnum, $text{'gdel_egroup'}),"\n"; next; } if (!$config{'delete_root'} && $group->{'gid'} <= 10) { print &text('gbatch_edaccess', $lnum, $text{'gdel_egroup'}),"\n"; next; } # Check if has primary members local $prim; foreach $u (&list_users()) { if ($u->{'gid'} == $group->{'gid'}) { $prim = $u; last; } } if ($prim) { print &text('gbatch_eprimary', $lnum, $prim->{'user'}),"\n"; next; } # Run the before command &set_user_envs($group, 'DELETE_GROUP'); $merr = &making_changes(); &error(&text('usave_emaking', "<tt>$merr</tt>")) if (defined($merr)); # Delete from other modules, ignoring errors $error_must_die = 1; eval { &other_modules("useradmin_delete_group", $group) if ($access{'dothers'} == 1 && $in{'others'} || $access{'dothers'} == 0); }; $other_err = $@; $error_must_die = 0; # Delete the user entry &delete_group($group); &made_changes(); print "<b>",&text('gbatch_deleted',$group->{'group'}),"</b>\n"; print "<b><i>",&text('batch_eother', $other_err),"</i></b>\n" if ($other_err); $deleted++; } elsif ($line[0] eq 'modify') { # Modifying an existing group if (@line != 6) { print &text('batch_elen', $lnum, 6),"\n"; next; } local @glist = &list_groups(); local ($group) = grep { $_->{'group'} eq $line[1] } @glist; if (!$group) { print &text('gbatch_enogroup', $lnum, $line[1]),"\n"; next; } %oldgroup = %group = %$group; $user{'olduser'} = $user->{'user'}; if (!&can_edit_group(\%access, \%group)) { print &text('gbatch_emaccess', $lnum, $text{'gsave_eedit'}),"\n"; next; } # Update supplied fields if ($line[2] ne '') { if (!$access{'grename'}) { print &text('gbatch_erename', $lnum, $line[1]),"\n"; } $group{'group'} = $line[2]; } if ($line[3] ne '') { # New normal password $group{'pass'} = &encrypt_password($line[3]); $group{'passmode'} = 3; $group{'plainpass'} = $line[3]; } else { # No change $group{'passmode'} = 4; } $group{'gid'} = $line[4] if ($line[4] ne ''); if ($line[5] =~ /^\s+$/ || $line[5] eq 'NONE') { # No members $group{'members'} = ''; } elsif ($line[5]) { $group{'members'} = $line[5]; } # Check access control restrictions local $ch = &check_group(\%group, \%oldgroup); if ($ch) { print &text('gbatch_emaccess', $lnum, $ch),"\n"; next; } # Run the before command &set_user_envs(\%group, 'MODIFY_GROUP'); $merr = &making_changes(); &error(&text('usave_emaking', "<tt>$merr</tt>")) if (defined($merr)); # Change GIDs if ($oldgroup{'gid'} != $group{'gid'} && $in{'chgid'}) { if ($in{'chgid'} == 1) { # Do all the home directories of members &change_all_home_groups( $oldgroup{'gid'}, $group{'gid'}, [ split(/,/, $group{'members'}) ]); } else { # Do all files in this group from the root dir &recursive_change("/", -1, $oldgroup{'gid'}, -1, $group{'gid'}); } } # Actually modify the group &modify_group(\%oldgroup, \%group); &made_changes(); # Modify in other modules, ignoring errors $error_must_die = 1; eval { &other_modules("groupadmin_modify_group", \%group, \%oldgroup) if ($access{'mothers'} == 1 && $in{'others'} || $access{'mothers'} == 0); }; $error_must_die = 0; $other_err = $@; print "<b>",&text('batch_modified',$oldgroup{'group'}),"</b>\n"; print "<b><i>",&text('batch_eother', $other_err),"</i></b>\n" if ($other_err); $modified++; } else { print &text('batch_eaction', $lnum, $line[0]),"\n"; next; } } print "</pre>\n"; &batch_end() if ($in{'batch'}); &unlock_user_files(); &webmin_log("gbatch", undef, $in{'source'} == 1 ? $in{'local'} : undef, { 'created' => $created, 'modified' => $modified, 'deleted' => $deleted, 'lnum' => $lnum } ); &ui_print_footer("gbatch_form.cgi", $text{'batch_return'}, "index.cgi?mode=groups", $text{'index_return'}); # check_group(\%group, [\%oldgroup]) # Check access control restrictions for a group sub check_group { # check if gid is within range if ($access{'lowgid'} && $_[0]->{'gid'} < $access{'lowgid'}) { return &text('usave_elowgid', $access{'lowuid'}); } if ($access{'hiuid'} && $_[0]->{'uid'} > $access{'hiuid'}) { return &text('usave_ehiuid', $access{'hiuid'}); } if ($_[1] && !$access{'ggid'} && $_[1]->{'gid'} != $_[0]->{'gid'}) { return $text{'gsave_eggid'}; } return undef; }Private