GraphQL-検証

データを追加または変更するときは、ユーザー入力を検証することが重要です。たとえば、フィールドの値が常にnullではないことを確認する必要がある場合があります。使用できます! (non-nullable) GraphQLにマーカーを入力して、このような検証を実行します。

を使用するための構文 ! タイプマーカーは以下のとおりです-

type TypeName {
   field1:String!,
   field2:String!,
   field3:Int!
}

上記の構文により、すべてのフィールドがnullにならないことが保証されます。

文字列の長さのチェックや数値が特定の範囲内にあるかどうかのチェックなどの追加のルールを実装する場合は、カスタムバリデーターを定義できます。カスタム検証ロジックは、リゾルバー関数の一部になります。例を使ってこれを理解しましょう。

イラスト-カスタムバリデーターの実装

基本的な検証を含むサインアップフォームを作成しましょう。フォームには、電子メール、名、パスワードのフィールドがあります。

ステップ1-プロジェクトに必要な依存関係をダウンロードしてインストールする

名前の付いたフォルダを作成します validation-app。ターミナルからディレクトリをvalidation-appに変更します。環境設定の章で説明されている手順3〜5に従います。

ステップ2-スキーマを作成する

追加 schema.graphql プロジェクトフォルダ内のファイル validation-app 次のコードを追加します-

type Query {
   greeting:String
}

type Mutation {
   signUp(input:SignUpInput):String
}

input SignUpInput {
   email:String!,
   password:String!,
   firstName:String!
}

Note−入力タイプSignUpInputを使用して、signUp関数のパラメーターの数を減らすことができます。したがって、signUp関数はSignUpInputタイプのパラメーターを1つだけ取ります。

ステップ3-リゾルバを作成する

ファイルを作成する resolvers.js プロジェクトフォルダに次のコードを追加します-

const Query = {
   greeting:() => "Hello"
}

const Mutation ={
   signUp:(root,args,context,info) => {

      const {email,firstName,password} = args.input;

      const emailExpression = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
      
      const isValidEmail =  emailExpression.test(String(email).toLowerCase())
      if(!isValidEmail)
      throw new Error("email not in proper format")

      if(firstName.length > 15)
      throw new Error("firstName should be less than 15 characters")

      if(password.length < 8 )
      throw new Error("password should be minimum 8 characters")
      
      return "success";
   }
}
module.exports = {Query,Mutation}

リゾルバー関数であるsignUpは、パラメーターemail、password、およびfirstNameを受け入れます。これらは入力変数を介して渡されるため、args.inputを介してアクセスできます。

ステップ4-アプリケーションを実行する

server.jsファイルを作成します。環境設定の章のステップ8を参照してください。ターミナルでコマンドnpmstartを実行します。サーバーは9000ポートで稼働します。ここでは、アプリケーションをテストするためのクライアントとしてGraphiQLを使用します。

ブラウザを開き、URLを入力します http://localhost:9000/graphiql。エディタに次のクエリを入力します-

mutation doSignUp($input:SignUpInput) {
   signUp(input:$input)
}

サインアップ関数への入力は複合型であるため、graphiqlでクエリ変数を使用する必要があります。このため、最初にクエリに名前を付けてdoSignUpと呼ぶ必要があります。$ inputはクエリ変数です。

次のクエリ変数は、graphiqlのクエリ変数タブに入力する必要があります-

{
   "input":{
      "email": "abc@abc",
      "firstName": "kannan",
      "password": "pass@1234"
   }
}

エラー配列には、以下に示す検証エラーの詳細が含まれています。

{
   "data": {
      "signUp": null
   },
   
   "errors": [
      {
         "message": "email not in proper format",
         "locations": [
            {
               "line": 2,
               "column": 4
            }
         ],
         "path": [
            "signUp"
         ]
      }
   ]
}

以下に示すように、各フィールドに適切な入力を入力する必要があります-

{
   "input":{
      "email": "[email protected]",
      "firstName": "kannan",
      "password": "pass@1234"
   }
}

応答は次のとおりです-

{
   "data": {
      "signUp": "success"
   }
}

ここで、以下のクエリでは、パスワードを割り当てていません。

{
   "input":{
      "email": "[email protected]",
      "firstName": "kannan"
   }
}

必須フィールドが指定されていない場合、qraphqlサーバーは次のエラーを表示します-

{
   "errors": [
      {
         "message": "Variable \"$input\" got invalid value {\"email\":\"[email protected]\",\"firstName\":\"kannan\"}; Field value.password of required type String! was not provided.",
         "locations": [
            {
               "line": 1,
               "column": 19
            }
         ]
      }
   ]
}