@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.
Files changed (107) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +28 -0
  3. package/bin/claude-code-booster +28 -0
  4. package/lib/assets/.claude/.mcp.json +45 -0
  5. package/lib/assets/.claude/README.md +169 -0
  6. package/lib/assets/.claude/agents/roles/analyzer.md +267 -0
  7. package/lib/assets/.claude/agents/roles/architect.md +233 -0
  8. package/lib/assets/.claude/agents/roles/backend.md +303 -0
  9. package/lib/assets/.claude/agents/roles/frontend.md +294 -0
  10. package/lib/assets/.claude/agents/roles/mobile.md +309 -0
  11. package/lib/assets/.claude/agents/roles/performance.md +254 -0
  12. package/lib/assets/.claude/agents/roles/qa.md +266 -0
  13. package/lib/assets/.claude/agents/roles/reviewer.md +252 -0
  14. package/lib/assets/.claude/agents/roles/security.md +392 -0
  15. package/lib/assets/.claude/assets/confirm.mp3 +0 -0
  16. package/lib/assets/.claude/assets/perfect.mp3 +0 -0
  17. package/lib/assets/.claude/assets/silent.wav +0 -0
  18. package/lib/assets/.claude/commands/analyze-dependencies.md +158 -0
  19. package/lib/assets/.claude/commands/analyze-performance.md +116 -0
  20. package/lib/assets/.claude/commands/check-fact.md +104 -0
  21. package/lib/assets/.claude/commands/check-github-ci.md +53 -0
  22. package/lib/assets/.claude/commands/check-prompt.md +461 -0
  23. package/lib/assets/.claude/commands/commit-message.md +348 -0
  24. package/lib/assets/.claude/commands/context7.md +50 -0
  25. package/lib/assets/.claude/commands/design-patterns.md +186 -0
  26. package/lib/assets/.claude/commands/explain-code.md +75 -0
  27. package/lib/assets/.claude/commands/fix-error.md +258 -0
  28. package/lib/assets/.claude/commands/multi-role.md +291 -0
  29. package/lib/assets/.claude/commands/plan.md +134 -0
  30. package/lib/assets/.claude/commands/pr-auto-update.md +460 -0
  31. package/lib/assets/.claude/commands/pr-create.md +249 -0
  32. package/lib/assets/.claude/commands/pr-feedback.md +143 -0
  33. package/lib/assets/.claude/commands/pr-issue.md +78 -0
  34. package/lib/assets/.claude/commands/pr-list.md +66 -0
  35. package/lib/assets/.claude/commands/pr-review.md +142 -0
  36. package/lib/assets/.claude/commands/refactor.md +147 -0
  37. package/lib/assets/.claude/commands/role-debate.md +571 -0
  38. package/lib/assets/.claude/commands/role-help.md +276 -0
  39. package/lib/assets/.claude/commands/role.md +360 -0
  40. package/lib/assets/.claude/commands/screenshot.md +103 -0
  41. package/lib/assets/.claude/commands/search-gemini.md +66 -0
  42. package/lib/assets/.claude/commands/semantic-commit.md +1129 -0
  43. package/lib/assets/.claude/commands/sequential-thinking.md +90 -0
  44. package/lib/assets/.claude/commands/show-plan.md +59 -0
  45. package/lib/assets/.claude/commands/smart-review.md +174 -0
  46. package/lib/assets/.claude/commands/spec.md +559 -0
  47. package/lib/assets/.claude/commands/style-ai-writing.md +186 -0
  48. package/lib/assets/.claude/commands/task.md +223 -0
  49. package/lib/assets/.claude/commands/tech-debt.md +87 -0
  50. package/lib/assets/.claude/commands/ultrathink.md +65 -0
  51. package/lib/assets/.claude/commands/update-dart-doc.md +202 -0
  52. package/lib/assets/.claude/commands/update-doc-string.md +306 -0
  53. package/lib/assets/.claude/commands/update-flutter-deps.md +105 -0
  54. package/lib/assets/.claude/commands/update-node-deps.md +105 -0
  55. package/lib/assets/.claude/commands/update-rust-deps.md +107 -0
  56. package/lib/assets/.claude/scripts/auto-comment.sh +16 -0
  57. package/lib/assets/.claude/scripts/check-ai-commit.sh +20 -0
  58. package/lib/assets/.claude/scripts/check-continue.sh +97 -0
  59. package/lib/assets/.claude/scripts/check-locales.sh +1080 -0
  60. package/lib/assets/.claude/scripts/check-project-plan.sh +25 -0
  61. package/lib/assets/.claude/scripts/debug-hook.sh +7 -0
  62. package/lib/assets/.claude/scripts/deny-check.sh +69 -0
  63. package/lib/assets/.claude/scripts/install.sh +174 -0
  64. package/lib/assets/.claude/scripts/ja-space-exclusions.json +18 -0
  65. package/lib/assets/.claude/scripts/ja-space-format.sh +45 -0
  66. package/lib/assets/.claude/scripts/preserve-file-permissions.sh +83 -0
  67. package/lib/assets/.claude/scripts/statusline.sh +153 -0
  68. package/lib/assets/.claude/settings.json +164 -0
  69. package/lib/assets/.claude/settings.local.json +14 -0
  70. package/lib/assets/.github/workflows/mkdocs.yml +32 -0
  71. package/lib/assets/CLAUDE.md +319 -0
  72. package/lib/assets/Dockerfile +77 -0
  73. package/lib/assets/README.md +51 -0
  74. package/lib/assets/app/.gitkeep +0 -0
  75. package/lib/assets/docker-compose.yml +22 -0
  76. package/lib/assets/docs/Dockerfile +19 -0
  77. package/lib/assets/docs/adr/.gitkeep +0 -0
  78. package/lib/assets/docs/assets/css/extra.css +30 -0
  79. package/lib/assets/docs/assets/js/extra.js +45 -0
  80. package/lib/assets/docs/design/.gitkeep +0 -0
  81. package/lib/assets/docs/development/.gitkeep +0 -0
  82. package/lib/assets/docs/index.md +13 -0
  83. package/lib/assets/docs/operation/.gitkeep +0 -0
  84. package/lib/assets/docs/reference/.gitkeep +0 -0
  85. 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
  86. 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
  87. 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
  88. 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
  89. package/lib/assets/docs/reference//351/226/213/347/231/272/343/202/254/343/202/244/343/203/211.md +556 -0
  90. package/lib/assets/docs/requirements/.gitkeep +0 -0
  91. package/lib/assets/docs/template/.gitkeep +0 -0
  92. package/lib/assets/docs/template/ADR.md +30 -0
  93. package/lib/assets/docs/template/README.md +50 -0
  94. 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
  95. 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
  96. 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
  97. package/lib/assets/docs/template//350/246/201/344/273/266/345/256/232/347/276/251.md +646 -0
  98. package/lib/assets/docs/template//350/250/255/350/250/210.md +164 -0
  99. package/lib/assets/gulpfile.js +18 -0
  100. package/lib/assets/mkdocs.yml +59 -0
  101. package/lib/assets/package-lock.json +3960 -0
  102. package/lib/assets/package.json +31 -0
  103. package/lib/assets/scripts/journal.js +170 -0
  104. package/lib/assets/scripts/mkdocs.js +59 -0
  105. package/lib/gulpfile.js +37 -0
  106. package/main.js +0 -0
  107. 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/