@k2works/claude-code-booster 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +28 -0
- package/bin/claude-code-booster +28 -0
- package/lib/assets/.claude/.mcp.json +45 -0
- package/lib/assets/.claude/README.md +169 -0
- package/lib/assets/.claude/agents/roles/analyzer.md +267 -0
- package/lib/assets/.claude/agents/roles/architect.md +233 -0
- package/lib/assets/.claude/agents/roles/backend.md +303 -0
- package/lib/assets/.claude/agents/roles/frontend.md +294 -0
- package/lib/assets/.claude/agents/roles/mobile.md +309 -0
- package/lib/assets/.claude/agents/roles/performance.md +254 -0
- package/lib/assets/.claude/agents/roles/qa.md +266 -0
- package/lib/assets/.claude/agents/roles/reviewer.md +252 -0
- package/lib/assets/.claude/agents/roles/security.md +392 -0
- package/lib/assets/.claude/assets/confirm.mp3 +0 -0
- package/lib/assets/.claude/assets/perfect.mp3 +0 -0
- package/lib/assets/.claude/assets/silent.wav +0 -0
- package/lib/assets/.claude/commands/analyze-dependencies.md +158 -0
- package/lib/assets/.claude/commands/analyze-performance.md +116 -0
- package/lib/assets/.claude/commands/check-fact.md +104 -0
- package/lib/assets/.claude/commands/check-github-ci.md +53 -0
- package/lib/assets/.claude/commands/check-prompt.md +461 -0
- package/lib/assets/.claude/commands/commit-message.md +348 -0
- package/lib/assets/.claude/commands/context7.md +50 -0
- package/lib/assets/.claude/commands/design-patterns.md +186 -0
- package/lib/assets/.claude/commands/explain-code.md +75 -0
- package/lib/assets/.claude/commands/fix-error.md +258 -0
- package/lib/assets/.claude/commands/multi-role.md +291 -0
- package/lib/assets/.claude/commands/plan.md +134 -0
- package/lib/assets/.claude/commands/pr-auto-update.md +460 -0
- package/lib/assets/.claude/commands/pr-create.md +249 -0
- package/lib/assets/.claude/commands/pr-feedback.md +143 -0
- package/lib/assets/.claude/commands/pr-issue.md +78 -0
- package/lib/assets/.claude/commands/pr-list.md +66 -0
- package/lib/assets/.claude/commands/pr-review.md +142 -0
- package/lib/assets/.claude/commands/refactor.md +147 -0
- package/lib/assets/.claude/commands/role-debate.md +571 -0
- package/lib/assets/.claude/commands/role-help.md +276 -0
- package/lib/assets/.claude/commands/role.md +360 -0
- package/lib/assets/.claude/commands/screenshot.md +103 -0
- package/lib/assets/.claude/commands/search-gemini.md +66 -0
- package/lib/assets/.claude/commands/semantic-commit.md +1129 -0
- package/lib/assets/.claude/commands/sequential-thinking.md +90 -0
- package/lib/assets/.claude/commands/show-plan.md +59 -0
- package/lib/assets/.claude/commands/smart-review.md +174 -0
- package/lib/assets/.claude/commands/spec.md +559 -0
- package/lib/assets/.claude/commands/style-ai-writing.md +186 -0
- package/lib/assets/.claude/commands/task.md +223 -0
- package/lib/assets/.claude/commands/tech-debt.md +87 -0
- package/lib/assets/.claude/commands/ultrathink.md +65 -0
- package/lib/assets/.claude/commands/update-dart-doc.md +202 -0
- package/lib/assets/.claude/commands/update-doc-string.md +306 -0
- package/lib/assets/.claude/commands/update-flutter-deps.md +105 -0
- package/lib/assets/.claude/commands/update-node-deps.md +105 -0
- package/lib/assets/.claude/commands/update-rust-deps.md +107 -0
- package/lib/assets/.claude/scripts/auto-comment.sh +16 -0
- package/lib/assets/.claude/scripts/check-ai-commit.sh +20 -0
- package/lib/assets/.claude/scripts/check-continue.sh +97 -0
- package/lib/assets/.claude/scripts/check-locales.sh +1080 -0
- package/lib/assets/.claude/scripts/check-project-plan.sh +25 -0
- package/lib/assets/.claude/scripts/debug-hook.sh +7 -0
- package/lib/assets/.claude/scripts/deny-check.sh +69 -0
- package/lib/assets/.claude/scripts/install.sh +174 -0
- package/lib/assets/.claude/scripts/ja-space-exclusions.json +18 -0
- package/lib/assets/.claude/scripts/ja-space-format.sh +45 -0
- package/lib/assets/.claude/scripts/preserve-file-permissions.sh +83 -0
- package/lib/assets/.claude/scripts/statusline.sh +153 -0
- package/lib/assets/.claude/settings.json +164 -0
- package/lib/assets/.claude/settings.local.json +14 -0
- package/lib/assets/.github/workflows/mkdocs.yml +32 -0
- package/lib/assets/CLAUDE.md +319 -0
- package/lib/assets/Dockerfile +77 -0
- package/lib/assets/README.md +51 -0
- package/lib/assets/app/.gitkeep +0 -0
- package/lib/assets/docker-compose.yml +22 -0
- package/lib/assets/docs/Dockerfile +19 -0
- package/lib/assets/docs/adr/.gitkeep +0 -0
- package/lib/assets/docs/assets/css/extra.css +30 -0
- package/lib/assets/docs/assets/js/extra.js +45 -0
- package/lib/assets/docs/design/.gitkeep +0 -0
- package/lib/assets/docs/development/.gitkeep +0 -0
- package/lib/assets/docs/index.md +13 -0
- package/lib/assets/docs/operation/.gitkeep +0 -0
- package/lib/assets/docs/reference/.gitkeep +0 -0
- package/lib/assets/docs/reference//343/202/210/343/201/204/343/202/275/343/203/225/343/203/210/343/202/246/343/202/247/343/202/242/343/201/250/343/201/257.md +220 -0
- package/lib/assets/docs/reference//343/202/242/343/202/270/343/203/243/343/202/244/343/203/253/343/201/252/350/246/213/347/251/215/343/201/250/350/250/210/347/224/273/343/201/245/343/201/217/343/202/212.md +789 -0
- package/lib/assets/docs/reference//343/202/250/343/202/257/343/202/271/343/203/210/343/203/252/343/203/274/343/203/240/343/203/227/343/203/255/343/202/260/343/203/251/343/203/237/343/203/263/343/202/260.md +554 -0
- package/lib/assets/docs/reference//350/246/201/344/273/266/345/256/232/347/276/251/343/202/254/343/202/244/343/203/211.md +1249 -0
- package/lib/assets/docs/reference//351/226/213/347/231/272/343/202/254/343/202/244/343/203/211.md +556 -0
- package/lib/assets/docs/requirements/.gitkeep +0 -0
- package/lib/assets/docs/template/.gitkeep +0 -0
- package/lib/assets/docs/template/ADR.md +30 -0
- package/lib/assets/docs/template/README.md +50 -0
- package/lib/assets/docs/template//343/201/276/343/201/232/343/201/223/343/202/214/343/202/222/350/252/255/343/202/202/343/201/206/343/203/252/343/202/271/343/203/210.md +12 -0
- package/lib/assets/docs/template//343/202/244/343/203/206/343/203/254/343/203/274/343/202/267/343/203/247/343/203/263/345/256/214/344/272/206/345/240/261/345/221/212/346/233/270.md +59 -0
- package/lib/assets/docs/template//343/202/244/343/203/263/343/202/273/343/203/227/343/202/267/343/203/247/343/203/263/343/203/207/343/203/203/343/202/255.md +13 -0
- package/lib/assets/docs/template//350/246/201/344/273/266/345/256/232/347/276/251.md +646 -0
- package/lib/assets/docs/template//350/250/255/350/250/210.md +164 -0
- package/lib/assets/gulpfile.js +18 -0
- package/lib/assets/mkdocs.yml +59 -0
- package/lib/assets/package-lock.json +3960 -0
- package/lib/assets/package.json +31 -0
- package/lib/assets/scripts/journal.js +170 -0
- package/lib/assets/scripts/mkdocs.js +59 -0
- package/lib/gulpfile.js +37 -0
- package/main.js +0 -0
- package/package.json +39 -0
|
@@ -0,0 +1,1249 @@
|
|
|
1
|
+
# 要件定義ガイド - RDRAワークフロー解説
|
|
2
|
+
|
|
3
|
+
## 概要
|
|
4
|
+
|
|
5
|
+
本ガイドでは、リレーションシップ駆動要件分析(RDRA)を使った要件定義のワークフローを解説します。RDRAは決められたアイコンを使い、アイコンとアイコン、アイコンと図を関連づけ、アイコンで表現されたモデル要素と関連のつながりから要件を説明する軽量な要件分析フレームワークです。
|
|
6
|
+
|
|
7
|
+
## RDRA用語解説
|
|
8
|
+
|
|
9
|
+
### 基本概念
|
|
10
|
+
|
|
11
|
+
- **RDRA(リレーションシップ駆動要件分析)**: Relationship Driven Requirements Analysisの略。決められたアイコンとモデル要素の関連から要件を説明する手法
|
|
12
|
+
- **モデル要素**: RDRAで定義された各種のアイコン(アクター、ユースケース、情報など)
|
|
13
|
+
- **関連(リレーションシップ)**: モデル要素同士を結ぶ線や矢印で表現される関係性
|
|
14
|
+
- **トレーサビリティ**: 要件の追跡可能性。上位の要求から下位の実装まで関連を追えること
|
|
15
|
+
|
|
16
|
+
### システム構成要素
|
|
17
|
+
|
|
18
|
+
- **システム価値**: システムが提供する価値を定義する領域
|
|
19
|
+
- **システム外部環境**: システムを取り巻く業務や環境を定義する領域
|
|
20
|
+
- **システム境界**: システムとユーザー・外部システムとの接点を定義する領域
|
|
21
|
+
- **システム**: システム内部の情報構造と状態を定義する領域
|
|
22
|
+
|
|
23
|
+
### アクター・主体
|
|
24
|
+
|
|
25
|
+
- **アクター**: システムと関わる人や外部システム。利用者、管理者、外部システムなど
|
|
26
|
+
- **利用者**: システムを直接使用する人
|
|
27
|
+
- **関係者(ステークホルダー)**: システムに関わる全ての人や組織
|
|
28
|
+
- **外部システム**: 連携対象となる他のシステムやサービス
|
|
29
|
+
|
|
30
|
+
### 業務・プロセス
|
|
31
|
+
|
|
32
|
+
- **業務**: 組織が行う一連の活動や作業
|
|
33
|
+
- **ビジネスユースケース(BUC)**: 業務を構成する具体的な作業単位
|
|
34
|
+
- **アクティビティ**: BUCを構成するより詳細な作業項目
|
|
35
|
+
- **業務フロー**: アクティビティの時系列での流れ
|
|
36
|
+
- **利用シーン**: システムが利用される具体的な場面や状況
|
|
37
|
+
|
|
38
|
+
### 要件・仕様
|
|
39
|
+
|
|
40
|
+
- **要求**: ステークホルダーが システムに対して望むこと
|
|
41
|
+
- **要件**: 要求を実現するためにシステムが満たすべき条件
|
|
42
|
+
- **ユースケース(UC)**: システムが提供する機能の単位
|
|
43
|
+
- **機能要件**: システムが実現すべき機能に関する要件
|
|
44
|
+
- **非機能要件**: 性能、セキュリティ、運用性などシステム品質に関する要件
|
|
45
|
+
|
|
46
|
+
### システム境界要素
|
|
47
|
+
|
|
48
|
+
- **画面**: ユーザーとのインターフェースを表す境界要素
|
|
49
|
+
- **帳票**: 出力される文書や報告書
|
|
50
|
+
- **イベント**: 外部システムとのデータ交換のきっかけ
|
|
51
|
+
- **プロトコル**: システム間の通信手順や規約
|
|
52
|
+
|
|
53
|
+
### 内部構造要素
|
|
54
|
+
|
|
55
|
+
- **情報(エンティティ)**: システムが管理するデータの単位
|
|
56
|
+
- **状態**: 情報が取りうる状況や段階
|
|
57
|
+
- **状態遷移**: ある状態から別の状態への変化
|
|
58
|
+
- **関連**: 情報同士の関係性(1対1、1対多、多対多など)
|
|
59
|
+
|
|
60
|
+
### 条件・制約
|
|
61
|
+
|
|
62
|
+
- **バリエーション**: ビジネス上重要な区分や種別(顧客種別、商品分類など)
|
|
63
|
+
- **条件**: システムの動作を決定する判定基準
|
|
64
|
+
- **ビジネスルール**: 業務上守るべき規則や制約
|
|
65
|
+
- **制約**: システムが満たすべき技術的・業務的な制限事項
|
|
66
|
+
|
|
67
|
+
### 作業プロセス用語
|
|
68
|
+
|
|
69
|
+
- **洗い出し**: 必要な要素を網羅的に抽出する作業
|
|
70
|
+
- **関係づけ**: 要素間の関連を明確にする作業
|
|
71
|
+
- **精緻化**: 粗い定義をより詳細で正確にしていく作業
|
|
72
|
+
- **整合性**: 各要素・図の間で矛盾がないこと
|
|
73
|
+
- **網羅性**: 必要な要素が漏れなく定義されていること
|
|
74
|
+
- **表現力**: 関係者が理解しやすく表現されていること
|
|
75
|
+
|
|
76
|
+
## RDRAの全体構造
|
|
77
|
+
|
|
78
|
+
```plantuml
|
|
79
|
+
@startuml
|
|
80
|
+
|
|
81
|
+
title RDRA要件定義の全体構造
|
|
82
|
+
|
|
83
|
+
left to right direction
|
|
84
|
+
|
|
85
|
+
package "システム価値" as sp {
|
|
86
|
+
rectangle "システムコンテキスト" as sc
|
|
87
|
+
rectangle "要求モデル" as rm
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
package "システム外部環境" as se {
|
|
91
|
+
rectangle "ビジネスコンテキスト" as bc
|
|
92
|
+
rectangle "ビジネスユースケース" as buc
|
|
93
|
+
rectangle "業務フロー" as bf
|
|
94
|
+
rectangle "利用シーン" as us
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
package "システム境界" as sb {
|
|
98
|
+
rectangle "ユースケース複合図" as ucc
|
|
99
|
+
rectangle "画面・帳票モデル" as ui
|
|
100
|
+
rectangle "イベントモデル" as em
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
package "システム" as sys {
|
|
104
|
+
rectangle "情報モデル" as im
|
|
105
|
+
rectangle "状態モデル" as sm
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
sp --> se : "価値を実現する\n環境を明確化"
|
|
109
|
+
se --> sb : "環境での\n接点を定義"
|
|
110
|
+
sb --> sys : "接点を実現する\nシステムを設計"
|
|
111
|
+
|
|
112
|
+
sc --> bc : "アクター"
|
|
113
|
+
rm --> buc : "要求"
|
|
114
|
+
buc --> ucc : "ユースケース"
|
|
115
|
+
bf --> ucc : "アクティビティ"
|
|
116
|
+
us --> ucc : "利用シーン"
|
|
117
|
+
ucc --> im : "情報"
|
|
118
|
+
ucc --> sm : "状態"
|
|
119
|
+
|
|
120
|
+
@enduml
|
|
121
|
+
```
|
|
122
|
+
|
|
123
|
+
## 要件定義の3フェーズアプローチ
|
|
124
|
+
|
|
125
|
+
```plantuml
|
|
126
|
+
@startuml
|
|
127
|
+
|
|
128
|
+
title 要件定義ワークフロー - ステートチャート図
|
|
129
|
+
|
|
130
|
+
[*] --> 要件定義開始
|
|
131
|
+
|
|
132
|
+
state "フェーズ1: 議論のベースを作る" as Phase1 {
|
|
133
|
+
[*] --> Step1_出発点を明らかにする
|
|
134
|
+
Step1_出発点を明らかにする : システムコンテキスト図作成
|
|
135
|
+
Step1_出発点を明らかにする : アクターと目的の明確化
|
|
136
|
+
|
|
137
|
+
Step1_出発点を明らかにする --> Step2_スコープの把握
|
|
138
|
+
Step2_スコープの把握 : ビジネスコンテキスト図作成
|
|
139
|
+
Step2_スコープの把握 : BUCの粗出し
|
|
140
|
+
|
|
141
|
+
Step2_スコープの把握 --> Step3_情報の明示
|
|
142
|
+
Step3_情報の明示 : 業務情報の洗い出し
|
|
143
|
+
Step3_情報の明示 : システム化対象の特定
|
|
144
|
+
|
|
145
|
+
Step3_情報の明示 --> Step4_状態の明示
|
|
146
|
+
Step4_状態の明示 : 業務状態の洗い出し
|
|
147
|
+
Step4_状態の明示 : 状態遷移の概要把握
|
|
148
|
+
|
|
149
|
+
Step4_状態の明示 --> [*]
|
|
150
|
+
|
|
151
|
+
state Step1_出発点を明らかにする #lightblue
|
|
152
|
+
state Step2_スコープの把握 #lightblue
|
|
153
|
+
state Step3_情報の明示 #lightblue
|
|
154
|
+
state Step4_状態の明示 #lightblue
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
Phase1 --> Phase2 : 全体像把握完了
|
|
158
|
+
|
|
159
|
+
state "フェーズ2: 要件を組み立てる" as Phase2 {
|
|
160
|
+
[*] --> Step5_要件組立て
|
|
161
|
+
Step5_要件組立て : UCの洗い出し
|
|
162
|
+
Step5_要件組立て : 画面・イベント導出
|
|
163
|
+
Step5_要件組立て : UC複合図作成
|
|
164
|
+
|
|
165
|
+
Step5_要件組立て --> Step6_情報状態見直し
|
|
166
|
+
Step6_情報状態見直し : 情報の関係づけ
|
|
167
|
+
Step6_情報状態見直し : UCと情報・状態の関連付け
|
|
168
|
+
Step6_情報状態見直し : 整合性確認
|
|
169
|
+
|
|
170
|
+
Step6_情報状態見直し --> 精度確認
|
|
171
|
+
|
|
172
|
+
state 精度確認 <<choice>>
|
|
173
|
+
精度確認 --> Step5_要件組立て : [精度不足]
|
|
174
|
+
精度確認 --> [*] : [精度十分]
|
|
175
|
+
|
|
176
|
+
state Step5_要件組立て #lightgreen
|
|
177
|
+
state Step6_情報状態見直し #lightgreen
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
Phase2 --> 仕様化判定 : 要件組立て完了
|
|
181
|
+
|
|
182
|
+
state 仕様化判定 <<choice>>
|
|
183
|
+
仕様化判定 --> Phase3 : [ビジネスルール詳細化が必要]
|
|
184
|
+
仕様化判定 --> 要件定義完了 : [UCで見積可能]
|
|
185
|
+
|
|
186
|
+
state "フェーズ3: ビジネスルールで仕様化可能にする" as Phase3 {
|
|
187
|
+
[*] --> Step7_条件洗い出し
|
|
188
|
+
Step7_条件洗い出し : UCにつながる条件の特定
|
|
189
|
+
Step7_条件洗い出し : ビジネスルール明確化
|
|
190
|
+
|
|
191
|
+
Step7_条件洗い出し --> Step8_バリエーション
|
|
192
|
+
Step8_バリエーション : 条件の軸となる要素
|
|
193
|
+
Step8_バリエーション : バリエーション整理
|
|
194
|
+
|
|
195
|
+
Step8_バリエーション --> Step9_要素詳細化
|
|
196
|
+
Step9_要素詳細化 : 条件とバリエーションの具体化
|
|
197
|
+
Step9_要素詳細化 : 実装指針の明確化
|
|
198
|
+
|
|
199
|
+
Step9_要素詳細化 --> [*]
|
|
200
|
+
|
|
201
|
+
state Step7_条件洗い出し #lightyellow
|
|
202
|
+
state Step8_バリエーション #lightyellow
|
|
203
|
+
state Step9_要素詳細化 #lightyellow
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
Phase3 --> 要件定義完了
|
|
207
|
+
|
|
208
|
+
要件定義完了 --> [*]
|
|
209
|
+
|
|
210
|
+
note right of Phase1
|
|
211
|
+
精度は無視して素早く全体像をつかむ
|
|
212
|
+
分かる範囲で合意できる範囲を洗い出し
|
|
213
|
+
期間目安: 4日間
|
|
214
|
+
end note
|
|
215
|
+
|
|
216
|
+
note right of Phase2
|
|
217
|
+
RDRAの論理的つながりを利用
|
|
218
|
+
トップダウンとボトムアップで整合性を高める
|
|
219
|
+
最もボリュームがあるフェーズ
|
|
220
|
+
期間目安: 7日間
|
|
221
|
+
end note
|
|
222
|
+
|
|
223
|
+
note right of Phase3
|
|
224
|
+
条件やバリエーションで仕様に直結
|
|
225
|
+
ビジネスルールで精度を上げる
|
|
226
|
+
次の仕様化工程につなげる
|
|
227
|
+
期間目安: 3日間
|
|
228
|
+
end note
|
|
229
|
+
|
|
230
|
+
@enduml
|
|
231
|
+
```
|
|
232
|
+
|
|
233
|
+
## 9ステップ詳細ワークフロー
|
|
234
|
+
|
|
235
|
+
### フェーズ1: 議論のベースを作る
|
|
236
|
+
|
|
237
|
+
#### Step1: 出発点を明らかにする
|
|
238
|
+
|
|
239
|
+
```plantuml
|
|
240
|
+
@startuml
|
|
241
|
+
|
|
242
|
+
title Step1: 出発点を明らかにする - ステートチャート図
|
|
243
|
+
|
|
244
|
+
[*] --> ヒアリング開始
|
|
245
|
+
|
|
246
|
+
state ヒアリング開始 {
|
|
247
|
+
[*] --> 関係者特定
|
|
248
|
+
関係者特定 : ステークホルダーの洗い出し
|
|
249
|
+
関係者特定 : 役割と責任の明確化
|
|
250
|
+
|
|
251
|
+
関係者特定 --> 登場人物洗い出し
|
|
252
|
+
登場人物洗い出し : アクターの識別
|
|
253
|
+
登場人物洗い出し : 外部システムの特定
|
|
254
|
+
|
|
255
|
+
登場人物洗い出し --> システムコンテキスト図作成
|
|
256
|
+
システムコンテキスト図作成 : アクター配置
|
|
257
|
+
システムコンテキスト図作成 : システム化の目的記述
|
|
258
|
+
システムコンテキスト図作成 : 外部システム連携定義
|
|
259
|
+
|
|
260
|
+
システムコンテキスト図作成 --> システム化対象の合意
|
|
261
|
+
システム化対象の合意 : スコープ明確化
|
|
262
|
+
システム化対象の合意 : 空中戦回避の土台完成
|
|
263
|
+
|
|
264
|
+
システム化対象の合意 --> [*]
|
|
265
|
+
}
|
|
266
|
+
|
|
267
|
+
ヒアリング開始 --> Step1完了 : 出発点明確化
|
|
268
|
+
|
|
269
|
+
Step1完了 --> [*]
|
|
270
|
+
|
|
271
|
+
note right of システムコンテキスト図作成
|
|
272
|
+
- アクター(利用者)の特定
|
|
273
|
+
- 外部システムの特定
|
|
274
|
+
- システム化の目的を記述
|
|
275
|
+
- 空中戦を避けて具体的な議論の土台作り
|
|
276
|
+
end note
|
|
277
|
+
|
|
278
|
+
@enduml
|
|
279
|
+
```
|
|
280
|
+
|
|
281
|
+
#### Step2: スコープの把握
|
|
282
|
+
|
|
283
|
+
```plantuml
|
|
284
|
+
@startuml
|
|
285
|
+
|
|
286
|
+
title Step2: スコープの把握 - ステートチャート図
|
|
287
|
+
|
|
288
|
+
[*] --> スコープ定義開始
|
|
289
|
+
|
|
290
|
+
state "業務全体の把握" as scope_analysis {
|
|
291
|
+
[*] --> ビジネスコンテキスト図作成
|
|
292
|
+
ビジネスコンテキスト図作成 : 業務の全体像把握
|
|
293
|
+
ビジネスコンテキスト図作成 : 組織とアクターの関係整理
|
|
294
|
+
|
|
295
|
+
ビジネスコンテキスト図作成 --> ビジネスユースケース図作成
|
|
296
|
+
ビジネスユースケース図作成 : 業務の細分化
|
|
297
|
+
ビジネスユースケース図作成 : BUCの洗い出し
|
|
298
|
+
|
|
299
|
+
ビジネスユースケース図作成 --> アクティビティ粗出し
|
|
300
|
+
アクティビティ粗出し : 具体的作業の把握
|
|
301
|
+
アクティビティ粗出し : 業務フローの骨格理解
|
|
302
|
+
|
|
303
|
+
アクティビティ粗出し --> スコープ確認
|
|
304
|
+
|
|
305
|
+
state スコープ確認 <<choice>>
|
|
306
|
+
スコープ確認 --> ビジネスコンテキスト図作成 : [見直し必要]
|
|
307
|
+
スコープ確認 --> [*] : [スコープ確定]
|
|
308
|
+
}
|
|
309
|
+
|
|
310
|
+
scope_analysis --> Step2完了
|
|
311
|
+
Step2完了 --> [*]
|
|
312
|
+
|
|
313
|
+
note right of アクティビティ粗出し
|
|
314
|
+
- BUCのアクティビティを粗く洗い出し
|
|
315
|
+
- 正確さより洗い出すことを優先
|
|
316
|
+
- システム化対象の理解を深める
|
|
317
|
+
- 業務フローの骨格を把握
|
|
318
|
+
end note
|
|
319
|
+
|
|
320
|
+
@enduml
|
|
321
|
+
```
|
|
322
|
+
|
|
323
|
+
#### Step3: システムで扱う情報の明示
|
|
324
|
+
|
|
325
|
+
```plantuml
|
|
326
|
+
@startuml
|
|
327
|
+
|
|
328
|
+
title Step3: システムで扱う情報の明示 - ステートチャート図
|
|
329
|
+
|
|
330
|
+
[*] --> 情報分析開始
|
|
331
|
+
|
|
332
|
+
state "情報の洗い出しと整理" as info_analysis {
|
|
333
|
+
[*] --> 業務情報の洗い出し
|
|
334
|
+
業務情報の洗い出し : 業務で使われる全情報リスト化
|
|
335
|
+
業務情報の洗い出し : 情報の種類と用途確認
|
|
336
|
+
|
|
337
|
+
業務情報の洗い出し --> システム化対象情報の特定
|
|
338
|
+
システム化対象情報の特定 : システム化判断
|
|
339
|
+
システム化対象情報の特定 : 必須情報の選別
|
|
340
|
+
|
|
341
|
+
システム化対象情報の特定 --> 情報モデル図作成_粗版
|
|
342
|
+
情報モデル図作成_粗版 : 情報間の関係性整理
|
|
343
|
+
情報モデル図作成_粗版 : 概念モデルの骨格作成
|
|
344
|
+
|
|
345
|
+
情報モデル図作成_粗版 --> 情報確認
|
|
346
|
+
|
|
347
|
+
state 情報確認 <<choice>>
|
|
348
|
+
情報確認 --> 業務情報の洗い出し : [不足あり]
|
|
349
|
+
情報確認 --> [*] : [情報整理完了]
|
|
350
|
+
}
|
|
351
|
+
|
|
352
|
+
info_analysis --> Step3完了
|
|
353
|
+
Step3完了 --> [*]
|
|
354
|
+
|
|
355
|
+
note right of 情報モデル図作成_粗版
|
|
356
|
+
- 業務で扱う情報を明らかにする
|
|
357
|
+
- システムで扱う必要がある情報を把握
|
|
358
|
+
- 正確さより必要と思われるものを一旦洗い出し
|
|
359
|
+
- 情報の関係性を大まかに整理
|
|
360
|
+
end note
|
|
361
|
+
|
|
362
|
+
@enduml
|
|
363
|
+
```
|
|
364
|
+
|
|
365
|
+
#### Step4: システムで管理する状態の明示
|
|
366
|
+
|
|
367
|
+
```plantuml
|
|
368
|
+
@startuml
|
|
369
|
+
|
|
370
|
+
title Step4: システムで管理する状態の明示 - ステートチャート図
|
|
371
|
+
|
|
372
|
+
[*] --> 状態分析開始
|
|
373
|
+
|
|
374
|
+
state "状態の洗い出しと整理" as state_analysis {
|
|
375
|
+
[*] --> 業務状態の洗い出し
|
|
376
|
+
業務状態の洗い出し : 業務で認識している状態を列挙
|
|
377
|
+
業務状態の洗い出し : 重要な状態変化の識別
|
|
378
|
+
|
|
379
|
+
業務状態の洗い出し --> 状態モデル図作成_粗版
|
|
380
|
+
状態モデル図作成_粗版 : 状態の整理と分類
|
|
381
|
+
状態モデル図作成_粗版 : 状態遷移の大まかな流れ
|
|
382
|
+
|
|
383
|
+
状態モデル図作成_粗版 --> フェーズ1完了判定
|
|
384
|
+
フェーズ1完了判定 : 全体像の確認
|
|
385
|
+
フェーズ1完了判定 : 議論ベースの完成度チェック
|
|
386
|
+
|
|
387
|
+
state 完了確認 <<choice>>
|
|
388
|
+
フェーズ1完了判定 --> 完了確認
|
|
389
|
+
完了確認 --> 業務状態の洗い出し : [見直し必要]
|
|
390
|
+
完了確認 --> [*] : [フェーズ1完了]
|
|
391
|
+
}
|
|
392
|
+
|
|
393
|
+
state_analysis --> Step4完了
|
|
394
|
+
Step4完了 --> [*]
|
|
395
|
+
|
|
396
|
+
note right of 状態モデル図作成_粗版
|
|
397
|
+
- 業務が認識している状態を洗い出し
|
|
398
|
+
- 無理に洗い出すのではなく思いつくものを整理
|
|
399
|
+
- 状態遷移の大まかな流れを把握
|
|
400
|
+
- フェーズ2への準備完了
|
|
401
|
+
end note
|
|
402
|
+
|
|
403
|
+
@enduml
|
|
404
|
+
```
|
|
405
|
+
|
|
406
|
+
### フェーズ2: 要件を組み立てる
|
|
407
|
+
|
|
408
|
+
```plantuml
|
|
409
|
+
@startuml
|
|
410
|
+
|
|
411
|
+
title フェーズ2: 要件を組み立てる - ステートチャート図
|
|
412
|
+
|
|
413
|
+
[*] --> フェーズ2開始
|
|
414
|
+
|
|
415
|
+
state "フェーズ2: 要件を組み立てる" as Phase2_Detail {
|
|
416
|
+
|
|
417
|
+
[*] --> Step5_トップダウン要件組立て
|
|
418
|
+
|
|
419
|
+
state "Step5: トップダウンで要件を組み立てる" as Step5_トップダウン要件組立て {
|
|
420
|
+
[*] --> 業務_BUC_アクティビティ見直し
|
|
421
|
+
|
|
422
|
+
state 業務_BUC_アクティビティ見直し {
|
|
423
|
+
[*] --> フェーズ1成果物の再評価
|
|
424
|
+
フェーズ1成果物の再評価 : 業務モデルの確認
|
|
425
|
+
フェーズ1成果物の再評価 : BUCの確認
|
|
426
|
+
フェーズ1成果物の再評価 --> システム化範囲の再確認
|
|
427
|
+
システム化範囲の再確認 : アクティビティ整理
|
|
428
|
+
システム化範囲の再確認 --> [*]
|
|
429
|
+
}
|
|
430
|
+
|
|
431
|
+
業務_BUC_アクティビティ見直し --> ユースケース洗い出し
|
|
432
|
+
|
|
433
|
+
state ユースケース洗い出し {
|
|
434
|
+
[*] --> UCの特定
|
|
435
|
+
UCの特定 : アクティビティからUC導出
|
|
436
|
+
UCの特定 --> システム化範囲の明確化
|
|
437
|
+
システム化範囲の明確化 : UC一覧作成
|
|
438
|
+
システム化範囲の明確化 --> [*]
|
|
439
|
+
}
|
|
440
|
+
|
|
441
|
+
ユースケース洗い出し --> 画面_イベント導出
|
|
442
|
+
|
|
443
|
+
state 画面_イベント導出 {
|
|
444
|
+
[*] --> 入出力の明確化
|
|
445
|
+
入出力の明確化 : 画面要素の特定
|
|
446
|
+
入出力の明確化 --> 外部システム連携点の特定
|
|
447
|
+
外部システム連携点の特定 : イベント定義
|
|
448
|
+
外部システム連携点の特定 --> [*]
|
|
449
|
+
}
|
|
450
|
+
|
|
451
|
+
画面_イベント導出 --> ユースケース複合図作成
|
|
452
|
+
|
|
453
|
+
state ユースケース複合図作成 {
|
|
454
|
+
[*] --> UCと入出力の関連付け
|
|
455
|
+
UCと入出力の関連付け : 画面との関連
|
|
456
|
+
UCと入出力の関連付け : イベントとの関連
|
|
457
|
+
UCと入出力の関連付け --> システム境界の明確化
|
|
458
|
+
システム境界の明確化 --> [*]
|
|
459
|
+
}
|
|
460
|
+
|
|
461
|
+
ユースケース複合図作成 --> UC確認
|
|
462
|
+
|
|
463
|
+
state UC確認 <<choice>>
|
|
464
|
+
UC確認 --> 業務_BUC_アクティビティ見直し : [新規UC発見]
|
|
465
|
+
UC確認 --> [*] : [洗い出し完了]
|
|
466
|
+
}
|
|
467
|
+
|
|
468
|
+
Step5_トップダウン要件組立て --> Step6_ボトムアップ見直し
|
|
469
|
+
|
|
470
|
+
state "Step6: 情報・状態を使って見直す" as Step6_ボトムアップ見直し {
|
|
471
|
+
[*] --> 情報の関係づけ
|
|
472
|
+
|
|
473
|
+
state 情報の関係づけ {
|
|
474
|
+
[*] --> 情報モデルの詳細化
|
|
475
|
+
情報モデルの詳細化 : エンティティ整理
|
|
476
|
+
情報モデルの詳細化 --> 情報間の関係性確認
|
|
477
|
+
情報間の関係性確認 : 関連の定義
|
|
478
|
+
情報間の関係性確認 --> [*]
|
|
479
|
+
}
|
|
480
|
+
|
|
481
|
+
情報の関係づけ --> 欠けている情報_状態の洗い出し
|
|
482
|
+
|
|
483
|
+
state 欠けている情報_状態の洗い出し {
|
|
484
|
+
[*] --> 不足情報の発見
|
|
485
|
+
不足情報の発見 : ギャップ分析
|
|
486
|
+
不足情報の発見 --> 状態遷移のギャップ発見
|
|
487
|
+
状態遷移のギャップ発見 : 状態モデル見直し
|
|
488
|
+
状態遷移のギャップ発見 --> [*]
|
|
489
|
+
}
|
|
490
|
+
|
|
491
|
+
欠けている情報_状態の洗い出し --> UCと情報_状態の関連付け
|
|
492
|
+
|
|
493
|
+
state UCと情報_状態の関連付け {
|
|
494
|
+
[*] --> UCと情報の関連明確化
|
|
495
|
+
UCと情報の関連明確化 : CRUD分析
|
|
496
|
+
UCと情報の関連明確化 --> UCと状態の関連明確化
|
|
497
|
+
UCと状態の関連明確化 : 状態遷移とUCの対応
|
|
498
|
+
UCと状態の関連明確化 --> [*]
|
|
499
|
+
}
|
|
500
|
+
|
|
501
|
+
UCと情報_状態の関連付け --> 整合性の確認と精度向上
|
|
502
|
+
|
|
503
|
+
state 整合性の確認と精度向上 {
|
|
504
|
+
[*] --> 全体整合性チェック
|
|
505
|
+
全体整合性チェック : トレーサビリティ確認
|
|
506
|
+
全体整合性チェック --> 要件の精度向上
|
|
507
|
+
要件の精度向上 : 詳細度の確認
|
|
508
|
+
要件の精度向上 --> [*]
|
|
509
|
+
}
|
|
510
|
+
|
|
511
|
+
整合性の確認と精度向上 --> 精度判定
|
|
512
|
+
|
|
513
|
+
state 精度判定 <<choice>>
|
|
514
|
+
精度判定 --> 情報の関係づけ : [精度不足]
|
|
515
|
+
精度判定 --> [*] : [精度十分]
|
|
516
|
+
}
|
|
517
|
+
|
|
518
|
+
Step6_ボトムアップ見直し --> 繰り返し判定
|
|
519
|
+
|
|
520
|
+
state 繰り返し判定 <<choice>>
|
|
521
|
+
繰り返し判定 --> Step5_トップダウン要件組立て : [要件の見直し必要]
|
|
522
|
+
繰り返し判定 --> [*] : [要件組立て完了]
|
|
523
|
+
}
|
|
524
|
+
|
|
525
|
+
Phase2_Detail --> フェーズ2完了
|
|
526
|
+
|
|
527
|
+
フェーズ2完了 --> [*]
|
|
528
|
+
|
|
529
|
+
note right of Step5_トップダウン要件組立て
|
|
530
|
+
トップダウンアプローチ:
|
|
531
|
+
- 業務レベルからシステムレベルへ
|
|
532
|
+
- UCを中心にシステム化範囲を定義
|
|
533
|
+
- 入出力を明確化
|
|
534
|
+
期間目安: 3日間
|
|
535
|
+
end note
|
|
536
|
+
|
|
537
|
+
note right of Step6_ボトムアップ見直し
|
|
538
|
+
ボトムアップアプローチ:
|
|
539
|
+
- 情報と状態から要件を精緻化
|
|
540
|
+
- UCとの関連性を確認
|
|
541
|
+
- 全体整合性を確保
|
|
542
|
+
期間目安: 4日間
|
|
543
|
+
end note
|
|
544
|
+
|
|
545
|
+
note right of 繰り返し判定
|
|
546
|
+
Step5とStep6の反復:
|
|
547
|
+
- トップダウンとボトムアップの相互検証
|
|
548
|
+
- 要件の精度が十分になるまで繰り返し
|
|
549
|
+
- 最もボリュームのあるフェーズ
|
|
550
|
+
end note
|
|
551
|
+
|
|
552
|
+
@enduml
|
|
553
|
+
```
|
|
554
|
+
|
|
555
|
+
### フェーズ3: ビジネスルールで仕様化可能にする
|
|
556
|
+
|
|
557
|
+
#### Step7-9: ビジネスルール詳細化
|
|
558
|
+
|
|
559
|
+
```plantuml
|
|
560
|
+
@startuml
|
|
561
|
+
|
|
562
|
+
title Step7-9: ビジネスルール詳細化 - ステートチャート図
|
|
563
|
+
|
|
564
|
+
[*] --> ビジネスルール定義開始
|
|
565
|
+
|
|
566
|
+
state "フェーズ3: ビジネスルールで仕様化" as phase3_detail {
|
|
567
|
+
[*] --> Step7_条件洗い出し
|
|
568
|
+
|
|
569
|
+
state "Step7: UCにつながる条件を洗い出す" as Step7_条件洗い出し {
|
|
570
|
+
[*] --> システム動作条件考察
|
|
571
|
+
システム動作条件考察 : UCごとの動作条件確認
|
|
572
|
+
システム動作条件考察 --> ビジネスルール明確化
|
|
573
|
+
ビジネスルール明確化 : ビジネスを駆動するルール
|
|
574
|
+
ビジネスルール明確化 --> 条件として整理
|
|
575
|
+
条件として整理 --> [*]
|
|
576
|
+
}
|
|
577
|
+
|
|
578
|
+
Step7_条件洗い出し --> Step8_バリエーション
|
|
579
|
+
|
|
580
|
+
state "Step8: 条件の軸となるバリエーションを洗い出す" as Step8_バリエーション {
|
|
581
|
+
[*] --> 条件の分解
|
|
582
|
+
条件の分解 : 条件をバリエーションの組合せで表現
|
|
583
|
+
条件の分解 --> バリエーション軸の特定
|
|
584
|
+
バリエーション軸の特定 : 条件の軸となる要素を洗い出し
|
|
585
|
+
バリエーション軸の特定 --> ビジネスルール構造化
|
|
586
|
+
ビジネスルール構造化 --> [*]
|
|
587
|
+
}
|
|
588
|
+
|
|
589
|
+
Step8_バリエーション --> Step9_要素詳細化
|
|
590
|
+
|
|
591
|
+
state "Step9: 条件とバリエーションの要素を洗い出す" as Step9_要素詳細化 {
|
|
592
|
+
[*] --> 具体要素の洗い出し
|
|
593
|
+
具体要素の洗い出し : 条件とバリエーションの具体化
|
|
594
|
+
具体要素の洗い出し --> 実装指針明確化
|
|
595
|
+
実装指針明確化 : 開発チーム向け指針作成
|
|
596
|
+
実装指針明確化 --> バリエーション_条件図作成
|
|
597
|
+
バリエーション_条件図作成 : 表形式での整理
|
|
598
|
+
バリエーション_条件図作成 --> [*]
|
|
599
|
+
}
|
|
600
|
+
|
|
601
|
+
Step9_要素詳細化 --> [*]
|
|
602
|
+
}
|
|
603
|
+
|
|
604
|
+
phase3_detail --> ビジネスルール定義完了
|
|
605
|
+
|
|
606
|
+
ビジネスルール定義完了 --> [*]
|
|
607
|
+
|
|
608
|
+
note right of Step7_条件洗い出し
|
|
609
|
+
システムの動作条件を考察
|
|
610
|
+
ビジネスを駆動するルールを明確化
|
|
611
|
+
条件としての整理
|
|
612
|
+
end note
|
|
613
|
+
|
|
614
|
+
note right of Step8_バリエーション
|
|
615
|
+
条件はバリエーションの組合せで表現
|
|
616
|
+
条件の軸となる要素を洗い出し
|
|
617
|
+
ビジネスルールの構造化
|
|
618
|
+
end note
|
|
619
|
+
|
|
620
|
+
note right of Step9_要素詳細化
|
|
621
|
+
条件とバリエーションの具体要素
|
|
622
|
+
実装指針の明確化
|
|
623
|
+
仕様化への準備完了
|
|
624
|
+
end note
|
|
625
|
+
|
|
626
|
+
@enduml
|
|
627
|
+
```
|
|
628
|
+
|
|
629
|
+
## 各図の作成順序とトレーサビリティ
|
|
630
|
+
|
|
631
|
+
```plantuml
|
|
632
|
+
@startuml
|
|
633
|
+
|
|
634
|
+
title RDRA図の作成順序とトレーサビリティ
|
|
635
|
+
|
|
636
|
+
left to right direction
|
|
637
|
+
|
|
638
|
+
rectangle "1. システムコンテキスト図" as sc #lightblue
|
|
639
|
+
rectangle "2. 要求モデル図" as rm #lightblue
|
|
640
|
+
rectangle "3. ビジネスコンテキスト図" as bc #lightgreen
|
|
641
|
+
rectangle "4. ビジネスユースケース図" as buc #lightgreen
|
|
642
|
+
rectangle "5. 業務フロー図/利用シーン図" as bf_us #lightgreen
|
|
643
|
+
rectangle "6. ユースケース複合図" as ucc #lightyellow
|
|
644
|
+
rectangle "7. 情報モデル図" as im #lightcyan
|
|
645
|
+
rectangle "8. 状態モデル図" as sm #lightcyan
|
|
646
|
+
rectangle "9. バリエーション・条件図" as vc #lightpink
|
|
647
|
+
|
|
648
|
+
sc --> bc : "アクター"
|
|
649
|
+
rm --> buc : "要求→BUC"
|
|
650
|
+
bc --> buc : "業務→BUC"
|
|
651
|
+
buc --> bf_us : "BUC→アクティビティ/利用シーン"
|
|
652
|
+
buc --> ucc : "BUC→UC"
|
|
653
|
+
bf_us --> ucc : "アクティビティ→UC"
|
|
654
|
+
ucc --> im : "UC→情報"
|
|
655
|
+
ucc --> sm : "UC→状態"
|
|
656
|
+
ucc --> vc : "UC→条件"
|
|
657
|
+
im --> sm : "情報→状態"
|
|
658
|
+
|
|
659
|
+
note bottom of sc
|
|
660
|
+
プロジェクトの出発点
|
|
661
|
+
関係者とシステムの位置づけ
|
|
662
|
+
end note
|
|
663
|
+
|
|
664
|
+
note bottom of ucc
|
|
665
|
+
システム境界の中心
|
|
666
|
+
全ての要素が集約される
|
|
667
|
+
end note
|
|
668
|
+
|
|
669
|
+
note bottom of im
|
|
670
|
+
システムで扱うデータ構造
|
|
671
|
+
概念モデルとして機能
|
|
672
|
+
end note
|
|
673
|
+
|
|
674
|
+
@enduml
|
|
675
|
+
```
|
|
676
|
+
|
|
677
|
+
## 期間配分と工数の目安
|
|
678
|
+
|
|
679
|
+
```plantuml
|
|
680
|
+
@startuml
|
|
681
|
+
|
|
682
|
+
title 要件定義期間配分の目安
|
|
683
|
+
|
|
684
|
+
left to right direction
|
|
685
|
+
|
|
686
|
+
rectangle "Step1\n出発点明確化\n(1日)" as s1 #lightblue
|
|
687
|
+
rectangle "Step2\nスコープ把握\n(1日)" as s2 #lightblue
|
|
688
|
+
rectangle "Step3\n情報明示\n(1日)" as s3 #lightblue
|
|
689
|
+
rectangle "Step4\n状態明示\n(1日)" as s4 #lightblue
|
|
690
|
+
rectangle "Step5\nUC組立て\n(3日)" as s5 #lightgreen
|
|
691
|
+
rectangle "Step6\n情報状態見直し\n(4日)" as s6 #lightgreen
|
|
692
|
+
rectangle "Step7\n条件洗出し\n(1日)" as s7 #lightyellow
|
|
693
|
+
rectangle "Step8\nバリエーション\n(1日)" as s8 #lightyellow
|
|
694
|
+
rectangle "Step9\n要素詳細化\n(1日)" as s9 #lightyellow
|
|
695
|
+
|
|
696
|
+
s1 --> s2
|
|
697
|
+
s2 --> s3
|
|
698
|
+
s3 --> s4
|
|
699
|
+
s4 --> s5
|
|
700
|
+
s5 --> s6
|
|
701
|
+
s6 --> s7
|
|
702
|
+
s7 --> s8
|
|
703
|
+
s8 --> s9
|
|
704
|
+
|
|
705
|
+
note bottom
|
|
706
|
+
合計: 14日間の目安
|
|
707
|
+
- フェーズ1: 4日間(全体の29%)
|
|
708
|
+
- フェーズ2: 7日間(全体の50%)
|
|
709
|
+
- フェーズ3: 3日間(全体の21%)
|
|
710
|
+
|
|
711
|
+
実際のプロジェクトでは規模と複雑さに応じて調整
|
|
712
|
+
よくわからない部分に時間を割き、明確な部分は素早く定義
|
|
713
|
+
end note
|
|
714
|
+
|
|
715
|
+
@enduml
|
|
716
|
+
```
|
|
717
|
+
|
|
718
|
+
## PlantUMLでのRDRA図作成ガイド
|
|
719
|
+
|
|
720
|
+
### アイコン対応表
|
|
721
|
+
|
|
722
|
+
```plantuml
|
|
723
|
+
@startuml
|
|
724
|
+
|
|
725
|
+
title PlantUMLでのRDRAアイコン対応
|
|
726
|
+
|
|
727
|
+
left to right direction
|
|
728
|
+
|
|
729
|
+
package "基本要素" {
|
|
730
|
+
actor "アクター\n(actor)" as ac
|
|
731
|
+
usecase "システム/業務\n(usecase)" as uc
|
|
732
|
+
agent "外部システム/組織\n(agent)" as ag
|
|
733
|
+
note "要求/要件\n(note)" as nt
|
|
734
|
+
}
|
|
735
|
+
|
|
736
|
+
package "境界要素" {
|
|
737
|
+
boundary "画面\n(boundary)" as bd
|
|
738
|
+
entity "情報\n(entity)" as en
|
|
739
|
+
control "条件\n(control)" as ct
|
|
740
|
+
interface "イベント\n(interface)" as if
|
|
741
|
+
}
|
|
742
|
+
|
|
743
|
+
package "構造要素" {
|
|
744
|
+
rectangle "組織\n(rectangle)" as rec
|
|
745
|
+
node "会社\n(node)" as nd
|
|
746
|
+
artifact "ビジネス要素\n(artifact)" as art
|
|
747
|
+
frame "利用シーン\n(frame)" as fr
|
|
748
|
+
}
|
|
749
|
+
|
|
750
|
+
@enduml
|
|
751
|
+
```
|
|
752
|
+
|
|
753
|
+
### PlantUMLテンプレート例
|
|
754
|
+
|
|
755
|
+
#### システムコンテキスト図
|
|
756
|
+
|
|
757
|
+
```plantuml
|
|
758
|
+
@startuml
|
|
759
|
+
|
|
760
|
+
title システムコンテキスト図
|
|
761
|
+
|
|
762
|
+
left to right direction
|
|
763
|
+
|
|
764
|
+
actor 会員
|
|
765
|
+
actor 図書館員
|
|
766
|
+
|
|
767
|
+
agent 書籍通販会社
|
|
768
|
+
|
|
769
|
+
usecase 図書館システム
|
|
770
|
+
note top of 図書館システム
|
|
771
|
+
図書館員の作業 (書籍購買の自動連携) を支援し、本の貸
|
|
772
|
+
出・返却業務において会員を待たせないスムーズな運用を
|
|
773
|
+
実現する。蔵書管理をリアルタイムで行い、検索、在庫な
|
|
774
|
+
ど会員サービスを向上させる
|
|
775
|
+
end note
|
|
776
|
+
|
|
777
|
+
:会員: -- (図書館システム)
|
|
778
|
+
:図書館員: -- (図書館システム)
|
|
779
|
+
(図書館システム) -- 書籍通販会社
|
|
780
|
+
|
|
781
|
+
@enduml
|
|
782
|
+
```
|
|
783
|
+
|
|
784
|
+
#### 要求モデル図
|
|
785
|
+
|
|
786
|
+
```plantuml
|
|
787
|
+
@startuml
|
|
788
|
+
|
|
789
|
+
title 要求モデル図
|
|
790
|
+
|
|
791
|
+
left to right direction
|
|
792
|
+
|
|
793
|
+
actor 司書
|
|
794
|
+
note "本の購入を簡素化したい" as s_r1
|
|
795
|
+
note "返却率が悪くならないように返却を簡単にする" as s_r2
|
|
796
|
+
note as s_dr1 #Turquoise
|
|
797
|
+
本の購入を Web で直接行え、購入した本の情
|
|
798
|
+
報をそのままシステムに取り込めること
|
|
799
|
+
end note
|
|
800
|
+
:司書: -- s_r1
|
|
801
|
+
:司書: -- s_r2
|
|
802
|
+
s_r1 -- s_dr1
|
|
803
|
+
s_r2 -- s_dr1
|
|
804
|
+
|
|
805
|
+
actor 図書館員
|
|
806
|
+
note "本の貸出、返却手続きを簡素化したい" as t_r1
|
|
807
|
+
note "本の在庫をリアルタイムで把握したい" as t_r2
|
|
808
|
+
note as t_dr1 #Turquoise
|
|
809
|
+
本の貸出と返却を簡易に行え、リアルタ
|
|
810
|
+
イムで在庫に反映できること
|
|
811
|
+
end note
|
|
812
|
+
:図書館員: -- t_r1
|
|
813
|
+
:図書館員: -- t_r2
|
|
814
|
+
t_r1 -- t_dr1
|
|
815
|
+
t_r2 -- t_dr1
|
|
816
|
+
|
|
817
|
+
actor 会員
|
|
818
|
+
note "見たい本が図書館にあるかを Web で検索したい" as k_r1
|
|
819
|
+
note "借りたい本を Web で予約したい" as k_r2
|
|
820
|
+
note as k_dr1 #Turquoise
|
|
821
|
+
Web で借りたい本を検索でき、
|
|
822
|
+
そのまま予約できること
|
|
823
|
+
end note
|
|
824
|
+
:会員: -- k_r1
|
|
825
|
+
:会員: -- k_r2
|
|
826
|
+
k_r1 -- k_dr1
|
|
827
|
+
k_r2 -- k_dr1
|
|
828
|
+
|
|
829
|
+
@enduml
|
|
830
|
+
```
|
|
831
|
+
|
|
832
|
+
#### ビジネスコンテキスト図
|
|
833
|
+
|
|
834
|
+
```plantuml
|
|
835
|
+
@startuml
|
|
836
|
+
|
|
837
|
+
title ビジネスコンテキスト図
|
|
838
|
+
|
|
839
|
+
left to right direction
|
|
840
|
+
|
|
841
|
+
actor 会員
|
|
842
|
+
|
|
843
|
+
node 図書館 {
|
|
844
|
+
rectangle 窓口 {
|
|
845
|
+
actor 図書館員
|
|
846
|
+
}
|
|
847
|
+
rectangle 司書室 {
|
|
848
|
+
actor 司書
|
|
849
|
+
}
|
|
850
|
+
usecase 会員管理
|
|
851
|
+
usecase 貸出返却
|
|
852
|
+
usecase 蔵書管理
|
|
853
|
+
artifact 蔵書
|
|
854
|
+
artifact 書架
|
|
855
|
+
}
|
|
856
|
+
|
|
857
|
+
node 書籍店
|
|
858
|
+
|
|
859
|
+
:会員: -- (会員管理)
|
|
860
|
+
(会員管理) -- :図書館員:
|
|
861
|
+
|
|
862
|
+
:会員: -- (貸出返却)
|
|
863
|
+
(貸出返却) -- :図書館員:
|
|
864
|
+
(貸出返却) -- 蔵書
|
|
865
|
+
(貸出返却) -- 書架
|
|
866
|
+
|
|
867
|
+
蔵書 -- (蔵書管理)
|
|
868
|
+
書架 -- (蔵書管理)
|
|
869
|
+
(蔵書管理) - :司書:
|
|
870
|
+
(蔵書管理) -- 書籍店
|
|
871
|
+
|
|
872
|
+
@enduml
|
|
873
|
+
```
|
|
874
|
+
|
|
875
|
+
#### ビジネスユースケース図
|
|
876
|
+
|
|
877
|
+
```plantuml
|
|
878
|
+
@startuml
|
|
879
|
+
|
|
880
|
+
title ビジネスユースケース図 - 貸出・返却:業務
|
|
881
|
+
|
|
882
|
+
left to right direction
|
|
883
|
+
|
|
884
|
+
actor 会員
|
|
885
|
+
actor 図書館員
|
|
886
|
+
|
|
887
|
+
agent 窓口
|
|
888
|
+
|
|
889
|
+
usecase 窓口貸出
|
|
890
|
+
usecase Web予約
|
|
891
|
+
usecase 返却
|
|
892
|
+
|
|
893
|
+
artifact 蔵書
|
|
894
|
+
artifact 書架
|
|
895
|
+
|
|
896
|
+
:図書館員: -- (窓口貸出)
|
|
897
|
+
(窓口貸出) -- 窓口
|
|
898
|
+
(窓口貸出) -- 蔵書
|
|
899
|
+
(窓口貸出) -- 書架
|
|
900
|
+
|
|
901
|
+
:会員: -- (Web予約)
|
|
902
|
+
:図書館員: -- (Web予約)
|
|
903
|
+
(Web予約) -- 蔵書
|
|
904
|
+
(Web予約) -- 書架
|
|
905
|
+
|
|
906
|
+
:図書館員: -- (返却)
|
|
907
|
+
(返却) -- 窓口
|
|
908
|
+
(返却) -- 蔵書
|
|
909
|
+
(返却) -- 書架
|
|
910
|
+
|
|
911
|
+
@enduml
|
|
912
|
+
```
|
|
913
|
+
|
|
914
|
+
#### 業務フロー図
|
|
915
|
+
|
|
916
|
+
```plantuml
|
|
917
|
+
@startuml
|
|
918
|
+
|
|
919
|
+
title 業務フロー図 - Web予約:BUC
|
|
920
|
+
|
|
921
|
+
/'
|
|
922
|
+
actor 会員
|
|
923
|
+
actor 図書館員
|
|
924
|
+
usecase 貸出本の予約・取消をする
|
|
925
|
+
usecase 予約図書一覧を出力する
|
|
926
|
+
usecase 予約図書を取り置く
|
|
927
|
+
usecase 取置図書を消しこむ
|
|
928
|
+
'/
|
|
929
|
+
|
|
930
|
+
|会員|
|
|
931
|
+
partition 貸出予約 {
|
|
932
|
+
:貸出本の予約・取消をする;
|
|
933
|
+
}
|
|
934
|
+
|
|
935
|
+
|図書館員|
|
|
936
|
+
partition 予約図書の準備 {
|
|
937
|
+
:予約図書一覧を出力する;
|
|
938
|
+
split
|
|
939
|
+
:予約図書を取り置く;
|
|
940
|
+
split again
|
|
941
|
+
-> 貸出図書が無い場合;
|
|
942
|
+
stop
|
|
943
|
+
end split
|
|
944
|
+
}
|
|
945
|
+
|
|
946
|
+
|会員|
|
|
947
|
+
partition 予約図書を受け取る {
|
|
948
|
+
:取置図書を消しこむ;
|
|
949
|
+
}
|
|
950
|
+
stop
|
|
951
|
+
|
|
952
|
+
@enduml
|
|
953
|
+
```
|
|
954
|
+
|
|
955
|
+
#### 利用シーン図
|
|
956
|
+
|
|
957
|
+
```plantuml
|
|
958
|
+
@startuml
|
|
959
|
+
|
|
960
|
+
title 利用シーン図 - 会員登録:BUC
|
|
961
|
+
|
|
962
|
+
left to right direction
|
|
963
|
+
|
|
964
|
+
actor 会員
|
|
965
|
+
actor 図書館員
|
|
966
|
+
|
|
967
|
+
frame 会員登録
|
|
968
|
+
note right of 会員登録
|
|
969
|
+
本の貸出・返却時の単純化のために事前に会員登録を行う
|
|
970
|
+
既に図書カードを導入しているが、忘れる人が多いので図書カード以外での確認方法も欲しい
|
|
971
|
+
新しい機器を持たない老人もいるので図書カードもそのまま残したい
|
|
972
|
+
会員登録も利用者本人ができるようにしたい
|
|
973
|
+
end note
|
|
974
|
+
|
|
975
|
+
frame 会員の確認
|
|
976
|
+
note right of 会員の確認
|
|
977
|
+
本 (電子図書含む) の貸出の時の会員認証を簡単に行いたい
|
|
978
|
+
図書カード等を忘れた場合にも口頭で対応できるようにしたい
|
|
979
|
+
end note
|
|
980
|
+
|
|
981
|
+
usecase 会員IDを発行する
|
|
982
|
+
usecase 会員カードを作成する
|
|
983
|
+
usecase 会員を特定する
|
|
984
|
+
|
|
985
|
+
:会員: -- 会員登録
|
|
986
|
+
:図書館員: -- 会員登録
|
|
987
|
+
会員登録 -- (会員IDを発行する)
|
|
988
|
+
会員登録 -- (会員カードを作成する)
|
|
989
|
+
|
|
990
|
+
:図書館員: -- 会員の確認
|
|
991
|
+
会員の確認 -- (会員を特定する)
|
|
992
|
+
|
|
993
|
+
@enduml
|
|
994
|
+
```
|
|
995
|
+
|
|
996
|
+
#### ユースケース複合図
|
|
997
|
+
|
|
998
|
+
```plantuml
|
|
999
|
+
@startuml
|
|
1000
|
+
|
|
1001
|
+
title ユースケース複合図 - Web予約:BUC
|
|
1002
|
+
|
|
1003
|
+
left to right direction
|
|
1004
|
+
|
|
1005
|
+
actor 会員
|
|
1006
|
+
|
|
1007
|
+
entity 貸出予約
|
|
1008
|
+
entity 蔵書
|
|
1009
|
+
|
|
1010
|
+
usecase 予約図書一覧を出力する
|
|
1011
|
+
boundary 貸出予約一覧
|
|
1012
|
+
control 貸出予約一覧出力条件
|
|
1013
|
+
|
|
1014
|
+
貸出予約一覧 - (予約図書一覧を出力する)
|
|
1015
|
+
貸出予約一覧 -- 貸出予約一覧出力条件
|
|
1016
|
+
(予約図書一覧を出力する) -- 貸出予約
|
|
1017
|
+
|
|
1018
|
+
usecase 予約図書を取り置く
|
|
1019
|
+
boundary 貸出準備登録
|
|
1020
|
+
control 取置期限
|
|
1021
|
+
interface 貸出可能を通知する
|
|
1022
|
+
control 予約貸出通知メッセージ
|
|
1023
|
+
|
|
1024
|
+
貸出準備登録 - (予約図書を取り置く)
|
|
1025
|
+
(予約図書を取り置く) - 取置期限
|
|
1026
|
+
(予約図書を取り置く) -- 貸出予約
|
|
1027
|
+
(予約図書を取り置く) -- 蔵書
|
|
1028
|
+
(予約図書を取り置く) -- 貸出可能を通知する
|
|
1029
|
+
予約貸出通知メッセージ - 貸出可能を通知する
|
|
1030
|
+
貸出可能を通知する -- 会員
|
|
1031
|
+
|
|
1032
|
+
@enduml
|
|
1033
|
+
```
|
|
1034
|
+
|
|
1035
|
+
#### ユースケース複合図 + 業務フロー
|
|
1036
|
+
|
|
1037
|
+
```plantuml
|
|
1038
|
+
@startuml
|
|
1039
|
+
|
|
1040
|
+
title ユースケース複合図 - Web予約:BUC
|
|
1041
|
+
|
|
1042
|
+
left to right direction
|
|
1043
|
+
|
|
1044
|
+
actor 会員
|
|
1045
|
+
actor 会員 as a会員
|
|
1046
|
+
actor 図書館員
|
|
1047
|
+
|
|
1048
|
+
frame 貸出予約 as f貸出予約
|
|
1049
|
+
frame 予約図書の準備 as f予約図書の準備
|
|
1050
|
+
note bottom of f予約図書の準備
|
|
1051
|
+
・貸出予約一覧を出力
|
|
1052
|
+
・未取り置きのものを探す
|
|
1053
|
+
・取置棚に置く
|
|
1054
|
+
end note
|
|
1055
|
+
frame 予約図書を受け取る as f予約図書を受け取る
|
|
1056
|
+
|
|
1057
|
+
usecase "貸出本の予約・取消をする"
|
|
1058
|
+
usecase 予約図書一覧を出力する
|
|
1059
|
+
usecase 予約図書を取り置く
|
|
1060
|
+
usecase 予約図書を消しこむ
|
|
1061
|
+
usecase 蔵書の貸出を登録する
|
|
1062
|
+
|
|
1063
|
+
boundary 蔵書検索 as b蔵書検索
|
|
1064
|
+
boundary 貸出予約 as b貸出予約
|
|
1065
|
+
boundary 貸出予約一覧 as b貸出予約一覧
|
|
1066
|
+
boundary 貸出準備登録 as b貸出準備登録
|
|
1067
|
+
boundary 予約消込 as b予約消込
|
|
1068
|
+
|
|
1069
|
+
control 貸出予約一覧出力条件 as c貸出予約一覧出力条件
|
|
1070
|
+
control 取置期限 as c取置期限
|
|
1071
|
+
control 予約貸出通知メッセージ as c予約貸出通知メッセージ
|
|
1072
|
+
|
|
1073
|
+
entity 貸出予約 as e貸出予約
|
|
1074
|
+
entity 蔵書 as e蔵書
|
|
1075
|
+
|
|
1076
|
+
interface 貸出可能を通知する as i貸出可能を通知する
|
|
1077
|
+
|
|
1078
|
+
:会員: -- f貸出予約
|
|
1079
|
+
f貸出予約 -- (貸出本の予約・取消をする)
|
|
1080
|
+
b蔵書検索 - (貸出本の予約・取消をする)
|
|
1081
|
+
b貸出予約 - (貸出本の予約・取消をする)
|
|
1082
|
+
(貸出本の予約・取消をする) -- e蔵書
|
|
1083
|
+
(貸出本の予約・取消をする) -- e貸出予約
|
|
1084
|
+
|
|
1085
|
+
f貸出予約 -> f予約図書の準備
|
|
1086
|
+
|
|
1087
|
+
:図書館員: -- f予約図書の準備
|
|
1088
|
+
c貸出予約一覧出力条件 - b貸出予約一覧
|
|
1089
|
+
b貸出予約一覧 - (予約図書一覧を出力する)
|
|
1090
|
+
f予約図書の準備 -- (予約図書一覧を出力する)
|
|
1091
|
+
(予約図書一覧を出力する) -- e貸出予約
|
|
1092
|
+
|
|
1093
|
+
f予約図書の準備 -- (予約図書を取り置く)
|
|
1094
|
+
b貸出準備登録 - (予約図書を取り置く)
|
|
1095
|
+
(予約図書を取り置く) - c取置期限
|
|
1096
|
+
(予約図書を取り置く) -- e貸出予約
|
|
1097
|
+
(予約図書を取り置く) -- e蔵書
|
|
1098
|
+
(予約図書を取り置く) -- i貸出可能を通知する
|
|
1099
|
+
c予約貸出通知メッセージ - i貸出可能を通知する
|
|
1100
|
+
i貸出可能を通知する -- :a会員:
|
|
1101
|
+
|
|
1102
|
+
f予約図書の準備 -> f予約図書を受け取る
|
|
1103
|
+
|
|
1104
|
+
:会員: -- f予約図書を受け取る
|
|
1105
|
+
:図書館員: -- f予約図書を受け取る
|
|
1106
|
+
f予約図書を受け取る -- (予約図書を消しこむ)
|
|
1107
|
+
(予約図書を消しこむ) - (蔵書の貸出を登録する)
|
|
1108
|
+
b予約消込 - (予約図書を消しこむ)
|
|
1109
|
+
(予約図書を消しこむ) -- e貸出予約
|
|
1110
|
+
|
|
1111
|
+
@enduml
|
|
1112
|
+
```
|
|
1113
|
+
|
|
1114
|
+
#### ユースケース複合図 + 利用シーン
|
|
1115
|
+
|
|
1116
|
+
```plantuml
|
|
1117
|
+
@startuml
|
|
1118
|
+
|
|
1119
|
+
title ユースケース複合図 - 期限管理:BUC
|
|
1120
|
+
|
|
1121
|
+
left to right direction
|
|
1122
|
+
|
|
1123
|
+
actor 会員
|
|
1124
|
+
actor 図書館員
|
|
1125
|
+
actor 日時<<タイマー>>
|
|
1126
|
+
|
|
1127
|
+
frame 取置図書の返却
|
|
1128
|
+
note bottom of 取置図書の返却
|
|
1129
|
+
取り置き期限切れのものを書架に戻す
|
|
1130
|
+
end note
|
|
1131
|
+
|
|
1132
|
+
usecase 貸出期限を確認する
|
|
1133
|
+
usecase 取置期限を確認する
|
|
1134
|
+
|
|
1135
|
+
boundary 取置期限切れ as b取置期限切れ
|
|
1136
|
+
|
|
1137
|
+
entity 貸出図書
|
|
1138
|
+
entity 貸出予約
|
|
1139
|
+
entity 取置期限切れ
|
|
1140
|
+
|
|
1141
|
+
interface 貸出期限切れ通知
|
|
1142
|
+
interface 取置期限切れ通知
|
|
1143
|
+
|
|
1144
|
+
:日時: -- (貸出期限を確認する)
|
|
1145
|
+
(貸出期限を確認する) -- 貸出図書
|
|
1146
|
+
(貸出期限を確認する) -- 貸出期限切れ通知
|
|
1147
|
+
貸出期限切れ通知 -- :会員:
|
|
1148
|
+
|
|
1149
|
+
:日時: -- (取置期限を確認する)
|
|
1150
|
+
(取置期限を確認する) -- 貸出予約
|
|
1151
|
+
(取置期限を確認する) -- 取置期限切れ通知
|
|
1152
|
+
取置期限切れ通知 -- :会員:
|
|
1153
|
+
(取置期限を確認する) - 取置期限切れ
|
|
1154
|
+
|
|
1155
|
+
:図書館員: -- 取置図書の返却
|
|
1156
|
+
取置図書の返却 -- (取置期限を確認する)
|
|
1157
|
+
b取置期限切れ - (取置期限を確認する)
|
|
1158
|
+
|
|
1159
|
+
@enduml
|
|
1160
|
+
```
|
|
1161
|
+
|
|
1162
|
+
#### 情報モデル図
|
|
1163
|
+
|
|
1164
|
+
```plantuml
|
|
1165
|
+
@startuml
|
|
1166
|
+
|
|
1167
|
+
title 情報モデル図
|
|
1168
|
+
|
|
1169
|
+
left to right direction
|
|
1170
|
+
|
|
1171
|
+
entity 会員
|
|
1172
|
+
|
|
1173
|
+
entity 本
|
|
1174
|
+
entity 蔵書
|
|
1175
|
+
entity 書架
|
|
1176
|
+
|
|
1177
|
+
entity 貸出予約
|
|
1178
|
+
entity 貸出図書
|
|
1179
|
+
|
|
1180
|
+
entity 書籍発注
|
|
1181
|
+
|
|
1182
|
+
会員 -- 貸出予約
|
|
1183
|
+
貸出予約 -- 本
|
|
1184
|
+
|
|
1185
|
+
会員 -- 貸出図書
|
|
1186
|
+
貸出図書 -- 本
|
|
1187
|
+
|
|
1188
|
+
本 - 蔵書
|
|
1189
|
+
蔵書 - 書架
|
|
1190
|
+
|
|
1191
|
+
本 -- 書籍発注
|
|
1192
|
+
|
|
1193
|
+
@enduml
|
|
1194
|
+
```
|
|
1195
|
+
|
|
1196
|
+
#### 状態モデル図
|
|
1197
|
+
|
|
1198
|
+
```plantuml
|
|
1199
|
+
@startuml
|
|
1200
|
+
|
|
1201
|
+
title 状態モデル図 - Web予約:情報
|
|
1202
|
+
|
|
1203
|
+
/'
|
|
1204
|
+
usecase 貸出本を予約する
|
|
1205
|
+
usecase 貸出本を予約取消する
|
|
1206
|
+
usecase 予約図書を取り置く
|
|
1207
|
+
usecase 取置期限を確認する
|
|
1208
|
+
usecase 取置図書を消しこむ
|
|
1209
|
+
'/
|
|
1210
|
+
|
|
1211
|
+
state 未予約
|
|
1212
|
+
|
|
1213
|
+
state 予約中 {
|
|
1214
|
+
state 未準備
|
|
1215
|
+
state 準備完了
|
|
1216
|
+
}
|
|
1217
|
+
|
|
1218
|
+
[*] --> 未予約
|
|
1219
|
+
未予約 --> [*]
|
|
1220
|
+
|
|
1221
|
+
未予約 --> 未準備: (貸出本を予約する)
|
|
1222
|
+
予約中 --> 未予約: (貸出本を予約取消する)
|
|
1223
|
+
|
|
1224
|
+
未準備 --> 準備完了: (予約図書を取り置く)
|
|
1225
|
+
|
|
1226
|
+
準備完了 --> 準備完了: (取置期限を確認する)\n[取置期限 >= 今]
|
|
1227
|
+
準備完了 --> 未予約: (取置期限を確認する)\n[取置期限 < 今]
|
|
1228
|
+
|
|
1229
|
+
準備完了 --> 未予約: (取置図書を消しこむ)
|
|
1230
|
+
|
|
1231
|
+
@enduml
|
|
1232
|
+
```
|
|
1233
|
+
|
|
1234
|
+
## まとめ
|
|
1235
|
+
|
|
1236
|
+
RDRAを使った要件定義は以下の特徴があります:
|
|
1237
|
+
|
|
1238
|
+
1. **段階的洗練**: 3フェーズで徐々に精度を上げる
|
|
1239
|
+
2. **網羅性**: システム価値から段階的に要素を導出
|
|
1240
|
+
3. **整合性**: 図間の関連性で整合性を保証
|
|
1241
|
+
4. **表現力**: 視覚的なダイアグラムで共通理解を促進
|
|
1242
|
+
5. **トレーサビリティ**: 全ての要素が関連づけられている
|
|
1243
|
+
|
|
1244
|
+
このワークフローに従うことで、短時間で精度の高い要件定義が可能になります。PlantUMLを活用することで、テキストベースでの管理とバージョン管理が容易になり、チーム開発にも適用しやすくなります。
|
|
1245
|
+
|
|
1246
|
+
## 参考文献
|
|
1247
|
+
|
|
1248
|
+
- [RDRA2.0 ハンドブック](https://www.amazon.co.jp/RDRA2-0-ハンドブック-軽く柔軟で精度の高い要件定義のモデリング手法-神崎善司-ebook/dp/B07STQZFBX)
|
|
1249
|
+
- PlantUML公式サイト: https://plantuml.com/ja/
|