HEX
Server: Apache
System: Linux vps-cdc32557.vps.ovh.ca 5.15.0-156-generic #166-Ubuntu SMP Sat Aug 9 00:02:46 UTC 2025 x86_64
User: hanode (1017)
PHP: 7.4.33
Disabled: 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,pcntl_unshare,
Upload Files
File: //usr/share/webmin/useradmin/search_user.cgi
#!/usr/bin/perl
# search_user.cgi
# Search the password file, and display a list of results

require './user-lib.pl';
&ReadParse();

# Build fields to search
$m = $in{'match'};
$w = lc($in{'what'});
@fields = ( );
if ($in{'field'} eq "group") {
	@fields = ( 'gid' );
	$w = &my_getgrnam($w) || $w;
	}
elsif ($in{'field'} eq 'userreal') {
	@fields = ( 'user', 'real' );
	}
else {
	@fields = ( $in{'field'} );
	}

# Search users for matches
@ulist = &list_users();
for($i=0; $i<@ulist; $i++) {
	$u = $ulist[$i];
	FIELD: foreach my $field (@fields) {
		$f = lc($u->{$field});
		if ($m == 0 && $f eq $w ||
		    $m == 1 && eval { $f =~ /$w/i } ||
		    $m == 4 && index($f, $w) >= 0 ||
		    $m == 2 && $f ne $w ||
		    $m == 3 && eval { $f !~ /$w/i } ||
		    $m == 5 && index($f, $w) < 0 ||
		    $m == 6 && $f < $w ||
		    $m == 7 && $f > $w) {
			if (&can_edit_user(\%access, $u)) {
				push(@match, $u);
				last FIELD;
				}
			}
		}
	}
if (@match == 1) {
	&redirect("edit_user.cgi?user=".$match[0]->{'user'});
	}
else {
	&ui_print_header(undef, $text{'search_title'}, "");
	if (@match == 0) {
		print "<b>$text{'search_notfound'}</b>. <p>\n";
		}
	else {
		print "<b>",&text('search_found', scalar(@match)),"</b><br>\n";
		@match = &sort_users(\@match, $config{'sort_mode'});
		&users_table(\@match);
		}
	&ui_print_footer("", $text{'index_return'});
	}