HEX
Server: nginx/1.28.1
System: Linux 10-41-63-61 6.8.0-31-generic #31-Ubuntu SMP PREEMPT_DYNAMIC Sat Apr 20 00:40:06 UTC 2024 x86_64
User: www (1001)
PHP: 7.4.33
Disabled: passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,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_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv
Upload Files
File: /www/wwwroot/www.whfie.com/tttt/api/login.php
<?php

require_once('common.php');

$action = isset($_GET['a']) ? $_GET['a'] : 'auth';
switch ($action) {
case 'auth':
	// validate request
	$body = file_get_contents('php://input');
	$auth = json_decode($body, true);
	if (!$auth || empty($auth)) {
		$r = array('error' => 'invalid request');
		localApiResponse(json_encode($r), 'HTTP/1.0 400 Bad Request');
		exit();
	}

	// load local db
	try {
		$ldb = getLocalDb();
		$cfg = $ldb->querySingle('SELECT username, password FROM config', true);
		if( !$cfg || sizeof($cfg) == 0 ) { throw new Exception($ldb->lastErrorMsg()); }
	} catch (Exception $e) {
		$r = array('error' => $e->getMessage());
		localApiResponse(json_encode($r), 'HTTP/1.0 500 Internal Server Error');
		exit();
	}
	$ldb->close();

	// validate auth
	if ( strtolower($auth['username']) !== strtolower($cfg['username']) || 
	(crypt($auth['password'], $cfg['password']) !== $cfg['password']) ) {
		localApiResponse('', 'HTTP/1.0 401 Authorization Required');
		sleep(2);
		exit();
	}

	$token = genToken(array('role' => 'api', 'username' => $auth['username'], 'exp' => strtotime('+3 hour')));
	localApiResponse(json_encode(array('token' => $token)));
	break;

default:
	$r = array('error' => 'unknown action');
	localApiResponse(json_encode($r), 'HTTP/1.0 400 Bad Request');
	exit();
}