管理者ユーザーの作成時に確認メールを送信するように AWS Cognito を設定する

Cognito

AdminCreateUserCommand を使用した AWS Cognito でのユーザー検証の設定

Web アプリケーションでユーザーの認証と認可を管理する場合、安全で検証済みのユーザー ベースを確保することが重要です。 AWS Cognito はユーザー管理のための堅牢なソリューションを提供しますが、カスタムユーザー検証フローの統合は、特にユーザーが管理者によって作成された場合には複雑になる可能性があります。通常、管理者がユーザーを作成すると、Cognito はデフォルトの招待メールを送信します。ただし、これをコードを含むカスタム確認メールに置き換えることで、セキュリティを強化し、よりパーソナライズされたユーザー エクスペリエンスを提供できます。

これを実装するために、開発者はバックエンドインフラストラクチャのセットアップに AWS CDK を利用し、フロントエンドの操作に Amplify を利用できます。このアプローチには、AdminCreateUserCommand によって開始されるユーザー作成プロセス中にカスタム検証電子メールをトリガーするように Cognito ユーザー プールを構成することが含まれます。管理者の作成フローに関する課題やドキュメントのギャップにもかかわらず、特定のユーザープール構成を設定し、カスタムメッセージングに AWS Lambda を活用することで、ユーザー検証プロセスをカスタマイズすることができます。

指示 説明
CognitoIdentityServiceProvider AWS SDK for JavaScript のこのクラスは、AWS Cognito サービスとの対話を可能にするクライアントを初期化します。
AdminCreateUserCommand このコマンドは、ユーザーの操作を必要とせずに、AWS Cognito ユーザープールに管理者として新しいユーザーを直接作成するために使用されます。
send AdminCreateUserCommand を実行するために使用されるメソッド。コマンドを AWS サービスに送信して、ユーザー作成操作を実行します。
handler AWS Cognito からのイベントを処理する AWS Lambda 関数ハンドラー。特にここではユーザー作成時のメッセージのカスタマイズに使用されます。
triggerSource トリガーのソースを示す Lambda のイベント オブジェクトのプロパティ。Cognito でトリガーされた操作の種類に基づいてロジックを条件付きで実行するのに役立ちます。
response Cognito から返される応答オブジェクトを変更するために Lambda で使用され、特に検証メールのカスタムメール件名とメッセージを設定します。

カスタム AWS Cognito 電子メール検証の実装の詳細な説明

提供されているスクリプトを使用すると、管理者が手動でユーザーを追加するときに、AWS Cognito でのユーザー検証プロセスの作成とカスタマイズが可能になります。具体的には、最初のスクリプトは、AWS SDK for JavaScript の AdminCreateUserCommand を使用して、Cognito ユーザー プールに新しいユーザーを作成します。このコマンドは、管理者が通常のサインアップ プロセスを実行せずにユーザーをオンボードする必要があるシナリオで特に役立ちます。このコマンドには、UserPoolId、Username、TemporaryPassword、UserAttributes などのパラメータが含まれます。 UserAttributes 配列を使用して、ユーザーの電子メールなどの重要な詳細を渡すことができます。 TemporaryPassword は初回ログイン用に提供され、ユーザーが必要な通信を電子メールで確実に受信できるように、DesireddeliveryMediums パラメーターは「EMAIL」に設定されます。スクリプトのこの部分は、ユーザー側の操作なしでユーザーのアカウントを設定するために重要です。

さらに、2 番目のスクリプトには、CustomMessage トリガーに基づいて動作する Lambda 関数が含まれています。この機能は、AWS Cognito によって提供され、ユーザーの招待や確認などのさまざまなアクションのメッセージングをカスタマイズします。この Lambda 関数は、トリガーイベントが「CustomMessage_AdminCreateUser」であるかどうかを確認し、メールの内容と件名をカスタマイズします。スクリプトは、event.response プロパティを変更することで、検証コード プレースホルダーを含むパーソナライズされた電子メールの件名とメッセージを設定します。このコードは、ユーザーの電子メール アドレスを検証し、検証されたユーザーのみがアプリケーションの使用を続行できるようにするために不可欠です。これらのカスタマイズにより、よりブランド化され制御されたユーザー エクスペリエンスが提供され、最初のユーザー インタラクションが組織の標準およびセキュリティ ポリシーに合わせられます。

管理者が作成したユーザー向けに AWS Cognito にカスタム検証メールフローを実装する

TypeScript と AWS SDK for JavaScript

import { CognitoIdentityServiceProvider } from '@aws-sdk/client-cognito-identity-provider';
import { AdminCreateUserCommand } from '@aws-sdk/client-cognito-identity-provider';
const cognitoClient = new CognitoIdentityServiceProvider({ region: 'us-west-2' });
const userPoolId = process.env.COGNITO_USER_POOL_ID;
const createUser = async (email, tempPassword) => {
  const params = {
    UserPoolId: userPoolId,
    Username: email,
    TemporaryPassword: tempPassword,
    UserAttributes: [{ Name: 'email', Value: email }],
    DesiredDeliveryMediums: ['EMAIL'],
    MessageAction: 'SUPPRESS',  // Suppress the default email
  };
  try {
    const response = await cognitoClient.send(new AdminCreateUserCommand(params));
    console.log('User created:', response);
    return response;
  } catch (error) {
    console.error('Error creating user:', error);
  }
};

Cognito で AWS Lambda トリガーを使用したメール検証のカスタマイズ

カスタムメッセージング用のAWS LambdaとNode.js

exports.handler = async (event) => {
  if (event.triggerSource === 'CustomMessage_AdminCreateUser') {
    event.response.emailSubject = 'Verify your email for our awesome app!';
    event.response.emailMessage = \`Hello $\{event.request.userAttributes.name},
      Thanks for signing up to our awesome app! Your verification code is $\{event.request.codeParameter}.\`;
  }
  return event;
};

AWS Cognito カスタム検証プロセスによるセキュリティとユーザーエクスペリエンスの強化

ユーザー管理に AWS Cognito を実装する重要な側面の 1 つは、セキュリティを強化し、シームレスなユーザー エクスペリエンスを提供することです。ユーザー検証プロセスをカスタマイズできる機能により、ユーザーの身元を検証してアプリケーションを保護するだけでなく、企業が自社のブランドに応じてユーザー ジャーニーを調整することもできます。このカスタマイズは、銀行業務、ヘルスケア、電子商取引アプリケーションなど、信頼とセキュリティが最優先されるシナリオで特に重要になります。 AWS Cognito の機能を活用してカスタム E メールを送信することで、管理者はユーザーが最初の連絡の時点から一貫したエクスペリエンスを確実に受け取ることができます。さらに、Cognito で「ロケール」などのカスタム属性を使用すると、アプリケーションがローカライズされたエクスペリエンスを提供できるようになり、ユーザー エンゲージメントと満足度が向上します。

さらに、AWS CDK (クラウド開発キット) を使用してこれらの機能を統合すると、開発者は使い慣れたプログラミング言語を使用してクラウド リソースを定義できます。このアプローチにより、カスタム検証フローなどの複雑な構成をセットアップするプロセスが簡素化されます。インフラストラクチャ全体をコードとしてスクリプト化することで、構成中の人的エラーのリスクを最小限に抑え、さまざまな環境やアプリケーションのライフサイクルの段階にわたるセットアップの再現性を高めます。フロントエンド用の AWS Amplify の統合により、AWS を活用した安全でスケーラブルなフルスタック アプリケーションの構築に役立つツールとサービスのセットが提供され、これがさらに強化されます。

AWS Cognito カスタム検証に関するよくある質問

  1. 管理者がユーザーを作成するときに、AWS Cognito は確認メールを送信できますか?
  2. はい、AWS Cognito は、AdminCreateUserCommand でユーザーが作成されるときに、デフォルトの招待メールの代わりにカスタム検証メールを送信するように設定できます。
  3. Cognito で検証メールをカスタマイズするには AWS Lambda を使用する必要がありますか?
  4. 必須ではありませんが、AWS Lambda を使用すると、メールの内容、件名、その他のパラメーターをより柔軟にカスタマイズできるため、ユーザー検証プロセスが強化されます。
  5. Cognito で AWS CDK を使用する利点は何ですか?
  6. AWS CDK を使用すると、開発者はクラウド インフラストラクチャをコードで定義できるため、セットアップが簡素化され、環境間の一貫性が向上し、AWS Cognito や他の AWS のサービスとシームレスに統合されます。
  7. カスタム属性は AWS Cognito でどのように機能しますか?
  8. Cognito のカスタム属性を使用すると、ロケールや設定などのユーザーに関する追加情報を保存できます。これらの情報は、構成に基づいて変更可能または不変にすることができます。
  9. 検証プロセスをさまざまな地域のユーザー向けにローカライズできますか?
  10. はい、「locale」カスタム属性を使用し、AWS Lambda トリガーを適切に設定することで、検証プロセスをローカライズして、ユーザーに自分の言語でパーソナライズされたメールを提供できます。

クラウドベースのアプリケーションが進化し続けるにつれて、堅牢なユーザー管理システムの必要性がさらに重要になっています。 AWS Cognito は、特に AdminCreateUserCommand を使用して、ユーザーのライフサイクルを管理するための強力なソリューションを提供します。この機能により、管理者は標準のユーザー サインアップ ワークフローをバイパスしてアカウントを直接作成し、カスタマイズされた電子メール検証プロセスを通じてすべてのユーザーが確実に検証されるようにすることができます。これを AWS CDK および AWS Lambda と統合してカスタムメッセージングおよび検証コードを実行できる機能は、安全なアプリケーション開発のベストプラクティスと密接に連携しています。さらに、これらの方法では、検証されたユーザーのみが機密機能にアクセスできるようにすることで、データ保護規制への準拠をサポートします。最終的に、ユーザー管理に AWS Cognito を採用すると、管理タスクが簡素化されるだけでなく、さまざまなセクターにわたるアプリケーションのセキュリティと使いやすさも向上します。