PDO::ERRMODE_EXCEPTION, PDO::MYSQL_ATTR_MULTI_STATEMENTS => false ); $pdo = new PDO('mysql:charset=utf8mb4;dbname='.DB_NAME.';host='.DB_HOST , DB_USER, DB_PASS, $option); } catch(PDOException $e) { // 接続エラーのときエラー内容を取得する $error_message[] = $e->getMessage(); } if(isset($_SESSION['admin_login']) && $_SESSION['admin_login'] === true) { $passQuery = $pdo->prepare("SELECT username,userid,loginid,follow,admin,role,sacinfo,blocklist FROM account WHERE userid = :userid"); $passQuery->bindValue(':userid', htmlentities($_SESSION['userid'])); $passQuery->execute(); $res = $passQuery->fetch(); if(empty($res["userid"])){ header("Location: ../login.php"); exit; }elseif($_SESSION['loginid'] === $res["loginid"] && $_SESSION['userid'] === $res["userid"]){ // セッションに値をセット $userid = htmlentities($res['userid']); // セッションに格納されている値をそのままセット $username = htmlentities($res['username']); // セッションに格納されている値をそのままセット $loginid = htmlentities($res["loginid"]); $role = htmlentities($res["role"]); $sacinfo = htmlentities($res["sacinfo"]); $myblocklist = htmlentities($res["blocklist"]); $myfollowlist = htmlentities($res["follow"]); $_SESSION['admin_login'] = true; $_SESSION['userid'] = $userid; $_SESSION['username'] = $username; $_SESSION['loginid'] = $res["loginid"]; setcookie('userid', $userid, [ 'expires' => time() + 60 * 60 * 24 * 14, 'path' => '/', 'samesite' => 'lax', ]); setcookie('username', $username,[ 'expires' => time() + 60 * 60 * 24 * 14, 'path' => '/', 'samesite' => 'lax', ]); setcookie('loginid', $res["loginid"],[ 'expires' => time() + 60 * 60 * 24 * 14, 'path' => '/', 'samesite' => 'lax', ]); setcookie('admin_login', true,[ 'expires' => time() + 60 * 60 * 24 * 14, 'path' => '/', 'samesite' => 'lax', ]); }else{ header("Location: ../login.php"); exit; } } elseif (isset($_COOKIE['admin_login']) && $_COOKIE['admin_login'] == true) { $passQuery = $pdo->prepare("SELECT username,userid,loginid,follow,admin,role,sacinfo,blocklist FROM account WHERE userid = :userid"); $passQuery->bindValue(':userid', htmlentities($_COOKIE['userid'])); $passQuery->execute(); $res = $passQuery->fetch(); if(empty($res["userid"])){ header("Location: ../login.php"); exit; }elseif($_COOKIE['loginid'] === $res["loginid"] && $_COOKIE['userid'] === $res["userid"]){ // セッションに値をセット $userid = htmlentities($res['userid']); // クッキーから取得した値をセット $username = htmlentities($res['username']); // クッキーから取得した値をセット $loginid = htmlentities($res["loginid"]); $role = htmlentities($res["role"]); $sacinfo = htmlentities($res["sacinfo"]); $myblocklist = htmlentities($res["blocklist"]); $myfollowlist = htmlentities($res["follow"]); $_SESSION['admin_login'] = true; $_SESSION['userid'] = $userid; $_SESSION['username'] = $username; $_SESSION['loginid'] = $res["loginid"]; setcookie('userid', $userid,[ 'expires' => time() + 60 * 60 * 24 * 14, 'path' => '/', 'samesite' => 'lax', ]); setcookie('username', $username,[ 'expires' => time() + 60 * 60 * 24 * 14, 'path' => '/', 'samesite' => 'lax', ]); setcookie('loginid', $res["loginid"],[ 'expires' => time() + 60 * 60 * 24 * 14, 'path' => '/', 'samesite' => 'lax', ]); setcookie('admin_login', true,[ 'expires' => time() + 60 * 60 * 24 * 14, 'path' => '/', 'samesite' => 'lax', ]); }else{ header("Location: ../login.php"); exit; } } else { // ログインが許可されていない場合、ログインページにリダイレクト header("Location: ../login.php"); exit; } if(empty($userid)){ header("Location: ../login.php"); exit; } if(empty($username)){ header("Location: ../login.php"); exit; } if(!($res["admin"] === "yes")){ header("Location: ../login.php"); exit; } $notiQuery = $pdo->prepare("SELECT COUNT(*) as notification_count FROM notification WHERE touserid = :userid AND userchk = 'none'"); $notiQuery->bindValue(':userid', $userid); $notiQuery->execute(); $notiData = $notiQuery->fetch(PDO::FETCH_ASSOC); $notificationcount = $notiData['notification_count']; if( !empty($_POST['role_btn_submit']) ) { $rolename = htmlentities($_POST['rolename']); $roleid = htmlentities($_POST['roleid']); $rolecolor = htmlentities($_POST['rolecolor']); $dbh = new PDO('mysql:charset=utf8mb4;dbname='.DB_NAME.';host='.DB_HOST , DB_USER, DB_PASS, $option); $query = $dbh->prepare('SELECT * FROM role WHERE roleidname = :roleid limit 1'); $query->execute(array(':roleid' => $roleid)); $result3 = $query->fetch(); if(empty($rolename)){ $error_message[] = "ロール名が入力されていません。"; } if(empty($roleid)){ $error_message[] = "ロールのidが入力されていません。"; }elseif($result3 > 0){ $error_message[] = 'このロールのid('.$roleid.')は既に使用されています。他のidを作成してください。'; } if(empty($rolecolor)){ $error_message[] = "ロールの色が入力されていません。"; } if (!empty($pdo)) { if (empty($error_message)) { // 書き込み日時を取得 $datetime = date("Y-m-d H:i:s"); $roleauth = "user"; // トランザクション開始 $pdo->beginTransaction(); try { // SQL作成 $stmt = $pdo->prepare("INSERT INTO role (rolename, roleauth, rolecolor, roleidname) VALUES (:rolename, :roleauth, :rolecolor, :roleidname)"); $stmt->bindParam(':rolename', $rolename, PDO::PARAM_STR); $stmt->bindParam(':roleauth', $roleauth, PDO::PARAM_STR); $stmt->bindParam(':rolecolor', $rolecolor, PDO::PARAM_STR); $stmt->bindParam(':roleidname', $roleid, PDO::PARAM_STR); // SQLクエリの実行 $res = $stmt->execute(); // コミット $res = $pdo->commit(); } catch(Exception $e) { // エラーが発生した時はロールバック $pdo->rollBack(); } if( $res ) { $url = (empty($_SERVER['HTTPS']) ? 'http://' : 'https://') . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI']; header("Location:".$url.""); exit; } else { $error_message[] = $e->getMessage(); } // プリペアドステートメントを削除 $stmt = null; } } } if( !empty($_POST['role_del']) ) { $role_id = htmlentities($_POST['role_id']); try{ // 通知削除クエリを実行 $deleteQuery = $pdo->prepare("DELETE FROM role WHERE roleidname = :roleid"); $deleteQuery->bindValue(':roleid', $role_id, PDO::PARAM_STR); $res = $deleteQuery->execute(); try{ // フォローの更新 $updateFollowQuery = $pdo->prepare("UPDATE account SET role = REPLACE(role, :roleid, '') WHERE role LIKE :pattern"); $updateFollowQuery->bindValue(':roleid', ",$role_id", PDO::PARAM_STR); $updateFollowQuery->bindValue(':pattern', "%,$role_id%", PDO::PARAM_STR); $res = $updateFollowQuery->execute(); } catch (Exception $e) { // エラーが発生した時はロールバック $pdo->rollBack(); } } catch (Exception $e) { // エラーが発生した時はロールバック $pdo->rollBack(); } if( $res ) { $url = (empty($_SERVER['HTTPS']) ? 'http://' : 'https://') . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI']; header("Location:".$url.""); exit; } else { $error_message[] = $e->getMessage(); } // プリペアドステートメントを削除 $stmt = null; } if( !empty($_POST['send_add_role_submit']) ) { $add_userid = htmlentities($_POST['add_userid']); $add_roleid = htmlentities($_POST['add_roleid']); $dbh = new PDO('mysql:charset=utf8mb4;dbname='.DB_NAME.';host='.DB_HOST , DB_USER, DB_PASS, $option); $query = $dbh->prepare('SELECT * FROM account WHERE userid = :userid limit 1'); $query->execute(array(':userid' => $add_userid)); $result4 = $query->fetch(); $dbh = new PDO('mysql:charset=utf8mb4;dbname='.DB_NAME.';host='.DB_HOST , DB_USER, DB_PASS, $option); $query = $dbh->prepare('SELECT * FROM role WHERE roleidname = :roleid limit 1'); $query->execute(array(':roleid' => $add_roleid)); $result5 = $query->fetch(); if($result4 > 0 && $result5 > 0){ if (false !== strstr($result4["role"], ','.$add_roleid)) { $error_message[] = "既に".$add_roleid."は付与済みです。"; } $New_role_id = $result4["role"] . ',' . $add_roleid; if(empty($error_message)){ try{ // フォローの更新 $updateRoleQuery = $pdo->prepare("UPDATE account SET role = :newrole WHERE userid = :userid"); $updateRoleQuery->bindValue(':newrole', "$New_role_id", PDO::PARAM_STR); $updateRoleQuery->bindValue(':userid', $add_userid, PDO::PARAM_STR); $res = $updateRoleQuery->execute(); } catch (Exception $e) { // エラーが発生した時はロールバック $pdo->rollBack(); } if( $res ) { $url = (empty($_SERVER['HTTPS']) ? 'http://' : 'https://') . $_SERVER['HTTP_HOST'] . $_SERVER['REQUEST_URI']; header("Location:".$url.""); exit; } else { $error_message[] = $e->getMessage(); } // プリペアドステートメントを削除 $stmt = null; } }else{ $error_message[] = "ロールがないまたはユーザーがいません。"; } } require('../logout/logout.php'); if (!empty($pdo)) { $sql = "SELECT * FROM role"; $allrole = $pdo->query($sql); while ($row = $allrole->fetch(PDO::FETCH_ASSOC)) { $roles[] = $row; } } ?> ロール - <?php echo file_get_contents($servernamefile);?>

ロール作成

ここではロールを作成できます。

ロール名

ロールの表示名です。

ロールid

ロールのidです。ロールを付与する際に使用されるidです。

ロールの色

ロールの色です。
HEXコードで入力してください。(#はつけないでください。)

ロール付与

特定のユーザーにロール付与するときに使用してください。


ロール一覧


ロールのid:

ロールの色:#


削除ボタンを押すとこのロールは削除されます。
また、このロールをつけているユーザー全員からこのロールが剥奪されます。

" style="display:none;" >

このロールは削除できません。