Kuidas kontrollida, kas üks või mitu kasutajat on WordPressi küpsiste abil sisse logitud?
WordPress pakub API-d is_user_logged_in(), et kontrollida, kas mõni kasutaja on sisse logitud, kuid kahjuks pole see pluginate kirjutamisel otse saadaval, nt Pluginad laaditakse enne pluggable.php – d, kus on määratletud is_user_logged_in().
Is_user_logged_in() rakendamisest näete, et see on:
function is_user_logged_in() {
$user = wp_get_current_user();
return $user->exists();
}
Seega saame funktsiooni muuta, et kontrollida, kas määratud kasutaja on sisse loginud.
function is_username_logged_in($username) {
$user = wp_get_current_user();
return $user->user_login == $username;
}
Põhifunktsioon wp_get_current_user on siiski failis pluggable.php defineeritud. Järgmine rakendab funktsiooni, mis võtab lubatud kasutajanimede massiivi ja tagastab tõene, kui mõni luba kasutajanimi on sisse logitud.
function allowedUsersLoggedIn($allowd_users) {
if (count($_COOKIE)) {
foreach ($_COOKIE as $key => $val) {
if (substr($key, 0, 19) === "wordpress_logged_in") {
if (preg_match('/^('. implode('|', $allowed_users). ')/', $val, $matches)) {
return true;
}
}
}
}
return false;
}
Saate seda funktsiooni turvaliselt kasutada kõikjal, isegi ilma WP-keskkonnata. Näidiskasutus oleks järgmine:
if (allowedUsersLoggedIn(array("helloacm", "steakovercooked")) {
// code that only allowed users run
}
Selle funktsiooni põhimõte on kontrollida COOKIE-s määratud stringi, kui lubatud kasutajad on sisse loginud.