@k2works/claude-code-booster 3.4.1 → 3.6.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 (712) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +42 -42
  3. package/bin/claude-code-booster +90 -90
  4. package/lib/assets/.claude/README.md +239 -239
  5. package/lib/assets/.claude/scripts/generate-inception-deck.mjs +911 -911
  6. package/lib/assets/.claude/settings.json +11 -11
  7. package/lib/assets/.claude/skills/ai-agent-guidelines/SKILL.md +111 -111
  8. package/lib/assets/.claude/skills/analyzing-architecture/SKILL.md +83 -83
  9. package/lib/assets/.claude/skills/analyzing-business/SKILL.md +95 -95
  10. package/lib/assets/.claude/skills/analyzing-data-model/SKILL.md +77 -77
  11. package/lib/assets/.claude/skills/analyzing-domain-model/SKILL.md +117 -88
  12. package/lib/assets/.claude/skills/analyzing-inception-deck/SKILL.md +84 -84
  13. package/lib/assets/.claude/skills/analyzing-non-functional/SKILL.md +95 -95
  14. package/lib/assets/.claude/skills/analyzing-operation/SKILL.md +95 -95
  15. package/lib/assets/.claude/skills/analyzing-requirements/SKILL.md +91 -91
  16. package/lib/assets/.claude/skills/analyzing-tech-stack/SKILL.md +101 -101
  17. package/lib/assets/.claude/skills/analyzing-test-strategy/SKILL.md +89 -89
  18. package/lib/assets/.claude/skills/analyzing-ui-design/SKILL.md +80 -80
  19. package/lib/assets/.claude/skills/analyzing-usecases/SKILL.md +72 -72
  20. package/lib/assets/.claude/skills/creating-adr/SKILL.md +113 -113
  21. package/lib/assets/.claude/skills/developing-backend/SKILL.md +100 -100
  22. package/lib/assets/.claude/skills/developing-frontend/SKILL.md +93 -93
  23. package/lib/assets/.claude/skills/developing-release/SKILL.md +120 -120
  24. package/lib/assets/.claude/skills/generating-slides/SKILL.md +94 -94
  25. package/lib/assets/.claude/skills/git-commit/SKILL.md +81 -81
  26. package/lib/assets/.claude/skills/killing-processes/SKILL.md +44 -44
  27. package/lib/assets/.claude/skills/operating-backup/SKILL.md +59 -59
  28. package/lib/assets/.claude/skills/operating-cicd/SKILL.md +54 -54
  29. package/lib/assets/.claude/skills/operating-deploy/SKILL.md +67 -67
  30. package/lib/assets/.claude/skills/operating-docs/SKILL.md +219 -219
  31. package/lib/assets/.claude/skills/operating-provision/SKILL.md +77 -77
  32. package/lib/assets/.claude/skills/operating-setup/SKILL.md +63 -63
  33. package/lib/assets/.claude/skills/orchestrating-analysis/SKILL.md +104 -104
  34. package/lib/assets/.claude/skills/orchestrating-development/SKILL.md +162 -161
  35. package/lib/assets/.claude/skills/orchestrating-operation/SKILL.md +158 -158
  36. package/lib/assets/.claude/skills/orchestrating-project/SKILL.md +144 -144
  37. package/lib/assets/.claude/skills/planning-releases/SKILL.md +119 -119
  38. package/lib/assets/.claude/skills/syncing-github-project/SKILL.md +151 -151
  39. package/lib/assets/.claude/skills/tracking-progress/SKILL.md +91 -91
  40. package/lib/assets/.claude/skills/validating-iteration-plan/SKILL.md +29 -1
  41. package/lib/assets/.devcontainer/devcontainer.json +34 -34
  42. package/lib/assets/.env.example +17 -17
  43. package/lib/assets/.gitattributes +4 -4
  44. package/lib/assets/.github/workflows/docker-publish.yml +77 -77
  45. package/lib/assets/.github/workflows/mkdocs.yml +39 -39
  46. package/lib/assets/AGENTS.md +94 -94
  47. package/lib/assets/CLAUDE.md +183 -183
  48. package/lib/assets/README.md +254 -254
  49. package/lib/assets/docker-compose.yml +33 -33
  50. package/lib/assets/docs/adr/index.md +10 -10
  51. package/lib/assets/docs/article/functional-desgin-ppp/all/01-immutability-and-data-transformation.md +475 -475
  52. package/lib/assets/docs/article/functional-desgin-ppp/all/02-function-composition.md +519 -519
  53. package/lib/assets/docs/article/functional-desgin-ppp/all/03-polymorphism.md +537 -537
  54. package/lib/assets/docs/article/functional-desgin-ppp/all/04-data-validation.md +300 -300
  55. package/lib/assets/docs/article/functional-desgin-ppp/all/05-property-based-testing.md +320 -320
  56. package/lib/assets/docs/article/functional-desgin-ppp/all/06-tdd-and-functional.md +498 -498
  57. package/lib/assets/docs/article/functional-desgin-ppp/all/07-composite-pattern.md +298 -298
  58. package/lib/assets/docs/article/functional-desgin-ppp/all/08-decorator-pattern.md +291 -291
  59. package/lib/assets/docs/article/functional-desgin-ppp/all/09-adapter-pattern.md +336 -336
  60. package/lib/assets/docs/article/functional-desgin-ppp/all/10-strategy-pattern.md +303 -303
  61. package/lib/assets/docs/article/functional-desgin-ppp/all/11-command-pattern.md +286 -286
  62. package/lib/assets/docs/article/functional-desgin-ppp/all/12-visitor-pattern.md +322 -322
  63. package/lib/assets/docs/article/functional-desgin-ppp/all/13-abstract-factory-pattern.md +319 -319
  64. package/lib/assets/docs/article/functional-desgin-ppp/all/14-abstract-server-pattern.md +365 -365
  65. package/lib/assets/docs/article/functional-desgin-ppp/all/15-gossiping-bus-drivers.md +156 -156
  66. package/lib/assets/docs/article/functional-desgin-ppp/all/16-payroll-system.md +178 -178
  67. package/lib/assets/docs/article/functional-desgin-ppp/all/17-video-rental-system.md +312 -312
  68. package/lib/assets/docs/article/functional-desgin-ppp/all/18-concurrency-system.md +287 -287
  69. package/lib/assets/docs/article/functional-desgin-ppp/all/19-wa-tor-simulation.md +286 -286
  70. package/lib/assets/docs/article/functional-desgin-ppp/all/20-pattern-interactions.md +274 -274
  71. package/lib/assets/docs/article/functional-desgin-ppp/all/21-best-practices.md +294 -294
  72. package/lib/assets/docs/article/functional-desgin-ppp/all/22-oo-to-fp-migration.md +337 -337
  73. package/lib/assets/docs/article/functional-desgin-ppp/all/index.md +388 -388
  74. package/lib/assets/docs/article/functional-desgin-ppp/clojure/01-immutability-and-data-transformation.md +273 -273
  75. package/lib/assets/docs/article/functional-desgin-ppp/clojure/02-function-composition.md +380 -380
  76. package/lib/assets/docs/article/functional-desgin-ppp/clojure/03-polymorphism.md +384 -384
  77. package/lib/assets/docs/article/functional-desgin-ppp/clojure/04-clojure-spec.md +350 -350
  78. package/lib/assets/docs/article/functional-desgin-ppp/clojure/05-property-based-testing.md +352 -352
  79. package/lib/assets/docs/article/functional-desgin-ppp/clojure/06-tdd-in-functional.md +383 -383
  80. package/lib/assets/docs/article/functional-desgin-ppp/clojure/07-composite-pattern.md +529 -529
  81. package/lib/assets/docs/article/functional-desgin-ppp/clojure/08-decorator-pattern.md +395 -395
  82. package/lib/assets/docs/article/functional-desgin-ppp/clojure/09-adapter-pattern.md +399 -399
  83. package/lib/assets/docs/article/functional-desgin-ppp/clojure/10-strategy-pattern.md +485 -485
  84. package/lib/assets/docs/article/functional-desgin-ppp/clojure/11-command-pattern.md +566 -566
  85. package/lib/assets/docs/article/functional-desgin-ppp/clojure/12-visitor-pattern.md +567 -567
  86. package/lib/assets/docs/article/functional-desgin-ppp/clojure/13-abstract-factory-pattern.md +475 -475
  87. package/lib/assets/docs/article/functional-desgin-ppp/clojure/14-abstract-server-pattern.md +462 -462
  88. package/lib/assets/docs/article/functional-desgin-ppp/clojure/15-gossiping-bus-drivers.md +325 -325
  89. package/lib/assets/docs/article/functional-desgin-ppp/clojure/16-payroll-system.md +401 -401
  90. package/lib/assets/docs/article/functional-desgin-ppp/clojure/17-video-rental-system.md +450 -450
  91. package/lib/assets/docs/article/functional-desgin-ppp/clojure/18-concurrency-system.md +475 -475
  92. package/lib/assets/docs/article/functional-desgin-ppp/clojure/19-wator-simulation.md +739 -739
  93. package/lib/assets/docs/article/functional-desgin-ppp/clojure/20-pattern-interactions.md +567 -567
  94. package/lib/assets/docs/article/functional-desgin-ppp/clojure/21-best-practices.md +518 -518
  95. package/lib/assets/docs/article/functional-desgin-ppp/clojure/22-oo-to-fp-migration.md +532 -532
  96. package/lib/assets/docs/article/functional-desgin-ppp/clojure/index.md +241 -241
  97. package/lib/assets/docs/article/functional-desgin-ppp/elixir/01-immutability-and-data-transformation.md +383 -383
  98. package/lib/assets/docs/article/functional-desgin-ppp/elixir/02-function-composition.md +374 -374
  99. package/lib/assets/docs/article/functional-desgin-ppp/elixir/03-polymorphism.md +375 -375
  100. package/lib/assets/docs/article/functional-desgin-ppp/elixir/04-data-validation.md +195 -195
  101. package/lib/assets/docs/article/functional-desgin-ppp/elixir/05-property-based-testing.md +268 -268
  102. package/lib/assets/docs/article/functional-desgin-ppp/elixir/06-tdd-and-fp.md +294 -294
  103. package/lib/assets/docs/article/functional-desgin-ppp/elixir/07-effects-and-pure-functions.md +164 -164
  104. package/lib/assets/docs/article/functional-desgin-ppp/elixir/08-error-handling-strategies.md +168 -168
  105. package/lib/assets/docs/article/functional-desgin-ppp/elixir/09-io-and-external-systems.md +254 -254
  106. package/lib/assets/docs/article/functional-desgin-ppp/elixir/10-concurrency-patterns.md +269 -269
  107. package/lib/assets/docs/article/functional-desgin-ppp/elixir/11-command-pattern.md +148 -148
  108. package/lib/assets/docs/article/functional-desgin-ppp/elixir/12-visitor-pattern.md +176 -176
  109. package/lib/assets/docs/article/functional-desgin-ppp/elixir/13-abstract-factory-pattern.md +604 -604
  110. package/lib/assets/docs/article/functional-desgin-ppp/elixir/14-abstract-server-pattern.md +729 -729
  111. package/lib/assets/docs/article/functional-desgin-ppp/elixir/15-gossiping-bus-drivers.md +291 -291
  112. package/lib/assets/docs/article/functional-desgin-ppp/elixir/16-payroll-system.md +420 -420
  113. package/lib/assets/docs/article/functional-desgin-ppp/elixir/17-video-rental-system.md +319 -319
  114. package/lib/assets/docs/article/functional-desgin-ppp/elixir/18-concurrency-system.md +466 -466
  115. package/lib/assets/docs/article/functional-desgin-ppp/elixir/19-wator-simulation.md +523 -523
  116. package/lib/assets/docs/article/functional-desgin-ppp/elixir/20-pattern-interactions.md +287 -287
  117. package/lib/assets/docs/article/functional-desgin-ppp/elixir/21-best-practices.md +340 -340
  118. package/lib/assets/docs/article/functional-desgin-ppp/elixir/22-oo-to-fp-migration.md +395 -395
  119. package/lib/assets/docs/article/functional-desgin-ppp/elixir/index.md +248 -248
  120. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/01-immutability-and-data-transformation.md +384 -384
  121. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/02-function-composition.md +452 -452
  122. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/03-polymorphism.md +495 -495
  123. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/04-data-validation.md +416 -416
  124. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/05-property-based-testing.md +382 -382
  125. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/06-tdd-functional.md +687 -687
  126. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/07-composite-pattern.md +442 -442
  127. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/08-decorator-pattern.md +479 -479
  128. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/09-adapter-pattern.md +479 -479
  129. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/10-strategy-pattern.md +427 -427
  130. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/11-command-pattern.md +428 -428
  131. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/12-visitor-pattern.md +339 -339
  132. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/13-abstract-factory-pattern.md +309 -309
  133. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/14-abstract-server-pattern.md +596 -596
  134. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/15-gossiping-bus-drivers.md +355 -355
  135. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/16-payroll-system.md +350 -350
  136. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/17-video-rental-system.md +414 -414
  137. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/18-concurrency-system.md +367 -367
  138. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/19-wator-simulation.md +403 -403
  139. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/20-pattern-interactions.md +291 -291
  140. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/21-best-practices.md +324 -324
  141. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/22-oo-to-fp-migration.md +332 -332
  142. package/lib/assets/docs/article/functional-desgin-ppp/fsharp/index.md +274 -274
  143. package/lib/assets/docs/article/functional-desgin-ppp/haskell/01-immutability-and-data-transformation.md +298 -298
  144. package/lib/assets/docs/article/functional-desgin-ppp/haskell/02-function-composition.md +304 -304
  145. package/lib/assets/docs/article/functional-desgin-ppp/haskell/03-polymorphism.md +362 -362
  146. package/lib/assets/docs/article/functional-desgin-ppp/haskell/04-data-validation.md +257 -257
  147. package/lib/assets/docs/article/functional-desgin-ppp/haskell/05-property-based-testing.md +254 -254
  148. package/lib/assets/docs/article/functional-desgin-ppp/haskell/06-tdd-functional.md +283 -283
  149. package/lib/assets/docs/article/functional-desgin-ppp/haskell/07-composite-pattern.md +395 -395
  150. package/lib/assets/docs/article/functional-desgin-ppp/haskell/08-decorator-pattern.md +319 -319
  151. package/lib/assets/docs/article/functional-desgin-ppp/haskell/09-adapter-pattern.md +382 -382
  152. package/lib/assets/docs/article/functional-desgin-ppp/haskell/10-strategy-pattern.md +287 -287
  153. package/lib/assets/docs/article/functional-desgin-ppp/haskell/11-command-pattern.md +303 -303
  154. package/lib/assets/docs/article/functional-desgin-ppp/haskell/12-visitor-pattern.md +326 -326
  155. package/lib/assets/docs/article/functional-desgin-ppp/haskell/13-abstract-factory-pattern.md +332 -332
  156. package/lib/assets/docs/article/functional-desgin-ppp/haskell/14-abstract-server-pattern.md +379 -379
  157. package/lib/assets/docs/article/functional-desgin-ppp/haskell/15-gossiping-bus-drivers.md +177 -177
  158. package/lib/assets/docs/article/functional-desgin-ppp/haskell/16-payroll-system.md +219 -219
  159. package/lib/assets/docs/article/functional-desgin-ppp/haskell/17-video-rental-system.md +244 -244
  160. package/lib/assets/docs/article/functional-desgin-ppp/haskell/18-concurrency-system.md +363 -363
  161. package/lib/assets/docs/article/functional-desgin-ppp/haskell/19-wator-simulation.md +438 -438
  162. package/lib/assets/docs/article/functional-desgin-ppp/haskell/20-pattern-interactions.md +325 -325
  163. package/lib/assets/docs/article/functional-desgin-ppp/haskell/21-best-practices.md +403 -403
  164. package/lib/assets/docs/article/functional-desgin-ppp/haskell/22-oo-to-fp-migration.md +469 -469
  165. package/lib/assets/docs/article/functional-desgin-ppp/haskell/index.md +174 -174
  166. package/lib/assets/docs/article/functional-desgin-ppp/index.md +90 -90
  167. package/lib/assets/docs/article/functional-desgin-ppp/rust/01-immutability-and-data-transformation.md +450 -450
  168. package/lib/assets/docs/article/functional-desgin-ppp/rust/02-function-composition.md +463 -463
  169. package/lib/assets/docs/article/functional-desgin-ppp/rust/03-polymorphism.md +425 -425
  170. package/lib/assets/docs/article/functional-desgin-ppp/rust/04-data-validation.md +273 -273
  171. package/lib/assets/docs/article/functional-desgin-ppp/rust/05-property-based-testing.md +247 -247
  172. package/lib/assets/docs/article/functional-desgin-ppp/rust/06-tdd-and-functional.md +841 -841
  173. package/lib/assets/docs/article/functional-desgin-ppp/rust/07-composite-pattern.md +384 -384
  174. package/lib/assets/docs/article/functional-desgin-ppp/rust/08-decorator-pattern.md +383 -383
  175. package/lib/assets/docs/article/functional-desgin-ppp/rust/09-adapter-pattern.md +339 -339
  176. package/lib/assets/docs/article/functional-desgin-ppp/rust/10-strategy-pattern.md +331 -331
  177. package/lib/assets/docs/article/functional-desgin-ppp/rust/11-command-pattern.md +356 -356
  178. package/lib/assets/docs/article/functional-desgin-ppp/rust/12-visitor-pattern.md +379 -379
  179. package/lib/assets/docs/article/functional-desgin-ppp/rust/13-abstract-factory-pattern.md +361 -361
  180. package/lib/assets/docs/article/functional-desgin-ppp/rust/14-abstract-server-pattern.md +392 -392
  181. package/lib/assets/docs/article/functional-desgin-ppp/rust/15-gossiping-bus-drivers.md +300 -300
  182. package/lib/assets/docs/article/functional-desgin-ppp/rust/16-payroll-system.md +297 -297
  183. package/lib/assets/docs/article/functional-desgin-ppp/rust/17-video-rental-system.md +304 -304
  184. package/lib/assets/docs/article/functional-desgin-ppp/rust/18-concurrency-system.md +315 -315
  185. package/lib/assets/docs/article/functional-desgin-ppp/rust/19-wator-simulation.md +311 -311
  186. package/lib/assets/docs/article/functional-desgin-ppp/rust/20-pattern-interactions.md +304 -304
  187. package/lib/assets/docs/article/functional-desgin-ppp/rust/21-best-practices.md +336 -336
  188. package/lib/assets/docs/article/functional-desgin-ppp/rust/22-oo-to-fp-migration.md +349 -349
  189. package/lib/assets/docs/article/functional-desgin-ppp/rust/index.md +243 -243
  190. package/lib/assets/docs/article/functional-desgin-ppp/scala/01-immutability-and-data-transformation.md +328 -328
  191. package/lib/assets/docs/article/functional-desgin-ppp/scala/02-function-composition.md +348 -348
  192. package/lib/assets/docs/article/functional-desgin-ppp/scala/03-polymorphism.md +357 -357
  193. package/lib/assets/docs/article/functional-desgin-ppp/scala/04-data-validation.md +364 -364
  194. package/lib/assets/docs/article/functional-desgin-ppp/scala/05-property-based-testing.md +515 -515
  195. package/lib/assets/docs/article/functional-desgin-ppp/scala/06-tdd-functional.md +557 -557
  196. package/lib/assets/docs/article/functional-desgin-ppp/scala/07-composite-pattern.md +363 -363
  197. package/lib/assets/docs/article/functional-desgin-ppp/scala/08-decorator-pattern.md +327 -327
  198. package/lib/assets/docs/article/functional-desgin-ppp/scala/09-adapter-pattern.md +517 -517
  199. package/lib/assets/docs/article/functional-desgin-ppp/scala/10-strategy-pattern.md +441 -441
  200. package/lib/assets/docs/article/functional-desgin-ppp/scala/11-command-pattern.md +407 -407
  201. package/lib/assets/docs/article/functional-desgin-ppp/scala/12-visitor-pattern.md +379 -379
  202. package/lib/assets/docs/article/functional-desgin-ppp/scala/13-abstract-factory-pattern.md +398 -398
  203. package/lib/assets/docs/article/functional-desgin-ppp/scala/14-abstract-server-pattern.md +476 -476
  204. package/lib/assets/docs/article/functional-desgin-ppp/scala/15-gossiping-bus-drivers.md +391 -391
  205. package/lib/assets/docs/article/functional-desgin-ppp/scala/16-payroll-system.md +342 -342
  206. package/lib/assets/docs/article/functional-desgin-ppp/scala/17-video-rental-system.md +324 -324
  207. package/lib/assets/docs/article/functional-desgin-ppp/scala/18-concurrency-system.md +730 -730
  208. package/lib/assets/docs/article/functional-desgin-ppp/scala/19-wator-simulation.md +624 -624
  209. package/lib/assets/docs/article/functional-desgin-ppp/scala/20-pattern-interactions.md +512 -512
  210. package/lib/assets/docs/article/functional-desgin-ppp/scala/21-best-practices.md +433 -433
  211. package/lib/assets/docs/article/functional-desgin-ppp/scala/22-oo-to-fp-migration.md +688 -688
  212. package/lib/assets/docs/article/functional-desgin-ppp/scala/index.md +243 -243
  213. package/lib/assets/docs/article/getting-start-tdd/clojure/01-todo-list-and-first-test.md +166 -166
  214. package/lib/assets/docs/article/getting-start-tdd/clojure/02-fake-it-and-triangulation.md +162 -162
  215. package/lib/assets/docs/article/getting-start-tdd/clojure/03-obvious-implementation-and-refactoring.md +135 -135
  216. package/lib/assets/docs/article/getting-start-tdd/clojure/04-version-control-and-conventional-commits.md +88 -88
  217. package/lib/assets/docs/article/getting-start-tdd/clojure/05-package-management-and-static-analysis.md +299 -299
  218. package/lib/assets/docs/article/getting-start-tdd/clojure/06-task-runner-and-ci-cd.md +241 -241
  219. package/lib/assets/docs/article/getting-start-tdd/clojure/07-protocols-and-records.md +131 -131
  220. package/lib/assets/docs/article/getting-start-tdd/clojure/08-multimethods-and-design-patterns.md +130 -130
  221. package/lib/assets/docs/article/getting-start-tdd/clojure/09-namespaces-and-module-design.md +127 -127
  222. package/lib/assets/docs/article/getting-start-tdd/clojure/10-higher-order-functions-and-composition.md +114 -114
  223. package/lib/assets/docs/article/getting-start-tdd/clojure/11-persistent-data-and-pipeline.md +138 -138
  224. package/lib/assets/docs/article/getting-start-tdd/clojure/12-error-handling-and-spec.md +161 -161
  225. package/lib/assets/docs/article/getting-start-tdd/clojure/index.md +65 -65
  226. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter01.md +232 -232
  227. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter02.md +244 -244
  228. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter03.md +202 -202
  229. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter04.md +92 -92
  230. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter05.md +256 -256
  231. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter06.md +195 -195
  232. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter07.md +214 -214
  233. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter08.md +249 -249
  234. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter09.md +174 -174
  235. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter10.md +166 -166
  236. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter11.md +192 -192
  237. package/lib/assets/docs/article/getting-start-tdd/csharp/chapter12.md +211 -211
  238. package/lib/assets/docs/article/getting-start-tdd/csharp/index.md +83 -83
  239. package/lib/assets/docs/article/getting-start-tdd/elixir/01-todo-list-and-first-test.md +87 -87
  240. package/lib/assets/docs/article/getting-start-tdd/elixir/02-fake-it-and-triangulation.md +95 -95
  241. package/lib/assets/docs/article/getting-start-tdd/elixir/03-obvious-implementation-and-refactoring.md +109 -109
  242. package/lib/assets/docs/article/getting-start-tdd/elixir/04-version-control-and-conventional-commits.md +96 -96
  243. package/lib/assets/docs/article/getting-start-tdd/elixir/05-package-management-and-static-analysis.md +88 -88
  244. package/lib/assets/docs/article/getting-start-tdd/elixir/06-task-runner-and-ci-cd.md +71 -71
  245. package/lib/assets/docs/article/getting-start-tdd/elixir/07-structs-and-protocols.md +110 -110
  246. package/lib/assets/docs/article/getting-start-tdd/elixir/08-pattern-matching-and-guards.md +108 -108
  247. package/lib/assets/docs/article/getting-start-tdd/elixir/09-module-design-and-behaviours.md +104 -104
  248. package/lib/assets/docs/article/getting-start-tdd/elixir/10-higher-order-functions-and-pipeline.md +178 -178
  249. package/lib/assets/docs/article/getting-start-tdd/elixir/11-stream-and-lazy-evaluation.md +142 -142
  250. package/lib/assets/docs/article/getting-start-tdd/elixir/12-error-handling-and-with.md +145 -145
  251. package/lib/assets/docs/article/getting-start-tdd/elixir/index.md +35 -35
  252. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter01.md +202 -202
  253. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter02.md +246 -246
  254. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter03.md +218 -218
  255. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter04.md +179 -179
  256. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter05.md +267 -267
  257. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter06.md +190 -190
  258. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter07.md +161 -161
  259. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter08.md +175 -175
  260. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter09.md +222 -222
  261. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter10.md +189 -189
  262. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter11.md +212 -212
  263. package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter12.md +215 -215
  264. package/lib/assets/docs/article/getting-start-tdd/fsharp/index.md +71 -71
  265. package/lib/assets/docs/article/getting-start-tdd/go/01-todo-list-and-first-test.md +213 -213
  266. package/lib/assets/docs/article/getting-start-tdd/go/02-fake-it-and-triangulation.md +302 -302
  267. package/lib/assets/docs/article/getting-start-tdd/go/03-obvious-implementation-and-refactoring.md +339 -339
  268. package/lib/assets/docs/article/getting-start-tdd/go/04-version-control-and-conventional-commits.md +112 -112
  269. package/lib/assets/docs/article/getting-start-tdd/go/05-package-management-and-static-analysis.md +272 -272
  270. package/lib/assets/docs/article/getting-start-tdd/go/06-task-runner-and-ci-cd.md +233 -233
  271. package/lib/assets/docs/article/getting-start-tdd/go/07-encapsulation-and-polymorphism.md +394 -394
  272. package/lib/assets/docs/article/getting-start-tdd/go/08-design-patterns.md +422 -422
  273. package/lib/assets/docs/article/getting-start-tdd/go/09-solid-principles-and-module-design.md +400 -400
  274. package/lib/assets/docs/article/getting-start-tdd/go/10-higher-order-functions-and-composition.md +226 -226
  275. package/lib/assets/docs/article/getting-start-tdd/go/11-immutable-data-and-pipeline.md +296 -296
  276. package/lib/assets/docs/article/getting-start-tdd/go/12-error-handling-and-type-safety.md +411 -411
  277. package/lib/assets/docs/article/getting-start-tdd/go/index.md +83 -83
  278. package/lib/assets/docs/article/getting-start-tdd/haskell/01-todo-list-and-first-test.md +279 -279
  279. package/lib/assets/docs/article/getting-start-tdd/haskell/02-fake-it-and-triangulation.md +337 -337
  280. package/lib/assets/docs/article/getting-start-tdd/haskell/03-obvious-implementation-and-refactoring.md +257 -257
  281. package/lib/assets/docs/article/getting-start-tdd/haskell/04-version-control-and-conventional-commits.md +182 -182
  282. package/lib/assets/docs/article/getting-start-tdd/haskell/05-package-management-and-static-analysis.md +313 -313
  283. package/lib/assets/docs/article/getting-start-tdd/haskell/06-task-runner-and-ci-cd.md +309 -309
  284. package/lib/assets/docs/article/getting-start-tdd/haskell/07-algebraic-data-types-and-type-classes.md +412 -412
  285. package/lib/assets/docs/article/getting-start-tdd/haskell/08-pattern-matching-and-guards.md +390 -390
  286. package/lib/assets/docs/article/getting-start-tdd/haskell/09-module-design-and-smart-constructors.md +461 -461
  287. package/lib/assets/docs/article/getting-start-tdd/haskell/10-higher-order-functions-and-currying.md +434 -434
  288. package/lib/assets/docs/article/getting-start-tdd/haskell/11-function-composition-and-point-free.md +392 -392
  289. package/lib/assets/docs/article/getting-start-tdd/haskell/12-monad-and-error-handling.md +631 -631
  290. package/lib/assets/docs/article/getting-start-tdd/haskell/index.md +49 -49
  291. package/lib/assets/docs/article/getting-start-tdd/index.md +93 -93
  292. package/lib/assets/docs/article/getting-start-tdd/integration/01-language-overview.md +375 -375
  293. package/lib/assets/docs/article/getting-start-tdd/integration/02-test-framework-comparison.md +349 -349
  294. package/lib/assets/docs/article/getting-start-tdd/integration/03-tdd-pattern-comparison.md +445 -445
  295. package/lib/assets/docs/article/getting-start-tdd/integration/04-type-system-comparison.md +409 -409
  296. package/lib/assets/docs/article/getting-start-tdd/integration/05-dev-environment-comparison.md +330 -330
  297. package/lib/assets/docs/article/getting-start-tdd/integration/06-learning-roadmap.md +290 -290
  298. package/lib/assets/docs/article/getting-start-tdd/integration/index.md +69 -69
  299. package/lib/assets/docs/article/getting-start-tdd/java/01-todo-list-and-first-test.md +234 -234
  300. package/lib/assets/docs/article/getting-start-tdd/java/02-fake-it-and-triangulation.md +261 -261
  301. package/lib/assets/docs/article/getting-start-tdd/java/03-obvious-implementation-and-refactoring.md +185 -185
  302. package/lib/assets/docs/article/getting-start-tdd/java/04-version-control-and-conventional-commits.md +115 -115
  303. package/lib/assets/docs/article/getting-start-tdd/java/05-package-management-and-static-analysis.md +382 -382
  304. package/lib/assets/docs/article/getting-start-tdd/java/06-task-runner-and-ci-cd.md +272 -272
  305. package/lib/assets/docs/article/getting-start-tdd/java/07-encapsulation-and-polymorphism.md +626 -626
  306. package/lib/assets/docs/article/getting-start-tdd/java/08-design-patterns.md +393 -393
  307. package/lib/assets/docs/article/getting-start-tdd/java/09-solid-principles-and-module-design.md +310 -310
  308. package/lib/assets/docs/article/getting-start-tdd/java/10-higher-order-functions-and-composition.md +188 -188
  309. package/lib/assets/docs/article/getting-start-tdd/java/11-immutable-data-and-pipeline.md +167 -167
  310. package/lib/assets/docs/article/getting-start-tdd/java/12-error-handling-and-type-safety.md +205 -205
  311. package/lib/assets/docs/article/getting-start-tdd/java/index.md +61 -61
  312. package/lib/assets/docs/article/getting-start-tdd/node/01-todo-list-and-first-test.md +244 -244
  313. package/lib/assets/docs/article/getting-start-tdd/node/02-fake-it-and-triangulation.md +262 -262
  314. package/lib/assets/docs/article/getting-start-tdd/node/03-obvious-implementation-and-refactoring.md +169 -169
  315. package/lib/assets/docs/article/getting-start-tdd/node/04-version-control-and-conventional-commits.md +112 -112
  316. package/lib/assets/docs/article/getting-start-tdd/node/05-package-management-and-static-analysis.md +314 -314
  317. package/lib/assets/docs/article/getting-start-tdd/node/06-task-runner-and-ci-cd.md +235 -235
  318. package/lib/assets/docs/article/getting-start-tdd/node/07-encapsulation-and-polymorphism.md +327 -327
  319. package/lib/assets/docs/article/getting-start-tdd/node/08-design-patterns.md +322 -322
  320. package/lib/assets/docs/article/getting-start-tdd/node/09-solid-principles-and-module-design.md +285 -285
  321. package/lib/assets/docs/article/getting-start-tdd/node/10-higher-order-functions-and-composition.md +199 -199
  322. package/lib/assets/docs/article/getting-start-tdd/node/11-immutable-data-and-pipeline.md +207 -207
  323. package/lib/assets/docs/article/getting-start-tdd/node/12-error-handling-and-type-safety.md +295 -295
  324. package/lib/assets/docs/article/getting-start-tdd/node/index.md +56 -56
  325. package/lib/assets/docs/article/getting-start-tdd/php/01-todo-list-and-first-test.md +259 -259
  326. package/lib/assets/docs/article/getting-start-tdd/php/02-fake-it-and-triangulation.md +200 -200
  327. package/lib/assets/docs/article/getting-start-tdd/php/03-obvious-implementation-and-refactoring.md +248 -248
  328. package/lib/assets/docs/article/getting-start-tdd/php/04-version-control-and-conventional-commits.md +141 -141
  329. package/lib/assets/docs/article/getting-start-tdd/php/05-package-management-and-static-analysis.md +410 -410
  330. package/lib/assets/docs/article/getting-start-tdd/php/06-task-runner-and-ci-cd.md +321 -321
  331. package/lib/assets/docs/article/getting-start-tdd/php/07-encapsulation-and-polymorphism.md +372 -372
  332. package/lib/assets/docs/article/getting-start-tdd/php/08-design-patterns.md +453 -453
  333. package/lib/assets/docs/article/getting-start-tdd/php/09-solid-principles-and-module-design.md +460 -460
  334. package/lib/assets/docs/article/getting-start-tdd/php/10-higher-order-functions-and-composition.md +182 -182
  335. package/lib/assets/docs/article/getting-start-tdd/php/11-immutable-data-and-pipeline.md +266 -266
  336. package/lib/assets/docs/article/getting-start-tdd/php/12-error-handling-and-type-safety.md +308 -308
  337. package/lib/assets/docs/article/getting-start-tdd/php/index.md +84 -84
  338. package/lib/assets/docs/article/getting-start-tdd/python/01-todo-list-and-first-test.md +201 -201
  339. package/lib/assets/docs/article/getting-start-tdd/python/02-fake-it-and-triangulation.md +247 -247
  340. package/lib/assets/docs/article/getting-start-tdd/python/03-obvious-implementation-and-refactoring.md +199 -199
  341. package/lib/assets/docs/article/getting-start-tdd/python/04-version-control-and-conventional-commits.md +87 -87
  342. package/lib/assets/docs/article/getting-start-tdd/python/05-package-management-and-static-analysis.md +274 -274
  343. package/lib/assets/docs/article/getting-start-tdd/python/06-task-runner-and-ci-cd.md +190 -190
  344. package/lib/assets/docs/article/getting-start-tdd/python/07-encapsulation-and-polymorphism.md +208 -208
  345. package/lib/assets/docs/article/getting-start-tdd/python/08-design-patterns.md +172 -172
  346. package/lib/assets/docs/article/getting-start-tdd/python/09-solid-principles-and-module-design.md +130 -130
  347. package/lib/assets/docs/article/getting-start-tdd/python/10-higher-order-functions-and-composition.md +122 -122
  348. package/lib/assets/docs/article/getting-start-tdd/python/11-immutable-data-and-pipeline.md +116 -116
  349. package/lib/assets/docs/article/getting-start-tdd/python/12-error-handling-and-type-safety.md +126 -126
  350. package/lib/assets/docs/article/getting-start-tdd/python/index.md +55 -55
  351. package/lib/assets/docs/article/getting-start-tdd/ruby/01-todo-list-and-first-test.md +231 -231
  352. package/lib/assets/docs/article/getting-start-tdd/ruby/02-fake-it-and-triangulation.md +238 -238
  353. package/lib/assets/docs/article/getting-start-tdd/ruby/03-obvious-implementation-and-refactoring.md +228 -228
  354. package/lib/assets/docs/article/getting-start-tdd/ruby/04-version-control-and-conventional-commits.md +112 -112
  355. package/lib/assets/docs/article/getting-start-tdd/ruby/05-package-management-and-static-analysis.md +287 -287
  356. package/lib/assets/docs/article/getting-start-tdd/ruby/06-task-runner-and-ci-cd.md +248 -248
  357. package/lib/assets/docs/article/getting-start-tdd/ruby/07-encapsulation-and-polymorphism.md +279 -279
  358. package/lib/assets/docs/article/getting-start-tdd/ruby/08-design-patterns.md +329 -329
  359. package/lib/assets/docs/article/getting-start-tdd/ruby/09-solid-principles-and-module-design.md +196 -196
  360. package/lib/assets/docs/article/getting-start-tdd/ruby/10-higher-order-functions-and-composition.md +175 -175
  361. package/lib/assets/docs/article/getting-start-tdd/ruby/11-immutable-data-and-pipeline.md +237 -237
  362. package/lib/assets/docs/article/getting-start-tdd/ruby/12-error-handling-and-type-safety.md +398 -398
  363. package/lib/assets/docs/article/getting-start-tdd/ruby/index.md +83 -83
  364. package/lib/assets/docs/article/getting-start-tdd/rust/01-todo-list-and-first-test.md +211 -211
  365. package/lib/assets/docs/article/getting-start-tdd/rust/02-fake-it-and-triangulation.md +264 -264
  366. package/lib/assets/docs/article/getting-start-tdd/rust/03-obvious-implementation-and-refactoring.md +233 -233
  367. package/lib/assets/docs/article/getting-start-tdd/rust/04-version-control-and-conventional-commits.md +92 -92
  368. package/lib/assets/docs/article/getting-start-tdd/rust/05-package-management-and-static-analysis.md +212 -212
  369. package/lib/assets/docs/article/getting-start-tdd/rust/06-task-runner-and-ci-cd.md +164 -164
  370. package/lib/assets/docs/article/getting-start-tdd/rust/07-encapsulation-and-polymorphism.md +142 -142
  371. package/lib/assets/docs/article/getting-start-tdd/rust/08-design-patterns.md +145 -145
  372. package/lib/assets/docs/article/getting-start-tdd/rust/09-solid-principles-and-module-design.md +110 -110
  373. package/lib/assets/docs/article/getting-start-tdd/rust/10-higher-order-functions-and-composition.md +94 -94
  374. package/lib/assets/docs/article/getting-start-tdd/rust/11-immutable-data-and-pipeline.md +105 -105
  375. package/lib/assets/docs/article/getting-start-tdd/rust/12-error-handling-and-type-safety.md +112 -112
  376. package/lib/assets/docs/article/getting-start-tdd/rust/index.md +83 -83
  377. package/lib/assets/docs/article/getting-start-tdd/scala/01-todo-list-and-first-test.md +111 -111
  378. package/lib/assets/docs/article/getting-start-tdd/scala/02-fake-it-and-triangulation.md +107 -107
  379. package/lib/assets/docs/article/getting-start-tdd/scala/03-obvious-implementation-and-refactoring.md +99 -99
  380. package/lib/assets/docs/article/getting-start-tdd/scala/04-version-control-and-conventional-commits.md +123 -123
  381. package/lib/assets/docs/article/getting-start-tdd/scala/05-package-management-and-static-analysis.md +196 -196
  382. package/lib/assets/docs/article/getting-start-tdd/scala/06-task-runner-and-ci-cd.md +186 -186
  383. package/lib/assets/docs/article/getting-start-tdd/scala/07-case-classes-and-traits.md +139 -139
  384. package/lib/assets/docs/article/getting-start-tdd/scala/08-pattern-matching-and-sealed-traits.md +106 -106
  385. package/lib/assets/docs/article/getting-start-tdd/scala/09-packages-and-module-design.md +75 -75
  386. package/lib/assets/docs/article/getting-start-tdd/scala/10-higher-order-functions-and-composition.md +104 -104
  387. package/lib/assets/docs/article/getting-start-tdd/scala/11-collections-and-lazy-evaluation.md +94 -94
  388. package/lib/assets/docs/article/getting-start-tdd/scala/12-error-handling-and-type-safety.md +92 -92
  389. package/lib/assets/docs/article/getting-start-tdd/scala/index.md +65 -65
  390. package/lib/assets/docs/article/grokking-concurrency/all/index.md +404 -404
  391. package/lib/assets/docs/article/grokking-concurrency/all/part-1-ch02-sequential.md +554 -554
  392. package/lib/assets/docs/article/grokking-concurrency/all/part-2-ch04-05-threads.md +469 -469
  393. package/lib/assets/docs/article/grokking-concurrency/all/part-3-ch06-multitasking.md +520 -520
  394. package/lib/assets/docs/article/grokking-concurrency/all/part-4-ch07-parallel-patterns.md +420 -420
  395. package/lib/assets/docs/article/grokking-concurrency/all/part-5-ch08-09-synchronization.md +510 -510
  396. package/lib/assets/docs/article/grokking-concurrency/all/part-6-ch10-11-nonblocking-io.md +435 -435
  397. package/lib/assets/docs/article/grokking-concurrency/all/part-7-ch12-async.md +465 -465
  398. package/lib/assets/docs/article/grokking-concurrency/all/part-8-ch13-mapreduce.md +377 -377
  399. package/lib/assets/docs/article/grokking-concurrency/clojure/index.md +116 -116
  400. package/lib/assets/docs/article/grokking-concurrency/clojure/part-1.md +108 -108
  401. package/lib/assets/docs/article/grokking-concurrency/clojure/part-2.md +101 -101
  402. package/lib/assets/docs/article/grokking-concurrency/clojure/part-3.md +122 -122
  403. package/lib/assets/docs/article/grokking-concurrency/clojure/part-4.md +123 -123
  404. package/lib/assets/docs/article/grokking-concurrency/clojure/part-5.md +118 -118
  405. package/lib/assets/docs/article/grokking-concurrency/clojure/part-6.md +89 -89
  406. package/lib/assets/docs/article/grokking-concurrency/clojure/part-7.md +100 -100
  407. package/lib/assets/docs/article/grokking-concurrency/clojure/part-8.md +120 -120
  408. package/lib/assets/docs/article/grokking-concurrency/csharp/index.md +101 -101
  409. package/lib/assets/docs/article/grokking-concurrency/csharp/part-1.md +97 -97
  410. package/lib/assets/docs/article/grokking-concurrency/csharp/part-2.md +123 -123
  411. package/lib/assets/docs/article/grokking-concurrency/csharp/part-3.md +101 -101
  412. package/lib/assets/docs/article/grokking-concurrency/csharp/part-4.md +112 -112
  413. package/lib/assets/docs/article/grokking-concurrency/csharp/part-5.md +99 -99
  414. package/lib/assets/docs/article/grokking-concurrency/csharp/part-6.md +61 -61
  415. package/lib/assets/docs/article/grokking-concurrency/csharp/part-7.md +84 -84
  416. package/lib/assets/docs/article/grokking-concurrency/csharp/part-8.md +92 -92
  417. package/lib/assets/docs/article/grokking-concurrency/fsharp/index.md +65 -65
  418. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-1.md +80 -80
  419. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-2.md +103 -103
  420. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-3.md +94 -94
  421. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-4.md +110 -110
  422. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-5.md +104 -104
  423. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-6.md +93 -93
  424. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-7.md +121 -121
  425. package/lib/assets/docs/article/grokking-concurrency/fsharp/part-8.md +107 -107
  426. package/lib/assets/docs/article/grokking-concurrency/haskell/index.md +248 -248
  427. package/lib/assets/docs/article/grokking-concurrency/haskell/part-1.md +96 -96
  428. package/lib/assets/docs/article/grokking-concurrency/haskell/part-2.md +96 -96
  429. package/lib/assets/docs/article/grokking-concurrency/haskell/part-3.md +91 -91
  430. package/lib/assets/docs/article/grokking-concurrency/haskell/part-4.md +106 -106
  431. package/lib/assets/docs/article/grokking-concurrency/haskell/part-5.md +99 -99
  432. package/lib/assets/docs/article/grokking-concurrency/haskell/part-6.md +95 -95
  433. package/lib/assets/docs/article/grokking-concurrency/haskell/part-7.md +111 -111
  434. package/lib/assets/docs/article/grokking-concurrency/haskell/part-8.md +118 -118
  435. package/lib/assets/docs/article/grokking-concurrency/index.md +66 -66
  436. package/lib/assets/docs/article/grokking-concurrency/java/index.md +102 -102
  437. package/lib/assets/docs/article/grokking-concurrency/java/part-1.md +308 -308
  438. package/lib/assets/docs/article/grokking-concurrency/java/part-2.md +334 -334
  439. package/lib/assets/docs/article/grokking-concurrency/java/part-3.md +221 -221
  440. package/lib/assets/docs/article/grokking-concurrency/java/part-4.md +213 -213
  441. package/lib/assets/docs/article/grokking-concurrency/java/part-5.md +112 -112
  442. package/lib/assets/docs/article/grokking-concurrency/java/part-6.md +69 -69
  443. package/lib/assets/docs/article/grokking-concurrency/java/part-7.md +101 -101
  444. package/lib/assets/docs/article/grokking-concurrency/java/part-8.md +101 -101
  445. package/lib/assets/docs/article/grokking-concurrency/python/index.md +313 -313
  446. package/lib/assets/docs/article/grokking-concurrency/python/part-1.md +239 -239
  447. package/lib/assets/docs/article/grokking-concurrency/python/part-2.md +418 -418
  448. package/lib/assets/docs/article/grokking-concurrency/python/part-3.md +227 -227
  449. package/lib/assets/docs/article/grokking-concurrency/python/part-4.md +299 -299
  450. package/lib/assets/docs/article/grokking-concurrency/python/part-5.md +315 -315
  451. package/lib/assets/docs/article/grokking-concurrency/python/part-6.md +297 -297
  452. package/lib/assets/docs/article/grokking-concurrency/python/part-7.md +314 -314
  453. package/lib/assets/docs/article/grokking-concurrency/python/part-8.md +360 -360
  454. package/lib/assets/docs/article/grokking-concurrency/rust/index.md +270 -270
  455. package/lib/assets/docs/article/grokking-concurrency/rust/part-1.md +108 -108
  456. package/lib/assets/docs/article/grokking-concurrency/rust/part-2.md +120 -120
  457. package/lib/assets/docs/article/grokking-concurrency/rust/part-3.md +126 -126
  458. package/lib/assets/docs/article/grokking-concurrency/rust/part-4.md +175 -175
  459. package/lib/assets/docs/article/grokking-concurrency/rust/part-5.md +158 -158
  460. package/lib/assets/docs/article/grokking-concurrency/rust/part-6.md +94 -94
  461. package/lib/assets/docs/article/grokking-concurrency/rust/part-7.md +133 -133
  462. package/lib/assets/docs/article/grokking-concurrency/rust/part-8.md +155 -155
  463. package/lib/assets/docs/article/grokking-concurrency/scala/index.md +69 -69
  464. package/lib/assets/docs/article/grokking-concurrency/scala/part-1.md +78 -78
  465. package/lib/assets/docs/article/grokking-concurrency/scala/part-2.md +112 -112
  466. package/lib/assets/docs/article/grokking-concurrency/scala/part-3.md +93 -93
  467. package/lib/assets/docs/article/grokking-concurrency/scala/part-4.md +110 -110
  468. package/lib/assets/docs/article/grokking-concurrency/scala/part-5.md +119 -119
  469. package/lib/assets/docs/article/grokking-concurrency/scala/part-6.md +83 -83
  470. package/lib/assets/docs/article/grokking-concurrency/scala/part-7.md +131 -131
  471. package/lib/assets/docs/article/grokking-concurrency/scala/part-8.md +129 -129
  472. package/lib/assets/docs/article/grokkingfp/all/index.md +368 -368
  473. package/lib/assets/docs/article/grokkingfp/all/part-1-ch01-fp-introduction.md +530 -530
  474. package/lib/assets/docs/article/grokkingfp/all/part-1-ch02-pure-functions.md +923 -923
  475. package/lib/assets/docs/article/grokkingfp/all/part-2-ch03-immutable-data.md +1128 -1128
  476. package/lib/assets/docs/article/grokkingfp/all/part-2-ch04-higher-order-functions.md +1104 -1104
  477. package/lib/assets/docs/article/grokkingfp/all/part-2-ch05-flatmap.md +1026 -1026
  478. package/lib/assets/docs/article/grokkingfp/all/part-3-ch06-option.md +785 -785
  479. package/lib/assets/docs/article/grokkingfp/all/part-3-ch07-either-adt.md +871 -871
  480. package/lib/assets/docs/article/grokkingfp/all/part-4-ch08-io-monad.md +972 -972
  481. package/lib/assets/docs/article/grokkingfp/all/part-4-ch09-streams.md +926 -926
  482. package/lib/assets/docs/article/grokkingfp/all/part-5-ch10-concurrency.md +870 -870
  483. package/lib/assets/docs/article/grokkingfp/all/part-6-ch11-application.md +715 -715
  484. package/lib/assets/docs/article/grokkingfp/all/part-6-ch12-testing.md +626 -626
  485. package/lib/assets/docs/article/grokkingfp/all/writing-plan.md +712 -712
  486. package/lib/assets/docs/article/grokkingfp/clojure/index.md +276 -276
  487. package/lib/assets/docs/article/grokkingfp/clojure/part-1.md +667 -667
  488. package/lib/assets/docs/article/grokkingfp/clojure/part-2.md +643 -643
  489. package/lib/assets/docs/article/grokkingfp/clojure/part-3.md +620 -620
  490. package/lib/assets/docs/article/grokkingfp/clojure/part-4.md +697 -697
  491. package/lib/assets/docs/article/grokkingfp/clojure/part-5.md +751 -751
  492. package/lib/assets/docs/article/grokkingfp/clojure/part-6.md +721 -721
  493. package/lib/assets/docs/article/grokkingfp/csharp/index.md +246 -246
  494. package/lib/assets/docs/article/grokkingfp/csharp/part-1.md +811 -811
  495. package/lib/assets/docs/article/grokkingfp/csharp/part-2.md +971 -971
  496. package/lib/assets/docs/article/grokkingfp/csharp/part-3.md +981 -981
  497. package/lib/assets/docs/article/grokkingfp/csharp/part-4.md +949 -949
  498. package/lib/assets/docs/article/grokkingfp/csharp/part-5.md +947 -947
  499. package/lib/assets/docs/article/grokkingfp/csharp/part-6.md +739 -739
  500. package/lib/assets/docs/article/grokkingfp/elixir/index.md +203 -203
  501. package/lib/assets/docs/article/grokkingfp/elixir/part-1.md +712 -712
  502. package/lib/assets/docs/article/grokkingfp/elixir/part-2.md +838 -838
  503. package/lib/assets/docs/article/grokkingfp/elixir/part-3.md +985 -985
  504. package/lib/assets/docs/article/grokkingfp/elixir/part-4.md +974 -974
  505. package/lib/assets/docs/article/grokkingfp/elixir/part-5.md +1286 -1286
  506. package/lib/assets/docs/article/grokkingfp/elixir/part-6.md +1049 -1049
  507. package/lib/assets/docs/article/grokkingfp/fsharp/index.md +210 -210
  508. package/lib/assets/docs/article/grokkingfp/fsharp/part-1.md +714 -714
  509. package/lib/assets/docs/article/grokkingfp/fsharp/part-2.md +961 -961
  510. package/lib/assets/docs/article/grokkingfp/fsharp/part-3.md +972 -972
  511. package/lib/assets/docs/article/grokkingfp/fsharp/part-4.md +832 -832
  512. package/lib/assets/docs/article/grokkingfp/fsharp/part-5.md +911 -911
  513. package/lib/assets/docs/article/grokkingfp/fsharp/part-6.md +922 -922
  514. package/lib/assets/docs/article/grokkingfp/haskell/index.md +234 -234
  515. package/lib/assets/docs/article/grokkingfp/haskell/part-1.md +591 -591
  516. package/lib/assets/docs/article/grokkingfp/haskell/part-2.md +866 -866
  517. package/lib/assets/docs/article/grokkingfp/haskell/part-3.md +915 -915
  518. package/lib/assets/docs/article/grokkingfp/haskell/part-4.md +878 -878
  519. package/lib/assets/docs/article/grokkingfp/haskell/part-5.md +845 -845
  520. package/lib/assets/docs/article/grokkingfp/haskell/part-6.md +844 -844
  521. package/lib/assets/docs/article/grokkingfp/index.md +143 -143
  522. package/lib/assets/docs/article/grokkingfp/java/index.md +211 -211
  523. package/lib/assets/docs/article/grokkingfp/java/part-1.md +648 -648
  524. package/lib/assets/docs/article/grokkingfp/java/part-2.md +675 -675
  525. package/lib/assets/docs/article/grokkingfp/java/part-3.md +672 -672
  526. package/lib/assets/docs/article/grokkingfp/java/part-4.md +771 -771
  527. package/lib/assets/docs/article/grokkingfp/java/part-5.md +959 -959
  528. package/lib/assets/docs/article/grokkingfp/java/part-6.md +1328 -1328
  529. package/lib/assets/docs/article/grokkingfp/python/index.md +258 -258
  530. package/lib/assets/docs/article/grokkingfp/python/part-1.md +443 -443
  531. package/lib/assets/docs/article/grokkingfp/python/part-2.md +958 -958
  532. package/lib/assets/docs/article/grokkingfp/python/part-3.md +1004 -1004
  533. package/lib/assets/docs/article/grokkingfp/python/part-4.md +765 -765
  534. package/lib/assets/docs/article/grokkingfp/python/part-5.md +747 -747
  535. package/lib/assets/docs/article/grokkingfp/python/part-6.md +861 -861
  536. package/lib/assets/docs/article/grokkingfp/ruby/index.md +330 -330
  537. package/lib/assets/docs/article/grokkingfp/ruby/part-1.md +755 -755
  538. package/lib/assets/docs/article/grokkingfp/ruby/part-2.md +938 -938
  539. package/lib/assets/docs/article/grokkingfp/ruby/part-3.md +946 -946
  540. package/lib/assets/docs/article/grokkingfp/ruby/part-4.md +921 -921
  541. package/lib/assets/docs/article/grokkingfp/ruby/part-5.md +908 -908
  542. package/lib/assets/docs/article/grokkingfp/ruby/part-6.md +1412 -1412
  543. package/lib/assets/docs/article/grokkingfp/rust/index.md +242 -242
  544. package/lib/assets/docs/article/grokkingfp/rust/part-1.md +634 -634
  545. package/lib/assets/docs/article/grokkingfp/rust/part-2.md +1060 -1060
  546. package/lib/assets/docs/article/grokkingfp/rust/part-3.md +994 -994
  547. package/lib/assets/docs/article/grokkingfp/rust/part-4.md +573 -573
  548. package/lib/assets/docs/article/grokkingfp/rust/part-5.md +705 -705
  549. package/lib/assets/docs/article/grokkingfp/rust/part-6.md +508 -508
  550. package/lib/assets/docs/article/grokkingfp/scala/index.md +171 -171
  551. package/lib/assets/docs/article/grokkingfp/scala/part-1.md +543 -543
  552. package/lib/assets/docs/article/grokkingfp/scala/part-2.md +946 -946
  553. package/lib/assets/docs/article/grokkingfp/scala/part-3.md +919 -919
  554. package/lib/assets/docs/article/grokkingfp/scala/part-4.md +742 -742
  555. package/lib/assets/docs/article/grokkingfp/scala/part-5.md +722 -722
  556. package/lib/assets/docs/article/grokkingfp/scala/part-6.md +867 -867
  557. package/lib/assets/docs/article/grokkingfp/typescript/index.md +273 -273
  558. package/lib/assets/docs/article/grokkingfp/typescript/part-1.md +561 -561
  559. package/lib/assets/docs/article/grokkingfp/typescript/part-2.md +1129 -1129
  560. package/lib/assets/docs/article/grokkingfp/typescript/part-3.md +842 -842
  561. package/lib/assets/docs/article/grokkingfp/typescript/part-4.md +1087 -1087
  562. package/lib/assets/docs/article/grokkingfp/typescript/part-5.md +717 -717
  563. package/lib/assets/docs/article/grokkingfp/typescript/part-6.md +982 -982
  564. package/lib/assets/docs/article/practical-database-design/index.md +121 -121
  565. package/lib/assets/docs/article/practical-database-design/part1/chapter01.md +288 -288
  566. package/lib/assets/docs/article/practical-database-design/part1/chapter02.md +518 -518
  567. package/lib/assets/docs/article/practical-database-design/part1/chapter03.md +557 -557
  568. package/lib/assets/docs/article/practical-database-design/part2/chapter04.md +924 -924
  569. package/lib/assets/docs/article/practical-database-design/part2/chapter05.md +1627 -1627
  570. package/lib/assets/docs/article/practical-database-design/part2/chapter06.md +2716 -2716
  571. package/lib/assets/docs/article/practical-database-design/part2/chapter07.md +2082 -2082
  572. package/lib/assets/docs/article/practical-database-design/part2/chapter08.md +2105 -2105
  573. package/lib/assets/docs/article/practical-database-design/part2/chapter09.md +2031 -2031
  574. package/lib/assets/docs/article/practical-database-design/part2/chapter10.md +1387 -1387
  575. package/lib/assets/docs/article/practical-database-design/part2/chapter11.md +1677 -1677
  576. package/lib/assets/docs/article/practical-database-design/part2/chapter12.md +1417 -1417
  577. package/lib/assets/docs/article/practical-database-design/part2/chapter13.md +1434 -1434
  578. package/lib/assets/docs/article/practical-database-design/part3/chapter14.md +667 -667
  579. package/lib/assets/docs/article/practical-database-design/part3/chapter15.md +1625 -1625
  580. package/lib/assets/docs/article/practical-database-design/part3/chapter16.md +1915 -1915
  581. package/lib/assets/docs/article/practical-database-design/part3/chapter17.md +1708 -1708
  582. package/lib/assets/docs/article/practical-database-design/part3/chapter18.md +2095 -2095
  583. package/lib/assets/docs/article/practical-database-design/part3/chapter19.md +1123 -1123
  584. package/lib/assets/docs/article/practical-database-design/part3/chapter20.md +1031 -1031
  585. package/lib/assets/docs/article/practical-database-design/part3/chapter21.md +1382 -1382
  586. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter14-orm.md +991 -991
  587. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter15-orm.md +1300 -1300
  588. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter16-orm.md +1166 -1166
  589. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter17-orm.md +1584 -1584
  590. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter18-orm.md +1183 -1183
  591. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter19-orm.md +1016 -1016
  592. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter20-orm.md +1753 -1753
  593. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter21-orm.md +1447 -1447
  594. package/lib/assets/docs/article/practical-database-design/part3-orm/chapter22-orm.md +1878 -1878
  595. package/lib/assets/docs/article/practical-database-design/part4/chapter22.md +965 -965
  596. package/lib/assets/docs/article/practical-database-design/part4/chapter23.md +2069 -2069
  597. package/lib/assets/docs/article/practical-database-design/part4/chapter24.md +2439 -2439
  598. package/lib/assets/docs/article/practical-database-design/part4/chapter25.md +3661 -3661
  599. package/lib/assets/docs/article/practical-database-design/part4/chapter26.md +2916 -2916
  600. package/lib/assets/docs/article/practical-database-design/part4/chapter27.md +3105 -3105
  601. package/lib/assets/docs/article/practical-database-design/part4/chapter28.md +2697 -2697
  602. package/lib/assets/docs/article/practical-database-design/part4/chapter29.md +2544 -2544
  603. package/lib/assets/docs/article/practical-database-design/part4/chapter30.md +2180 -2180
  604. package/lib/assets/docs/article/practical-database-design/part4/chapter31.md +1192 -1192
  605. package/lib/assets/docs/article/practical-database-design/part4/chapter32.md +2101 -2101
  606. package/lib/assets/docs/article/practical-database-design/part5/chapter33.md +1032 -1032
  607. package/lib/assets/docs/article/practical-database-design/part5/chapter34.md +1609 -1609
  608. package/lib/assets/docs/article/practical-database-design/part5/chapter35.md +1453 -1453
  609. package/lib/assets/docs/article/practical-database-design/part5/chapter36.md +1292 -1292
  610. package/lib/assets/docs/article/practical-database-design/part5/chapter37.md +1470 -1470
  611. package/lib/assets/docs/article/practical-database-design/part5/chapter38.md +1698 -1698
  612. package/lib/assets/docs/article/practical-database-design/part5/chapter39.md +2334 -2334
  613. package/lib/assets/docs/article/practical-database-design/study/study2-1.md +1693 -1693
  614. package/lib/assets/docs/article/practical-database-design/study/study2-2.md +1347 -1347
  615. package/lib/assets/docs/article/practical-database-design/study/study2-3.md +2044 -2044
  616. package/lib/assets/docs/article/practical-database-design/study/study2-4.md +2229 -2229
  617. package/lib/assets/docs/article/practical-database-design/study/study2-5.md +2418 -2418
  618. package/lib/assets/docs/article/practical-database-design/study/study3-1.md +2205 -2205
  619. package/lib/assets/docs/article/practical-database-design/study/study3-2.md +2221 -2221
  620. package/lib/assets/docs/article/practical-database-design/study/study3-3.md +2253 -2253
  621. package/lib/assets/docs/article/practical-database-design/study/study3-4.md +2106 -2106
  622. package/lib/assets/docs/article/practical-database-design/study/study3-5.md +2507 -2507
  623. package/lib/assets/docs/article/practical-database-design/study/study4-1.md +2587 -2587
  624. package/lib/assets/docs/article/practical-database-design/study/study4-2.md +2075 -2075
  625. package/lib/assets/docs/article/practical-database-design/study/study4-3.md +1805 -1805
  626. package/lib/assets/docs/article/practical-database-design/study/study4-4.md +1895 -1895
  627. package/lib/assets/docs/article/practical-database-design/study/study4-5.md +2878 -2878
  628. package/lib/assets/docs/assets/css/extra.css +29 -29
  629. package/lib/assets/docs/assets/js/extra.js +44 -44
  630. package/lib/assets/docs/development/index.md +39 -39
  631. package/lib/assets/docs/operation/index.md +11 -11
  632. package/lib/assets/docs/reference/CodexCLIMCP/343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/351/226/213/347/231/272/343/203/225/343/203/255/343/203/274.md +532 -532
  633. package/lib/assets/docs/reference/CodexCLIMCP/343/202/265/343/203/274/343/203/220/343/203/274/350/250/255/345/256/232/346/211/213/351/240/206.md +341 -341
  634. package/lib/assets/docs/reference/Java/343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/347/222/260/345/242/203/346/247/213/347/257/211/343/202/254/343/202/244/343/203/211.md +581 -580
  635. package/lib/assets/docs/reference/SonarQube/343/203/255/343/203/274/343/202/253/343/203/253/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +642 -642
  636. package/lib/assets/docs/reference/TypeScript/343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/347/222/260/345/242/203/346/247/213/347/257/211/343/202/254/343/202/244/343/203/211.md +465 -465
  637. package/lib/assets/docs/reference/UI/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +450 -450
  638. package/lib/assets/docs/reference/images/Ansoff.drawio.svg +3 -3
  639. package/lib/assets/docs/reference/images/BrandBasicStrategy.drawio.svg +3 -3
  640. package/lib/assets/docs/reference/images/BrandCategorization.drawio.svg +3 -3
  641. package/lib/assets/docs/reference/images/BrandRecurutementStrategy.drawio.svg +3 -3
  642. package/lib/assets/docs/reference/images/BrandValue.drawio.svg +3 -3
  643. package/lib/assets/docs/reference/images/BusinessActivitiy.svg +3 -3
  644. package/lib/assets/docs/reference/images/HRM.drawio.svg +3 -3
  645. package/lib/assets/docs/reference/images/MarketingStructure.drawio.svg +3 -3
  646. package/lib/assets/docs/reference/images/OrganizationElemnts.svg +3 -3
  647. package/lib/assets/docs/reference/images/PPM.drawio.svg +3 -3
  648. package/lib/assets/docs/reference/images/PositioningMap.drawio.svg +3 -3
  649. package/lib/assets/docs/reference/images/ProductLayer.drawio.svg +3 -3
  650. package/lib/assets/docs/reference/images/ProductMix.drawio.svg +3 -3
  651. package/lib/assets/docs/reference/images/SWOT.drawio.svg +3 -3
  652. package/lib/assets/docs/reference/images/TargetMarket.drawio.svg +3 -3
  653. package/lib/assets/docs/reference/images/ThreeGenericStrategies.drawio.svg +3 -3
  654. package/lib/assets/docs/reference/images/VRIO.drawio.svg +3 -3
  655. package/lib/assets/docs/reference/images/ValueChain.drawio.svg +3 -3
  656. package/lib/assets/docs/reference/index.md +52 -52
  657. 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 +250 -242
  658. package/lib/assets/docs/reference//343/202/242/343/203/274/343/202/255/343/203/206/343/202/257/343/203/201/343/203/243/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +2216 -2216
  659. package/lib/assets/docs/reference//343/202/244/343/203/263/343/203/225/343/203/251/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +1878 -1878
  660. 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 +550 -544
  661. package/lib/assets/docs/reference//343/202/263/343/203/274/343/203/207/343/202/243/343/203/263/343/202/260/343/201/250/343/203/206/343/202/271/343/203/210/343/202/254/343/202/244/343/203/211.md +705 -705
  662. package/lib/assets/docs/reference//343/203/206/343/202/271/343/203/210/346/210/246/347/225/245/343/202/254/343/202/244/343/203/211.md +1313 -1313
  663. package/lib/assets/docs/reference//343/203/207/343/203/274/343/202/277/343/203/242/343/203/207/343/203/253/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +311 -311
  664. package/lib/assets/docs/reference//343/203/211/343/203/241/343/202/244/343/203/263/343/203/242/343/203/207/343/203/253/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +599 -599
  665. package/lib/assets/docs/reference//343/203/223/343/202/270/343/203/215/343/202/271/343/202/242/343/203/274/343/202/255/343/203/206/343/202/257/343/203/201/343/203/243/345/210/206/346/236/220/343/202/254/343/202/244/343/203/211.md +528 -528
  666. package/lib/assets/docs/reference//343/203/246/343/203/274/343/202/271/343/202/261/343/203/274/343/202/271/344/275/234/346/210/220/343/202/254/343/202/244/343/203/211.md +689 -682
  667. package/lib/assets/docs/reference//343/203/252/343/203/252/343/203/274/343/202/271/343/202/254/343/202/244/343/203/211.md +461 -461
  668. package/lib/assets/docs/reference//343/203/252/343/203/252/343/203/274/343/202/271/343/203/273/343/202/244/343/203/206/343/203/254/343/203/274/343/202/267/343/203/247/343/203/263/350/250/210/347/224/273/343/202/254/343/202/244/343/203/211.md +580 -560
  669. package/lib/assets/docs/reference//343/203/255/343/202/270/343/202/253/343/203/253/343/202/267/343/203/263/343/202/255/343/203/263/343/202/260.md +1367 -1367
  670. package/lib/assets/docs/reference//344/274/201/346/245/255/347/265/214/345/226/266/350/253/226.md +2637 -2636
  671. package/lib/assets/docs/reference//347/222/260/345/242/203/345/244/211/346/225/260/347/256/241/347/220/206/343/202/254/343/202/244/343/203/211.md +665 -663
  672. 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 +1248 -1248
  673. package/lib/assets/docs/reference//350/250/200/350/252/236/345/210/245/351/226/213/347/231/272/343/202/254/343/202/244/343/203/211.md +28 -0
  674. package/lib/assets/docs/reference//351/201/213/345/226/266/347/256/241/347/220/206.md +1482 -1482
  675. package/lib/assets/docs/reference//351/201/213/347/224/250/343/202/271/343/202/257/343/203/252/343/203/227/343/203/210/344/275/234/346/210/220/343/202/254/343/202/244/343/203/211.md +421 -421
  676. package/lib/assets/docs/reference//351/201/213/347/224/250/350/246/201/344/273/266/345/256/232/347/276/251/343/202/254/343/202/244/343/203/211.md +392 -392
  677. package/lib/assets/docs/reference//351/226/213/347/231/272/343/202/254/343/202/244/343/203/211.md +299 -299
  678. package/lib/assets/docs/reference//351/235/236/346/251/237/350/203/275/350/246/201/344/273/266/345/256/232/347/276/251/343/202/254/343/202/244/343/203/211.md +1236 -1236
  679. package/lib/assets/docs/review/index.md +5 -5
  680. package/lib/assets/docs/strategy/index.md +1 -1
  681. package/lib/assets/docs/template/ADR.md +30 -30
  682. package/lib/assets/docs/template/AWS/343/202/271/343/203/206/343/203/274/343/202/270/343/203/263/343/202/260/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +1366 -1366
  683. package/lib/assets/docs/template/AWS/343/203/227/343/203/255/343/203/200/343/202/257/343/202/267/343/203/247/343/203/263/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +634 -634
  684. package/lib/assets/docs/template/README.md +50 -50
  685. package/lib/assets/docs/template/index.md +23 -23
  686. 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 -12
  687. package/lib/assets/docs/template//343/202/242/343/203/227/343/203/252/343/202/261/343/203/274/343/202/267/343/203/247/343/203/263/351/226/213/347/231/272/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +547 -547
  688. 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 +58 -58
  689. 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 -13
  690. package/lib/assets/docs/template//343/203/223/343/202/270/343/203/215/343/202/271/343/202/242/343/203/274/343/202/255/343/203/206/343/202/257/343/203/201/343/203/243.md +379 -379
  691. package/lib/assets/docs/template//344/274/201/346/245/255/345/210/206/346/236/220.md +573 -573
  692. package/lib/assets/docs/template//345/256/214/345/205/250/345/275/242/345/274/217/343/201/256/343/203/246/343/203/274/343/202/271/343/202/261/343/203/274/343/202/271.md +69 -68
  693. package/lib/assets/docs/template//350/246/201/344/273/266/345/256/232/347/276/251.md +669 -669
  694. package/lib/assets/docs/template//350/250/255/350/250/210.md +173 -173
  695. package/lib/assets/docs/template//351/226/213/347/231/272/347/222/260/345/242/203/343/202/273/343/203/203/343/203/210/343/202/242/343/203/203/343/203/227/346/211/213/351/240/206/346/233/270.md +688 -688
  696. package/lib/assets/gulpfile.js +25 -25
  697. package/lib/assets/mkdocs.yml +136 -135
  698. package/lib/assets/ops/docker/mkdoc/Dockerfile +19 -19
  699. package/lib/assets/ops/scripts/journal.js +180 -180
  700. package/lib/assets/ops/scripts/mkdocs.js +82 -82
  701. package/lib/assets/ops/scripts/release.js +431 -431
  702. package/lib/assets/ops/scripts/sonar_local.js +726 -726
  703. package/lib/assets/ops/scripts/ssh.js +190 -190
  704. package/lib/assets/ops/scripts/vault.js +299 -299
  705. package/lib/assets/package-lock.json +1653 -1653
  706. package/lib/assets/package.json +40 -40
  707. package/lib/gulpfile.js +37 -37
  708. package/package.json +41 -41
  709. package/lib/assets/.claude/agent-memory/xp-programmer/MEMORY.md +0 -6
  710. package/lib/assets/.claude/agent-memory/xp-programmer/project_cargo_tracker.md +0 -11
  711. package/lib/assets/.claude/agent-memory/xp-programmer/project_ddd_patterns.md +0 -27
  712. package/lib/assets/.claude/agent-memory/xp-programmer/project_us07_route_assignment.md +0 -19
@@ -1,1249 +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)
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
1249
  - PlantUML公式サイト: https://plantuml.com/ja/