Our review
Develops and fixes JSON Schema Validation (Draft 2020-12) for user registration, identity verification, and external API requests.
Strengths
- Structured validation with detailed error messages
- Supports tenant-specific custom schemas
- Covers both user registration and identity verification flows
- Includes E2E tests for validation
Limitations
- Schema changes require careful tenant configuration
- Error messages may need localization for end users
- Does not handle dynamic schema generation
When adding or modifying input validation for user registration or identity verification forms.
When simple field-level validation suffices and no complex schema constraints are needed.
Security analysis
SafeThe skill provides development guidance for JSON schema validation, with no executable instructions that could cause harm.
No concerns found
Examples
I need to add an email field with format validation to the user registration JSON schema. The field should be required and must use the email format. Update the JsonSchemaDefinition and the IdPUserCreator to handle it.The identity verification schema is rejecting valid passport document numbers. The pattern should allow alphanumeric characters. Please fix the schema and add a test for it.name: spec-json-schema description: JSONスキーマ検証(JSON Schema Validation)機能の開発・修正を行う際に使用。ユーザー登録スキーマ、Identity Verificationスキーマ、外部API検証実装時に役立つ。
JSONスキーマ検証(JSON Schema Validation)開発ガイド
ドキュメント
documentation/docs/content_03_concepts/06-security-extensions/concept-03-schema-validation.md- JSONスキーマ検証概念
機能概要
JSONスキーマ検証は、入力データの構造・型・制約を検証する層。
- JSON Schema Draft 2020-12準拠
- ユーザー登録検証: テナント別カスタムスキーマ
- Identity Verification検証: 本人確認申請データ検証
- 外部API検証: リクエスト/レスポンス検証
- 詳細エラーメッセージ: フィールド別エラー
モジュール構成
libs/
└── idp-server-platform/ # プラットフォーム基盤
└── .../platform/json/schema/
├── JsonSchemaDefinition.java # スキーマ定義
├── JsonSchemaValidator.java # スキーマ検証
└── JsonSchemaValidationException.java
ユーザー登録でのスキーマ検証
idp-server-core/openid/identity/IdPUserCreator.java 内:
public class IdPUserCreator {
JsonSchemaDefinition definition;
AuthenticationInteractionRequest request;
public User create() {
User user = User.initialized();
// スキーマ定義に基づいてフィールドを設定
if (definition.hasProperty("name") &&
request.containsKey("name")) {
user.setName(request.getValueAsString("name"));
}
if (definition.hasProperty("email") &&
request.containsKey("email")) {
user.setEmail(request.getValueAsString("email"));
}
// その他のフィールドも同様に処理
// ...
return user;
}
}
注意: JsonSchemaDefinitionが、許可されたフィールドを定義します。
スキーマ定義例
ユーザー登録スキーマ
{
"$schema": "https://json-schema.org/draft/2020-12/schema",
"type": "object",
"properties": {
"email": {
"type": "string",
"format": "email"
},
"name": {
"type": "string",
"minLength": 1,
"maxLength": 100
},
"birthdate": {
"type": "string",
"pattern": "^[0-9]{4}-[0-9]{2}-[0-9]{2}$"
}
},
"required": ["email", "name"]
}
Identity Verification申請スキーマ
{
"$schema": "https://json-schema.org/draft/2020-12/schema",
"type": "object",
"properties": {
"document_type": {
"type": "string",
"enum": ["passport", "drivers_license", "national_id"]
},
"document_number": {
"type": "string",
"minLength": 5
}
},
"required": ["document_type", "document_number"]
}
スキーマ検証エラー
public class JsonSchemaValidationException {
// フィールド別の詳細エラーメッセージ
// - 必須フィールド不足
// - 型不一致
// - フォーマット違反
// - 制約違反(minLength, maxLength, pattern等)
}
E2Eテスト
e2e/src/tests/
└── integration/ida/
└── (Identity Verificationスキーマ検証テスト)
コマンド
# ビルド
./gradlew :libs:idp-server-platform:compileJava
# テスト
cd e2e && npm test -- integration/ida/
トラブルシューティング
スキーマ検証失敗
- スキーマ定義が正しいか確認(JSON Schema Draft 2020-12形式)
- 必須フィールドが含まれているか確認
型エラー
- フィールドの型がスキーマと一致するか確認
- string, number, boolean, object, arrayを正しく使用
フォーマット検証失敗
- email, uri, date-time等のフォーマットが正しいか確認
- カスタムpattern(正規表現)が正しいか確認
カスタムスキーマが反映されない
- テナント別スキーマ設定が正しいか確認
- JsonSchemaDefinitionが正しくロードされているか確認
Next.js App Router Expert
Development
A skill that turns Claude into a Next.js App Router expert.
README Generator
Development
Creates professional and comprehensive README.md files for your projects.
API Documentation Writer
Development
Generates comprehensive API documentation in OpenAPI/Swagger format.