メインコンテンツまでスキップ

ユーザー移行

Logto は、他のプラットフォームから既存ユーザーを手動で移行することをサポートしています。このガイドでは、Management API を使って既存ユーザーをインポートする方法と、移行前に考慮すべき事項について説明します。

ユーザースキーマ

始める前に、Logto の ユーザースキーマ を見てみましょう。ユーザースキーマには、次の 3 つの部分があります:

  1. 基本データ:ユーザープロファイルからの基本情報で、既存のユーザープロファイルのデータとマッチさせることができます。
  2. カスタムデータ:追加のユーザー情報を保存します。基本データにマッチできないファイルなどを保存するのに利用できます。
  3. ソーシャルアイデンティティ:ソーシャルサインインから取得したユーザー情報を保存します。

既存のユーザープロファイルから 基本データ および カスタムデータ へのマッピングを作成できます。ソーシャルサインインの場合は、ソーシャルアイデンティティのインポートに追加の手順が必要です。詳しくは Link social identity to user の API を参照してください。

パスワードハッシュ化

Logto は Argon2 を使ってユーザーのパスワードをハッシュ化していますが、移行の利便性のために MD5SHA1SHA256Bcrypt など他のアルゴリズムもサポートしています。これらのアルゴリズムは安全ではないと考えられており、該当するパスワードハッシュはユーザーが初めてサインインに成功した際に Argon2 へ移行されます。

他のハッシュアルゴリズムやソルトを使用している場合は、passwordAlgorithmLegacy に設定できます。これにより、Node.js でサポートされている任意のハッシュアルゴリズムを利用できます。サポートされているアルゴリズムの一覧は Node.js crypto ドキュメント で確認できます。この場合、passwordDigest はハッシュアルゴリズムやその他のアルゴリズム固有パラメータを含む JSON 文字列となります。

一般的な Legacy フォーマット

JSON 文字列のフォーマットは次の通りです:

["hash_algorithm", ["argument1", "argument2", ...], "expected_hashed_value"]

引数内で実際のパスワード値のプレースホルダーとして @ を使用できます。

たとえば、SHA256 とソルトを使っている場合、パスワードは次のような形式で保存できます:

["sha256", ["salt123", "@"], "c465f66c6ac481a7a17e9ed5b4e2e7e7288d892f12bf1c95c140901e9a70436e"]

これは次のコードと同等です:

const hash = crypto.createHash('sha256');
hash.update('salt123' + 'password123');
const expectedHashedValue = hash.digest('hex');

PBKDF2 サポート

Logto は PBKDF2 も特別にサポートしています。

PBKDF2 でハッシュ化されたパスワードを移行するには、passwordAlgorithmLegacy に設定し、passwordDigest を次のようにフォーマットします:

["pbkdf2", ["salt", "1000", "20", "sha512", "@"], "expected_hashed_value"]

各パラメータの意味は以下の通りです:

  • salt:元のハッシュ化で使用したソルト値
  • iterations:繰り返し回数(例:"1000")
  • keylen:導出キーのバイト長(例:"20")
  • digest:使用したハッシュ関数(例:"sha512"、"sha256"、"sha1")
  • @:実際のパスワード値のプレースホルダー
  • expected_hashed_value:期待されるハッシュ結果(16進文字列)

移行ペイロード例:

{
"username": "john_doe",
"primaryEmail": "john.doe@example.com",
"passwordAlgorithm": "Legacy",
"passwordDigest": "[\"pbkdf2\", [\"mySalt123\", \"1000\", \"20\", \"sha512\", \"@\"], \"c465f66c6ac481a7a17e9ed5b4e2e7e7288d892f12bf1c95c140901e9a70436e\"]"
}

移行手順

  1. ユーザーデータの準備
    まず、既存プラットフォームからユーザーデータをエクスポートし、ユーザー情報を Logto のユーザースキーマにマッピングします。マッピング済みデータは JSON 形式で準備することを推奨します。ユーザーデータの例は以下の通りです:

    [
    {
    "username": "user1",
    "passwordDigest": "password-encrypted",
    "passwordAlgorithm": "SHA256"
    },
    {
    "username": "user2",
    "passwordDigest": "password-encrypted",
    "passwordAlgorithm": "SHA256"
    }
    ]
  2. Logto テナントの作成
    Logto でテナントをセットアップする必要があります。Logto Cloud または Logto OSS のいずれかを利用できます。まだセットアップしていない場合は、Logto Cloud のセットアップ ガイドを参照してください。

  3. Management API の接続設定
    Management API を使ってユーザーデータをインポートします。開発環境での接続方法については Management API を参照してください。

  4. ユーザーデータのインポート
    ユーザーデータを 1 件ずつインポートするスクリプトを準備することを推奨します。create user API を呼び出してユーザーデータをインポートします。スクリプト例は以下の通りです:

    const users = require('./users.json');

    const importUsers = async () => {
    for (const user of users) {
    try {
    await fetch('https://[tenant_id].logto.app/api/users', {
    method: 'POST',
    headers: {
    'Content-Type': 'application/json',
    Authorization: 'Bearer [your-access-token]',
    },
    body: JSON.stringify(user),
    });
    // レートリミット回避のため少し待機
    await new Promise((resolve) => setTimeout(resolve, 200));
    } catch (error) {
    console.error(`Failed to import user ${user.username}: ${error.message}`);
    }
    }
    };

    importUsers();

API エンドポイントにはレートリミットがあるため、各リクエストの間に待機時間を設けてください。詳細は レートリミット ページをご確認ください。

大量のユーザーデータ(10 万件以上)がある場合は、こちらからご連絡ください 。レートリミットの引き上げが可能です。

既存ユーザーデータベースを Logto へ移行するための一般的なガイドライン