allra-api-design
AllraのバックエンドAPI設計やパッケージ構造に関するルールを理解し、REST APIやDTOを作成したり、バックエンドのコード構造を整理したりする際に、設計の指針として活用するSkill。
📜 元の英語説明(参考)
Allra 백엔드 API 설계 및 패키지 구조 규칙. Use when creating REST APIs, DTOs, or organizing backend code structure.
🇯🇵 日本人クリエイター向け解説
AllraのバックエンドAPI設計やパッケージ構造に関するルールを理解し、REST APIやDTOを作成したり、バックエンドのコード構造を整理したりする際に、設計の指針として活用するSkill。
※ jpskill.com 編集部が日本のビジネス現場向けに補足した解説です。Skill本体の挙動とは独立した参考情報です。
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o allra-api-design.zip https://jpskill.com/download/17135.zip && unzip -o allra-api-design.zip && rm allra-api-design.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/17135.zip -OutFile "$d\allra-api-design.zip"; Expand-Archive "$d\allra-api-design.zip" -DestinationPath $d -Force; ri "$d\allra-api-design.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
allra-api-design.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
allra-api-designフォルダができる - 3. そのフォルダを
C:\Users\あなたの名前\.claude\skills\(Win)または~/.claude/skills/(Mac)へ移動 - 4. Claude Code を再起動
⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。
🎯 このSkillでできること
下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。
📦 インストール方法 (3ステップ)
- 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
- 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
- 3. 展開してできたフォルダを、ホームフォルダの
.claude/skills/に置く- · macOS / Linux:
~/.claude/skills/ - · Windows:
%USERPROFILE%\.claude\skills\
- · macOS / Linux:
Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。
詳しい使い方ガイドを見る →- 最終更新
- 2026-05-18
- 取得日時
- 2026-05-18
- 同梱ファイル
- 1
📖 Skill本文(日本語訳)
※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。
Allra バックエンド API 設計およびパッケージ構造
Allra バックエンドチームの API 設計、DTO 命名、パッケージ構造の標準を定義します。
プロジェクト基本情報
このガイドは、次の環境を基準に作成されました。
- Java: 17 以上
- Spring Boot: 3.2 以上
- 主要技術: JPA/Hibernate, QueryDSL, JWT
参考: プロジェクトごとに使用する技術スタックやバージョンが異なる場合があります。プロジェクトに合わせて調整して使用してください。
パッケージ構造規則
ドメイン別のパッケージ構造を推奨します。
└── {domain}
├── api // コントローラレイヤ
├── dto // データ転送オブジェクト
├── entity // JPA エンティティ
├── enums // Enum 定義 (選択)
├── repository // データアクセス階層
└── service // ビジネスロジック
参考: プロジェクトによっては controller、model、dao など、異なる名前を使用する場合があります。重要なのは、レイヤ別の責任を明確に分離することです。
例
└── user
├── api
│ └── UserController.java
├── dto
│ ├── UserSignUpEventDto.java // 内部使用
│ ├── request
│ │ └── SignUpRequest.java
│ └── response
│ └── SignUpResponse.java
├── entity
│ └── User.java
├── repository
│ ├── UserRepository.java
│ └── UserRepositorySupport.java
└── service
└── UserService.java
DTO 命名規則
1. クライアント通信 DTO
- Request:
{Operation}Request- 例:
SignUpRequest,UpdateUserRequest
- 例:
- Response:
{Operation}Response- 例:
SignUpResponse,UserDetailResponse
- 例:
2. 内部使用 DTO
内部でのみ使用する DTO は Dto 接尾辞を追加します。
- Repository Layer QueryDSL Fetch DTO
- Internal Layer Transfer DTO
- 例:
UserSignUpEventDto,UserSummaryDto
3. Record 使用
DTO のような単純なクラスは、可能であればほとんど record で生成
// Request/Response
public record SignUpRequest(
String email,
String password,
String name
) {}
public record SignUpResponse(
Long userId,
String email
) {}
// 内部使用 DTO
public record UserSignUpEventDto(
Long userId,
String email,
LocalDateTime signUpAt
) {}
API コントローラ設計ガイド
1. REST API 命名規則
@RestController
@RequestMapping("/api/v1/users")
public class UserController {
// GET /api/v1/users - 一覧照会
@GetMapping
public List<UserResponse> getUsers() { }
// GET /api/v1/users/{id} - 単件照会
@GetMapping("/{id}")
public UserDetailResponse getUser(@PathVariable Long id) { }
// POST /api/v1/users - 生成
@PostMapping
public SignUpResponse createUser(@RequestBody @Valid SignUpRequest request) { }
// PUT /api/v1/users/{id} - 全体修正
@PutMapping("/{id}")
public UserResponse updateUser(
@PathVariable Long id,
@RequestBody @Valid UpdateUserRequest request
) { }
// PATCH /api/v1/users/{id} - 部分修正
@PatchMapping("/{id}")
public UserResponse patchUser(
@PathVariable Long id,
@RequestBody @Valid PatchUserRequest request
) { }
// DELETE /api/v1/users/{id} - 削除
@DeleteMapping("/{id}")
public void deleteUser(@PathVariable Long id) { }
}
参考: API バージョニング(/api/v1/...)は、プロジェクトのポリシーに応じて選択的に適用します。
2. Request Validation
すべての Request DTO は Bean Validation を使用します。
public record SignUpRequest(
@NotBlank(message = "이메일은 필수입니다")
@Email(message = "올바른 이메일 형식이 아닙니다")
String email,
@NotBlank(message = "비밀번호는 필수입니다")
@Size(min = 8, message = "비밀번호는 최소 8자 이상이어야 합니다")
String password,
@NotBlank(message = "이름은 필수입니다")
String name
) {}
3. 応答形式
Allra 標準形式 (例):
成功応答:
{
"data": { ... },
"message": "요청이 성공적으로 처리되었습니다"
}
エラー応答:
{
"error": {
"code": "USER_NOT_FOUND",
"message": "사용자를 찾을 수 없습니다",
"details": []
}
}
参考: 応答形式はプロジェクトごとに異なる場合があります。一貫性のある形式を維持することが重要です。
When to Use This Skill
この skill は、次の状況で自動的に適用されます。
- 新しい API エンドポイントの生成
- DTO クラスの作成
- コントローラの実装
- ドメインパッケージ構造の設計
Request/Responseオブジェクトの命名
Examples
例 1: 新しいドメイン API の生成
// 1. パッケージ構造生成
kr.co.allra.product/
├── api/ProductController.java
├── dto/
│ ├── request/CreateProductRequest.java
│ └── response/ProductResponse.java
├── entity/Product.java
├── repository/ProductRepository.java
└── service/ProductService.java
// 2. Request DTO
public record CreateProductRequest(
@NotBlank String name,
@NotNull BigDecimal price
) {}
// 3. Response DTO
public record ProductResponse(
Long id,
String name,
BigDecimal price,
LocalDateTime createdAt
) {}
// 4. Controller
@RestController
@RequestMapping("/api/v1/products")
public class ProductController {
@PostMapping
public ProductResponse createProduct(
@RequestBody @Valid CreateProductRequest request
) {
return productService.createProduct(request);
}
}
例 2: 内部 DTO の生成
// QueryDSL 結果のための内部 DTO
public record ProductSummaryDto(
Long id,
String name,
Long orderCount
) {
@QueryProjection
public ProductSummaryDto {}
}
// イベント伝達用の内部 DTO
public record ProductCreatedEventDto(
Long productId,
String productName,
LocalDateTime createdAt
) {}
Checklist
新しい API を作成する際の確認事項:
- [ ] ドメイン別のパッケージ構造に従っているか?
- [ ]
Request/ResponseDTO の命名が規則に従っているか? - [ ] DTO が
recordで作成されているか? - [ ]
RequestDTO に Validation が適用されているか? - [ ] REST API 命名規則に従っているか?
- [ ] 内部使用 DTO に
Dto接尾辞があるか?
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開
Allra Backend API 설계 및 패키지 구조
Allra 백엔드 팀의 API 설계, DTO 네이밍, 패키지 구조 표준을 정의합니다.
프로젝트 기본 정보
이 가이드는 다음 환경을 기준으로 작성되었습니다:
- Java: 17 이상
- Spring Boot: 3.2 이상
- 주요 기술: JPA/Hibernate, QueryDSL, JWT
참고: 프로젝트별로 사용하는 기술 스택이나 버전이 다를 수 있습니다. 프로젝트에 맞게 조정하여 사용하세요.
패키지 구조 규칙
도메인별 패키지 구조를 권장합니다:
└── {domain}
├── api // 컨트롤러 레이어
├── dto // 데이터 전송 객체
├── entity // JPA 엔티티
├── enums // Enum 정의 (선택)
├── repository // 데이터 접근 계층
└── service // 비즈니스 로직
참고: 프로젝트에 따라 controller, model, dao 등 다른 이름을 사용할 수 있습니다. 중요한 것은 레이어별 책임을 명확히 분리하는 것입니다.
예시
└── user
├── api
│ └── UserController.java
├── dto
│ ├── UserSignUpEventDto.java // 내부 사용
│ ├── request
│ │ └── SignUpRequest.java
│ └── response
│ └── SignUpResponse.java
├── entity
│ └── User.java
├── repository
│ ├── UserRepository.java
│ └── UserRepositorySupport.java
└── service
└── UserService.java
DTO 네이밍 규칙
1. 클라이언트 통신 DTO
- Request:
{Operation}Request- 예:
SignUpRequest,UpdateUserRequest
- 예:
- Response:
{Operation}Response- 예:
SignUpResponse,UserDetailResponse
- 예:
2. 내부 사용 DTO
내부에서만 사용하는 DTO는 Dto 접미사 추가:
- Repository Layer QueryDSL Fetch DTO
- Internal Layer Transfer DTO
- 예:
UserSignUpEventDto,UserSummaryDto
3. Record 사용
DTO 같은 단순 클래스들은 가능하면 대부분 record로 생성
// Request/Response
public record SignUpRequest(
String email,
String password,
String name
) {}
public record SignUpResponse(
Long userId,
String email
) {}
// 내부 사용 DTO
public record UserSignUpEventDto(
Long userId,
String email,
LocalDateTime signUpAt
) {}
API 컨트롤러 설계 가이드
1. REST API 명명 규칙
@RestController
@RequestMapping("/api/v1/users")
public class UserController {
// GET /api/v1/users - 목록 조회
@GetMapping
public List<UserResponse> getUsers() { }
// GET /api/v1/users/{id} - 단건 조회
@GetMapping("/{id}")
public UserDetailResponse getUser(@PathVariable Long id) { }
// POST /api/v1/users - 생성
@PostMapping
public SignUpResponse createUser(@RequestBody @Valid SignUpRequest request) { }
// PUT /api/v1/users/{id} - 전체 수정
@PutMapping("/{id}")
public UserResponse updateUser(
@PathVariable Long id,
@RequestBody @Valid UpdateUserRequest request
) { }
// PATCH /api/v1/users/{id} - 부분 수정
@PatchMapping("/{id}")
public UserResponse patchUser(
@PathVariable Long id,
@RequestBody @Valid PatchUserRequest request
) { }
// DELETE /api/v1/users/{id} - 삭제
@DeleteMapping("/{id}")
public void deleteUser(@PathVariable Long id) { }
}
참고: API 버저닝(/api/v1/...)은 프로젝트 정책에 따라 선택적으로 적용합니다.
2. Request Validation
모든 Request DTO는 Bean Validation 사용:
public record SignUpRequest(
@NotBlank(message = "이메일은 필수입니다")
@Email(message = "올바른 이메일 형식이 아닙니다")
String email,
@NotBlank(message = "비밀번호는 필수입니다")
@Size(min = 8, message = "비밀번호는 최소 8자 이상이어야 합니다")
String password,
@NotBlank(message = "이름은 필수입니다")
String name
) {}
3. 응답 형식
Allra 표준 형식 (예시):
성공 응답:
{
"data": { ... },
"message": "요청이 성공적으로 처리되었습니다"
}
에러 응답:
{
"error": {
"code": "USER_NOT_FOUND",
"message": "사용자를 찾을 수 없습니다",
"details": []
}
}
참고: 응답 형식은 프로젝트별로 다를 수 있습니다. 일관성 있는 형식을 유지하는 것이 중요합니다.
When to Use This Skill
이 skill은 다음 상황에서 자동으로 적용됩니다:
- 새로운 API 엔드포인트 생성
- DTO 클래스 작성
- 컨트롤러 구현
- 도메인 패키지 구조 설계
- Request/Response 객체 네이밍
Examples
예제 1: 새로운 도메인 API 생성
// 1. 패키지 구조 생성
kr.co.allra.product/
├── api/ProductController.java
├── dto/
│ ├── request/CreateProductRequest.java
│ └── response/ProductResponse.java
├── entity/Product.java
├── repository/ProductRepository.java
└── service/ProductService.java
// 2. Request DTO
public record CreateProductRequest(
@NotBlank String name,
@NotNull BigDecimal price
) {}
// 3. Response DTO
public record ProductResponse(
Long id,
String name,
BigDecimal price,
LocalDateTime createdAt
) {}
// 4. Controller
@RestController
@RequestMapping("/api/v1/products")
public class ProductController {
@PostMapping
public ProductResponse createProduct(
@RequestBody @Valid CreateProductRequest request
) {
return productService.createProduct(request);
}
}
예제 2: 내부 DTO 생성
// QueryDSL 결과를 위한 내부 DTO
public record ProductSummaryDto(
Long id,
String name,
Long orderCount
) {
@QueryProjection
public ProductSummaryDto {}
}
// 이벤트 전달용 내부 DTO
public record ProductCreatedEventDto(
Long productId,
String productName,
LocalDateTime createdAt
) {}
Checklist
새로운 API를 만들 때 확인사항:
- [ ] 도메인별 패키지 구조를 따르는가?
- [ ] Request/Response DTO 네이밍이 규칙을 따르는가?
- [ ] DTO가 record로 작성되었는가?
- [ ] Request DTO에 Validation이 적용되었는가?
- [ ] REST API 명명 규칙을 따르는가?
- [ ] 내부 사용 DTO에
Dto접미사가 있는가?