おマンコ

This commit is contained in:
2025-12-08 01:44:38 +09:00
parent c7537ab36f
commit d810b7155f
2 changed files with 17 additions and 1 deletions

View File

@@ -9,6 +9,7 @@ class User {
use Mods; use Mods;
public function login(array $params): void { public function login(array $params): void {
if (!AUTH_ENABLED) return;
try { try {
$auth = new Auth; $auth = new Auth;
$user = $auth->getLoggedInUser(); $user = $auth->getLoggedInUser();
@@ -57,6 +58,7 @@ class User {
} }
public function logout(array $params): void { public function logout(array $params): void {
if (!AUTH_ENABLED) return;
try { try {
$auth = new Auth; $auth = new Auth;
$user = $auth->getLoggedInUser(); $user = $auth->getLoggedInUser();

View File

@@ -35,6 +35,7 @@ class Auth {
} }
public function setToken(string $username, string $password): \Result { public function setToken(string $username, string $password): \Result {
if (!AUTH_ENABLED) return \Result::Error('エラー:認証システムは無効です。');
$userData = $this->getUserData(); $userData = $this->getUserData();
if (!isset($userData->tokens) || !is_array($userData->tokens)) $userData->tokens = []; if (!isset($userData->tokens) || !is_array($userData->tokens)) $userData->tokens = [];
@@ -102,12 +103,14 @@ class Auth {
} }
public function getToken(): string { public function getToken(): string {
if (!AUTH_ENABLED) return '';
$userData = $this->getUserData(); $userData = $this->getUserData();
if (!isset($userData->tokens) || !is_array($userData->tokens)) $userData->tokens = []; if (!isset($userData->tokens) || !is_array($userData->tokens)) $userData->tokens = [];
$userData = $this->purgeOldTokens($userData); $userData = $this->purgeOldTokens($userData);
} }
public function logout(?string $token = null): \Result { public function logout(?string $token = null): \Result {
if (!AUTH_ENABLED) return \Result::Error('エラー:認証システムは無効です。');
$secure = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off'); $secure = (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off');
$domain = $_SERVER['SERVER_NAME']; $domain = $_SERVER['SERVER_NAME'];
$userData = $this->getUserData(); $userData = $this->getUserData();
@@ -131,6 +134,7 @@ class Auth {
} }
public function isUserExist(?string $username = null): \Result { public function isUserExist(?string $username = null): \Result {
if (!AUTH_ENABLED) return \Result::Error('エラー:認証システムは無効です。');
if (null === $username) return \Result::Error('エラー:ユーザー名をご入力下さい。'); if (null === $username) return \Result::Error('エラー:ユーザー名をご入力下さい。');
$userList = scandir($this->dataDir); $userList = scandir($this->dataDir);
@@ -145,6 +149,7 @@ class Auth {
} }
public function mkUser(?string $username = null, ?string $password = null, ?string $passwordVerify = null, ?string $email = null): \Result { public function mkUser(?string $username = null, ?string $password = null, ?string $passwordVerify = null, ?string $email = null): \Result {
if (!AUTH_ENABLED) return \Result::Error('エラー:認証システムは無効です。');
if (!AUTH_REGISTER_ENABLED) return \Result::Error('ユーザー登録は無効です。'); if (!AUTH_REGISTER_ENABLED) return \Result::Error('ユーザー登録は無効です。');
$resUsr = $this->verifyUsername($username); $resUsr = $this->verifyUsername($username);
$resPwd = $this->verifyPassword($password, $passwordVerify); $resPwd = $this->verifyPassword($password, $passwordVerify);
@@ -206,6 +211,7 @@ class Auth {
//////////////////// ////////////////////
private function verifyLogin(string $username, string $password): \Result { private function verifyLogin(string $username, string $password): \Result {
if (!AUTH_ENABLED) return \Result::Error('エラー:認証システムは無効です。');
$userData = $this->getUserData(); $userData = $this->getUserData();
if ($username !== $userData->username || !password_verify($password, $userData->password)) { if ($username !== $userData->username || !password_verify($password, $userData->password)) {
return \Result::Error('エラー:ユーザー名又はパスワードが一致していません。'); return \Result::Error('エラー:ユーザー名又はパスワードが一致していません。');
@@ -225,6 +231,7 @@ class Auth {
} }
private function purgeOldTokens(\stdClass $userData): \stdClass|\Result { private function purgeOldTokens(\stdClass $userData): \stdClass|\Result {
if (!AUTH_ENABLED) return \Result::Error('エラー:認証システムは無効です。');
// 有効期限切れたトークンの削除 // 有効期限切れたトークンの削除
$out = $userData; $out = $userData;
$out->tokens = array_filter($userData->tokens, function($t): bool { $out->tokens = array_filter($userData->tokens, function($t): bool {
@@ -241,7 +248,8 @@ class Auth {
return $out; return $out;
} }
private function getUserId(?string $username = null, ?string $token): int { private function getUserId(?string $username = null, ?string $token = null): int {
if (!AUTH_ENABLED) return 0;
if (!$username && !$token) return 0; if (!$username && !$token) return 0;
$file = scandir($this->dataDir); $file = scandir($this->dataDir);
$matches = []; $matches = [];
@@ -267,6 +275,7 @@ class Auth {
} }
private function getUserData(): \stdClass { private function getUserData(): \stdClass {
if (!AUTH_ENABLED) return new \stdClass;
$file = scandir($this->dataDir); $file = scandir($this->dataDir);
$userFile = ""; $userFile = "";
$matches = []; $matches = [];
@@ -297,6 +306,7 @@ class Auth {
} }
private function isEmailExist(?string $email = null): \Result { private function isEmailExist(?string $email = null): \Result {
if (!AUTH_ENABLED) return \Result::Error('エラー:認証システムは無効です。');
$userList = scandir($this->dataDir); $userList = scandir($this->dataDir);
$matches = []; $matches = [];
@@ -316,6 +326,7 @@ class Auth {
} }
private function verifyEmail(?string $email = null): \Result { private function verifyEmail(?string $email = null): \Result {
if (!AUTH_ENABLED) return \Result::Error('エラー:認証システムは無効です。');
if (null === $email || '' === $email) return \Result::Error('エラー:メールアドレスをご入力下さい。'); if (null === $email || '' === $email) return \Result::Error('エラー:メールアドレスをご入力下さい。');
if (strpos($email, '@') === false) return \Result::Error('エラー:メールアドレスは不正です。'); if (strpos($email, '@') === false) return \Result::Error('エラー:メールアドレスは不正です。');
@@ -335,6 +346,7 @@ class Auth {
} }
private function verifyUsername(?string $username): \Result { private function verifyUsername(?string $username): \Result {
if (!AUTH_ENABLED) return \Result::Error('エラー:認証システムは無効です。');
if (null === $username || '' === $username) return \Result::Error('エラー:ユーザー名をご入力下さい。'); if (null === $username || '' === $username) return \Result::Error('エラー:ユーザー名をご入力下さい。');
if (strlen($username) < 6) return \Result::Error('エラーユーザー名は6文字以上をご入力下さい。'); if (strlen($username) < 6) return \Result::Error('エラーユーザー名は6文字以上をご入力下さい。');
@@ -350,6 +362,7 @@ class Auth {
} }
private function verifyPassword(?string $password = null, ?string $passwordVerify = null): \Result { private function verifyPassword(?string $password = null, ?string $passwordVerify = null): \Result {
if (!AUTH_ENABLED) return \Result::Error('エラー:認証システムは無効です。');
if (null === $password || '' === $password) return \Result::Error('エラー:パスワードをご入力下さい。'); if (null === $password || '' === $password) return \Result::Error('エラー:パスワードをご入力下さい。');
if ($password !== $passwordVerify) return \Result::Error('エラー:パスワードは一致していません。'); if ($password !== $passwordVerify) return \Result::Error('エラー:パスワードは一致していません。');
@@ -362,6 +375,7 @@ class Auth {
} }
private function checkPasswordStandards(?string $password = null): \Result { private function checkPasswordStandards(?string $password = null): \Result {
if (!AUTH_ENABLED) return \Result::Error('エラー:認証システムは無効です。');
if (strlen($password) < $this->minPassLen) return \Result::Error("エラー:パスワードは{$this->minPassLen}以上をご入力下さい。"); if (strlen($password) < $this->minPassLen) return \Result::Error("エラー:パスワードは{$this->minPassLen}以上をご入力下さい。");
if (!\countmatch($password)) { if (!\countmatch($password)) {