# MQTT 5.0 強化認証 - SCRAM

この認証機構は [Salted Challenge Response Authentication Mechanism (SCRAM)](https://en.wikipedia.org/wiki/Salted_Challenge_Response_Authentication_Mechanism) を実装しており、EMQX の組み込みデータベースを使用してクライアント認証情報（ユーザー）を保存します。

SCRAM はパスワード認証よりも複雑な仕組みであり、接続時に追加の MQTT パケットのやり取りが必要です。SCRAM 認証は外部データソースに依存せず、シンプルかつ軽量に利用できます。

::: tip
SCRAM 認証機構は MQTT 5.0 接続のみをサポートしています。
:::

## ダッシュボードでの設定

1. [EMQX ダッシュボード](http://127.0.0.1:18083/#/authentication)の左側ナビゲーションメニューで **アクセス制御** -> **認証** をクリックします。  
2. 右上の **作成** をクリックし、**Mechanism** に **SCRAM**、**Backend** に **Built-in Database** を選択します。すると **設定** タブに移動します。  
3. 認証バックエンドの設定を以下のように行います：  
   - **Password Hash**：パスワードハッシュアルゴリズムを選択します。`sha256` または `sha512`。  
   - **Iteration Count**：SCRAM 認証でパスワードをハッシュ化する際の反復回数を定義します。反復回数が多いほど計算コストが増え、ブルートフォース攻撃に対する耐性が高まります。デフォルトは `4096` です。パフォーマンスとセキュリティのバランスを考慮して調整してください。  
   - **Precondition**：[Variform 式](../../configuration/configuration.md#variform-expressions)で、クライアント接続に対してこの組み込みデータベース認証機構を適用するかどうかを制御します。式はクライアントの属性（`username`、`clientid`、`listener` など）に対して評価され、結果が文字列 `"true"` の場合のみ認証機構が呼び出されます。それ以外の場合はスキップされます。詳細は [認証の事前条件](./authn.md#authentication-preconditions) を参照してください。  
4. **作成** をクリックして設定を完了します。

## 設定ファイルでの設定例

```hcl
{
    mechanism = scram
    backend = built_in_database
    algorithm = sha512
    iteration_count = 4096
}
```

項目の説明：

- `algorithm`：パスワードハッシュアルゴリズム。`sha256` または `sha512` を指定。  
- `iteration_count`（省略可）：SCRAM の反復回数。デフォルトは `4096`。

## 認証フロー

![scram_workflow](./assets/scram_workflow.png)  
SCRAM 認証のフロー図
