起動・前提準備
初期テーブル、依存状態、定期処理の点灯など、このクラスが動き始める前提をまとめています。
WebCoop (イベント/チャット) を SparkJava でマウントする薄いアダプタ。
com.example.rankingplugin.webcoopwebcoop/WebCoopSpark.javaclassWebCoop (イベント/チャット) を SparkJava でマウントする薄いアダプタ。 まずはダッシュボード/管理画面/疎通APIだけを提供する最小実装です。 今後、/webevent/api/* の各エンドポイントを段階的に実装していけます。
WebCoop (イベント/チャット) を SparkJava でマウントする薄いアダプタ。webcoop パッケージの中でも 830 行規模の中核クラスで、永続化境界・Web 導線・スケジューラが一か所に集まっています。中規模クラス群の中では変更影響が広く、章立てで読む価値が高いため重点解説へ追加しています。
WebCoopSparkapplyAdminPasswordisAdminrequireAdminrandTokencfgcurrentMcidregisterescape初期テーブル、依存状態、定期処理の点灯など、このクラスが動き始める前提をまとめています。
メモリ状態と保存状態を揃え、結果を次の呼び出しや画面表示へ繋ぐ部分です。
Web から見えるエンドポイント、セッション解決、レスポンス整形を含みます。画面追加や API 変更時の起点になります。
DB テーブルとの境界です。スキーマ変更や保存漏れの切り分けはここから行います。
このクラスが前提状態を揃え、外部から利用可能な形まで立ち上がる流れです。新規依存の追加や起動失敗の調査はまずここから追います。
イベント受理、判定、状態更新、通知までの主経路です。体感不具合や想定外の分岐はこの流れのどこで止まるかを見ると切り分けやすいです。
結果を保持し、必要なら永続化し、最後に掃除まで行う出口です。画面更新だけ合って保存が壊れるケースや残骸が残るケースの確認に向きます。
このクラス内で直接見つかる主な Web ルート/項目名です。
SQL 文字列から抽出できた主要テーブルです。スキーマ変更時の確認用です。
| Signature | 説明 | 主要呼び出し |
|---|---|---|
private WebCoopSpark() | 依存オブジェクトや初期状態を受け取り、このクラスの動作を開始できる状態へ組み立てます。 | 主要呼び出しなし |
| Name | Visibility | Kind | 説明 |
|---|---|---|---|
| WebCoopSpark | private | コンストラクタ | 依存オブジェクトや初期状態を受け取り、このクラスの動作を開始できる状態へ組み立てます。 |
| isAdmin | private | メソッド | 条件判定を行い、後続処理の分岐に使える真偽値を返します。 |
| requireAdmin | private | メソッド | requireAdmin の主要処理を担当します。 |
| randToken | private | メソッド | randToken の主要処理を担当します。 |
| cfg | private | メソッド | cfg の主要処理を担当します。 |
| currentMcid | private | メソッド | DB への問い合わせまたは更新処理を担当します。 |
| register | public | メソッド | 初期化と各種登録を行い、機能を有効化します。 |
| escape | private | メソッド | escape の主要処理を担当します。 |
| applyAdminPassword | package | メソッド | DB への問い合わせまたは更新処理を担当します。 |
| typeLabel | private | メソッド | typeLabel の主要処理を担当します。 |
| isBanned | private | メソッド | 条件判定を行い、後続処理の分岐に使える真偽値を返します。 |
| mcidFromSession | private | メソッド | mcidFromSession の主要処理を担当します。 |
| serverDisplayName | private | メソッド | serverDisplayName の主要処理を担当します。 |
| migrateWebcoopChat | private | メソッド | DB への問い合わせまたは更新処理を担当します。 |
private WebCoopSpark()依存オブジェクトや初期状態を受け取り、このクラスの動作を開始できる状態へ組み立てます。
なし
private static boolean isAdmin(Request req)条件判定を行い、後続処理の分岐に使える真偽値を返します。
Request reqなし
private static boolean requireAdmin(spark.Request req, spark.Response res)requireAdmin の主要処理を担当します。
spark.Request reqspark.Response resなし
private static String randToken()randToken の主要処理を担当します。
なし
private static String cfg(String key, String def)cfg の主要処理を担当します。
String keyString defなし
private static String currentMcid(spark.Request req)DB への問い合わせまたは更新処理を担当します。
spark.Request reqなし
public static void register(JavaPlugin plugin, DataSource dataSource, EventService eventService, ChatRelayService chatService, String serverId, String serverName)初期化と各種登録を行い、機能を有効化します。
JavaPlugin pluginDataSource dataSourceEventService eventServiceChatRelayService chatServiceString serverIdString serverNameなし
private static String escape(String s)escape の主要処理を担当します。
String sなし
static void applyAdminPassword(javax.sql.DataSource ds, String plaintext, boolean force)DB への問い合わせまたは更新処理を担当します。
javax.sql.DataSource dsString plaintextboolean forceなし
private static String typeLabel(String code)typeLabel の主要処理を担当します。
String codeなし
private static boolean isBanned(DataSource ds, String mcid)条件判定を行い、後続処理の分岐に使える真偽値を返します。
DataSource dsString mcidなし
private static String mcidFromSession(Request req, DataSource ds)mcidFromSession の主要処理を担当します。
Request reqDataSource dsなし
private static String serverDisplayName(JavaPlugin plugin)serverDisplayName の主要処理を担当します。
JavaPlugin pluginなし
private static void migrateWebcoopChat(DataSource ds, String serverId)DB への問い合わせまたは更新処理を担当します。
DataSource dsString serverIdなし
register → isEmpty → getConfig → getString → getServer → getMotdapplyAdminPassword → isBlank → getConnection → prepareStatement → executeQuery → nextcurrentMcid → cookie → isEmpty → getConnection → prepareStatement → setStringmigrateWebcoopChat → getConnection → createStatement → executeUpdate → webcoop_chat → executeQuerymcidFromSession → cookies → getConnection → prepareStatement → setString → executeQuery