@k2works/claude-code-booster 3.6.1 → 3.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -21
- package/README.md +42 -42
- package/bin/claude-code-booster +90 -90
- package/lib/assets/.claude/README.md +258 -239
- package/lib/assets/.claude/agent-memory/xp-programmer/MEMORY.md +6 -0
- package/lib/assets/.claude/agent-memory/xp-programmer/project_cargo_tracker.md +11 -0
- package/lib/assets/.claude/agent-memory/xp-programmer/project_ddd_patterns.md +27 -0
- package/lib/assets/.claude/agent-memory/xp-programmer/project_us07_route_assignment.md +19 -0
- package/lib/assets/.claude/scripts/generate-inception-deck.mjs +911 -911
- package/lib/assets/.claude/settings.json +11 -11
- package/lib/assets/.claude/skills/ai-agent-guidelines/SKILL.md +111 -111
- package/lib/assets/.claude/skills/analyzing-architecture/SKILL.md +83 -83
- package/lib/assets/.claude/skills/analyzing-business/SKILL.md +95 -95
- package/lib/assets/.claude/skills/analyzing-data-model/SKILL.md +77 -77
- package/lib/assets/.claude/skills/analyzing-domain-model/SKILL.md +117 -117
- package/lib/assets/.claude/skills/analyzing-inception-deck/SKILL.md +84 -84
- package/lib/assets/.claude/skills/analyzing-non-functional/SKILL.md +95 -95
- package/lib/assets/.claude/skills/analyzing-operation/SKILL.md +95 -95
- package/lib/assets/.claude/skills/analyzing-requirements/SKILL.md +91 -91
- package/lib/assets/.claude/skills/analyzing-tech-stack/SKILL.md +101 -101
- package/lib/assets/.claude/skills/analyzing-test-strategy/SKILL.md +89 -89
- package/lib/assets/.claude/skills/analyzing-ui-design/SKILL.md +80 -80
- package/lib/assets/.claude/skills/analyzing-usecases/SKILL.md +72 -72
- package/lib/assets/.claude/skills/creating-adr/SKILL.md +113 -113
- package/lib/assets/.claude/skills/developing-backend/SKILL.md +100 -100
- package/lib/assets/.claude/skills/developing-frontend/SKILL.md +93 -93
- package/lib/assets/.claude/skills/developing-release/SKILL.md +120 -120
- package/lib/assets/.claude/skills/generating-bmc/SKILL.md +97 -0
- package/lib/assets/.claude/skills/generating-slides/SKILL.md +94 -94
- package/lib/assets/.claude/skills/git-commit/SKILL.md +81 -81
- package/lib/assets/.claude/skills/killing-processes/SKILL.md +44 -44
- package/lib/assets/.claude/skills/operating-backup/SKILL.md +59 -59
- package/lib/assets/.claude/skills/operating-cicd/SKILL.md +54 -54
- package/lib/assets/.claude/skills/operating-deploy/SKILL.md +67 -67
- package/lib/assets/.claude/skills/operating-docs/SKILL.md +219 -219
- package/lib/assets/.claude/skills/operating-provision/SKILL.md +77 -77
- package/lib/assets/.claude/skills/operating-setup/SKILL.md +63 -63
- package/lib/assets/.claude/skills/orchestrating-analysis/SKILL.md +104 -104
- package/lib/assets/.claude/skills/orchestrating-development/SKILL.md +27 -21
- package/lib/assets/.claude/skills/orchestrating-operation/SKILL.md +158 -158
- package/lib/assets/.claude/skills/orchestrating-project/SKILL.md +144 -144
- package/lib/assets/.claude/skills/planning-releases/SKILL.md +119 -119
- package/lib/assets/.claude/skills/syncing-github-project/SKILL.md +151 -151
- package/lib/assets/.claude/skills/tracking-progress/SKILL.md +91 -91
- package/lib/assets/.claude/skills/validating-iteration-plan/SKILL.md +215 -215
- package/lib/assets/.devcontainer/devcontainer.json +34 -34
- package/lib/assets/.env.example +17 -17
- package/lib/assets/.gitattributes +4 -4
- package/lib/assets/.github/workflows/docker-publish.yml +77 -77
- package/lib/assets/.github/workflows/mkdocs.yml +39 -39
- package/lib/assets/AGENTS.md +94 -94
- package/lib/assets/CLAUDE.md +1 -0
- package/lib/assets/README.md +254 -254
- package/lib/assets/docker-compose.yml +33 -33
- package/lib/assets/docs/adr/index.md +10 -10
- package/lib/assets/docs/article/functional-desgin-ppp/all/01-immutability-and-data-transformation.md +475 -475
- package/lib/assets/docs/article/functional-desgin-ppp/all/02-function-composition.md +519 -519
- package/lib/assets/docs/article/functional-desgin-ppp/all/03-polymorphism.md +537 -537
- package/lib/assets/docs/article/functional-desgin-ppp/all/04-data-validation.md +300 -300
- package/lib/assets/docs/article/functional-desgin-ppp/all/05-property-based-testing.md +320 -320
- package/lib/assets/docs/article/functional-desgin-ppp/all/06-tdd-and-functional.md +498 -498
- package/lib/assets/docs/article/functional-desgin-ppp/all/07-composite-pattern.md +298 -298
- package/lib/assets/docs/article/functional-desgin-ppp/all/08-decorator-pattern.md +291 -291
- package/lib/assets/docs/article/functional-desgin-ppp/all/09-adapter-pattern.md +336 -336
- package/lib/assets/docs/article/functional-desgin-ppp/all/10-strategy-pattern.md +303 -303
- package/lib/assets/docs/article/functional-desgin-ppp/all/11-command-pattern.md +286 -286
- package/lib/assets/docs/article/functional-desgin-ppp/all/12-visitor-pattern.md +322 -322
- package/lib/assets/docs/article/functional-desgin-ppp/all/13-abstract-factory-pattern.md +319 -319
- package/lib/assets/docs/article/functional-desgin-ppp/all/14-abstract-server-pattern.md +365 -365
- package/lib/assets/docs/article/functional-desgin-ppp/all/15-gossiping-bus-drivers.md +156 -156
- package/lib/assets/docs/article/functional-desgin-ppp/all/16-payroll-system.md +178 -178
- package/lib/assets/docs/article/functional-desgin-ppp/all/17-video-rental-system.md +312 -312
- package/lib/assets/docs/article/functional-desgin-ppp/all/18-concurrency-system.md +287 -287
- package/lib/assets/docs/article/functional-desgin-ppp/all/19-wa-tor-simulation.md +286 -286
- package/lib/assets/docs/article/functional-desgin-ppp/all/20-pattern-interactions.md +274 -274
- package/lib/assets/docs/article/functional-desgin-ppp/all/21-best-practices.md +294 -294
- package/lib/assets/docs/article/functional-desgin-ppp/all/22-oo-to-fp-migration.md +337 -337
- package/lib/assets/docs/article/functional-desgin-ppp/all/index.md +388 -388
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/01-immutability-and-data-transformation.md +273 -273
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/02-function-composition.md +380 -380
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/03-polymorphism.md +384 -384
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/04-clojure-spec.md +350 -350
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/05-property-based-testing.md +352 -352
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/06-tdd-in-functional.md +383 -383
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/07-composite-pattern.md +529 -529
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/08-decorator-pattern.md +395 -395
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/09-adapter-pattern.md +399 -399
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/10-strategy-pattern.md +485 -485
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/11-command-pattern.md +566 -566
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/12-visitor-pattern.md +567 -567
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/13-abstract-factory-pattern.md +475 -475
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/14-abstract-server-pattern.md +462 -462
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/15-gossiping-bus-drivers.md +325 -325
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/16-payroll-system.md +401 -401
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/17-video-rental-system.md +450 -450
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/18-concurrency-system.md +475 -475
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/19-wator-simulation.md +739 -739
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/20-pattern-interactions.md +567 -567
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/21-best-practices.md +518 -518
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/22-oo-to-fp-migration.md +532 -532
- package/lib/assets/docs/article/functional-desgin-ppp/clojure/index.md +241 -241
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/01-immutability-and-data-transformation.md +383 -383
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/02-function-composition.md +374 -374
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/03-polymorphism.md +375 -375
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/04-data-validation.md +195 -195
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/05-property-based-testing.md +268 -268
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/06-tdd-and-fp.md +294 -294
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/07-effects-and-pure-functions.md +164 -164
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/08-error-handling-strategies.md +168 -168
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/09-io-and-external-systems.md +254 -254
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/10-concurrency-patterns.md +269 -269
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/11-command-pattern.md +148 -148
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/12-visitor-pattern.md +176 -176
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/13-abstract-factory-pattern.md +604 -604
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/14-abstract-server-pattern.md +729 -729
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/15-gossiping-bus-drivers.md +291 -291
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/16-payroll-system.md +420 -420
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/17-video-rental-system.md +319 -319
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/18-concurrency-system.md +466 -466
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/19-wator-simulation.md +523 -523
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/20-pattern-interactions.md +287 -287
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/21-best-practices.md +340 -340
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/22-oo-to-fp-migration.md +395 -395
- package/lib/assets/docs/article/functional-desgin-ppp/elixir/index.md +248 -248
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/01-immutability-and-data-transformation.md +384 -384
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/02-function-composition.md +452 -452
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/03-polymorphism.md +495 -495
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/04-data-validation.md +416 -416
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/05-property-based-testing.md +382 -382
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/06-tdd-functional.md +687 -687
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/07-composite-pattern.md +442 -442
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/08-decorator-pattern.md +479 -479
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/09-adapter-pattern.md +479 -479
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/10-strategy-pattern.md +427 -427
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/11-command-pattern.md +428 -428
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/12-visitor-pattern.md +339 -339
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/13-abstract-factory-pattern.md +309 -309
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/14-abstract-server-pattern.md +596 -596
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/15-gossiping-bus-drivers.md +355 -355
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/16-payroll-system.md +350 -350
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/17-video-rental-system.md +414 -414
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/18-concurrency-system.md +367 -367
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/19-wator-simulation.md +403 -403
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/20-pattern-interactions.md +291 -291
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/21-best-practices.md +324 -324
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/22-oo-to-fp-migration.md +332 -332
- package/lib/assets/docs/article/functional-desgin-ppp/fsharp/index.md +274 -274
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/01-immutability-and-data-transformation.md +298 -298
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/02-function-composition.md +304 -304
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/03-polymorphism.md +362 -362
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/04-data-validation.md +257 -257
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/05-property-based-testing.md +254 -254
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/06-tdd-functional.md +283 -283
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/07-composite-pattern.md +395 -395
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/08-decorator-pattern.md +319 -319
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/09-adapter-pattern.md +382 -382
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/10-strategy-pattern.md +287 -287
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/11-command-pattern.md +303 -303
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/12-visitor-pattern.md +326 -326
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/13-abstract-factory-pattern.md +332 -332
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/14-abstract-server-pattern.md +379 -379
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/15-gossiping-bus-drivers.md +177 -177
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/16-payroll-system.md +219 -219
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/17-video-rental-system.md +244 -244
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/18-concurrency-system.md +363 -363
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/19-wator-simulation.md +438 -438
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/20-pattern-interactions.md +325 -325
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/21-best-practices.md +403 -403
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/22-oo-to-fp-migration.md +469 -469
- package/lib/assets/docs/article/functional-desgin-ppp/haskell/index.md +174 -174
- package/lib/assets/docs/article/functional-desgin-ppp/index.md +90 -90
- package/lib/assets/docs/article/functional-desgin-ppp/rust/01-immutability-and-data-transformation.md +450 -450
- package/lib/assets/docs/article/functional-desgin-ppp/rust/02-function-composition.md +463 -463
- package/lib/assets/docs/article/functional-desgin-ppp/rust/03-polymorphism.md +425 -425
- package/lib/assets/docs/article/functional-desgin-ppp/rust/04-data-validation.md +273 -273
- package/lib/assets/docs/article/functional-desgin-ppp/rust/05-property-based-testing.md +247 -247
- package/lib/assets/docs/article/functional-desgin-ppp/rust/06-tdd-and-functional.md +841 -841
- package/lib/assets/docs/article/functional-desgin-ppp/rust/07-composite-pattern.md +384 -384
- package/lib/assets/docs/article/functional-desgin-ppp/rust/08-decorator-pattern.md +383 -383
- package/lib/assets/docs/article/functional-desgin-ppp/rust/09-adapter-pattern.md +339 -339
- package/lib/assets/docs/article/functional-desgin-ppp/rust/10-strategy-pattern.md +331 -331
- package/lib/assets/docs/article/functional-desgin-ppp/rust/11-command-pattern.md +356 -356
- package/lib/assets/docs/article/functional-desgin-ppp/rust/12-visitor-pattern.md +379 -379
- package/lib/assets/docs/article/functional-desgin-ppp/rust/13-abstract-factory-pattern.md +361 -361
- package/lib/assets/docs/article/functional-desgin-ppp/rust/14-abstract-server-pattern.md +392 -392
- package/lib/assets/docs/article/functional-desgin-ppp/rust/15-gossiping-bus-drivers.md +300 -300
- package/lib/assets/docs/article/functional-desgin-ppp/rust/16-payroll-system.md +297 -297
- package/lib/assets/docs/article/functional-desgin-ppp/rust/17-video-rental-system.md +304 -304
- package/lib/assets/docs/article/functional-desgin-ppp/rust/18-concurrency-system.md +315 -315
- package/lib/assets/docs/article/functional-desgin-ppp/rust/19-wator-simulation.md +311 -311
- package/lib/assets/docs/article/functional-desgin-ppp/rust/20-pattern-interactions.md +304 -304
- package/lib/assets/docs/article/functional-desgin-ppp/rust/21-best-practices.md +336 -336
- package/lib/assets/docs/article/functional-desgin-ppp/rust/22-oo-to-fp-migration.md +349 -349
- package/lib/assets/docs/article/functional-desgin-ppp/rust/index.md +243 -243
- package/lib/assets/docs/article/functional-desgin-ppp/scala/01-immutability-and-data-transformation.md +328 -328
- package/lib/assets/docs/article/functional-desgin-ppp/scala/02-function-composition.md +348 -348
- package/lib/assets/docs/article/functional-desgin-ppp/scala/03-polymorphism.md +357 -357
- package/lib/assets/docs/article/functional-desgin-ppp/scala/04-data-validation.md +364 -364
- package/lib/assets/docs/article/functional-desgin-ppp/scala/05-property-based-testing.md +515 -515
- package/lib/assets/docs/article/functional-desgin-ppp/scala/06-tdd-functional.md +557 -557
- package/lib/assets/docs/article/functional-desgin-ppp/scala/07-composite-pattern.md +363 -363
- package/lib/assets/docs/article/functional-desgin-ppp/scala/08-decorator-pattern.md +327 -327
- package/lib/assets/docs/article/functional-desgin-ppp/scala/09-adapter-pattern.md +517 -517
- package/lib/assets/docs/article/functional-desgin-ppp/scala/10-strategy-pattern.md +441 -441
- package/lib/assets/docs/article/functional-desgin-ppp/scala/11-command-pattern.md +407 -407
- package/lib/assets/docs/article/functional-desgin-ppp/scala/12-visitor-pattern.md +379 -379
- package/lib/assets/docs/article/functional-desgin-ppp/scala/13-abstract-factory-pattern.md +398 -398
- package/lib/assets/docs/article/functional-desgin-ppp/scala/14-abstract-server-pattern.md +476 -476
- package/lib/assets/docs/article/functional-desgin-ppp/scala/15-gossiping-bus-drivers.md +391 -391
- package/lib/assets/docs/article/functional-desgin-ppp/scala/16-payroll-system.md +342 -342
- package/lib/assets/docs/article/functional-desgin-ppp/scala/17-video-rental-system.md +324 -324
- package/lib/assets/docs/article/functional-desgin-ppp/scala/18-concurrency-system.md +730 -730
- package/lib/assets/docs/article/functional-desgin-ppp/scala/19-wator-simulation.md +624 -624
- package/lib/assets/docs/article/functional-desgin-ppp/scala/20-pattern-interactions.md +512 -512
- package/lib/assets/docs/article/functional-desgin-ppp/scala/21-best-practices.md +433 -433
- package/lib/assets/docs/article/functional-desgin-ppp/scala/22-oo-to-fp-migration.md +688 -688
- package/lib/assets/docs/article/functional-desgin-ppp/scala/index.md +243 -243
- package/lib/assets/docs/article/getting-start-tdd/clojure/01-todo-list-and-first-test.md +166 -166
- package/lib/assets/docs/article/getting-start-tdd/clojure/02-fake-it-and-triangulation.md +162 -162
- package/lib/assets/docs/article/getting-start-tdd/clojure/03-obvious-implementation-and-refactoring.md +135 -135
- package/lib/assets/docs/article/getting-start-tdd/clojure/04-version-control-and-conventional-commits.md +88 -88
- package/lib/assets/docs/article/getting-start-tdd/clojure/05-package-management-and-static-analysis.md +299 -299
- package/lib/assets/docs/article/getting-start-tdd/clojure/06-task-runner-and-ci-cd.md +241 -241
- package/lib/assets/docs/article/getting-start-tdd/clojure/07-protocols-and-records.md +131 -131
- package/lib/assets/docs/article/getting-start-tdd/clojure/08-multimethods-and-design-patterns.md +130 -130
- package/lib/assets/docs/article/getting-start-tdd/clojure/09-namespaces-and-module-design.md +127 -127
- package/lib/assets/docs/article/getting-start-tdd/clojure/10-higher-order-functions-and-composition.md +114 -114
- package/lib/assets/docs/article/getting-start-tdd/clojure/11-persistent-data-and-pipeline.md +138 -138
- package/lib/assets/docs/article/getting-start-tdd/clojure/12-error-handling-and-spec.md +161 -161
- package/lib/assets/docs/article/getting-start-tdd/clojure/index.md +65 -65
- package/lib/assets/docs/article/getting-start-tdd/csharp/chapter01.md +232 -232
- package/lib/assets/docs/article/getting-start-tdd/csharp/chapter02.md +244 -244
- package/lib/assets/docs/article/getting-start-tdd/csharp/chapter03.md +202 -202
- package/lib/assets/docs/article/getting-start-tdd/csharp/chapter04.md +92 -92
- package/lib/assets/docs/article/getting-start-tdd/csharp/chapter05.md +256 -256
- package/lib/assets/docs/article/getting-start-tdd/csharp/chapter06.md +195 -195
- package/lib/assets/docs/article/getting-start-tdd/csharp/chapter07.md +214 -214
- package/lib/assets/docs/article/getting-start-tdd/csharp/chapter08.md +249 -249
- package/lib/assets/docs/article/getting-start-tdd/csharp/chapter09.md +174 -174
- package/lib/assets/docs/article/getting-start-tdd/csharp/chapter10.md +166 -166
- package/lib/assets/docs/article/getting-start-tdd/csharp/chapter11.md +192 -192
- package/lib/assets/docs/article/getting-start-tdd/csharp/chapter12.md +211 -211
- package/lib/assets/docs/article/getting-start-tdd/csharp/index.md +83 -83
- package/lib/assets/docs/article/getting-start-tdd/elixir/01-todo-list-and-first-test.md +87 -87
- package/lib/assets/docs/article/getting-start-tdd/elixir/02-fake-it-and-triangulation.md +95 -95
- package/lib/assets/docs/article/getting-start-tdd/elixir/03-obvious-implementation-and-refactoring.md +109 -109
- package/lib/assets/docs/article/getting-start-tdd/elixir/04-version-control-and-conventional-commits.md +96 -96
- package/lib/assets/docs/article/getting-start-tdd/elixir/05-package-management-and-static-analysis.md +88 -88
- package/lib/assets/docs/article/getting-start-tdd/elixir/06-task-runner-and-ci-cd.md +71 -71
- package/lib/assets/docs/article/getting-start-tdd/elixir/07-structs-and-protocols.md +110 -110
- package/lib/assets/docs/article/getting-start-tdd/elixir/08-pattern-matching-and-guards.md +108 -108
- package/lib/assets/docs/article/getting-start-tdd/elixir/09-module-design-and-behaviours.md +104 -104
- package/lib/assets/docs/article/getting-start-tdd/elixir/10-higher-order-functions-and-pipeline.md +178 -178
- package/lib/assets/docs/article/getting-start-tdd/elixir/11-stream-and-lazy-evaluation.md +142 -142
- package/lib/assets/docs/article/getting-start-tdd/elixir/12-error-handling-and-with.md +145 -145
- package/lib/assets/docs/article/getting-start-tdd/elixir/index.md +35 -35
- package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter01.md +202 -202
- package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter02.md +246 -246
- package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter03.md +218 -218
- package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter04.md +179 -179
- package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter05.md +267 -267
- package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter06.md +190 -190
- package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter07.md +161 -161
- package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter08.md +175 -175
- package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter09.md +222 -222
- package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter10.md +189 -189
- package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter11.md +212 -212
- package/lib/assets/docs/article/getting-start-tdd/fsharp/chapter12.md +215 -215
- package/lib/assets/docs/article/getting-start-tdd/fsharp/index.md +71 -71
- package/lib/assets/docs/article/getting-start-tdd/go/01-todo-list-and-first-test.md +213 -213
- package/lib/assets/docs/article/getting-start-tdd/go/02-fake-it-and-triangulation.md +302 -302
- package/lib/assets/docs/article/getting-start-tdd/go/03-obvious-implementation-and-refactoring.md +339 -339
- package/lib/assets/docs/article/getting-start-tdd/go/04-version-control-and-conventional-commits.md +112 -112
- package/lib/assets/docs/article/getting-start-tdd/go/05-package-management-and-static-analysis.md +272 -272
- package/lib/assets/docs/article/getting-start-tdd/go/06-task-runner-and-ci-cd.md +233 -233
- package/lib/assets/docs/article/getting-start-tdd/go/07-encapsulation-and-polymorphism.md +394 -394
- package/lib/assets/docs/article/getting-start-tdd/go/08-design-patterns.md +422 -422
- package/lib/assets/docs/article/getting-start-tdd/go/09-solid-principles-and-module-design.md +400 -400
- package/lib/assets/docs/article/getting-start-tdd/go/10-higher-order-functions-and-composition.md +226 -226
- package/lib/assets/docs/article/getting-start-tdd/go/11-immutable-data-and-pipeline.md +296 -296
- package/lib/assets/docs/article/getting-start-tdd/go/12-error-handling-and-type-safety.md +411 -411
- package/lib/assets/docs/article/getting-start-tdd/go/index.md +83 -83
- package/lib/assets/docs/article/getting-start-tdd/haskell/01-todo-list-and-first-test.md +279 -279
- package/lib/assets/docs/article/getting-start-tdd/haskell/02-fake-it-and-triangulation.md +337 -337
- package/lib/assets/docs/article/getting-start-tdd/haskell/03-obvious-implementation-and-refactoring.md +257 -257
- package/lib/assets/docs/article/getting-start-tdd/haskell/04-version-control-and-conventional-commits.md +182 -182
- package/lib/assets/docs/article/getting-start-tdd/haskell/05-package-management-and-static-analysis.md +313 -313
- package/lib/assets/docs/article/getting-start-tdd/haskell/06-task-runner-and-ci-cd.md +309 -309
- package/lib/assets/docs/article/getting-start-tdd/haskell/07-algebraic-data-types-and-type-classes.md +412 -412
- package/lib/assets/docs/article/getting-start-tdd/haskell/08-pattern-matching-and-guards.md +390 -390
- package/lib/assets/docs/article/getting-start-tdd/haskell/09-module-design-and-smart-constructors.md +461 -461
- package/lib/assets/docs/article/getting-start-tdd/haskell/10-higher-order-functions-and-currying.md +434 -434
- package/lib/assets/docs/article/getting-start-tdd/haskell/11-function-composition-and-point-free.md +392 -392
- package/lib/assets/docs/article/getting-start-tdd/haskell/12-monad-and-error-handling.md +631 -631
- package/lib/assets/docs/article/getting-start-tdd/haskell/index.md +49 -49
- package/lib/assets/docs/article/getting-start-tdd/index.md +93 -93
- package/lib/assets/docs/article/getting-start-tdd/integration/01-language-overview.md +375 -375
- package/lib/assets/docs/article/getting-start-tdd/integration/02-test-framework-comparison.md +349 -349
- package/lib/assets/docs/article/getting-start-tdd/integration/03-tdd-pattern-comparison.md +445 -445
- package/lib/assets/docs/article/getting-start-tdd/integration/04-type-system-comparison.md +409 -409
- package/lib/assets/docs/article/getting-start-tdd/integration/05-dev-environment-comparison.md +330 -330
- package/lib/assets/docs/article/getting-start-tdd/integration/06-learning-roadmap.md +290 -290
- package/lib/assets/docs/article/getting-start-tdd/integration/index.md +69 -69
- package/lib/assets/docs/article/getting-start-tdd/java/01-todo-list-and-first-test.md +234 -234
- package/lib/assets/docs/article/getting-start-tdd/java/02-fake-it-and-triangulation.md +261 -261
- package/lib/assets/docs/article/getting-start-tdd/java/03-obvious-implementation-and-refactoring.md +185 -185
- package/lib/assets/docs/article/getting-start-tdd/java/04-version-control-and-conventional-commits.md +115 -115
- package/lib/assets/docs/article/getting-start-tdd/java/05-package-management-and-static-analysis.md +382 -382
- package/lib/assets/docs/article/getting-start-tdd/java/06-task-runner-and-ci-cd.md +272 -272
- package/lib/assets/docs/article/getting-start-tdd/java/07-encapsulation-and-polymorphism.md +626 -626
- package/lib/assets/docs/article/getting-start-tdd/java/08-design-patterns.md +393 -393
- package/lib/assets/docs/article/getting-start-tdd/java/09-solid-principles-and-module-design.md +310 -310
- package/lib/assets/docs/article/getting-start-tdd/java/10-higher-order-functions-and-composition.md +188 -188
- package/lib/assets/docs/article/getting-start-tdd/java/11-immutable-data-and-pipeline.md +167 -167
- package/lib/assets/docs/article/getting-start-tdd/java/12-error-handling-and-type-safety.md +205 -205
- package/lib/assets/docs/article/getting-start-tdd/java/index.md +61 -61
- package/lib/assets/docs/article/getting-start-tdd/node/01-todo-list-and-first-test.md +244 -244
- package/lib/assets/docs/article/getting-start-tdd/node/02-fake-it-and-triangulation.md +262 -262
- package/lib/assets/docs/article/getting-start-tdd/node/03-obvious-implementation-and-refactoring.md +169 -169
- package/lib/assets/docs/article/getting-start-tdd/node/04-version-control-and-conventional-commits.md +112 -112
- package/lib/assets/docs/article/getting-start-tdd/node/05-package-management-and-static-analysis.md +314 -314
- package/lib/assets/docs/article/getting-start-tdd/node/06-task-runner-and-ci-cd.md +235 -235
- package/lib/assets/docs/article/getting-start-tdd/node/07-encapsulation-and-polymorphism.md +327 -327
- package/lib/assets/docs/article/getting-start-tdd/node/08-design-patterns.md +322 -322
- package/lib/assets/docs/article/getting-start-tdd/node/09-solid-principles-and-module-design.md +285 -285
- package/lib/assets/docs/article/getting-start-tdd/node/10-higher-order-functions-and-composition.md +199 -199
- package/lib/assets/docs/article/getting-start-tdd/node/11-immutable-data-and-pipeline.md +207 -207
- package/lib/assets/docs/article/getting-start-tdd/node/12-error-handling-and-type-safety.md +295 -295
- package/lib/assets/docs/article/getting-start-tdd/node/index.md +56 -56
- package/lib/assets/docs/article/getting-start-tdd/php/01-todo-list-and-first-test.md +259 -259
- package/lib/assets/docs/article/getting-start-tdd/php/02-fake-it-and-triangulation.md +200 -200
- package/lib/assets/docs/article/getting-start-tdd/php/03-obvious-implementation-and-refactoring.md +248 -248
- package/lib/assets/docs/article/getting-start-tdd/php/04-version-control-and-conventional-commits.md +141 -141
- package/lib/assets/docs/article/getting-start-tdd/php/05-package-management-and-static-analysis.md +410 -410
- package/lib/assets/docs/article/getting-start-tdd/php/06-task-runner-and-ci-cd.md +321 -321
- package/lib/assets/docs/article/getting-start-tdd/php/07-encapsulation-and-polymorphism.md +372 -372
- package/lib/assets/docs/article/getting-start-tdd/php/08-design-patterns.md +453 -453
- package/lib/assets/docs/article/getting-start-tdd/php/09-solid-principles-and-module-design.md +460 -460
- package/lib/assets/docs/article/getting-start-tdd/php/10-higher-order-functions-and-composition.md +182 -182
- package/lib/assets/docs/article/getting-start-tdd/php/11-immutable-data-and-pipeline.md +266 -266
- package/lib/assets/docs/article/getting-start-tdd/php/12-error-handling-and-type-safety.md +308 -308
- package/lib/assets/docs/article/getting-start-tdd/php/index.md +84 -84
- package/lib/assets/docs/article/getting-start-tdd/python/01-todo-list-and-first-test.md +201 -201
- package/lib/assets/docs/article/getting-start-tdd/python/02-fake-it-and-triangulation.md +247 -247
- package/lib/assets/docs/article/getting-start-tdd/python/03-obvious-implementation-and-refactoring.md +199 -199
- package/lib/assets/docs/article/getting-start-tdd/python/04-version-control-and-conventional-commits.md +87 -87
- package/lib/assets/docs/article/getting-start-tdd/python/05-package-management-and-static-analysis.md +274 -274
- package/lib/assets/docs/article/getting-start-tdd/python/06-task-runner-and-ci-cd.md +190 -190
- package/lib/assets/docs/article/getting-start-tdd/python/07-encapsulation-and-polymorphism.md +208 -208
- package/lib/assets/docs/article/getting-start-tdd/python/08-design-patterns.md +172 -172
- package/lib/assets/docs/article/getting-start-tdd/python/09-solid-principles-and-module-design.md +130 -130
- package/lib/assets/docs/article/getting-start-tdd/python/10-higher-order-functions-and-composition.md +122 -122
- package/lib/assets/docs/article/getting-start-tdd/python/11-immutable-data-and-pipeline.md +116 -116
- package/lib/assets/docs/article/getting-start-tdd/python/12-error-handling-and-type-safety.md +126 -126
- package/lib/assets/docs/article/getting-start-tdd/python/index.md +55 -55
- package/lib/assets/docs/article/getting-start-tdd/ruby/01-todo-list-and-first-test.md +231 -231
- package/lib/assets/docs/article/getting-start-tdd/ruby/02-fake-it-and-triangulation.md +238 -238
- package/lib/assets/docs/article/getting-start-tdd/ruby/03-obvious-implementation-and-refactoring.md +228 -228
- package/lib/assets/docs/article/getting-start-tdd/ruby/04-version-control-and-conventional-commits.md +112 -112
- package/lib/assets/docs/article/getting-start-tdd/ruby/05-package-management-and-static-analysis.md +287 -287
- package/lib/assets/docs/article/getting-start-tdd/ruby/06-task-runner-and-ci-cd.md +248 -248
- package/lib/assets/docs/article/getting-start-tdd/ruby/07-encapsulation-and-polymorphism.md +279 -279
- package/lib/assets/docs/article/getting-start-tdd/ruby/08-design-patterns.md +329 -329
- package/lib/assets/docs/article/getting-start-tdd/ruby/09-solid-principles-and-module-design.md +196 -196
- package/lib/assets/docs/article/getting-start-tdd/ruby/10-higher-order-functions-and-composition.md +175 -175
- package/lib/assets/docs/article/getting-start-tdd/ruby/11-immutable-data-and-pipeline.md +237 -237
- package/lib/assets/docs/article/getting-start-tdd/ruby/12-error-handling-and-type-safety.md +398 -398
- package/lib/assets/docs/article/getting-start-tdd/ruby/index.md +83 -83
- package/lib/assets/docs/article/getting-start-tdd/rust/01-todo-list-and-first-test.md +211 -211
- package/lib/assets/docs/article/getting-start-tdd/rust/02-fake-it-and-triangulation.md +264 -264
- package/lib/assets/docs/article/getting-start-tdd/rust/03-obvious-implementation-and-refactoring.md +233 -233
- package/lib/assets/docs/article/getting-start-tdd/rust/04-version-control-and-conventional-commits.md +92 -92
- package/lib/assets/docs/article/getting-start-tdd/rust/05-package-management-and-static-analysis.md +212 -212
- package/lib/assets/docs/article/getting-start-tdd/rust/06-task-runner-and-ci-cd.md +164 -164
- package/lib/assets/docs/article/getting-start-tdd/rust/07-encapsulation-and-polymorphism.md +142 -142
- package/lib/assets/docs/article/getting-start-tdd/rust/08-design-patterns.md +145 -145
- package/lib/assets/docs/article/getting-start-tdd/rust/09-solid-principles-and-module-design.md +110 -110
- package/lib/assets/docs/article/getting-start-tdd/rust/10-higher-order-functions-and-composition.md +94 -94
- package/lib/assets/docs/article/getting-start-tdd/rust/11-immutable-data-and-pipeline.md +105 -105
- package/lib/assets/docs/article/getting-start-tdd/rust/12-error-handling-and-type-safety.md +112 -112
- package/lib/assets/docs/article/getting-start-tdd/rust/index.md +83 -83
- package/lib/assets/docs/article/getting-start-tdd/scala/01-todo-list-and-first-test.md +111 -111
- package/lib/assets/docs/article/getting-start-tdd/scala/02-fake-it-and-triangulation.md +107 -107
- package/lib/assets/docs/article/getting-start-tdd/scala/03-obvious-implementation-and-refactoring.md +99 -99
- package/lib/assets/docs/article/getting-start-tdd/scala/04-version-control-and-conventional-commits.md +123 -123
- package/lib/assets/docs/article/getting-start-tdd/scala/05-package-management-and-static-analysis.md +196 -196
- package/lib/assets/docs/article/getting-start-tdd/scala/06-task-runner-and-ci-cd.md +186 -186
- package/lib/assets/docs/article/getting-start-tdd/scala/07-case-classes-and-traits.md +139 -139
- package/lib/assets/docs/article/getting-start-tdd/scala/08-pattern-matching-and-sealed-traits.md +106 -106
- package/lib/assets/docs/article/getting-start-tdd/scala/09-packages-and-module-design.md +75 -75
- package/lib/assets/docs/article/getting-start-tdd/scala/10-higher-order-functions-and-composition.md +104 -104
- package/lib/assets/docs/article/getting-start-tdd/scala/11-collections-and-lazy-evaluation.md +94 -94
- package/lib/assets/docs/article/getting-start-tdd/scala/12-error-handling-and-type-safety.md +92 -92
- package/lib/assets/docs/article/getting-start-tdd/scala/index.md +65 -65
- package/lib/assets/docs/article/grokking-concurrency/all/index.md +404 -404
- package/lib/assets/docs/article/grokking-concurrency/all/part-1-ch02-sequential.md +554 -554
- package/lib/assets/docs/article/grokking-concurrency/all/part-2-ch04-05-threads.md +469 -469
- package/lib/assets/docs/article/grokking-concurrency/all/part-3-ch06-multitasking.md +520 -520
- package/lib/assets/docs/article/grokking-concurrency/all/part-4-ch07-parallel-patterns.md +420 -420
- package/lib/assets/docs/article/grokking-concurrency/all/part-5-ch08-09-synchronization.md +510 -510
- package/lib/assets/docs/article/grokking-concurrency/all/part-6-ch10-11-nonblocking-io.md +435 -435
- package/lib/assets/docs/article/grokking-concurrency/all/part-7-ch12-async.md +465 -465
- package/lib/assets/docs/article/grokking-concurrency/all/part-8-ch13-mapreduce.md +377 -377
- package/lib/assets/docs/article/grokking-concurrency/clojure/index.md +116 -116
- package/lib/assets/docs/article/grokking-concurrency/clojure/part-1.md +108 -108
- package/lib/assets/docs/article/grokking-concurrency/clojure/part-2.md +101 -101
- package/lib/assets/docs/article/grokking-concurrency/clojure/part-3.md +122 -122
- package/lib/assets/docs/article/grokking-concurrency/clojure/part-4.md +123 -123
- package/lib/assets/docs/article/grokking-concurrency/clojure/part-5.md +118 -118
- package/lib/assets/docs/article/grokking-concurrency/clojure/part-6.md +89 -89
- package/lib/assets/docs/article/grokking-concurrency/clojure/part-7.md +100 -100
- package/lib/assets/docs/article/grokking-concurrency/clojure/part-8.md +120 -120
- package/lib/assets/docs/article/grokking-concurrency/csharp/index.md +101 -101
- package/lib/assets/docs/article/grokking-concurrency/csharp/part-1.md +97 -97
- package/lib/assets/docs/article/grokking-concurrency/csharp/part-2.md +123 -123
- package/lib/assets/docs/article/grokking-concurrency/csharp/part-3.md +101 -101
- package/lib/assets/docs/article/grokking-concurrency/csharp/part-4.md +112 -112
- package/lib/assets/docs/article/grokking-concurrency/csharp/part-5.md +99 -99
- package/lib/assets/docs/article/grokking-concurrency/csharp/part-6.md +61 -61
- package/lib/assets/docs/article/grokking-concurrency/csharp/part-7.md +84 -84
- package/lib/assets/docs/article/grokking-concurrency/csharp/part-8.md +92 -92
- package/lib/assets/docs/article/grokking-concurrency/fsharp/index.md +65 -65
- package/lib/assets/docs/article/grokking-concurrency/fsharp/part-1.md +80 -80
- package/lib/assets/docs/article/grokking-concurrency/fsharp/part-2.md +103 -103
- package/lib/assets/docs/article/grokking-concurrency/fsharp/part-3.md +94 -94
- package/lib/assets/docs/article/grokking-concurrency/fsharp/part-4.md +110 -110
- package/lib/assets/docs/article/grokking-concurrency/fsharp/part-5.md +104 -104
- package/lib/assets/docs/article/grokking-concurrency/fsharp/part-6.md +93 -93
- package/lib/assets/docs/article/grokking-concurrency/fsharp/part-7.md +121 -121
- package/lib/assets/docs/article/grokking-concurrency/fsharp/part-8.md +107 -107
- package/lib/assets/docs/article/grokking-concurrency/haskell/index.md +248 -248
- package/lib/assets/docs/article/grokking-concurrency/haskell/part-1.md +96 -96
- package/lib/assets/docs/article/grokking-concurrency/haskell/part-2.md +96 -96
- package/lib/assets/docs/article/grokking-concurrency/haskell/part-3.md +91 -91
- package/lib/assets/docs/article/grokking-concurrency/haskell/part-4.md +106 -106
- package/lib/assets/docs/article/grokking-concurrency/haskell/part-5.md +99 -99
- package/lib/assets/docs/article/grokking-concurrency/haskell/part-6.md +95 -95
- package/lib/assets/docs/article/grokking-concurrency/haskell/part-7.md +111 -111
- package/lib/assets/docs/article/grokking-concurrency/haskell/part-8.md +118 -118
- package/lib/assets/docs/article/grokking-concurrency/index.md +66 -66
- package/lib/assets/docs/article/grokking-concurrency/java/index.md +102 -102
- package/lib/assets/docs/article/grokking-concurrency/java/part-1.md +308 -308
- package/lib/assets/docs/article/grokking-concurrency/java/part-2.md +334 -334
- package/lib/assets/docs/article/grokking-concurrency/java/part-3.md +221 -221
- package/lib/assets/docs/article/grokking-concurrency/java/part-4.md +213 -213
- package/lib/assets/docs/article/grokking-concurrency/java/part-5.md +112 -112
- package/lib/assets/docs/article/grokking-concurrency/java/part-6.md +69 -69
- package/lib/assets/docs/article/grokking-concurrency/java/part-7.md +101 -101
- package/lib/assets/docs/article/grokking-concurrency/java/part-8.md +101 -101
- package/lib/assets/docs/article/grokking-concurrency/python/index.md +313 -313
- package/lib/assets/docs/article/grokking-concurrency/python/part-1.md +239 -239
- package/lib/assets/docs/article/grokking-concurrency/python/part-2.md +418 -418
- package/lib/assets/docs/article/grokking-concurrency/python/part-3.md +227 -227
- package/lib/assets/docs/article/grokking-concurrency/python/part-4.md +299 -299
- package/lib/assets/docs/article/grokking-concurrency/python/part-5.md +315 -315
- package/lib/assets/docs/article/grokking-concurrency/python/part-6.md +297 -297
- package/lib/assets/docs/article/grokking-concurrency/python/part-7.md +314 -314
- package/lib/assets/docs/article/grokking-concurrency/python/part-8.md +360 -360
- package/lib/assets/docs/article/grokking-concurrency/rust/index.md +270 -270
- package/lib/assets/docs/article/grokking-concurrency/rust/part-1.md +108 -108
- package/lib/assets/docs/article/grokking-concurrency/rust/part-2.md +120 -120
- package/lib/assets/docs/article/grokking-concurrency/rust/part-3.md +126 -126
- package/lib/assets/docs/article/grokking-concurrency/rust/part-4.md +175 -175
- package/lib/assets/docs/article/grokking-concurrency/rust/part-5.md +158 -158
- package/lib/assets/docs/article/grokking-concurrency/rust/part-6.md +94 -94
- package/lib/assets/docs/article/grokking-concurrency/rust/part-7.md +133 -133
- package/lib/assets/docs/article/grokking-concurrency/rust/part-8.md +155 -155
- package/lib/assets/docs/article/grokking-concurrency/scala/index.md +69 -69
- package/lib/assets/docs/article/grokking-concurrency/scala/part-1.md +78 -78
- package/lib/assets/docs/article/grokking-concurrency/scala/part-2.md +112 -112
- package/lib/assets/docs/article/grokking-concurrency/scala/part-3.md +93 -93
- package/lib/assets/docs/article/grokking-concurrency/scala/part-4.md +110 -110
- package/lib/assets/docs/article/grokking-concurrency/scala/part-5.md +119 -119
- package/lib/assets/docs/article/grokking-concurrency/scala/part-6.md +83 -83
- package/lib/assets/docs/article/grokking-concurrency/scala/part-7.md +131 -131
- package/lib/assets/docs/article/grokking-concurrency/scala/part-8.md +129 -129
- package/lib/assets/docs/article/grokkingfp/all/index.md +368 -368
- package/lib/assets/docs/article/grokkingfp/all/part-1-ch01-fp-introduction.md +530 -530
- package/lib/assets/docs/article/grokkingfp/all/part-1-ch02-pure-functions.md +923 -923
- package/lib/assets/docs/article/grokkingfp/all/part-2-ch03-immutable-data.md +1128 -1128
- package/lib/assets/docs/article/grokkingfp/all/part-2-ch04-higher-order-functions.md +1104 -1104
- package/lib/assets/docs/article/grokkingfp/all/part-2-ch05-flatmap.md +1026 -1026
- package/lib/assets/docs/article/grokkingfp/all/part-3-ch06-option.md +785 -785
- package/lib/assets/docs/article/grokkingfp/all/part-3-ch07-either-adt.md +871 -871
- package/lib/assets/docs/article/grokkingfp/all/part-4-ch08-io-monad.md +972 -972
- package/lib/assets/docs/article/grokkingfp/all/part-4-ch09-streams.md +926 -926
- package/lib/assets/docs/article/grokkingfp/all/part-5-ch10-concurrency.md +870 -870
- package/lib/assets/docs/article/grokkingfp/all/part-6-ch11-application.md +715 -715
- package/lib/assets/docs/article/grokkingfp/all/part-6-ch12-testing.md +626 -626
- package/lib/assets/docs/article/grokkingfp/all/writing-plan.md +712 -712
- package/lib/assets/docs/article/grokkingfp/clojure/index.md +276 -276
- package/lib/assets/docs/article/grokkingfp/clojure/part-1.md +667 -667
- package/lib/assets/docs/article/grokkingfp/clojure/part-2.md +643 -643
- package/lib/assets/docs/article/grokkingfp/clojure/part-3.md +620 -620
- package/lib/assets/docs/article/grokkingfp/clojure/part-4.md +697 -697
- package/lib/assets/docs/article/grokkingfp/clojure/part-5.md +751 -751
- package/lib/assets/docs/article/grokkingfp/clojure/part-6.md +721 -721
- package/lib/assets/docs/article/grokkingfp/csharp/index.md +246 -246
- package/lib/assets/docs/article/grokkingfp/csharp/part-1.md +811 -811
- package/lib/assets/docs/article/grokkingfp/csharp/part-2.md +971 -971
- package/lib/assets/docs/article/grokkingfp/csharp/part-3.md +981 -981
- package/lib/assets/docs/article/grokkingfp/csharp/part-4.md +949 -949
- package/lib/assets/docs/article/grokkingfp/csharp/part-5.md +947 -947
- package/lib/assets/docs/article/grokkingfp/csharp/part-6.md +739 -739
- package/lib/assets/docs/article/grokkingfp/elixir/index.md +203 -203
- package/lib/assets/docs/article/grokkingfp/elixir/part-1.md +712 -712
- package/lib/assets/docs/article/grokkingfp/elixir/part-2.md +838 -838
- package/lib/assets/docs/article/grokkingfp/elixir/part-3.md +985 -985
- package/lib/assets/docs/article/grokkingfp/elixir/part-4.md +974 -974
- package/lib/assets/docs/article/grokkingfp/elixir/part-5.md +1286 -1286
- package/lib/assets/docs/article/grokkingfp/elixir/part-6.md +1049 -1049
- package/lib/assets/docs/article/grokkingfp/fsharp/index.md +210 -210
- package/lib/assets/docs/article/grokkingfp/fsharp/part-1.md +714 -714
- package/lib/assets/docs/article/grokkingfp/fsharp/part-2.md +961 -961
- package/lib/assets/docs/article/grokkingfp/fsharp/part-3.md +972 -972
- package/lib/assets/docs/article/grokkingfp/fsharp/part-4.md +832 -832
- package/lib/assets/docs/article/grokkingfp/fsharp/part-5.md +911 -911
- package/lib/assets/docs/article/grokkingfp/fsharp/part-6.md +922 -922
- package/lib/assets/docs/article/grokkingfp/haskell/index.md +234 -234
- package/lib/assets/docs/article/grokkingfp/haskell/part-1.md +591 -591
- package/lib/assets/docs/article/grokkingfp/haskell/part-2.md +866 -866
- package/lib/assets/docs/article/grokkingfp/haskell/part-3.md +915 -915
- package/lib/assets/docs/article/grokkingfp/haskell/part-4.md +878 -878
- package/lib/assets/docs/article/grokkingfp/haskell/part-5.md +845 -845
- package/lib/assets/docs/article/grokkingfp/haskell/part-6.md +844 -844
- package/lib/assets/docs/article/grokkingfp/index.md +143 -143
- package/lib/assets/docs/article/grokkingfp/java/index.md +211 -211
- package/lib/assets/docs/article/grokkingfp/java/part-1.md +648 -648
- package/lib/assets/docs/article/grokkingfp/java/part-2.md +675 -675
- package/lib/assets/docs/article/grokkingfp/java/part-3.md +672 -672
- package/lib/assets/docs/article/grokkingfp/java/part-4.md +771 -771
- package/lib/assets/docs/article/grokkingfp/java/part-5.md +959 -959
- package/lib/assets/docs/article/grokkingfp/java/part-6.md +1328 -1328
- package/lib/assets/docs/article/grokkingfp/python/index.md +258 -258
- package/lib/assets/docs/article/grokkingfp/python/part-1.md +443 -443
- package/lib/assets/docs/article/grokkingfp/python/part-2.md +958 -958
- package/lib/assets/docs/article/grokkingfp/python/part-3.md +1004 -1004
- package/lib/assets/docs/article/grokkingfp/python/part-4.md +765 -765
- package/lib/assets/docs/article/grokkingfp/python/part-5.md +747 -747
- package/lib/assets/docs/article/grokkingfp/python/part-6.md +861 -861
- package/lib/assets/docs/article/grokkingfp/ruby/index.md +330 -330
- package/lib/assets/docs/article/grokkingfp/ruby/part-1.md +755 -755
- package/lib/assets/docs/article/grokkingfp/ruby/part-2.md +938 -938
- package/lib/assets/docs/article/grokkingfp/ruby/part-3.md +946 -946
- package/lib/assets/docs/article/grokkingfp/ruby/part-4.md +921 -921
- package/lib/assets/docs/article/grokkingfp/ruby/part-5.md +908 -908
- package/lib/assets/docs/article/grokkingfp/ruby/part-6.md +1412 -1412
- package/lib/assets/docs/article/grokkingfp/rust/index.md +242 -242
- package/lib/assets/docs/article/grokkingfp/rust/part-1.md +634 -634
- package/lib/assets/docs/article/grokkingfp/rust/part-2.md +1060 -1060
- package/lib/assets/docs/article/grokkingfp/rust/part-3.md +994 -994
- package/lib/assets/docs/article/grokkingfp/rust/part-4.md +573 -573
- package/lib/assets/docs/article/grokkingfp/rust/part-5.md +705 -705
- package/lib/assets/docs/article/grokkingfp/rust/part-6.md +508 -508
- package/lib/assets/docs/article/grokkingfp/scala/index.md +171 -171
- package/lib/assets/docs/article/grokkingfp/scala/part-1.md +543 -543
- package/lib/assets/docs/article/grokkingfp/scala/part-2.md +946 -946
- package/lib/assets/docs/article/grokkingfp/scala/part-3.md +919 -919
- package/lib/assets/docs/article/grokkingfp/scala/part-4.md +742 -742
- package/lib/assets/docs/article/grokkingfp/scala/part-5.md +722 -722
- package/lib/assets/docs/article/grokkingfp/scala/part-6.md +867 -867
- package/lib/assets/docs/article/grokkingfp/typescript/index.md +273 -273
- package/lib/assets/docs/article/grokkingfp/typescript/part-1.md +561 -561
- package/lib/assets/docs/article/grokkingfp/typescript/part-2.md +1129 -1129
- package/lib/assets/docs/article/grokkingfp/typescript/part-3.md +842 -842
- package/lib/assets/docs/article/grokkingfp/typescript/part-4.md +1087 -1087
- package/lib/assets/docs/article/grokkingfp/typescript/part-5.md +717 -717
- package/lib/assets/docs/article/grokkingfp/typescript/part-6.md +982 -982
- package/lib/assets/docs/article/practical-database-design/index.md +121 -121
- package/lib/assets/docs/article/practical-database-design/part1/chapter01.md +288 -288
- package/lib/assets/docs/article/practical-database-design/part1/chapter02.md +518 -518
- package/lib/assets/docs/article/practical-database-design/part1/chapter03.md +557 -557
- package/lib/assets/docs/article/practical-database-design/part2/chapter04.md +924 -924
- package/lib/assets/docs/article/practical-database-design/part2/chapter05.md +1627 -1627
- package/lib/assets/docs/article/practical-database-design/part2/chapter06.md +2716 -2716
- package/lib/assets/docs/article/practical-database-design/part2/chapter07.md +2082 -2082
- package/lib/assets/docs/article/practical-database-design/part2/chapter08.md +2105 -2105
- package/lib/assets/docs/article/practical-database-design/part2/chapter09.md +2031 -2031
- package/lib/assets/docs/article/practical-database-design/part2/chapter10.md +1387 -1387
- package/lib/assets/docs/article/practical-database-design/part2/chapter11.md +1677 -1677
- package/lib/assets/docs/article/practical-database-design/part2/chapter12.md +1417 -1417
- package/lib/assets/docs/article/practical-database-design/part2/chapter13.md +1434 -1434
- package/lib/assets/docs/article/practical-database-design/part3/chapter14.md +667 -667
- package/lib/assets/docs/article/practical-database-design/part3/chapter15.md +1625 -1625
- package/lib/assets/docs/article/practical-database-design/part3/chapter16.md +1915 -1915
- package/lib/assets/docs/article/practical-database-design/part3/chapter17.md +1708 -1708
- package/lib/assets/docs/article/practical-database-design/part3/chapter18.md +2095 -2095
- package/lib/assets/docs/article/practical-database-design/part3/chapter19.md +1123 -1123
- package/lib/assets/docs/article/practical-database-design/part3/chapter20.md +1031 -1031
- package/lib/assets/docs/article/practical-database-design/part3/chapter21.md +1382 -1382
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter14-orm.md +991 -991
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter15-orm.md +1300 -1300
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter16-orm.md +1166 -1166
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter17-orm.md +1584 -1584
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter18-orm.md +1183 -1183
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter19-orm.md +1016 -1016
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter20-orm.md +1753 -1753
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter21-orm.md +1447 -1447
- package/lib/assets/docs/article/practical-database-design/part3-orm/chapter22-orm.md +1878 -1878
- package/lib/assets/docs/article/practical-database-design/part4/chapter22.md +965 -965
- package/lib/assets/docs/article/practical-database-design/part4/chapter23.md +2069 -2069
- package/lib/assets/docs/article/practical-database-design/part4/chapter24.md +2439 -2439
- package/lib/assets/docs/article/practical-database-design/part4/chapter25.md +3661 -3661
- package/lib/assets/docs/article/practical-database-design/part4/chapter26.md +2916 -2916
- package/lib/assets/docs/article/practical-database-design/part4/chapter27.md +3105 -3105
- package/lib/assets/docs/article/practical-database-design/part4/chapter28.md +2697 -2697
- package/lib/assets/docs/article/practical-database-design/part4/chapter29.md +2544 -2544
- package/lib/assets/docs/article/practical-database-design/part4/chapter30.md +2180 -2180
- package/lib/assets/docs/article/practical-database-design/part4/chapter31.md +1192 -1192
- package/lib/assets/docs/article/practical-database-design/part4/chapter32.md +2101 -2101
- package/lib/assets/docs/article/practical-database-design/part5/chapter33.md +1032 -1032
- package/lib/assets/docs/article/practical-database-design/part5/chapter34.md +1609 -1609
- package/lib/assets/docs/article/practical-database-design/part5/chapter35.md +1453 -1453
- package/lib/assets/docs/article/practical-database-design/part5/chapter36.md +1292 -1292
- package/lib/assets/docs/article/practical-database-design/part5/chapter37.md +1470 -1470
- package/lib/assets/docs/article/practical-database-design/part5/chapter38.md +1698 -1698
- package/lib/assets/docs/article/practical-database-design/part5/chapter39.md +2334 -2334
- package/lib/assets/docs/article/practical-database-design/study/study2-1.md +1693 -1693
- package/lib/assets/docs/article/practical-database-design/study/study2-2.md +1347 -1347
- package/lib/assets/docs/article/practical-database-design/study/study2-3.md +2044 -2044
- package/lib/assets/docs/article/practical-database-design/study/study2-4.md +2229 -2229
- package/lib/assets/docs/article/practical-database-design/study/study2-5.md +2418 -2418
- package/lib/assets/docs/article/practical-database-design/study/study3-1.md +2205 -2205
- package/lib/assets/docs/article/practical-database-design/study/study3-2.md +2221 -2221
- package/lib/assets/docs/article/practical-database-design/study/study3-3.md +2253 -2253
- package/lib/assets/docs/article/practical-database-design/study/study3-4.md +2106 -2106
- package/lib/assets/docs/article/practical-database-design/study/study3-5.md +2507 -2507
- package/lib/assets/docs/article/practical-database-design/study/study4-1.md +2587 -2587
- package/lib/assets/docs/article/practical-database-design/study/study4-2.md +2075 -2075
- package/lib/assets/docs/article/practical-database-design/study/study4-3.md +1805 -1805
- package/lib/assets/docs/article/practical-database-design/study/study4-4.md +1895 -1895
- package/lib/assets/docs/article/practical-database-design/study/study4-5.md +2878 -2878
- package/lib/assets/docs/assets/css/extra.css +29 -29
- package/lib/assets/docs/assets/js/extra.js +44 -44
- package/lib/assets/docs/development/index.md +39 -39
- package/lib/assets/docs/operation/index.md +11 -11
- 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 +19 -5
- 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
- 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 -581
- 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
- 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
- package/lib/assets/docs/reference/UI/350/250/255/350/250/210/343/202/254/343/202/244/343/203/211.md +450 -450
- package/lib/assets/docs/reference/images/Ansoff.drawio.svg +3 -3
- package/lib/assets/docs/reference/images/BrandBasicStrategy.drawio.svg +3 -3
- package/lib/assets/docs/reference/images/BrandCategorization.drawio.svg +3 -3
- package/lib/assets/docs/reference/images/BrandRecurutementStrategy.drawio.svg +3 -3
- package/lib/assets/docs/reference/images/BrandValue.drawio.svg +3 -3
- package/lib/assets/docs/reference/images/BusinessActivitiy.svg +3 -3
- package/lib/assets/docs/reference/images/HRM.drawio.svg +3 -3
- package/lib/assets/docs/reference/images/MarketingStructure.drawio.svg +3 -3
- package/lib/assets/docs/reference/images/OrganizationElemnts.svg +3 -3
- package/lib/assets/docs/reference/images/PPM.drawio.svg +3 -3
- package/lib/assets/docs/reference/images/PositioningMap.drawio.svg +3 -3
- package/lib/assets/docs/reference/images/ProductLayer.drawio.svg +3 -3
- package/lib/assets/docs/reference/images/ProductMix.drawio.svg +3 -3
- package/lib/assets/docs/reference/images/SWOT.drawio.svg +3 -3
- package/lib/assets/docs/reference/images/TargetMarket.drawio.svg +3 -3
- package/lib/assets/docs/reference/images/ThreeGenericStrategies.drawio.svg +3 -3
- package/lib/assets/docs/reference/images/VRIO.drawio.svg +3 -3
- package/lib/assets/docs/reference/images/ValueChain.drawio.svg +3 -3
- package/lib/assets/docs/reference/index.md +52 -52
- 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 -250
- 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
- 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
- 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 -550
- 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
- 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
- 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
- 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
- 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
- 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 -689
- 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
- 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 -580
- 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
- package/lib/assets/docs/reference//344/274/201/346/245/255/347/265/214/345/226/266/350/253/226.md +2637 -2637
- 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 -665
- 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
- 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 +518 -518
- package/lib/assets/docs/reference//351/201/213/345/226/266/347/256/241/347/220/206.md +1482 -1482
- 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
- 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
- package/lib/assets/docs/reference//351/226/213/347/231/272/343/202/254/343/202/244/343/203/211.md +299 -299
- 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
- package/lib/assets/docs/review/index.md +5 -5
- package/lib/assets/docs/strategy/index.md +1 -1
- package/lib/assets/docs/template/ADR.md +30 -30
- 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
- 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
- package/lib/assets/docs/template/README.md +50 -50
- package/lib/assets/docs/template/index.md +23 -23
- 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
- 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
- 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
- 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
- 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
- package/lib/assets/docs/template//344/274/201/346/245/255/345/210/206/346/236/220.md +573 -573
- 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 -69
- package/lib/assets/docs/template//350/246/201/344/273/266/345/256/232/347/276/251.md +669 -669
- package/lib/assets/docs/template//350/250/255/350/250/210.md +173 -173
- 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
- package/lib/assets/gulpfile.js +25 -25
- package/lib/assets/mkdocs.yml +136 -136
- package/lib/assets/ops/docker/mkdoc/Dockerfile +19 -19
- package/lib/assets/ops/scripts/journal.js +180 -180
- package/lib/assets/ops/scripts/mkdocs.js +82 -82
- package/lib/assets/ops/scripts/release.js +431 -431
- package/lib/assets/ops/scripts/sonar_local.js +726 -726
- package/lib/assets/ops/scripts/ssh.js +190 -190
- package/lib/assets/ops/scripts/vault.js +299 -299
- package/lib/assets/package-lock.json +1653 -1653
- package/lib/assets/package.json +40 -40
- package/lib/gulpfile.js +37 -37
- package/package.json +41 -41
|
@@ -1,1453 +1,1453 @@
|
|
|
1
|
-
# 第35章:システム間連携パターン
|
|
2
|
-
|
|
3
|
-
本章では、第33章で解説した境界づけられたコンテキストと、第34章で解説したメッセージングパターンを活用して、販売管理・財務会計・生産管理の3つのシステム間の具体的な連携パターンを解説します。
|
|
4
|
-
|
|
5
|
-
---
|
|
6
|
-
|
|
7
|
-
## 35.1 販売管理と財務会計の連携
|
|
8
|
-
|
|
9
|
-
販売管理システムと財務会計システムの連携は、基幹業務システム統合の中核となる部分です。売上、請求、入金などの取引データを正確に会計仕訳へ変換することが求められます。
|
|
10
|
-
|
|
11
|
-
### 連携の全体像
|
|
12
|
-
|
|
13
|
-
```plantuml
|
|
14
|
-
@startuml
|
|
15
|
-
title 販売管理と財務会計の連携全体像
|
|
16
|
-
|
|
17
|
-
package "販売管理システム" as sales {
|
|
18
|
-
rectangle "受注管理" as order
|
|
19
|
-
rectangle "出荷管理" as shipment
|
|
20
|
-
rectangle "売上管理" as sales_mgmt
|
|
21
|
-
rectangle "請求管理" as billing
|
|
22
|
-
rectangle "入金管理" as receipt
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
package "イベントバス" as events {
|
|
26
|
-
collections "売上イベント" as sales_event
|
|
27
|
-
collections "請求イベント" as billing_event
|
|
28
|
-
collections "入金イベント" as receipt_event
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
package "財務会計システム" as accounting {
|
|
32
|
-
rectangle "自動仕訳" as auto_journal
|
|
33
|
-
rectangle "仕訳管理" as journal
|
|
34
|
-
rectangle "残高管理" as balance
|
|
35
|
-
rectangle "決算処理" as closing
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
order --> shipment
|
|
39
|
-
shipment --> sales_mgmt
|
|
40
|
-
sales_mgmt --> billing
|
|
41
|
-
billing --> receipt
|
|
42
|
-
|
|
43
|
-
sales_mgmt --> sales_event : 売上計上
|
|
44
|
-
billing --> billing_event : 請求確定
|
|
45
|
-
receipt --> receipt_event : 入金確認
|
|
46
|
-
|
|
47
|
-
sales_event --> auto_journal
|
|
48
|
-
billing_event --> auto_journal
|
|
49
|
-
receipt_event --> auto_journal
|
|
50
|
-
|
|
51
|
-
auto_journal --> journal
|
|
52
|
-
journal --> balance
|
|
53
|
-
|
|
54
|
-
@enduml
|
|
55
|
-
```
|
|
56
|
-
|
|
57
|
-
### 売上データから仕訳データへの変換
|
|
58
|
-
|
|
59
|
-
売上計上時に発生する仕訳は、売上の種類や取引条件によって異なります。
|
|
60
|
-
|
|
61
|
-
```plantuml
|
|
62
|
-
@startuml
|
|
63
|
-
title 売上から仕訳への変換フロー
|
|
64
|
-
|
|
65
|
-
|販売管理|
|
|
66
|
-
start
|
|
67
|
-
:売上計上;
|
|
68
|
-
:売上イベント発行;
|
|
69
|
-
|
|
70
|
-
|イベントバス|
|
|
71
|
-
:売上イベント受信;
|
|
72
|
-
|
|
73
|
-
|財務会計|
|
|
74
|
-
:仕訳パターン判定;
|
|
75
|
-
note right
|
|
76
|
-
・商品グループ
|
|
77
|
-
・顧客グループ
|
|
78
|
-
・取引条件
|
|
79
|
-
end note
|
|
80
|
-
|
|
81
|
-
:仕訳明細生成;
|
|
82
|
-
note right
|
|
83
|
-
借方:売掛金
|
|
84
|
-
貸方:売上高
|
|
85
|
-
貸方:仮受消費税
|
|
86
|
-
end note
|
|
87
|
-
|
|
88
|
-
:貸借一致検証;
|
|
89
|
-
:仕訳登録;
|
|
90
|
-
:残高更新;
|
|
91
|
-
|
|
92
|
-
stop
|
|
93
|
-
|
|
94
|
-
@enduml
|
|
95
|
-
```
|
|
96
|
-
|
|
97
|
-
#### 売上仕訳の基本パターン
|
|
98
|
-
|
|
99
|
-
```plantuml
|
|
100
|
-
@startuml
|
|
101
|
-
title 売上仕訳の基本パターン
|
|
102
|
-
|
|
103
|
-
object "売上データ" as sales {
|
|
104
|
-
売上番号 = "SLS-2024-001"
|
|
105
|
-
売上日 = "2024/01/15"
|
|
106
|
-
顧客コード = "CUS-001"
|
|
107
|
-
売上金額 = 110,000円
|
|
108
|
-
消費税額 = 10,000円
|
|
109
|
-
税抜金額 = 100,000円
|
|
110
|
-
}
|
|
111
|
-
|
|
112
|
-
object "仕訳伝票" as journal {
|
|
113
|
-
伝票番号 = "JRN-2024-001"
|
|
114
|
-
起票日 = "2024/01/15"
|
|
115
|
-
伝票区分 = "売上仕訳"
|
|
116
|
-
}
|
|
117
|
-
|
|
118
|
-
object "借方明細" as debit {
|
|
119
|
-
勘定科目 = "売掛金"
|
|
120
|
-
金額 = 110,000円
|
|
121
|
-
摘要 = "CUS-001 売上"
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
object "貸方明細1" as credit1 {
|
|
125
|
-
勘定科目 = "売上高"
|
|
126
|
-
金額 = 100,000円
|
|
127
|
-
摘要 = "商品売上"
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
object "貸方明細2" as credit2 {
|
|
131
|
-
勘定科目 = "仮受消費税"
|
|
132
|
-
金額 = 10,000円
|
|
133
|
-
摘要 = "消費税10%"
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
sales --> journal : 変換
|
|
137
|
-
journal --> debit
|
|
138
|
-
journal --> credit1
|
|
139
|
-
journal --> credit2
|
|
140
|
-
|
|
141
|
-
note bottom of journal
|
|
142
|
-
【貸借一致の検証】
|
|
143
|
-
借方合計:110,000円
|
|
144
|
-
貸方合計:110,000円
|
|
145
|
-
差額:0円 ✓
|
|
146
|
-
end note
|
|
147
|
-
|
|
148
|
-
@enduml
|
|
149
|
-
```
|
|
150
|
-
|
|
151
|
-
#### 売上仕訳パターンマスタ
|
|
152
|
-
|
|
153
|
-
```plantuml
|
|
154
|
-
@startuml
|
|
155
|
-
title 自動仕訳パターンマスタの構造
|
|
156
|
-
|
|
157
|
-
entity "自動仕訳パターン" as pattern {
|
|
158
|
-
*パターンID : string
|
|
159
|
-
--
|
|
160
|
-
*取引種別 : string
|
|
161
|
-
商品グループ : string
|
|
162
|
-
顧客グループ : string
|
|
163
|
-
借方科目コード : string
|
|
164
|
-
貸方科目コード : string
|
|
165
|
-
消費税科目コード : string
|
|
166
|
-
適用開始日 : date
|
|
167
|
-
適用終了日 : date
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
entity "勘定科目" as account {
|
|
171
|
-
*科目コード : string
|
|
172
|
-
--
|
|
173
|
-
科目名 : string
|
|
174
|
-
BSPL区分 : string
|
|
175
|
-
貸借区分 : string
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
pattern }o--|| account : 借方科目
|
|
179
|
-
pattern }o--|| account : 貸方科目
|
|
180
|
-
pattern }o--|| account : 消費税科目
|
|
181
|
-
|
|
182
|
-
@enduml
|
|
183
|
-
```
|
|
184
|
-
|
|
185
|
-
<details>
|
|
186
|
-
<summary>仕訳パターンテーブル定義</summary>
|
|
187
|
-
|
|
188
|
-
```sql
|
|
189
|
-
-- 自動仕訳パターンマスタ
|
|
190
|
-
CREATE TABLE 自動仕訳パターン (
|
|
191
|
-
パターンID VARCHAR(20) PRIMARY KEY,
|
|
192
|
-
取引種別 VARCHAR(20) NOT NULL,
|
|
193
|
-
商品グループ VARCHAR(10),
|
|
194
|
-
顧客グループ VARCHAR(10),
|
|
195
|
-
借方科目コード VARCHAR(10) NOT NULL,
|
|
196
|
-
貸方科目コード VARCHAR(10) NOT NULL,
|
|
197
|
-
消費税科目コード VARCHAR(10),
|
|
198
|
-
適用開始日 DATE NOT NULL,
|
|
199
|
-
適用終了日 DATE,
|
|
200
|
-
作成日時 TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
201
|
-
更新日時 TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
202
|
-
FOREIGN KEY (借方科目コード) REFERENCES 勘定科目(科目コード),
|
|
203
|
-
FOREIGN KEY (貸方科目コード) REFERENCES 勘定科目(科目コード),
|
|
204
|
-
FOREIGN KEY (消費税科目コード) REFERENCES 勘定科目(科目コード)
|
|
205
|
-
);
|
|
206
|
-
|
|
207
|
-
-- サンプルデータ
|
|
208
|
-
INSERT INTO 自動仕訳パターン VALUES
|
|
209
|
-
('PTN-SALES-001', '売上', NULL, NULL, '1310', '4110', '2191', '2024-01-01', NULL),
|
|
210
|
-
('PTN-SALES-002', '売上', 'FOOD', NULL, '1310', '4120', '2191', '2024-01-01', NULL),
|
|
211
|
-
('PTN-RETURN-001', '売上返品', NULL, NULL, '4110', '1310', '2191', '2024-01-01', NULL);
|
|
212
|
-
```
|
|
213
|
-
|
|
214
|
-
</details>
|
|
215
|
-
|
|
216
|
-
### 自動仕訳パターンの適用
|
|
217
|
-
|
|
218
|
-
商品グループや顧客グループに応じて、適切な仕訳パターンを自動選択します。
|
|
219
|
-
|
|
220
|
-
```plantuml
|
|
221
|
-
@startuml
|
|
222
|
-
title 自動仕訳パターン判定ロジック
|
|
223
|
-
|
|
224
|
-
start
|
|
225
|
-
|
|
226
|
-
:売上イベント受信;
|
|
227
|
-
|
|
228
|
-
:商品グループ取得;
|
|
229
|
-
:顧客グループ取得;
|
|
230
|
-
|
|
231
|
-
if (特定商品グループ?) then (yes)
|
|
232
|
-
:商品グループ専用\nパターン検索;
|
|
233
|
-
else (no)
|
|
234
|
-
if (特定顧客グループ?) then (yes)
|
|
235
|
-
:顧客グループ専用\nパターン検索;
|
|
236
|
-
else (no)
|
|
237
|
-
:汎用パターン検索;
|
|
238
|
-
endif
|
|
239
|
-
endif
|
|
240
|
-
|
|
241
|
-
if (パターン見つかった?) then (yes)
|
|
242
|
-
:仕訳明細生成;
|
|
243
|
-
:仕訳登録;
|
|
244
|
-
else (no)
|
|
245
|
-
:エラー通知;
|
|
246
|
-
:手動仕訳待ち\nキューに投入;
|
|
247
|
-
endif
|
|
248
|
-
|
|
249
|
-
stop
|
|
250
|
-
|
|
251
|
-
@enduml
|
|
252
|
-
```
|
|
253
|
-
|
|
254
|
-
<details>
|
|
255
|
-
<summary>Java 実装例</summary>
|
|
256
|
-
|
|
257
|
-
```java
|
|
258
|
-
// 自動仕訳パターンリポジトリ
|
|
259
|
-
public interface JournalPatternRepository {
|
|
260
|
-
Optional<JournalPattern> findByTransactionTypeAndGroups(
|
|
261
|
-
TransactionType type,
|
|
262
|
-
String productGroup,
|
|
263
|
-
String customerGroup,
|
|
264
|
-
LocalDate effectiveDate
|
|
265
|
-
);
|
|
266
|
-
}
|
|
267
|
-
|
|
268
|
-
// 自動仕訳サービス
|
|
269
|
-
@Service
|
|
270
|
-
@Transactional
|
|
271
|
-
public class AutoJournalService {
|
|
272
|
-
private final JournalPatternRepository patternRepository;
|
|
273
|
-
private final JournalRepository journalRepository;
|
|
274
|
-
private final AccountRepository accountRepository;
|
|
275
|
-
|
|
276
|
-
@EventListener
|
|
277
|
-
public void handleSalesCompleted(SalesCompletedEvent event) {
|
|
278
|
-
// パターン検索(優先順位:商品グループ > 顧客グループ > 汎用)
|
|
279
|
-
JournalPattern pattern = findPattern(event);
|
|
280
|
-
|
|
281
|
-
// 仕訳伝票生成
|
|
282
|
-
JournalEntry journal = createJournalEntry(event, pattern);
|
|
283
|
-
|
|
284
|
-
// 貸借一致検証
|
|
285
|
-
validateBalance(journal);
|
|
286
|
-
|
|
287
|
-
// 仕訳登録
|
|
288
|
-
journalRepository.save(journal);
|
|
289
|
-
|
|
290
|
-
// 残高更新イベント発行
|
|
291
|
-
publishBalanceUpdateEvent(journal);
|
|
292
|
-
}
|
|
293
|
-
|
|
294
|
-
private JournalPattern findPattern(SalesCompletedEvent event) {
|
|
295
|
-
// 1. 商品グループ + 顧客グループで検索
|
|
296
|
-
Optional<JournalPattern> pattern = patternRepository
|
|
297
|
-
.findByTransactionTypeAndGroups(
|
|
298
|
-
TransactionType.SALES,
|
|
299
|
-
event.productGroup(),
|
|
300
|
-
event.customerGroup(),
|
|
301
|
-
event.salesDate()
|
|
302
|
-
);
|
|
303
|
-
|
|
304
|
-
if (pattern.isPresent()) return pattern.get();
|
|
305
|
-
|
|
306
|
-
// 2. 商品グループのみで検索
|
|
307
|
-
pattern = patternRepository.findByTransactionTypeAndGroups(
|
|
308
|
-
TransactionType.SALES,
|
|
309
|
-
event.productGroup(),
|
|
310
|
-
null,
|
|
311
|
-
event.salesDate()
|
|
312
|
-
);
|
|
313
|
-
|
|
314
|
-
if (pattern.isPresent()) return pattern.get();
|
|
315
|
-
|
|
316
|
-
// 3. 顧客グループのみで検索
|
|
317
|
-
pattern = patternRepository.findByTransactionTypeAndGroups(
|
|
318
|
-
TransactionType.SALES,
|
|
319
|
-
null,
|
|
320
|
-
event.customerGroup(),
|
|
321
|
-
event.salesDate()
|
|
322
|
-
);
|
|
323
|
-
|
|
324
|
-
if (pattern.isPresent()) return pattern.get();
|
|
325
|
-
|
|
326
|
-
// 4. 汎用パターンで検索
|
|
327
|
-
return patternRepository.findByTransactionTypeAndGroups(
|
|
328
|
-
TransactionType.SALES,
|
|
329
|
-
null,
|
|
330
|
-
null,
|
|
331
|
-
event.salesDate()
|
|
332
|
-
).orElseThrow(() -> new PatternNotFoundException(
|
|
333
|
-
"仕訳パターンが見つかりません: " + event.salesId()
|
|
334
|
-
));
|
|
335
|
-
}
|
|
336
|
-
|
|
337
|
-
private JournalEntry createJournalEntry(
|
|
338
|
-
SalesCompletedEvent event,
|
|
339
|
-
JournalPattern pattern) {
|
|
340
|
-
|
|
341
|
-
List<JournalLine> lines = new ArrayList<>();
|
|
342
|
-
|
|
343
|
-
// 借方:売掛金
|
|
344
|
-
lines.add(JournalLine.debit(
|
|
345
|
-
pattern.debitAccountCode(),
|
|
346
|
-
event.totalAmount(),
|
|
347
|
-
"売掛金計上 " + event.customerName()
|
|
348
|
-
));
|
|
349
|
-
|
|
350
|
-
// 貸方:売上高
|
|
351
|
-
lines.add(JournalLine.credit(
|
|
352
|
-
pattern.creditAccountCode(),
|
|
353
|
-
event.netAmount(),
|
|
354
|
-
"売上計上 " + event.salesId()
|
|
355
|
-
));
|
|
356
|
-
|
|
357
|
-
// 貸方:仮受消費税
|
|
358
|
-
if (event.taxAmount().compareTo(BigDecimal.ZERO) > 0) {
|
|
359
|
-
lines.add(JournalLine.credit(
|
|
360
|
-
pattern.taxAccountCode(),
|
|
361
|
-
event.taxAmount(),
|
|
362
|
-
"仮受消費税"
|
|
363
|
-
));
|
|
364
|
-
}
|
|
365
|
-
|
|
366
|
-
return new JournalEntry(
|
|
367
|
-
generateJournalId(),
|
|
368
|
-
event.salesDate(),
|
|
369
|
-
JournalType.AUTO_SALES,
|
|
370
|
-
event.salesId(),
|
|
371
|
-
lines
|
|
372
|
-
);
|
|
373
|
-
}
|
|
374
|
-
|
|
375
|
-
private void validateBalance(JournalEntry journal) {
|
|
376
|
-
BigDecimal debitTotal = journal.lines().stream()
|
|
377
|
-
.filter(l -> l.debitCredit() == DebitCredit.DEBIT)
|
|
378
|
-
.map(JournalLine::amount)
|
|
379
|
-
.reduce(BigDecimal.ZERO, BigDecimal::add);
|
|
380
|
-
|
|
381
|
-
BigDecimal creditTotal = journal.lines().stream()
|
|
382
|
-
.filter(l -> l.debitCredit() == DebitCredit.CREDIT)
|
|
383
|
-
.map(JournalLine::amount)
|
|
384
|
-
.reduce(BigDecimal.ZERO, BigDecimal::add);
|
|
385
|
-
|
|
386
|
-
if (debitTotal.compareTo(creditTotal) != 0) {
|
|
387
|
-
throw new BalanceMismatchException(
|
|
388
|
-
"貸借不一致: 借方=" + debitTotal + ", 貸方=" + creditTotal
|
|
389
|
-
);
|
|
390
|
-
}
|
|
391
|
-
}
|
|
392
|
-
}
|
|
393
|
-
```
|
|
394
|
-
|
|
395
|
-
</details>
|
|
396
|
-
|
|
397
|
-
### イベント駆動による仕訳生成
|
|
398
|
-
|
|
399
|
-
販売管理システムで発生する各種イベントに応じて、自動的に仕訳を生成します。
|
|
400
|
-
|
|
401
|
-
```plantuml
|
|
402
|
-
@startuml
|
|
403
|
-
title 販売イベントと仕訳の対応
|
|
404
|
-
|
|
405
|
-
' 配置を制御するための設定
|
|
406
|
-
skinparam nodesep 50
|
|
407
|
-
skinparam ranksep 50
|
|
408
|
-
|
|
409
|
-
rectangle "販売管理イベント" as sales_events {
|
|
410
|
-
rectangle "売上計上" as sales_completed
|
|
411
|
-
rectangle "売上返品" as sales_return
|
|
412
|
-
rectangle "請求確定" as billing_confirmed
|
|
413
|
-
rectangle "入金確認" as payment_received
|
|
414
|
-
rectangle "貸倒発生" as bad_debt
|
|
415
|
-
}
|
|
416
|
-
|
|
417
|
-
rectangle "自動仕訳" as auto_journal {
|
|
418
|
-
rectangle "売上仕訳\n生成" as sales_journal
|
|
419
|
-
rectangle "返品仕訳\n生成" as return_journal
|
|
420
|
-
rectangle "(請求時仕訳\nなし)" as billing_journal
|
|
421
|
-
rectangle "入金仕訳\n生成" as payment_journal
|
|
422
|
-
rectangle "貸倒仕訳\n生成" as bad_debt_journal
|
|
423
|
-
}
|
|
424
|
-
|
|
425
|
-
rectangle "仕訳パターン" as patterns {
|
|
426
|
-
rectangle "==売上仕訳\n\n借方: 売掛金\n貸方: 売上高\n貸方: 仮受消費税" as p1
|
|
427
|
-
rectangle "==返品仕訳\n\n借方: 売上高\n借方: 仮受消費税\n貸方: 売掛金" as p2
|
|
428
|
-
rectangle "==入金仕訳\n\n借方: 普通預金\n貸方: 売掛金" as p3
|
|
429
|
-
rectangle "==貸倒仕訳\n\n借方: 貸倒損失\n貸方: 売掛金" as p4
|
|
430
|
-
}
|
|
431
|
-
|
|
432
|
-
sales_completed --> sales_journal
|
|
433
|
-
sales_return --> return_journal
|
|
434
|
-
billing_confirmed --> billing_journal
|
|
435
|
-
payment_received --> payment_journal
|
|
436
|
-
bad_debt --> bad_debt_journal
|
|
437
|
-
|
|
438
|
-
sales_journal --> p1
|
|
439
|
-
return_journal --> p2
|
|
440
|
-
payment_journal --> p3
|
|
441
|
-
bad_debt_journal --> p4
|
|
442
|
-
|
|
443
|
-
@enduml
|
|
444
|
-
```
|
|
445
|
-
|
|
446
|
-
#### 入金消込と仕訳生成
|
|
447
|
-
|
|
448
|
-
```plantuml
|
|
449
|
-
@startuml
|
|
450
|
-
title 入金消込と仕訳生成フロー
|
|
451
|
-
|
|
452
|
-
|販売管理|
|
|
453
|
-
start
|
|
454
|
-
:入金データ受信;
|
|
455
|
-
:請求データ照合;
|
|
456
|
-
|
|
457
|
-
if (消込対象あり?) then (yes)
|
|
458
|
-
:入金消込処理;
|
|
459
|
-
:消込イベント発行;
|
|
460
|
-
else (no)
|
|
461
|
-
:前受金計上;
|
|
462
|
-
:前受金イベント発行;
|
|
463
|
-
endif
|
|
464
|
-
|
|
465
|
-
|財務会計|
|
|
466
|
-
if (消込イベント?) then (yes)
|
|
467
|
-
:入金仕訳生成;
|
|
468
|
-
note right
|
|
469
|
-
借方: 普通預金
|
|
470
|
-
貸方: 売掛金
|
|
471
|
-
end note
|
|
472
|
-
else (no)
|
|
473
|
-
:前受金仕訳生成;
|
|
474
|
-
note right
|
|
475
|
-
借方: 普通預金
|
|
476
|
-
貸方: 前受金
|
|
477
|
-
end note
|
|
478
|
-
endif
|
|
479
|
-
|
|
480
|
-
:仕訳登録;
|
|
481
|
-
:売掛金残高更新;
|
|
482
|
-
|
|
483
|
-
stop
|
|
484
|
-
|
|
485
|
-
@enduml
|
|
486
|
-
```
|
|
487
|
-
|
|
488
|
-
---
|
|
489
|
-
|
|
490
|
-
## 35.2 販売管理と生産管理の連携
|
|
491
|
-
|
|
492
|
-
販売管理システムと生産管理システムの連携は、需要と供給のバランスを取るために重要です。受注情報を生産計画に反映し、在庫情報を双方向で同期します。
|
|
493
|
-
|
|
494
|
-
### 連携の全体像
|
|
495
|
-
|
|
496
|
-
```plantuml
|
|
497
|
-
@startuml
|
|
498
|
-
title 販売管理と生産管理の連携全体像
|
|
499
|
-
|
|
500
|
-
package "販売管理システム" as sales {
|
|
501
|
-
rectangle "受注管理" as order
|
|
502
|
-
rectangle "出荷管理" as shipment
|
|
503
|
-
rectangle "在庫照会" as sales_inv
|
|
504
|
-
}
|
|
505
|
-
|
|
506
|
-
package "イベントバス" as events {
|
|
507
|
-
collections "受注イベント" as order_event
|
|
508
|
-
collections "在庫イベント" as inv_event
|
|
509
|
-
collections "完成イベント" as complete_event
|
|
510
|
-
}
|
|
511
|
-
|
|
512
|
-
package "生産管理システム" as production {
|
|
513
|
-
rectangle "生産計画" as plan
|
|
514
|
-
rectangle "MRP" as mrp
|
|
515
|
-
rectangle "製造管理" as manufacturing
|
|
516
|
-
rectangle "在庫管理" as prod_inv
|
|
517
|
-
}
|
|
518
|
-
|
|
519
|
-
order --> order_event : 受注確定
|
|
520
|
-
order_event --> plan : 需要情報
|
|
521
|
-
|
|
522
|
-
plan --> mrp : 所要量展開
|
|
523
|
-
mrp --> manufacturing : 製造指示
|
|
524
|
-
|
|
525
|
-
manufacturing --> complete_event : 完成報告
|
|
526
|
-
complete_event --> prod_inv : 在庫計上
|
|
527
|
-
prod_inv --> inv_event : 在庫更新
|
|
528
|
-
|
|
529
|
-
inv_event --> sales_inv : 在庫同期
|
|
530
|
-
sales_inv --> shipment : 引当可能数
|
|
531
|
-
|
|
532
|
-
@enduml
|
|
533
|
-
```
|
|
534
|
-
|
|
535
|
-
### 受注情報から生産計画への連携
|
|
536
|
-
|
|
537
|
-
```plantuml
|
|
538
|
-
@startuml
|
|
539
|
-
title 受注から生産計画への連携フロー
|
|
540
|
-
|
|
541
|
-
|販売管理|
|
|
542
|
-
start
|
|
543
|
-
:受注登録;
|
|
544
|
-
:受注確定;
|
|
545
|
-
:受注イベント発行;
|
|
546
|
-
|
|
547
|
-
|生産計画|
|
|
548
|
-
:受注イベント受信;
|
|
549
|
-
:需要情報登録;
|
|
550
|
-
|
|
551
|
-
:在庫・発注残確認;
|
|
552
|
-
if (在庫で充足?) then (yes)
|
|
553
|
-
:引当処理;
|
|
554
|
-
else (no)
|
|
555
|
-
:正味所要量計算;
|
|
556
|
-
if (製品?) then (yes)
|
|
557
|
-
:製造オーダ作成;
|
|
558
|
-
else (no)
|
|
559
|
-
:発注提案作成;
|
|
560
|
-
endif
|
|
561
|
-
endif
|
|
562
|
-
|
|
563
|
-
:計画確定;
|
|
564
|
-
:計画確定イベント発行;
|
|
565
|
-
|
|
566
|
-
|販売管理|
|
|
567
|
-
:納期回答更新;
|
|
568
|
-
|
|
569
|
-
stop
|
|
570
|
-
|
|
571
|
-
@enduml
|
|
572
|
-
```
|
|
573
|
-
|
|
574
|
-
#### 受注イベントの構造
|
|
575
|
-
|
|
576
|
-
```plantuml
|
|
577
|
-
@startuml
|
|
578
|
-
title 受注イベントの構造
|
|
579
|
-
|
|
580
|
-
class "OrderConfirmedEvent" as event {
|
|
581
|
-
+eventId: String
|
|
582
|
-
+timestamp: Instant
|
|
583
|
-
+orderId: String
|
|
584
|
-
+customerId: String
|
|
585
|
-
+requestedDeliveryDate: LocalDate
|
|
586
|
-
+priority: Priority
|
|
587
|
-
+lines: List<OrderLineEvent>
|
|
588
|
-
}
|
|
589
|
-
|
|
590
|
-
class "OrderLineEvent" as line {
|
|
591
|
-
+lineNumber: int
|
|
592
|
-
+productId: String
|
|
593
|
-
+quantity: BigDecimal
|
|
594
|
-
+unit: String
|
|
595
|
-
+requestedDate: LocalDate
|
|
596
|
-
}
|
|
597
|
-
|
|
598
|
-
event "1" -- "*" line
|
|
599
|
-
|
|
600
|
-
note right of event
|
|
601
|
-
【生産計画に必要な情報】
|
|
602
|
-
・製品コード
|
|
603
|
-
・必要数量
|
|
604
|
-
・希望納期
|
|
605
|
-
・優先度
|
|
606
|
-
end note
|
|
607
|
-
|
|
608
|
-
@enduml
|
|
609
|
-
```
|
|
610
|
-
|
|
611
|
-
<details>
|
|
612
|
-
<summary>Java 実装例</summary>
|
|
613
|
-
|
|
614
|
-
```java
|
|
615
|
-
// 受注確定イベント
|
|
616
|
-
public record OrderConfirmedEvent(
|
|
617
|
-
String eventId,
|
|
618
|
-
Instant timestamp,
|
|
619
|
-
String orderId,
|
|
620
|
-
String customerId,
|
|
621
|
-
LocalDate requestedDeliveryDate,
|
|
622
|
-
Priority priority,
|
|
623
|
-
List<OrderLineEvent> lines
|
|
624
|
-
) {
|
|
625
|
-
public enum Priority {
|
|
626
|
-
URGENT, // 緊急
|
|
627
|
-
HIGH, // 高
|
|
628
|
-
NORMAL, // 通常
|
|
629
|
-
LOW // 低
|
|
630
|
-
}
|
|
631
|
-
}
|
|
632
|
-
|
|
633
|
-
// 生産計画サービス
|
|
634
|
-
@Service
|
|
635
|
-
public class ProductionPlanningService {
|
|
636
|
-
private final DemandRepository demandRepository;
|
|
637
|
-
private final InventoryRepository inventoryRepository;
|
|
638
|
-
private final MrpService mrpService;
|
|
639
|
-
|
|
640
|
-
@EventListener
|
|
641
|
-
public void handleOrderConfirmed(OrderConfirmedEvent event) {
|
|
642
|
-
// 需要情報として登録
|
|
643
|
-
for (OrderLineEvent line : event.lines()) {
|
|
644
|
-
Demand demand = Demand.fromOrder(
|
|
645
|
-
event.orderId(),
|
|
646
|
-
line.productId(),
|
|
647
|
-
line.quantity(),
|
|
648
|
-
line.requestedDate(),
|
|
649
|
-
event.priority()
|
|
650
|
-
);
|
|
651
|
-
demandRepository.save(demand);
|
|
652
|
-
|
|
653
|
-
// 在庫引当を試行
|
|
654
|
-
AllocationResult result = tryAllocate(demand);
|
|
655
|
-
|
|
656
|
-
if (!result.isFullyAllocated()) {
|
|
657
|
-
// MRP実行して製造/発注オーダを生成
|
|
658
|
-
mrpService.execute(demand);
|
|
659
|
-
}
|
|
660
|
-
}
|
|
661
|
-
|
|
662
|
-
// 納期回答イベント発行
|
|
663
|
-
publishDeliveryDateResponse(event.orderId());
|
|
664
|
-
}
|
|
665
|
-
|
|
666
|
-
private AllocationResult tryAllocate(Demand demand) {
|
|
667
|
-
BigDecimal available = inventoryRepository
|
|
668
|
-
.findAvailableQuantity(demand.productId());
|
|
669
|
-
|
|
670
|
-
if (available.compareTo(demand.quantity()) >= 0) {
|
|
671
|
-
// 引当実行
|
|
672
|
-
inventoryRepository.allocate(
|
|
673
|
-
demand.productId(),
|
|
674
|
-
demand.quantity(),
|
|
675
|
-
demand.demandId()
|
|
676
|
-
);
|
|
677
|
-
return AllocationResult.fullyAllocated(demand.quantity());
|
|
678
|
-
} else {
|
|
679
|
-
// 部分引当
|
|
680
|
-
if (available.compareTo(BigDecimal.ZERO) > 0) {
|
|
681
|
-
inventoryRepository.allocate(
|
|
682
|
-
demand.productId(),
|
|
683
|
-
available,
|
|
684
|
-
demand.demandId()
|
|
685
|
-
);
|
|
686
|
-
}
|
|
687
|
-
return AllocationResult.partiallyAllocated(
|
|
688
|
-
available,
|
|
689
|
-
demand.quantity().subtract(available)
|
|
690
|
-
);
|
|
691
|
-
}
|
|
692
|
-
}
|
|
693
|
-
}
|
|
694
|
-
```
|
|
695
|
-
|
|
696
|
-
</details>
|
|
697
|
-
|
|
698
|
-
### 需要予測データの共有
|
|
699
|
-
|
|
700
|
-
```plantuml
|
|
701
|
-
@startuml
|
|
702
|
-
title 需要予測データの共有
|
|
703
|
-
|
|
704
|
-
package "販売管理" as sales {
|
|
705
|
-
rectangle "販売実績" as sales_history
|
|
706
|
-
rectangle "受注残" as backlog
|
|
707
|
-
rectangle "見積案件" as quotation
|
|
708
|
-
}
|
|
709
|
-
|
|
710
|
-
package "需要予測エンジン" as forecast {
|
|
711
|
-
rectangle "時系列分析" as time_series
|
|
712
|
-
rectangle "季節調整" as seasonal
|
|
713
|
-
rectangle "トレンド分析" as trend
|
|
714
|
-
}
|
|
715
|
-
|
|
716
|
-
package "生産計画" as planning {
|
|
717
|
-
rectangle "MPS\n(基準生産計画)" as mps
|
|
718
|
-
rectangle "MRP\n(所要量計画)" as mrp
|
|
719
|
-
}
|
|
720
|
-
|
|
721
|
-
sales_history --> forecast
|
|
722
|
-
backlog --> forecast
|
|
723
|
-
quotation --> forecast
|
|
724
|
-
|
|
725
|
-
forecast --> mps : 需要予測データ
|
|
726
|
-
mps --> mrp : 計画生産量
|
|
727
|
-
|
|
728
|
-
note right of forecast
|
|
729
|
-
【予測データの内容】
|
|
730
|
-
・製品別月次予測数量
|
|
731
|
-
・予測精度(信頼区間)
|
|
732
|
-
・季節変動係数
|
|
733
|
-
・トレンド方向
|
|
734
|
-
end note
|
|
735
|
-
|
|
736
|
-
@enduml
|
|
737
|
-
```
|
|
738
|
-
|
|
739
|
-
#### 需要予測イベント
|
|
740
|
-
|
|
741
|
-
```plantuml
|
|
742
|
-
@startuml
|
|
743
|
-
title 需要予測の連携サイクル
|
|
744
|
-
|
|
745
|
-
|販売管理|
|
|
746
|
-
start
|
|
747
|
-
:月次販売実績集計;
|
|
748
|
-
:受注残・見積集計;
|
|
749
|
-
:需要予測更新;
|
|
750
|
-
:予測データ発行;
|
|
751
|
-
|
|
752
|
-
|生産計画|
|
|
753
|
-
:予測データ受信;
|
|
754
|
-
:MPS更新;
|
|
755
|
-
note right
|
|
756
|
-
・月次生産計画
|
|
757
|
-
・安全在庫調整
|
|
758
|
-
・生産能力確認
|
|
759
|
-
end note
|
|
760
|
-
|
|
761
|
-
:MRP実行;
|
|
762
|
-
:発注提案生成;
|
|
763
|
-
:製造計画生成;
|
|
764
|
-
|
|
765
|
-
if (計画変更あり?) then (yes)
|
|
766
|
-
:計画変更通知;
|
|
767
|
-
endif
|
|
768
|
-
|
|
769
|
-
|販売管理|
|
|
770
|
-
:納期情報更新;
|
|
771
|
-
|
|
772
|
-
stop
|
|
773
|
-
|
|
774
|
-
@enduml
|
|
775
|
-
```
|
|
776
|
-
|
|
777
|
-
### 在庫情報の同期
|
|
778
|
-
|
|
779
|
-
販売管理と生産管理の両方で在庫を管理する場合、整合性を保つ必要があります。
|
|
780
|
-
|
|
781
|
-
```plantuml
|
|
782
|
-
@startuml
|
|
783
|
-
title 在庫情報の同期パターン
|
|
784
|
-
|
|
785
|
-
package "販売管理" as sales {
|
|
786
|
-
database "販売在庫ビュー\n----\n在庫数\n引当数\n有効在庫数" as sales_inv
|
|
787
|
-
}
|
|
788
|
-
|
|
789
|
-
package "生産管理" as production {
|
|
790
|
-
database "生産在庫(マスタ)\n----\n在庫数\n引当数\n品質状態\nロット情報" as prod_inv
|
|
791
|
-
}
|
|
792
|
-
|
|
793
|
-
package "同期メカニズム" as sync {
|
|
794
|
-
collections "在庫更新\nイベント" as inv_event
|
|
795
|
-
rectangle "在庫同期\nサービス" as sync_svc
|
|
796
|
-
}
|
|
797
|
-
|
|
798
|
-
prod_inv --> inv_event : 在庫変動時
|
|
799
|
-
inv_event --> sync_svc
|
|
800
|
-
sync_svc --> sales_inv : ビュー更新
|
|
801
|
-
|
|
802
|
-
note bottom of sync
|
|
803
|
-
【同期タイミング】
|
|
804
|
-
・完成時(入庫)
|
|
805
|
-
・出荷時(出庫)
|
|
806
|
-
・棚卸差異発生時
|
|
807
|
-
・品質状態変更時
|
|
808
|
-
|
|
809
|
-
【同期内容】
|
|
810
|
-
・製品別在庫数
|
|
811
|
-
・引当可能数
|
|
812
|
-
・入庫予定
|
|
813
|
-
end note
|
|
814
|
-
|
|
815
|
-
@enduml
|
|
816
|
-
```
|
|
817
|
-
|
|
818
|
-
<details>
|
|
819
|
-
<summary>Java 実装例</summary>
|
|
820
|
-
|
|
821
|
-
```java
|
|
822
|
-
// 在庫更新イベント
|
|
823
|
-
public record InventoryUpdatedEvent(
|
|
824
|
-
String eventId,
|
|
825
|
-
Instant timestamp,
|
|
826
|
-
String productId,
|
|
827
|
-
String warehouseId,
|
|
828
|
-
BigDecimal previousQuantity,
|
|
829
|
-
BigDecimal currentQuantity,
|
|
830
|
-
BigDecimal allocatedQuantity,
|
|
831
|
-
UpdateReason reason
|
|
832
|
-
) {
|
|
833
|
-
public enum UpdateReason {
|
|
834
|
-
COMPLETION, // 製造完成
|
|
835
|
-
SHIPMENT, // 出荷
|
|
836
|
-
RECEIPT, // 入荷
|
|
837
|
-
ADJUSTMENT, // 棚卸調整
|
|
838
|
-
QUALITY_CHANGE // 品質状態変更
|
|
839
|
-
}
|
|
840
|
-
|
|
841
|
-
public BigDecimal getAvailableQuantity() {
|
|
842
|
-
return currentQuantity.subtract(allocatedQuantity);
|
|
843
|
-
}
|
|
844
|
-
}
|
|
845
|
-
|
|
846
|
-
// 在庫同期サービス
|
|
847
|
-
@Service
|
|
848
|
-
public class InventorySyncService {
|
|
849
|
-
private final SalesInventoryRepository salesInventoryRepository;
|
|
850
|
-
|
|
851
|
-
@EventListener
|
|
852
|
-
public void handleInventoryUpdated(InventoryUpdatedEvent event) {
|
|
853
|
-
// 販売在庫ビューを更新
|
|
854
|
-
SalesInventory salesInv = salesInventoryRepository
|
|
855
|
-
.findByProductId(event.productId())
|
|
856
|
-
.orElse(new SalesInventory(event.productId()));
|
|
857
|
-
|
|
858
|
-
salesInv.updateQuantity(
|
|
859
|
-
event.currentQuantity(),
|
|
860
|
-
event.allocatedQuantity()
|
|
861
|
-
);
|
|
862
|
-
|
|
863
|
-
salesInventoryRepository.save(salesInv);
|
|
864
|
-
|
|
865
|
-
// 低在庫アラート
|
|
866
|
-
if (salesInv.getAvailableQuantity()
|
|
867
|
-
.compareTo(salesInv.getSafetyStock()) < 0) {
|
|
868
|
-
publishLowStockAlert(event.productId());
|
|
869
|
-
}
|
|
870
|
-
}
|
|
871
|
-
}
|
|
872
|
-
```
|
|
873
|
-
|
|
874
|
-
</details>
|
|
875
|
-
|
|
876
|
-
---
|
|
877
|
-
|
|
878
|
-
## 35.3 生産管理と財務会計の連携
|
|
879
|
-
|
|
880
|
-
生産管理システムと財務会計システムの連携は、製造原価の正確な把握と会計処理に不可欠です。
|
|
881
|
-
|
|
882
|
-
### 連携の全体像
|
|
883
|
-
|
|
884
|
-
```plantuml
|
|
885
|
-
@startuml
|
|
886
|
-
title 生産管理と財務会計の連携全体像
|
|
887
|
-
|
|
888
|
-
package "生産管理システム" as production {
|
|
889
|
-
rectangle "購買管理" as purchase
|
|
890
|
-
rectangle "製造管理" as manufacturing
|
|
891
|
-
rectangle "在庫管理" as inventory
|
|
892
|
-
rectangle "原価管理" as cost
|
|
893
|
-
}
|
|
894
|
-
|
|
895
|
-
package "イベントバス" as events {
|
|
896
|
-
collections "検収イベント" as receipt_event
|
|
897
|
-
collections "完成イベント" as complete_event
|
|
898
|
-
collections "棚卸イベント" as inventory_event
|
|
899
|
-
collections "原価イベント" as cost_event
|
|
900
|
-
}
|
|
901
|
-
|
|
902
|
-
package "財務会計システム" as accounting {
|
|
903
|
-
rectangle "自動仕訳" as auto_journal
|
|
904
|
-
rectangle "仕訳管理" as journal
|
|
905
|
-
rectangle "原価会計" as cost_acc
|
|
906
|
-
}
|
|
907
|
-
|
|
908
|
-
purchase --> receipt_event : 検収確定
|
|
909
|
-
manufacturing --> complete_event : 製造完成
|
|
910
|
-
inventory --> inventory_event : 棚卸差異
|
|
911
|
-
cost --> cost_event : 原価計算完了
|
|
912
|
-
|
|
913
|
-
receipt_event --> auto_journal
|
|
914
|
-
complete_event --> auto_journal
|
|
915
|
-
inventory_event --> auto_journal
|
|
916
|
-
cost_event --> cost_acc
|
|
917
|
-
|
|
918
|
-
auto_journal --> journal
|
|
919
|
-
|
|
920
|
-
@enduml
|
|
921
|
-
```
|
|
922
|
-
|
|
923
|
-
### 製造原価から仕訳への変換
|
|
924
|
-
|
|
925
|
-
製造原価は、材料費・労務費・製造間接費の3要素で構成されます。
|
|
926
|
-
|
|
927
|
-
```plantuml
|
|
928
|
-
@startuml
|
|
929
|
-
title 製造原価の構成と仕訳
|
|
930
|
-
|
|
931
|
-
object "製造原価" as cost {
|
|
932
|
-
製造オーダ = "WO-2024-001"
|
|
933
|
-
製品コード = "PRD-001"
|
|
934
|
-
完成数量 = 100
|
|
935
|
-
}
|
|
936
|
-
|
|
937
|
-
object "材料費" as material {
|
|
938
|
-
直接材料費 = 50,000円
|
|
939
|
-
間接材料費 = 5,000円
|
|
940
|
-
}
|
|
941
|
-
|
|
942
|
-
object "労務費" as labor {
|
|
943
|
-
直接労務費 = 30,000円
|
|
944
|
-
間接労務費 = 10,000円
|
|
945
|
-
}
|
|
946
|
-
|
|
947
|
-
object "製造間接費" as overhead {
|
|
948
|
-
配賦額 = 15,000円
|
|
949
|
-
}
|
|
950
|
-
|
|
951
|
-
object "原価仕訳" as journal {
|
|
952
|
-
借方: 製品 110,000円
|
|
953
|
-
貸方: 仕掛品 110,000円
|
|
954
|
-
}
|
|
955
|
-
|
|
956
|
-
cost --> material
|
|
957
|
-
cost --> labor
|
|
958
|
-
cost --> overhead
|
|
959
|
-
|
|
960
|
-
material --> journal : 55,000円
|
|
961
|
-
labor --> journal : 40,000円
|
|
962
|
-
overhead --> journal : 15,000円
|
|
963
|
-
|
|
964
|
-
note bottom of journal
|
|
965
|
-
【製造完成時の仕訳】
|
|
966
|
-
借方:製品(資産)
|
|
967
|
-
貸方:仕掛品(資産)
|
|
968
|
-
|
|
969
|
-
製品原価 = 材料費 + 労務費 + 製造間接費
|
|
970
|
-
= 55,000 + 40,000 + 15,000
|
|
971
|
-
= 110,000円
|
|
972
|
-
end note
|
|
973
|
-
|
|
974
|
-
@enduml
|
|
975
|
-
```
|
|
976
|
-
|
|
977
|
-
#### 製造原価計算フロー
|
|
978
|
-
|
|
979
|
-
```plantuml
|
|
980
|
-
@startuml
|
|
981
|
-
title 製造原価計算と仕訳生成フロー
|
|
982
|
-
|
|
983
|
-
|生産管理|
|
|
984
|
-
start
|
|
985
|
-
:製造完成報告;
|
|
986
|
-
|
|
987
|
-
:材料消費実績集計;
|
|
988
|
-
note right
|
|
989
|
-
・直接材料費
|
|
990
|
-
・間接材料費
|
|
991
|
-
end note
|
|
992
|
-
|
|
993
|
-
:工数実績集計;
|
|
994
|
-
note right
|
|
995
|
-
・直接労務費
|
|
996
|
-
・間接労務費
|
|
997
|
-
end note
|
|
998
|
-
|
|
999
|
-
:製造間接費配賦;
|
|
1000
|
-
note right
|
|
1001
|
-
・配賦基準で按分
|
|
1002
|
-
(直接作業時間等)
|
|
1003
|
-
end note
|
|
1004
|
-
|
|
1005
|
-
:製品原価計算;
|
|
1006
|
-
:完成原価イベント発行;
|
|
1007
|
-
|
|
1008
|
-
|財務会計|
|
|
1009
|
-
:原価イベント受信;
|
|
1010
|
-
:製造完成仕訳生成;
|
|
1011
|
-
note right
|
|
1012
|
-
借方: 製品
|
|
1013
|
-
貸方: 仕掛品
|
|
1014
|
-
end note
|
|
1015
|
-
|
|
1016
|
-
:仕訳登録;
|
|
1017
|
-
:在庫評価額更新;
|
|
1018
|
-
|
|
1019
|
-
stop
|
|
1020
|
-
|
|
1021
|
-
@enduml
|
|
1022
|
-
```
|
|
1023
|
-
|
|
1024
|
-
<details>
|
|
1025
|
-
<summary>Java 実装例</summary>
|
|
1026
|
-
|
|
1027
|
-
```java
|
|
1028
|
-
// 製造完成原価イベント
|
|
1029
|
-
public record ManufacturingCompletedEvent(
|
|
1030
|
-
String eventId,
|
|
1031
|
-
Instant timestamp,
|
|
1032
|
-
String workOrderId,
|
|
1033
|
-
String productId,
|
|
1034
|
-
BigDecimal completedQuantity,
|
|
1035
|
-
CostBreakdown costBreakdown
|
|
1036
|
-
) {
|
|
1037
|
-
public record CostBreakdown(
|
|
1038
|
-
BigDecimal directMaterialCost,
|
|
1039
|
-
BigDecimal indirectMaterialCost,
|
|
1040
|
-
BigDecimal directLaborCost,
|
|
1041
|
-
BigDecimal indirectLaborCost,
|
|
1042
|
-
BigDecimal manufacturingOverhead
|
|
1043
|
-
) {
|
|
1044
|
-
public BigDecimal getTotalCost() {
|
|
1045
|
-
return directMaterialCost
|
|
1046
|
-
.add(indirectMaterialCost)
|
|
1047
|
-
.add(directLaborCost)
|
|
1048
|
-
.add(indirectLaborCost)
|
|
1049
|
-
.add(manufacturingOverhead);
|
|
1050
|
-
}
|
|
1051
|
-
|
|
1052
|
-
public BigDecimal getMaterialCost() {
|
|
1053
|
-
return directMaterialCost.add(indirectMaterialCost);
|
|
1054
|
-
}
|
|
1055
|
-
|
|
1056
|
-
public BigDecimal getLaborCost() {
|
|
1057
|
-
return directLaborCost.add(indirectLaborCost);
|
|
1058
|
-
}
|
|
1059
|
-
}
|
|
1060
|
-
}
|
|
1061
|
-
|
|
1062
|
-
// 製造原価仕訳サービス
|
|
1063
|
-
@Service
|
|
1064
|
-
public class ManufacturingJournalService {
|
|
1065
|
-
private final JournalRepository journalRepository;
|
|
1066
|
-
|
|
1067
|
-
@EventListener
|
|
1068
|
-
public void handleManufacturingCompleted(ManufacturingCompletedEvent event) {
|
|
1069
|
-
CostBreakdown cost = event.costBreakdown();
|
|
1070
|
-
|
|
1071
|
-
List<JournalLine> lines = new ArrayList<>();
|
|
1072
|
-
|
|
1073
|
-
// 借方:製品
|
|
1074
|
-
lines.add(JournalLine.debit(
|
|
1075
|
-
AccountCode.FINISHED_GOODS,
|
|
1076
|
-
cost.getTotalCost(),
|
|
1077
|
-
"製造完成 " + event.workOrderId()
|
|
1078
|
-
));
|
|
1079
|
-
|
|
1080
|
-
// 貸方:仕掛品
|
|
1081
|
-
lines.add(JournalLine.credit(
|
|
1082
|
-
AccountCode.WORK_IN_PROCESS,
|
|
1083
|
-
cost.getTotalCost(),
|
|
1084
|
-
"仕掛品振替"
|
|
1085
|
-
));
|
|
1086
|
-
|
|
1087
|
-
JournalEntry journal = new JournalEntry(
|
|
1088
|
-
generateJournalId(),
|
|
1089
|
-
LocalDate.now(),
|
|
1090
|
-
JournalType.MANUFACTURING_COMPLETION,
|
|
1091
|
-
event.workOrderId(),
|
|
1092
|
-
lines
|
|
1093
|
-
);
|
|
1094
|
-
|
|
1095
|
-
journalRepository.save(journal);
|
|
1096
|
-
}
|
|
1097
|
-
}
|
|
1098
|
-
```
|
|
1099
|
-
|
|
1100
|
-
</details>
|
|
1101
|
-
|
|
1102
|
-
### 検収データの会計連携
|
|
1103
|
-
|
|
1104
|
-
仕入先からの購買品検収時に、買掛金を計上します。
|
|
1105
|
-
|
|
1106
|
-
```plantuml
|
|
1107
|
-
@startuml
|
|
1108
|
-
title 検収から仕訳への連携
|
|
1109
|
-
|
|
1110
|
-
|生産管理|
|
|
1111
|
-
start
|
|
1112
|
-
:入荷受入;
|
|
1113
|
-
:受入検査;
|
|
1114
|
-
|
|
1115
|
-
if (検査合格?) then (yes)
|
|
1116
|
-
:検収処理;
|
|
1117
|
-
:在庫計上;
|
|
1118
|
-
:検収イベント発行;
|
|
1119
|
-
else (no)
|
|
1120
|
-
:返品処理;
|
|
1121
|
-
stop
|
|
1122
|
-
endif
|
|
1123
|
-
|
|
1124
|
-
|財務会計|
|
|
1125
|
-
:検収イベント受信;
|
|
1126
|
-
:仕入仕訳生成;
|
|
1127
|
-
note right
|
|
1128
|
-
借方: 材料/仕掛品
|
|
1129
|
-
借方: 仮払消費税
|
|
1130
|
-
貸方: 買掛金
|
|
1131
|
-
end note
|
|
1132
|
-
|
|
1133
|
-
:仕訳登録;
|
|
1134
|
-
:買掛金残高更新;
|
|
1135
|
-
|
|
1136
|
-
stop
|
|
1137
|
-
|
|
1138
|
-
@enduml
|
|
1139
|
-
```
|
|
1140
|
-
|
|
1141
|
-
#### 検収仕訳のパターン
|
|
1142
|
-
|
|
1143
|
-
```plantuml
|
|
1144
|
-
@startuml
|
|
1145
|
-
title 検収仕訳のパターン
|
|
1146
|
-
|
|
1147
|
-
object "検収データ" as receipt {
|
|
1148
|
-
検収番号 = "RCV-2024-001"
|
|
1149
|
-
検収日 = "2024/01/15"
|
|
1150
|
-
仕入先 = "SUP-001"
|
|
1151
|
-
検収金額 = 55,000円
|
|
1152
|
-
消費税額 = 5,000円
|
|
1153
|
-
}
|
|
1154
|
-
|
|
1155
|
-
object "材料検収仕訳" as material_journal {
|
|
1156
|
-
借方: 材料 50,000円
|
|
1157
|
-
借方: 仮払消費税 5,000円
|
|
1158
|
-
貸方: 買掛金 55,000円
|
|
1159
|
-
}
|
|
1160
|
-
|
|
1161
|
-
object "外注検収仕訳" as subcontract_journal {
|
|
1162
|
-
借方: 外注加工費 50,000円
|
|
1163
|
-
借方: 仮払消費税 5,000円
|
|
1164
|
-
貸方: 買掛金 55,000円
|
|
1165
|
-
}
|
|
1166
|
-
|
|
1167
|
-
receipt --> material_journal : 材料の場合
|
|
1168
|
-
receipt --> subcontract_journal : 外注の場合
|
|
1169
|
-
|
|
1170
|
-
@enduml
|
|
1171
|
-
```
|
|
1172
|
-
|
|
1173
|
-
### 棚卸差異の会計処理
|
|
1174
|
-
|
|
1175
|
-
棚卸で発見された差異は、適切に会計処理する必要があります。
|
|
1176
|
-
|
|
1177
|
-
```plantuml
|
|
1178
|
-
@startuml
|
|
1179
|
-
title 棚卸差異の会計処理フロー
|
|
1180
|
-
|
|
1181
|
-
|生産管理|
|
|
1182
|
-
start
|
|
1183
|
-
:棚卸実施;
|
|
1184
|
-
:帳簿在庫と\n実地在庫の比較;
|
|
1185
|
-
|
|
1186
|
-
if (差異あり?) then (yes)
|
|
1187
|
-
:差異原因分析;
|
|
1188
|
-
|
|
1189
|
-
if (帳簿 > 実地?) then (棚卸減耗)
|
|
1190
|
-
:減耗損計上;
|
|
1191
|
-
:棚卸減耗\nイベント発行;
|
|
1192
|
-
else (帳簿 < 実地)
|
|
1193
|
-
:在庫増加調整;
|
|
1194
|
-
:棚卸増加\nイベント発行;
|
|
1195
|
-
endif
|
|
1196
|
-
else (no)
|
|
1197
|
-
:差異なし\n処理終了;
|
|
1198
|
-
stop
|
|
1199
|
-
endif
|
|
1200
|
-
|
|
1201
|
-
|財務会計|
|
|
1202
|
-
:棚卸イベント受信;
|
|
1203
|
-
|
|
1204
|
-
if (減耗?) then (yes)
|
|
1205
|
-
:減耗仕訳生成;
|
|
1206
|
-
note right
|
|
1207
|
-
借方: 棚卸減耗損
|
|
1208
|
-
貸方: 材料/製品
|
|
1209
|
-
end note
|
|
1210
|
-
else (no)
|
|
1211
|
-
:増加仕訳生成;
|
|
1212
|
-
note right
|
|
1213
|
-
借方: 材料/製品
|
|
1214
|
-
貸方: 雑収入
|
|
1215
|
-
end note
|
|
1216
|
-
endif
|
|
1217
|
-
|
|
1218
|
-
:仕訳登録;
|
|
1219
|
-
:在庫評価額更新;
|
|
1220
|
-
|
|
1221
|
-
stop
|
|
1222
|
-
|
|
1223
|
-
@enduml
|
|
1224
|
-
```
|
|
1225
|
-
|
|
1226
|
-
<details>
|
|
1227
|
-
<summary>Java 実装例</summary>
|
|
1228
|
-
|
|
1229
|
-
```java
|
|
1230
|
-
// 棚卸差異イベント
|
|
1231
|
-
public record InventoryAdjustmentEvent(
|
|
1232
|
-
String eventId,
|
|
1233
|
-
Instant timestamp,
|
|
1234
|
-
String productId,
|
|
1235
|
-
String warehouseId,
|
|
1236
|
-
BigDecimal bookQuantity,
|
|
1237
|
-
BigDecimal actualQuantity,
|
|
1238
|
-
BigDecimal differenceQuantity,
|
|
1239
|
-
BigDecimal unitCost,
|
|
1240
|
-
AdjustmentType type,
|
|
1241
|
-
String reason
|
|
1242
|
-
) {
|
|
1243
|
-
public enum AdjustmentType {
|
|
1244
|
-
SHRINKAGE, // 減耗(帳簿 > 実地)
|
|
1245
|
-
SURPLUS // 過剰(帳簿 < 実地)
|
|
1246
|
-
}
|
|
1247
|
-
|
|
1248
|
-
public BigDecimal getAdjustmentAmount() {
|
|
1249
|
-
return differenceQuantity.abs().multiply(unitCost);
|
|
1250
|
-
}
|
|
1251
|
-
}
|
|
1252
|
-
|
|
1253
|
-
// 棚卸仕訳サービス
|
|
1254
|
-
@Service
|
|
1255
|
-
public class InventoryAdjustmentJournalService {
|
|
1256
|
-
private final JournalRepository journalRepository;
|
|
1257
|
-
|
|
1258
|
-
@EventListener
|
|
1259
|
-
public void handleInventoryAdjustment(InventoryAdjustmentEvent event) {
|
|
1260
|
-
List<JournalLine> lines = new ArrayList<>();
|
|
1261
|
-
|
|
1262
|
-
if (event.type() == AdjustmentType.SHRINKAGE) {
|
|
1263
|
-
// 減耗の場合
|
|
1264
|
-
lines.add(JournalLine.debit(
|
|
1265
|
-
AccountCode.INVENTORY_SHRINKAGE_LOSS,
|
|
1266
|
-
event.getAdjustmentAmount(),
|
|
1267
|
-
"棚卸減耗 " + event.productId() + " " + event.reason()
|
|
1268
|
-
));
|
|
1269
|
-
lines.add(JournalLine.credit(
|
|
1270
|
-
determineInventoryAccount(event.productId()),
|
|
1271
|
-
event.getAdjustmentAmount(),
|
|
1272
|
-
"在庫減少"
|
|
1273
|
-
));
|
|
1274
|
-
} else {
|
|
1275
|
-
// 過剰の場合
|
|
1276
|
-
lines.add(JournalLine.debit(
|
|
1277
|
-
determineInventoryAccount(event.productId()),
|
|
1278
|
-
event.getAdjustmentAmount(),
|
|
1279
|
-
"在庫増加"
|
|
1280
|
-
));
|
|
1281
|
-
lines.add(JournalLine.credit(
|
|
1282
|
-
AccountCode.MISCELLANEOUS_INCOME,
|
|
1283
|
-
event.getAdjustmentAmount(),
|
|
1284
|
-
"棚卸差益 " + event.productId()
|
|
1285
|
-
));
|
|
1286
|
-
}
|
|
1287
|
-
|
|
1288
|
-
JournalEntry journal = new JournalEntry(
|
|
1289
|
-
generateJournalId(),
|
|
1290
|
-
LocalDate.now(),
|
|
1291
|
-
JournalType.INVENTORY_ADJUSTMENT,
|
|
1292
|
-
event.eventId(),
|
|
1293
|
-
lines
|
|
1294
|
-
);
|
|
1295
|
-
|
|
1296
|
-
journalRepository.save(journal);
|
|
1297
|
-
}
|
|
1298
|
-
|
|
1299
|
-
private String determineInventoryAccount(String productId) {
|
|
1300
|
-
// 製品か材料かで勘定科目を決定
|
|
1301
|
-
Product product = productRepository.findById(productId).orElseThrow();
|
|
1302
|
-
return switch (product.type()) {
|
|
1303
|
-
case FINISHED_GOODS -> AccountCode.FINISHED_GOODS;
|
|
1304
|
-
case WORK_IN_PROCESS -> AccountCode.WORK_IN_PROCESS;
|
|
1305
|
-
case RAW_MATERIAL -> AccountCode.RAW_MATERIALS;
|
|
1306
|
-
default -> AccountCode.SUPPLIES;
|
|
1307
|
-
};
|
|
1308
|
-
}
|
|
1309
|
-
}
|
|
1310
|
-
```
|
|
1311
|
-
|
|
1312
|
-
</details>
|
|
1313
|
-
|
|
1314
|
-
---
|
|
1315
|
-
|
|
1316
|
-
## 35.4 三システム統合の全体像
|
|
1317
|
-
|
|
1318
|
-
販売・生産・会計の3システムを統合した全体像を整理します。
|
|
1319
|
-
|
|
1320
|
-
```plantuml
|
|
1321
|
-
@startuml
|
|
1322
|
-
title 基幹業務システム統合の全体像
|
|
1323
|
-
|
|
1324
|
-
package "販売管理" as sales {
|
|
1325
|
-
rectangle "受注" as order
|
|
1326
|
-
rectangle "出荷" as shipment
|
|
1327
|
-
rectangle "売上" as sales_tx
|
|
1328
|
-
rectangle "請求" as billing
|
|
1329
|
-
rectangle "入金" as receipt
|
|
1330
|
-
}
|
|
1331
|
-
|
|
1332
|
-
package "生産管理" as production {
|
|
1333
|
-
rectangle "生産計画" as plan
|
|
1334
|
-
rectangle "購買" as purchase
|
|
1335
|
-
rectangle "製造" as manufacturing
|
|
1336
|
-
rectangle "在庫" as inventory
|
|
1337
|
-
rectangle "原価" as cost
|
|
1338
|
-
}
|
|
1339
|
-
|
|
1340
|
-
package "財務会計" as accounting {
|
|
1341
|
-
rectangle "仕訳" as journal
|
|
1342
|
-
rectangle "売掛金" as ar
|
|
1343
|
-
rectangle "買掛金" as ap
|
|
1344
|
-
rectangle "在庫資産" as inv_asset
|
|
1345
|
-
}
|
|
1346
|
-
|
|
1347
|
-
' 販売→生産
|
|
1348
|
-
order --> plan : 受注情報
|
|
1349
|
-
inventory --> shipment : 在庫引当
|
|
1350
|
-
|
|
1351
|
-
' 販売→会計
|
|
1352
|
-
sales_tx --> journal : 売上仕訳
|
|
1353
|
-
billing --> ar : 請求
|
|
1354
|
-
receipt --> ar : 入金消込
|
|
1355
|
-
|
|
1356
|
-
' 生産→会計
|
|
1357
|
-
purchase --> ap : 検収仕訳
|
|
1358
|
-
manufacturing --> inv_asset : 完成仕訳
|
|
1359
|
-
cost --> journal : 原価仕訳
|
|
1360
|
-
|
|
1361
|
-
' 在庫
|
|
1362
|
-
inventory --> inv_asset : 在庫評価
|
|
1363
|
-
|
|
1364
|
-
@enduml
|
|
1365
|
-
```
|
|
1366
|
-
|
|
1367
|
-
### イベントカタログ
|
|
1368
|
-
|
|
1369
|
-
```plantuml
|
|
1370
|
-
@startuml
|
|
1371
|
-
title システム間連携イベントカタログ
|
|
1372
|
-
|
|
1373
|
-
class "販売イベント" as sales_events {
|
|
1374
|
-
OrderConfirmed(受注確定)
|
|
1375
|
-
ShipmentCompleted(出荷完了)
|
|
1376
|
-
SalesCompleted(売上計上)
|
|
1377
|
-
BillingConfirmed(請求確定)
|
|
1378
|
-
PaymentReceived(入金確認)
|
|
1379
|
-
}
|
|
1380
|
-
|
|
1381
|
-
class "生産イベント" as prod_events {
|
|
1382
|
-
DemandRegistered(需要登録)
|
|
1383
|
-
WorkOrderReleased(製造指示)
|
|
1384
|
-
ProductionCompleted(製造完成)
|
|
1385
|
-
ReceiptConfirmed(検収確定)
|
|
1386
|
-
InventoryAdjusted(在庫調整)
|
|
1387
|
-
}
|
|
1388
|
-
|
|
1389
|
-
class "会計イベント" as acc_events {
|
|
1390
|
-
JournalPosted(仕訳計上)
|
|
1391
|
-
BalanceUpdated(残高更新)
|
|
1392
|
-
MonthEndClosed(月次締め)
|
|
1393
|
-
}
|
|
1394
|
-
|
|
1395
|
-
note right of sales_events
|
|
1396
|
-
【発行元】販売管理
|
|
1397
|
-
【購読者】生産計画、自動仕訳
|
|
1398
|
-
end note
|
|
1399
|
-
|
|
1400
|
-
note right of prod_events
|
|
1401
|
-
【発行元】生産管理
|
|
1402
|
-
【購読者】販売在庫、自動仕訳
|
|
1403
|
-
end note
|
|
1404
|
-
|
|
1405
|
-
note right of acc_events
|
|
1406
|
-
【発行元】財務会計
|
|
1407
|
-
【購読者】経営ダッシュボード
|
|
1408
|
-
end note
|
|
1409
|
-
|
|
1410
|
-
@enduml
|
|
1411
|
-
```
|
|
1412
|
-
|
|
1413
|
-
---
|
|
1414
|
-
|
|
1415
|
-
## 35.5 まとめ
|
|
1416
|
-
|
|
1417
|
-
本章では、基幹業務システムの具体的な連携パターンについて解説しました。
|
|
1418
|
-
|
|
1419
|
-
### 学んだ連携パターン
|
|
1420
|
-
|
|
1421
|
-
| 連携パターン | 発生元 | 連携先 | 主な処理 |
|
|
1422
|
-
|------------|-------|-------|---------|
|
|
1423
|
-
| 売上→仕訳 | 販売管理 | 財務会計 | 売掛金・売上計上 |
|
|
1424
|
-
| 入金→消込 | 販売管理 | 財務会計 | 売掛金消込 |
|
|
1425
|
-
| 受注→計画 | 販売管理 | 生産管理 | 需要登録・MRP |
|
|
1426
|
-
| 完成→在庫 | 生産管理 | 販売管理 | 在庫同期 |
|
|
1427
|
-
| 検収→仕訳 | 生産管理 | 財務会計 | 買掛金計上 |
|
|
1428
|
-
| 完成→仕訳 | 生産管理 | 財務会計 | 製品・仕掛品振替 |
|
|
1429
|
-
| 棚卸→仕訳 | 生産管理 | 財務会計 | 棚卸損益計上 |
|
|
1430
|
-
|
|
1431
|
-
### 連携設計のポイント
|
|
1432
|
-
|
|
1433
|
-
1. **イベント駆動の採用**
|
|
1434
|
-
|
|
1435
|
-
- システム間の疎結合を実現
|
|
1436
|
-
- 非同期処理による可用性向上
|
|
1437
|
-
- 監査証跡の確保
|
|
1438
|
-
|
|
1439
|
-
2. **自動仕訳パターンの標準化**
|
|
1440
|
-
|
|
1441
|
-
- 取引種別ごとの仕訳パターン定義
|
|
1442
|
-
- 柔軟な条件分岐(商品/顧客グループ)
|
|
1443
|
-
- 例外処理の明確化
|
|
1444
|
-
|
|
1445
|
-
3. **データ整合性の確保**
|
|
1446
|
-
|
|
1447
|
-
- イベント順序の保証
|
|
1448
|
-
- 補償トランザクション
|
|
1449
|
-
- 定期的な突合処理
|
|
1450
|
-
|
|
1451
|
-
### 次章の予告
|
|
1452
|
-
|
|
1453
|
-
第36章では、マスタデータ管理(MDM)について解説します。複数システムで共有されるマスタデータの一元管理方法と、MDMパターンの選択基準を学びます。
|
|
1
|
+
# 第35章:システム間連携パターン
|
|
2
|
+
|
|
3
|
+
本章では、第33章で解説した境界づけられたコンテキストと、第34章で解説したメッセージングパターンを活用して、販売管理・財務会計・生産管理の3つのシステム間の具体的な連携パターンを解説します。
|
|
4
|
+
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
## 35.1 販売管理と財務会計の連携
|
|
8
|
+
|
|
9
|
+
販売管理システムと財務会計システムの連携は、基幹業務システム統合の中核となる部分です。売上、請求、入金などの取引データを正確に会計仕訳へ変換することが求められます。
|
|
10
|
+
|
|
11
|
+
### 連携の全体像
|
|
12
|
+
|
|
13
|
+
```plantuml
|
|
14
|
+
@startuml
|
|
15
|
+
title 販売管理と財務会計の連携全体像
|
|
16
|
+
|
|
17
|
+
package "販売管理システム" as sales {
|
|
18
|
+
rectangle "受注管理" as order
|
|
19
|
+
rectangle "出荷管理" as shipment
|
|
20
|
+
rectangle "売上管理" as sales_mgmt
|
|
21
|
+
rectangle "請求管理" as billing
|
|
22
|
+
rectangle "入金管理" as receipt
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
package "イベントバス" as events {
|
|
26
|
+
collections "売上イベント" as sales_event
|
|
27
|
+
collections "請求イベント" as billing_event
|
|
28
|
+
collections "入金イベント" as receipt_event
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
package "財務会計システム" as accounting {
|
|
32
|
+
rectangle "自動仕訳" as auto_journal
|
|
33
|
+
rectangle "仕訳管理" as journal
|
|
34
|
+
rectangle "残高管理" as balance
|
|
35
|
+
rectangle "決算処理" as closing
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
order --> shipment
|
|
39
|
+
shipment --> sales_mgmt
|
|
40
|
+
sales_mgmt --> billing
|
|
41
|
+
billing --> receipt
|
|
42
|
+
|
|
43
|
+
sales_mgmt --> sales_event : 売上計上
|
|
44
|
+
billing --> billing_event : 請求確定
|
|
45
|
+
receipt --> receipt_event : 入金確認
|
|
46
|
+
|
|
47
|
+
sales_event --> auto_journal
|
|
48
|
+
billing_event --> auto_journal
|
|
49
|
+
receipt_event --> auto_journal
|
|
50
|
+
|
|
51
|
+
auto_journal --> journal
|
|
52
|
+
journal --> balance
|
|
53
|
+
|
|
54
|
+
@enduml
|
|
55
|
+
```
|
|
56
|
+
|
|
57
|
+
### 売上データから仕訳データへの変換
|
|
58
|
+
|
|
59
|
+
売上計上時に発生する仕訳は、売上の種類や取引条件によって異なります。
|
|
60
|
+
|
|
61
|
+
```plantuml
|
|
62
|
+
@startuml
|
|
63
|
+
title 売上から仕訳への変換フロー
|
|
64
|
+
|
|
65
|
+
|販売管理|
|
|
66
|
+
start
|
|
67
|
+
:売上計上;
|
|
68
|
+
:売上イベント発行;
|
|
69
|
+
|
|
70
|
+
|イベントバス|
|
|
71
|
+
:売上イベント受信;
|
|
72
|
+
|
|
73
|
+
|財務会計|
|
|
74
|
+
:仕訳パターン判定;
|
|
75
|
+
note right
|
|
76
|
+
・商品グループ
|
|
77
|
+
・顧客グループ
|
|
78
|
+
・取引条件
|
|
79
|
+
end note
|
|
80
|
+
|
|
81
|
+
:仕訳明細生成;
|
|
82
|
+
note right
|
|
83
|
+
借方:売掛金
|
|
84
|
+
貸方:売上高
|
|
85
|
+
貸方:仮受消費税
|
|
86
|
+
end note
|
|
87
|
+
|
|
88
|
+
:貸借一致検証;
|
|
89
|
+
:仕訳登録;
|
|
90
|
+
:残高更新;
|
|
91
|
+
|
|
92
|
+
stop
|
|
93
|
+
|
|
94
|
+
@enduml
|
|
95
|
+
```
|
|
96
|
+
|
|
97
|
+
#### 売上仕訳の基本パターン
|
|
98
|
+
|
|
99
|
+
```plantuml
|
|
100
|
+
@startuml
|
|
101
|
+
title 売上仕訳の基本パターン
|
|
102
|
+
|
|
103
|
+
object "売上データ" as sales {
|
|
104
|
+
売上番号 = "SLS-2024-001"
|
|
105
|
+
売上日 = "2024/01/15"
|
|
106
|
+
顧客コード = "CUS-001"
|
|
107
|
+
売上金額 = 110,000円
|
|
108
|
+
消費税額 = 10,000円
|
|
109
|
+
税抜金額 = 100,000円
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
object "仕訳伝票" as journal {
|
|
113
|
+
伝票番号 = "JRN-2024-001"
|
|
114
|
+
起票日 = "2024/01/15"
|
|
115
|
+
伝票区分 = "売上仕訳"
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
object "借方明細" as debit {
|
|
119
|
+
勘定科目 = "売掛金"
|
|
120
|
+
金額 = 110,000円
|
|
121
|
+
摘要 = "CUS-001 売上"
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
object "貸方明細1" as credit1 {
|
|
125
|
+
勘定科目 = "売上高"
|
|
126
|
+
金額 = 100,000円
|
|
127
|
+
摘要 = "商品売上"
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
object "貸方明細2" as credit2 {
|
|
131
|
+
勘定科目 = "仮受消費税"
|
|
132
|
+
金額 = 10,000円
|
|
133
|
+
摘要 = "消費税10%"
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
sales --> journal : 変換
|
|
137
|
+
journal --> debit
|
|
138
|
+
journal --> credit1
|
|
139
|
+
journal --> credit2
|
|
140
|
+
|
|
141
|
+
note bottom of journal
|
|
142
|
+
【貸借一致の検証】
|
|
143
|
+
借方合計:110,000円
|
|
144
|
+
貸方合計:110,000円
|
|
145
|
+
差額:0円 ✓
|
|
146
|
+
end note
|
|
147
|
+
|
|
148
|
+
@enduml
|
|
149
|
+
```
|
|
150
|
+
|
|
151
|
+
#### 売上仕訳パターンマスタ
|
|
152
|
+
|
|
153
|
+
```plantuml
|
|
154
|
+
@startuml
|
|
155
|
+
title 自動仕訳パターンマスタの構造
|
|
156
|
+
|
|
157
|
+
entity "自動仕訳パターン" as pattern {
|
|
158
|
+
*パターンID : string
|
|
159
|
+
--
|
|
160
|
+
*取引種別 : string
|
|
161
|
+
商品グループ : string
|
|
162
|
+
顧客グループ : string
|
|
163
|
+
借方科目コード : string
|
|
164
|
+
貸方科目コード : string
|
|
165
|
+
消費税科目コード : string
|
|
166
|
+
適用開始日 : date
|
|
167
|
+
適用終了日 : date
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
entity "勘定科目" as account {
|
|
171
|
+
*科目コード : string
|
|
172
|
+
--
|
|
173
|
+
科目名 : string
|
|
174
|
+
BSPL区分 : string
|
|
175
|
+
貸借区分 : string
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
pattern }o--|| account : 借方科目
|
|
179
|
+
pattern }o--|| account : 貸方科目
|
|
180
|
+
pattern }o--|| account : 消費税科目
|
|
181
|
+
|
|
182
|
+
@enduml
|
|
183
|
+
```
|
|
184
|
+
|
|
185
|
+
<details>
|
|
186
|
+
<summary>仕訳パターンテーブル定義</summary>
|
|
187
|
+
|
|
188
|
+
```sql
|
|
189
|
+
-- 自動仕訳パターンマスタ
|
|
190
|
+
CREATE TABLE 自動仕訳パターン (
|
|
191
|
+
パターンID VARCHAR(20) PRIMARY KEY,
|
|
192
|
+
取引種別 VARCHAR(20) NOT NULL,
|
|
193
|
+
商品グループ VARCHAR(10),
|
|
194
|
+
顧客グループ VARCHAR(10),
|
|
195
|
+
借方科目コード VARCHAR(10) NOT NULL,
|
|
196
|
+
貸方科目コード VARCHAR(10) NOT NULL,
|
|
197
|
+
消費税科目コード VARCHAR(10),
|
|
198
|
+
適用開始日 DATE NOT NULL,
|
|
199
|
+
適用終了日 DATE,
|
|
200
|
+
作成日時 TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
201
|
+
更新日時 TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
202
|
+
FOREIGN KEY (借方科目コード) REFERENCES 勘定科目(科目コード),
|
|
203
|
+
FOREIGN KEY (貸方科目コード) REFERENCES 勘定科目(科目コード),
|
|
204
|
+
FOREIGN KEY (消費税科目コード) REFERENCES 勘定科目(科目コード)
|
|
205
|
+
);
|
|
206
|
+
|
|
207
|
+
-- サンプルデータ
|
|
208
|
+
INSERT INTO 自動仕訳パターン VALUES
|
|
209
|
+
('PTN-SALES-001', '売上', NULL, NULL, '1310', '4110', '2191', '2024-01-01', NULL),
|
|
210
|
+
('PTN-SALES-002', '売上', 'FOOD', NULL, '1310', '4120', '2191', '2024-01-01', NULL),
|
|
211
|
+
('PTN-RETURN-001', '売上返品', NULL, NULL, '4110', '1310', '2191', '2024-01-01', NULL);
|
|
212
|
+
```
|
|
213
|
+
|
|
214
|
+
</details>
|
|
215
|
+
|
|
216
|
+
### 自動仕訳パターンの適用
|
|
217
|
+
|
|
218
|
+
商品グループや顧客グループに応じて、適切な仕訳パターンを自動選択します。
|
|
219
|
+
|
|
220
|
+
```plantuml
|
|
221
|
+
@startuml
|
|
222
|
+
title 自動仕訳パターン判定ロジック
|
|
223
|
+
|
|
224
|
+
start
|
|
225
|
+
|
|
226
|
+
:売上イベント受信;
|
|
227
|
+
|
|
228
|
+
:商品グループ取得;
|
|
229
|
+
:顧客グループ取得;
|
|
230
|
+
|
|
231
|
+
if (特定商品グループ?) then (yes)
|
|
232
|
+
:商品グループ専用\nパターン検索;
|
|
233
|
+
else (no)
|
|
234
|
+
if (特定顧客グループ?) then (yes)
|
|
235
|
+
:顧客グループ専用\nパターン検索;
|
|
236
|
+
else (no)
|
|
237
|
+
:汎用パターン検索;
|
|
238
|
+
endif
|
|
239
|
+
endif
|
|
240
|
+
|
|
241
|
+
if (パターン見つかった?) then (yes)
|
|
242
|
+
:仕訳明細生成;
|
|
243
|
+
:仕訳登録;
|
|
244
|
+
else (no)
|
|
245
|
+
:エラー通知;
|
|
246
|
+
:手動仕訳待ち\nキューに投入;
|
|
247
|
+
endif
|
|
248
|
+
|
|
249
|
+
stop
|
|
250
|
+
|
|
251
|
+
@enduml
|
|
252
|
+
```
|
|
253
|
+
|
|
254
|
+
<details>
|
|
255
|
+
<summary>Java 実装例</summary>
|
|
256
|
+
|
|
257
|
+
```java
|
|
258
|
+
// 自動仕訳パターンリポジトリ
|
|
259
|
+
public interface JournalPatternRepository {
|
|
260
|
+
Optional<JournalPattern> findByTransactionTypeAndGroups(
|
|
261
|
+
TransactionType type,
|
|
262
|
+
String productGroup,
|
|
263
|
+
String customerGroup,
|
|
264
|
+
LocalDate effectiveDate
|
|
265
|
+
);
|
|
266
|
+
}
|
|
267
|
+
|
|
268
|
+
// 自動仕訳サービス
|
|
269
|
+
@Service
|
|
270
|
+
@Transactional
|
|
271
|
+
public class AutoJournalService {
|
|
272
|
+
private final JournalPatternRepository patternRepository;
|
|
273
|
+
private final JournalRepository journalRepository;
|
|
274
|
+
private final AccountRepository accountRepository;
|
|
275
|
+
|
|
276
|
+
@EventListener
|
|
277
|
+
public void handleSalesCompleted(SalesCompletedEvent event) {
|
|
278
|
+
// パターン検索(優先順位:商品グループ > 顧客グループ > 汎用)
|
|
279
|
+
JournalPattern pattern = findPattern(event);
|
|
280
|
+
|
|
281
|
+
// 仕訳伝票生成
|
|
282
|
+
JournalEntry journal = createJournalEntry(event, pattern);
|
|
283
|
+
|
|
284
|
+
// 貸借一致検証
|
|
285
|
+
validateBalance(journal);
|
|
286
|
+
|
|
287
|
+
// 仕訳登録
|
|
288
|
+
journalRepository.save(journal);
|
|
289
|
+
|
|
290
|
+
// 残高更新イベント発行
|
|
291
|
+
publishBalanceUpdateEvent(journal);
|
|
292
|
+
}
|
|
293
|
+
|
|
294
|
+
private JournalPattern findPattern(SalesCompletedEvent event) {
|
|
295
|
+
// 1. 商品グループ + 顧客グループで検索
|
|
296
|
+
Optional<JournalPattern> pattern = patternRepository
|
|
297
|
+
.findByTransactionTypeAndGroups(
|
|
298
|
+
TransactionType.SALES,
|
|
299
|
+
event.productGroup(),
|
|
300
|
+
event.customerGroup(),
|
|
301
|
+
event.salesDate()
|
|
302
|
+
);
|
|
303
|
+
|
|
304
|
+
if (pattern.isPresent()) return pattern.get();
|
|
305
|
+
|
|
306
|
+
// 2. 商品グループのみで検索
|
|
307
|
+
pattern = patternRepository.findByTransactionTypeAndGroups(
|
|
308
|
+
TransactionType.SALES,
|
|
309
|
+
event.productGroup(),
|
|
310
|
+
null,
|
|
311
|
+
event.salesDate()
|
|
312
|
+
);
|
|
313
|
+
|
|
314
|
+
if (pattern.isPresent()) return pattern.get();
|
|
315
|
+
|
|
316
|
+
// 3. 顧客グループのみで検索
|
|
317
|
+
pattern = patternRepository.findByTransactionTypeAndGroups(
|
|
318
|
+
TransactionType.SALES,
|
|
319
|
+
null,
|
|
320
|
+
event.customerGroup(),
|
|
321
|
+
event.salesDate()
|
|
322
|
+
);
|
|
323
|
+
|
|
324
|
+
if (pattern.isPresent()) return pattern.get();
|
|
325
|
+
|
|
326
|
+
// 4. 汎用パターンで検索
|
|
327
|
+
return patternRepository.findByTransactionTypeAndGroups(
|
|
328
|
+
TransactionType.SALES,
|
|
329
|
+
null,
|
|
330
|
+
null,
|
|
331
|
+
event.salesDate()
|
|
332
|
+
).orElseThrow(() -> new PatternNotFoundException(
|
|
333
|
+
"仕訳パターンが見つかりません: " + event.salesId()
|
|
334
|
+
));
|
|
335
|
+
}
|
|
336
|
+
|
|
337
|
+
private JournalEntry createJournalEntry(
|
|
338
|
+
SalesCompletedEvent event,
|
|
339
|
+
JournalPattern pattern) {
|
|
340
|
+
|
|
341
|
+
List<JournalLine> lines = new ArrayList<>();
|
|
342
|
+
|
|
343
|
+
// 借方:売掛金
|
|
344
|
+
lines.add(JournalLine.debit(
|
|
345
|
+
pattern.debitAccountCode(),
|
|
346
|
+
event.totalAmount(),
|
|
347
|
+
"売掛金計上 " + event.customerName()
|
|
348
|
+
));
|
|
349
|
+
|
|
350
|
+
// 貸方:売上高
|
|
351
|
+
lines.add(JournalLine.credit(
|
|
352
|
+
pattern.creditAccountCode(),
|
|
353
|
+
event.netAmount(),
|
|
354
|
+
"売上計上 " + event.salesId()
|
|
355
|
+
));
|
|
356
|
+
|
|
357
|
+
// 貸方:仮受消費税
|
|
358
|
+
if (event.taxAmount().compareTo(BigDecimal.ZERO) > 0) {
|
|
359
|
+
lines.add(JournalLine.credit(
|
|
360
|
+
pattern.taxAccountCode(),
|
|
361
|
+
event.taxAmount(),
|
|
362
|
+
"仮受消費税"
|
|
363
|
+
));
|
|
364
|
+
}
|
|
365
|
+
|
|
366
|
+
return new JournalEntry(
|
|
367
|
+
generateJournalId(),
|
|
368
|
+
event.salesDate(),
|
|
369
|
+
JournalType.AUTO_SALES,
|
|
370
|
+
event.salesId(),
|
|
371
|
+
lines
|
|
372
|
+
);
|
|
373
|
+
}
|
|
374
|
+
|
|
375
|
+
private void validateBalance(JournalEntry journal) {
|
|
376
|
+
BigDecimal debitTotal = journal.lines().stream()
|
|
377
|
+
.filter(l -> l.debitCredit() == DebitCredit.DEBIT)
|
|
378
|
+
.map(JournalLine::amount)
|
|
379
|
+
.reduce(BigDecimal.ZERO, BigDecimal::add);
|
|
380
|
+
|
|
381
|
+
BigDecimal creditTotal = journal.lines().stream()
|
|
382
|
+
.filter(l -> l.debitCredit() == DebitCredit.CREDIT)
|
|
383
|
+
.map(JournalLine::amount)
|
|
384
|
+
.reduce(BigDecimal.ZERO, BigDecimal::add);
|
|
385
|
+
|
|
386
|
+
if (debitTotal.compareTo(creditTotal) != 0) {
|
|
387
|
+
throw new BalanceMismatchException(
|
|
388
|
+
"貸借不一致: 借方=" + debitTotal + ", 貸方=" + creditTotal
|
|
389
|
+
);
|
|
390
|
+
}
|
|
391
|
+
}
|
|
392
|
+
}
|
|
393
|
+
```
|
|
394
|
+
|
|
395
|
+
</details>
|
|
396
|
+
|
|
397
|
+
### イベント駆動による仕訳生成
|
|
398
|
+
|
|
399
|
+
販売管理システムで発生する各種イベントに応じて、自動的に仕訳を生成します。
|
|
400
|
+
|
|
401
|
+
```plantuml
|
|
402
|
+
@startuml
|
|
403
|
+
title 販売イベントと仕訳の対応
|
|
404
|
+
|
|
405
|
+
' 配置を制御するための設定
|
|
406
|
+
skinparam nodesep 50
|
|
407
|
+
skinparam ranksep 50
|
|
408
|
+
|
|
409
|
+
rectangle "販売管理イベント" as sales_events {
|
|
410
|
+
rectangle "売上計上" as sales_completed
|
|
411
|
+
rectangle "売上返品" as sales_return
|
|
412
|
+
rectangle "請求確定" as billing_confirmed
|
|
413
|
+
rectangle "入金確認" as payment_received
|
|
414
|
+
rectangle "貸倒発生" as bad_debt
|
|
415
|
+
}
|
|
416
|
+
|
|
417
|
+
rectangle "自動仕訳" as auto_journal {
|
|
418
|
+
rectangle "売上仕訳\n生成" as sales_journal
|
|
419
|
+
rectangle "返品仕訳\n生成" as return_journal
|
|
420
|
+
rectangle "(請求時仕訳\nなし)" as billing_journal
|
|
421
|
+
rectangle "入金仕訳\n生成" as payment_journal
|
|
422
|
+
rectangle "貸倒仕訳\n生成" as bad_debt_journal
|
|
423
|
+
}
|
|
424
|
+
|
|
425
|
+
rectangle "仕訳パターン" as patterns {
|
|
426
|
+
rectangle "==売上仕訳\n\n借方: 売掛金\n貸方: 売上高\n貸方: 仮受消費税" as p1
|
|
427
|
+
rectangle "==返品仕訳\n\n借方: 売上高\n借方: 仮受消費税\n貸方: 売掛金" as p2
|
|
428
|
+
rectangle "==入金仕訳\n\n借方: 普通預金\n貸方: 売掛金" as p3
|
|
429
|
+
rectangle "==貸倒仕訳\n\n借方: 貸倒損失\n貸方: 売掛金" as p4
|
|
430
|
+
}
|
|
431
|
+
|
|
432
|
+
sales_completed --> sales_journal
|
|
433
|
+
sales_return --> return_journal
|
|
434
|
+
billing_confirmed --> billing_journal
|
|
435
|
+
payment_received --> payment_journal
|
|
436
|
+
bad_debt --> bad_debt_journal
|
|
437
|
+
|
|
438
|
+
sales_journal --> p1
|
|
439
|
+
return_journal --> p2
|
|
440
|
+
payment_journal --> p3
|
|
441
|
+
bad_debt_journal --> p4
|
|
442
|
+
|
|
443
|
+
@enduml
|
|
444
|
+
```
|
|
445
|
+
|
|
446
|
+
#### 入金消込と仕訳生成
|
|
447
|
+
|
|
448
|
+
```plantuml
|
|
449
|
+
@startuml
|
|
450
|
+
title 入金消込と仕訳生成フロー
|
|
451
|
+
|
|
452
|
+
|販売管理|
|
|
453
|
+
start
|
|
454
|
+
:入金データ受信;
|
|
455
|
+
:請求データ照合;
|
|
456
|
+
|
|
457
|
+
if (消込対象あり?) then (yes)
|
|
458
|
+
:入金消込処理;
|
|
459
|
+
:消込イベント発行;
|
|
460
|
+
else (no)
|
|
461
|
+
:前受金計上;
|
|
462
|
+
:前受金イベント発行;
|
|
463
|
+
endif
|
|
464
|
+
|
|
465
|
+
|財務会計|
|
|
466
|
+
if (消込イベント?) then (yes)
|
|
467
|
+
:入金仕訳生成;
|
|
468
|
+
note right
|
|
469
|
+
借方: 普通預金
|
|
470
|
+
貸方: 売掛金
|
|
471
|
+
end note
|
|
472
|
+
else (no)
|
|
473
|
+
:前受金仕訳生成;
|
|
474
|
+
note right
|
|
475
|
+
借方: 普通預金
|
|
476
|
+
貸方: 前受金
|
|
477
|
+
end note
|
|
478
|
+
endif
|
|
479
|
+
|
|
480
|
+
:仕訳登録;
|
|
481
|
+
:売掛金残高更新;
|
|
482
|
+
|
|
483
|
+
stop
|
|
484
|
+
|
|
485
|
+
@enduml
|
|
486
|
+
```
|
|
487
|
+
|
|
488
|
+
---
|
|
489
|
+
|
|
490
|
+
## 35.2 販売管理と生産管理の連携
|
|
491
|
+
|
|
492
|
+
販売管理システムと生産管理システムの連携は、需要と供給のバランスを取るために重要です。受注情報を生産計画に反映し、在庫情報を双方向で同期します。
|
|
493
|
+
|
|
494
|
+
### 連携の全体像
|
|
495
|
+
|
|
496
|
+
```plantuml
|
|
497
|
+
@startuml
|
|
498
|
+
title 販売管理と生産管理の連携全体像
|
|
499
|
+
|
|
500
|
+
package "販売管理システム" as sales {
|
|
501
|
+
rectangle "受注管理" as order
|
|
502
|
+
rectangle "出荷管理" as shipment
|
|
503
|
+
rectangle "在庫照会" as sales_inv
|
|
504
|
+
}
|
|
505
|
+
|
|
506
|
+
package "イベントバス" as events {
|
|
507
|
+
collections "受注イベント" as order_event
|
|
508
|
+
collections "在庫イベント" as inv_event
|
|
509
|
+
collections "完成イベント" as complete_event
|
|
510
|
+
}
|
|
511
|
+
|
|
512
|
+
package "生産管理システム" as production {
|
|
513
|
+
rectangle "生産計画" as plan
|
|
514
|
+
rectangle "MRP" as mrp
|
|
515
|
+
rectangle "製造管理" as manufacturing
|
|
516
|
+
rectangle "在庫管理" as prod_inv
|
|
517
|
+
}
|
|
518
|
+
|
|
519
|
+
order --> order_event : 受注確定
|
|
520
|
+
order_event --> plan : 需要情報
|
|
521
|
+
|
|
522
|
+
plan --> mrp : 所要量展開
|
|
523
|
+
mrp --> manufacturing : 製造指示
|
|
524
|
+
|
|
525
|
+
manufacturing --> complete_event : 完成報告
|
|
526
|
+
complete_event --> prod_inv : 在庫計上
|
|
527
|
+
prod_inv --> inv_event : 在庫更新
|
|
528
|
+
|
|
529
|
+
inv_event --> sales_inv : 在庫同期
|
|
530
|
+
sales_inv --> shipment : 引当可能数
|
|
531
|
+
|
|
532
|
+
@enduml
|
|
533
|
+
```
|
|
534
|
+
|
|
535
|
+
### 受注情報から生産計画への連携
|
|
536
|
+
|
|
537
|
+
```plantuml
|
|
538
|
+
@startuml
|
|
539
|
+
title 受注から生産計画への連携フロー
|
|
540
|
+
|
|
541
|
+
|販売管理|
|
|
542
|
+
start
|
|
543
|
+
:受注登録;
|
|
544
|
+
:受注確定;
|
|
545
|
+
:受注イベント発行;
|
|
546
|
+
|
|
547
|
+
|生産計画|
|
|
548
|
+
:受注イベント受信;
|
|
549
|
+
:需要情報登録;
|
|
550
|
+
|
|
551
|
+
:在庫・発注残確認;
|
|
552
|
+
if (在庫で充足?) then (yes)
|
|
553
|
+
:引当処理;
|
|
554
|
+
else (no)
|
|
555
|
+
:正味所要量計算;
|
|
556
|
+
if (製品?) then (yes)
|
|
557
|
+
:製造オーダ作成;
|
|
558
|
+
else (no)
|
|
559
|
+
:発注提案作成;
|
|
560
|
+
endif
|
|
561
|
+
endif
|
|
562
|
+
|
|
563
|
+
:計画確定;
|
|
564
|
+
:計画確定イベント発行;
|
|
565
|
+
|
|
566
|
+
|販売管理|
|
|
567
|
+
:納期回答更新;
|
|
568
|
+
|
|
569
|
+
stop
|
|
570
|
+
|
|
571
|
+
@enduml
|
|
572
|
+
```
|
|
573
|
+
|
|
574
|
+
#### 受注イベントの構造
|
|
575
|
+
|
|
576
|
+
```plantuml
|
|
577
|
+
@startuml
|
|
578
|
+
title 受注イベントの構造
|
|
579
|
+
|
|
580
|
+
class "OrderConfirmedEvent" as event {
|
|
581
|
+
+eventId: String
|
|
582
|
+
+timestamp: Instant
|
|
583
|
+
+orderId: String
|
|
584
|
+
+customerId: String
|
|
585
|
+
+requestedDeliveryDate: LocalDate
|
|
586
|
+
+priority: Priority
|
|
587
|
+
+lines: List<OrderLineEvent>
|
|
588
|
+
}
|
|
589
|
+
|
|
590
|
+
class "OrderLineEvent" as line {
|
|
591
|
+
+lineNumber: int
|
|
592
|
+
+productId: String
|
|
593
|
+
+quantity: BigDecimal
|
|
594
|
+
+unit: String
|
|
595
|
+
+requestedDate: LocalDate
|
|
596
|
+
}
|
|
597
|
+
|
|
598
|
+
event "1" -- "*" line
|
|
599
|
+
|
|
600
|
+
note right of event
|
|
601
|
+
【生産計画に必要な情報】
|
|
602
|
+
・製品コード
|
|
603
|
+
・必要数量
|
|
604
|
+
・希望納期
|
|
605
|
+
・優先度
|
|
606
|
+
end note
|
|
607
|
+
|
|
608
|
+
@enduml
|
|
609
|
+
```
|
|
610
|
+
|
|
611
|
+
<details>
|
|
612
|
+
<summary>Java 実装例</summary>
|
|
613
|
+
|
|
614
|
+
```java
|
|
615
|
+
// 受注確定イベント
|
|
616
|
+
public record OrderConfirmedEvent(
|
|
617
|
+
String eventId,
|
|
618
|
+
Instant timestamp,
|
|
619
|
+
String orderId,
|
|
620
|
+
String customerId,
|
|
621
|
+
LocalDate requestedDeliveryDate,
|
|
622
|
+
Priority priority,
|
|
623
|
+
List<OrderLineEvent> lines
|
|
624
|
+
) {
|
|
625
|
+
public enum Priority {
|
|
626
|
+
URGENT, // 緊急
|
|
627
|
+
HIGH, // 高
|
|
628
|
+
NORMAL, // 通常
|
|
629
|
+
LOW // 低
|
|
630
|
+
}
|
|
631
|
+
}
|
|
632
|
+
|
|
633
|
+
// 生産計画サービス
|
|
634
|
+
@Service
|
|
635
|
+
public class ProductionPlanningService {
|
|
636
|
+
private final DemandRepository demandRepository;
|
|
637
|
+
private final InventoryRepository inventoryRepository;
|
|
638
|
+
private final MrpService mrpService;
|
|
639
|
+
|
|
640
|
+
@EventListener
|
|
641
|
+
public void handleOrderConfirmed(OrderConfirmedEvent event) {
|
|
642
|
+
// 需要情報として登録
|
|
643
|
+
for (OrderLineEvent line : event.lines()) {
|
|
644
|
+
Demand demand = Demand.fromOrder(
|
|
645
|
+
event.orderId(),
|
|
646
|
+
line.productId(),
|
|
647
|
+
line.quantity(),
|
|
648
|
+
line.requestedDate(),
|
|
649
|
+
event.priority()
|
|
650
|
+
);
|
|
651
|
+
demandRepository.save(demand);
|
|
652
|
+
|
|
653
|
+
// 在庫引当を試行
|
|
654
|
+
AllocationResult result = tryAllocate(demand);
|
|
655
|
+
|
|
656
|
+
if (!result.isFullyAllocated()) {
|
|
657
|
+
// MRP実行して製造/発注オーダを生成
|
|
658
|
+
mrpService.execute(demand);
|
|
659
|
+
}
|
|
660
|
+
}
|
|
661
|
+
|
|
662
|
+
// 納期回答イベント発行
|
|
663
|
+
publishDeliveryDateResponse(event.orderId());
|
|
664
|
+
}
|
|
665
|
+
|
|
666
|
+
private AllocationResult tryAllocate(Demand demand) {
|
|
667
|
+
BigDecimal available = inventoryRepository
|
|
668
|
+
.findAvailableQuantity(demand.productId());
|
|
669
|
+
|
|
670
|
+
if (available.compareTo(demand.quantity()) >= 0) {
|
|
671
|
+
// 引当実行
|
|
672
|
+
inventoryRepository.allocate(
|
|
673
|
+
demand.productId(),
|
|
674
|
+
demand.quantity(),
|
|
675
|
+
demand.demandId()
|
|
676
|
+
);
|
|
677
|
+
return AllocationResult.fullyAllocated(demand.quantity());
|
|
678
|
+
} else {
|
|
679
|
+
// 部分引当
|
|
680
|
+
if (available.compareTo(BigDecimal.ZERO) > 0) {
|
|
681
|
+
inventoryRepository.allocate(
|
|
682
|
+
demand.productId(),
|
|
683
|
+
available,
|
|
684
|
+
demand.demandId()
|
|
685
|
+
);
|
|
686
|
+
}
|
|
687
|
+
return AllocationResult.partiallyAllocated(
|
|
688
|
+
available,
|
|
689
|
+
demand.quantity().subtract(available)
|
|
690
|
+
);
|
|
691
|
+
}
|
|
692
|
+
}
|
|
693
|
+
}
|
|
694
|
+
```
|
|
695
|
+
|
|
696
|
+
</details>
|
|
697
|
+
|
|
698
|
+
### 需要予測データの共有
|
|
699
|
+
|
|
700
|
+
```plantuml
|
|
701
|
+
@startuml
|
|
702
|
+
title 需要予測データの共有
|
|
703
|
+
|
|
704
|
+
package "販売管理" as sales {
|
|
705
|
+
rectangle "販売実績" as sales_history
|
|
706
|
+
rectangle "受注残" as backlog
|
|
707
|
+
rectangle "見積案件" as quotation
|
|
708
|
+
}
|
|
709
|
+
|
|
710
|
+
package "需要予測エンジン" as forecast {
|
|
711
|
+
rectangle "時系列分析" as time_series
|
|
712
|
+
rectangle "季節調整" as seasonal
|
|
713
|
+
rectangle "トレンド分析" as trend
|
|
714
|
+
}
|
|
715
|
+
|
|
716
|
+
package "生産計画" as planning {
|
|
717
|
+
rectangle "MPS\n(基準生産計画)" as mps
|
|
718
|
+
rectangle "MRP\n(所要量計画)" as mrp
|
|
719
|
+
}
|
|
720
|
+
|
|
721
|
+
sales_history --> forecast
|
|
722
|
+
backlog --> forecast
|
|
723
|
+
quotation --> forecast
|
|
724
|
+
|
|
725
|
+
forecast --> mps : 需要予測データ
|
|
726
|
+
mps --> mrp : 計画生産量
|
|
727
|
+
|
|
728
|
+
note right of forecast
|
|
729
|
+
【予測データの内容】
|
|
730
|
+
・製品別月次予測数量
|
|
731
|
+
・予測精度(信頼区間)
|
|
732
|
+
・季節変動係数
|
|
733
|
+
・トレンド方向
|
|
734
|
+
end note
|
|
735
|
+
|
|
736
|
+
@enduml
|
|
737
|
+
```
|
|
738
|
+
|
|
739
|
+
#### 需要予測イベント
|
|
740
|
+
|
|
741
|
+
```plantuml
|
|
742
|
+
@startuml
|
|
743
|
+
title 需要予測の連携サイクル
|
|
744
|
+
|
|
745
|
+
|販売管理|
|
|
746
|
+
start
|
|
747
|
+
:月次販売実績集計;
|
|
748
|
+
:受注残・見積集計;
|
|
749
|
+
:需要予測更新;
|
|
750
|
+
:予測データ発行;
|
|
751
|
+
|
|
752
|
+
|生産計画|
|
|
753
|
+
:予測データ受信;
|
|
754
|
+
:MPS更新;
|
|
755
|
+
note right
|
|
756
|
+
・月次生産計画
|
|
757
|
+
・安全在庫調整
|
|
758
|
+
・生産能力確認
|
|
759
|
+
end note
|
|
760
|
+
|
|
761
|
+
:MRP実行;
|
|
762
|
+
:発注提案生成;
|
|
763
|
+
:製造計画生成;
|
|
764
|
+
|
|
765
|
+
if (計画変更あり?) then (yes)
|
|
766
|
+
:計画変更通知;
|
|
767
|
+
endif
|
|
768
|
+
|
|
769
|
+
|販売管理|
|
|
770
|
+
:納期情報更新;
|
|
771
|
+
|
|
772
|
+
stop
|
|
773
|
+
|
|
774
|
+
@enduml
|
|
775
|
+
```
|
|
776
|
+
|
|
777
|
+
### 在庫情報の同期
|
|
778
|
+
|
|
779
|
+
販売管理と生産管理の両方で在庫を管理する場合、整合性を保つ必要があります。
|
|
780
|
+
|
|
781
|
+
```plantuml
|
|
782
|
+
@startuml
|
|
783
|
+
title 在庫情報の同期パターン
|
|
784
|
+
|
|
785
|
+
package "販売管理" as sales {
|
|
786
|
+
database "販売在庫ビュー\n----\n在庫数\n引当数\n有効在庫数" as sales_inv
|
|
787
|
+
}
|
|
788
|
+
|
|
789
|
+
package "生産管理" as production {
|
|
790
|
+
database "生産在庫(マスタ)\n----\n在庫数\n引当数\n品質状態\nロット情報" as prod_inv
|
|
791
|
+
}
|
|
792
|
+
|
|
793
|
+
package "同期メカニズム" as sync {
|
|
794
|
+
collections "在庫更新\nイベント" as inv_event
|
|
795
|
+
rectangle "在庫同期\nサービス" as sync_svc
|
|
796
|
+
}
|
|
797
|
+
|
|
798
|
+
prod_inv --> inv_event : 在庫変動時
|
|
799
|
+
inv_event --> sync_svc
|
|
800
|
+
sync_svc --> sales_inv : ビュー更新
|
|
801
|
+
|
|
802
|
+
note bottom of sync
|
|
803
|
+
【同期タイミング】
|
|
804
|
+
・完成時(入庫)
|
|
805
|
+
・出荷時(出庫)
|
|
806
|
+
・棚卸差異発生時
|
|
807
|
+
・品質状態変更時
|
|
808
|
+
|
|
809
|
+
【同期内容】
|
|
810
|
+
・製品別在庫数
|
|
811
|
+
・引当可能数
|
|
812
|
+
・入庫予定
|
|
813
|
+
end note
|
|
814
|
+
|
|
815
|
+
@enduml
|
|
816
|
+
```
|
|
817
|
+
|
|
818
|
+
<details>
|
|
819
|
+
<summary>Java 実装例</summary>
|
|
820
|
+
|
|
821
|
+
```java
|
|
822
|
+
// 在庫更新イベント
|
|
823
|
+
public record InventoryUpdatedEvent(
|
|
824
|
+
String eventId,
|
|
825
|
+
Instant timestamp,
|
|
826
|
+
String productId,
|
|
827
|
+
String warehouseId,
|
|
828
|
+
BigDecimal previousQuantity,
|
|
829
|
+
BigDecimal currentQuantity,
|
|
830
|
+
BigDecimal allocatedQuantity,
|
|
831
|
+
UpdateReason reason
|
|
832
|
+
) {
|
|
833
|
+
public enum UpdateReason {
|
|
834
|
+
COMPLETION, // 製造完成
|
|
835
|
+
SHIPMENT, // 出荷
|
|
836
|
+
RECEIPT, // 入荷
|
|
837
|
+
ADJUSTMENT, // 棚卸調整
|
|
838
|
+
QUALITY_CHANGE // 品質状態変更
|
|
839
|
+
}
|
|
840
|
+
|
|
841
|
+
public BigDecimal getAvailableQuantity() {
|
|
842
|
+
return currentQuantity.subtract(allocatedQuantity);
|
|
843
|
+
}
|
|
844
|
+
}
|
|
845
|
+
|
|
846
|
+
// 在庫同期サービス
|
|
847
|
+
@Service
|
|
848
|
+
public class InventorySyncService {
|
|
849
|
+
private final SalesInventoryRepository salesInventoryRepository;
|
|
850
|
+
|
|
851
|
+
@EventListener
|
|
852
|
+
public void handleInventoryUpdated(InventoryUpdatedEvent event) {
|
|
853
|
+
// 販売在庫ビューを更新
|
|
854
|
+
SalesInventory salesInv = salesInventoryRepository
|
|
855
|
+
.findByProductId(event.productId())
|
|
856
|
+
.orElse(new SalesInventory(event.productId()));
|
|
857
|
+
|
|
858
|
+
salesInv.updateQuantity(
|
|
859
|
+
event.currentQuantity(),
|
|
860
|
+
event.allocatedQuantity()
|
|
861
|
+
);
|
|
862
|
+
|
|
863
|
+
salesInventoryRepository.save(salesInv);
|
|
864
|
+
|
|
865
|
+
// 低在庫アラート
|
|
866
|
+
if (salesInv.getAvailableQuantity()
|
|
867
|
+
.compareTo(salesInv.getSafetyStock()) < 0) {
|
|
868
|
+
publishLowStockAlert(event.productId());
|
|
869
|
+
}
|
|
870
|
+
}
|
|
871
|
+
}
|
|
872
|
+
```
|
|
873
|
+
|
|
874
|
+
</details>
|
|
875
|
+
|
|
876
|
+
---
|
|
877
|
+
|
|
878
|
+
## 35.3 生産管理と財務会計の連携
|
|
879
|
+
|
|
880
|
+
生産管理システムと財務会計システムの連携は、製造原価の正確な把握と会計処理に不可欠です。
|
|
881
|
+
|
|
882
|
+
### 連携の全体像
|
|
883
|
+
|
|
884
|
+
```plantuml
|
|
885
|
+
@startuml
|
|
886
|
+
title 生産管理と財務会計の連携全体像
|
|
887
|
+
|
|
888
|
+
package "生産管理システム" as production {
|
|
889
|
+
rectangle "購買管理" as purchase
|
|
890
|
+
rectangle "製造管理" as manufacturing
|
|
891
|
+
rectangle "在庫管理" as inventory
|
|
892
|
+
rectangle "原価管理" as cost
|
|
893
|
+
}
|
|
894
|
+
|
|
895
|
+
package "イベントバス" as events {
|
|
896
|
+
collections "検収イベント" as receipt_event
|
|
897
|
+
collections "完成イベント" as complete_event
|
|
898
|
+
collections "棚卸イベント" as inventory_event
|
|
899
|
+
collections "原価イベント" as cost_event
|
|
900
|
+
}
|
|
901
|
+
|
|
902
|
+
package "財務会計システム" as accounting {
|
|
903
|
+
rectangle "自動仕訳" as auto_journal
|
|
904
|
+
rectangle "仕訳管理" as journal
|
|
905
|
+
rectangle "原価会計" as cost_acc
|
|
906
|
+
}
|
|
907
|
+
|
|
908
|
+
purchase --> receipt_event : 検収確定
|
|
909
|
+
manufacturing --> complete_event : 製造完成
|
|
910
|
+
inventory --> inventory_event : 棚卸差異
|
|
911
|
+
cost --> cost_event : 原価計算完了
|
|
912
|
+
|
|
913
|
+
receipt_event --> auto_journal
|
|
914
|
+
complete_event --> auto_journal
|
|
915
|
+
inventory_event --> auto_journal
|
|
916
|
+
cost_event --> cost_acc
|
|
917
|
+
|
|
918
|
+
auto_journal --> journal
|
|
919
|
+
|
|
920
|
+
@enduml
|
|
921
|
+
```
|
|
922
|
+
|
|
923
|
+
### 製造原価から仕訳への変換
|
|
924
|
+
|
|
925
|
+
製造原価は、材料費・労務費・製造間接費の3要素で構成されます。
|
|
926
|
+
|
|
927
|
+
```plantuml
|
|
928
|
+
@startuml
|
|
929
|
+
title 製造原価の構成と仕訳
|
|
930
|
+
|
|
931
|
+
object "製造原価" as cost {
|
|
932
|
+
製造オーダ = "WO-2024-001"
|
|
933
|
+
製品コード = "PRD-001"
|
|
934
|
+
完成数量 = 100
|
|
935
|
+
}
|
|
936
|
+
|
|
937
|
+
object "材料費" as material {
|
|
938
|
+
直接材料費 = 50,000円
|
|
939
|
+
間接材料費 = 5,000円
|
|
940
|
+
}
|
|
941
|
+
|
|
942
|
+
object "労務費" as labor {
|
|
943
|
+
直接労務費 = 30,000円
|
|
944
|
+
間接労務費 = 10,000円
|
|
945
|
+
}
|
|
946
|
+
|
|
947
|
+
object "製造間接費" as overhead {
|
|
948
|
+
配賦額 = 15,000円
|
|
949
|
+
}
|
|
950
|
+
|
|
951
|
+
object "原価仕訳" as journal {
|
|
952
|
+
借方: 製品 110,000円
|
|
953
|
+
貸方: 仕掛品 110,000円
|
|
954
|
+
}
|
|
955
|
+
|
|
956
|
+
cost --> material
|
|
957
|
+
cost --> labor
|
|
958
|
+
cost --> overhead
|
|
959
|
+
|
|
960
|
+
material --> journal : 55,000円
|
|
961
|
+
labor --> journal : 40,000円
|
|
962
|
+
overhead --> journal : 15,000円
|
|
963
|
+
|
|
964
|
+
note bottom of journal
|
|
965
|
+
【製造完成時の仕訳】
|
|
966
|
+
借方:製品(資産)
|
|
967
|
+
貸方:仕掛品(資産)
|
|
968
|
+
|
|
969
|
+
製品原価 = 材料費 + 労務費 + 製造間接費
|
|
970
|
+
= 55,000 + 40,000 + 15,000
|
|
971
|
+
= 110,000円
|
|
972
|
+
end note
|
|
973
|
+
|
|
974
|
+
@enduml
|
|
975
|
+
```
|
|
976
|
+
|
|
977
|
+
#### 製造原価計算フロー
|
|
978
|
+
|
|
979
|
+
```plantuml
|
|
980
|
+
@startuml
|
|
981
|
+
title 製造原価計算と仕訳生成フロー
|
|
982
|
+
|
|
983
|
+
|生産管理|
|
|
984
|
+
start
|
|
985
|
+
:製造完成報告;
|
|
986
|
+
|
|
987
|
+
:材料消費実績集計;
|
|
988
|
+
note right
|
|
989
|
+
・直接材料費
|
|
990
|
+
・間接材料費
|
|
991
|
+
end note
|
|
992
|
+
|
|
993
|
+
:工数実績集計;
|
|
994
|
+
note right
|
|
995
|
+
・直接労務費
|
|
996
|
+
・間接労務費
|
|
997
|
+
end note
|
|
998
|
+
|
|
999
|
+
:製造間接費配賦;
|
|
1000
|
+
note right
|
|
1001
|
+
・配賦基準で按分
|
|
1002
|
+
(直接作業時間等)
|
|
1003
|
+
end note
|
|
1004
|
+
|
|
1005
|
+
:製品原価計算;
|
|
1006
|
+
:完成原価イベント発行;
|
|
1007
|
+
|
|
1008
|
+
|財務会計|
|
|
1009
|
+
:原価イベント受信;
|
|
1010
|
+
:製造完成仕訳生成;
|
|
1011
|
+
note right
|
|
1012
|
+
借方: 製品
|
|
1013
|
+
貸方: 仕掛品
|
|
1014
|
+
end note
|
|
1015
|
+
|
|
1016
|
+
:仕訳登録;
|
|
1017
|
+
:在庫評価額更新;
|
|
1018
|
+
|
|
1019
|
+
stop
|
|
1020
|
+
|
|
1021
|
+
@enduml
|
|
1022
|
+
```
|
|
1023
|
+
|
|
1024
|
+
<details>
|
|
1025
|
+
<summary>Java 実装例</summary>
|
|
1026
|
+
|
|
1027
|
+
```java
|
|
1028
|
+
// 製造完成原価イベント
|
|
1029
|
+
public record ManufacturingCompletedEvent(
|
|
1030
|
+
String eventId,
|
|
1031
|
+
Instant timestamp,
|
|
1032
|
+
String workOrderId,
|
|
1033
|
+
String productId,
|
|
1034
|
+
BigDecimal completedQuantity,
|
|
1035
|
+
CostBreakdown costBreakdown
|
|
1036
|
+
) {
|
|
1037
|
+
public record CostBreakdown(
|
|
1038
|
+
BigDecimal directMaterialCost,
|
|
1039
|
+
BigDecimal indirectMaterialCost,
|
|
1040
|
+
BigDecimal directLaborCost,
|
|
1041
|
+
BigDecimal indirectLaborCost,
|
|
1042
|
+
BigDecimal manufacturingOverhead
|
|
1043
|
+
) {
|
|
1044
|
+
public BigDecimal getTotalCost() {
|
|
1045
|
+
return directMaterialCost
|
|
1046
|
+
.add(indirectMaterialCost)
|
|
1047
|
+
.add(directLaborCost)
|
|
1048
|
+
.add(indirectLaborCost)
|
|
1049
|
+
.add(manufacturingOverhead);
|
|
1050
|
+
}
|
|
1051
|
+
|
|
1052
|
+
public BigDecimal getMaterialCost() {
|
|
1053
|
+
return directMaterialCost.add(indirectMaterialCost);
|
|
1054
|
+
}
|
|
1055
|
+
|
|
1056
|
+
public BigDecimal getLaborCost() {
|
|
1057
|
+
return directLaborCost.add(indirectLaborCost);
|
|
1058
|
+
}
|
|
1059
|
+
}
|
|
1060
|
+
}
|
|
1061
|
+
|
|
1062
|
+
// 製造原価仕訳サービス
|
|
1063
|
+
@Service
|
|
1064
|
+
public class ManufacturingJournalService {
|
|
1065
|
+
private final JournalRepository journalRepository;
|
|
1066
|
+
|
|
1067
|
+
@EventListener
|
|
1068
|
+
public void handleManufacturingCompleted(ManufacturingCompletedEvent event) {
|
|
1069
|
+
CostBreakdown cost = event.costBreakdown();
|
|
1070
|
+
|
|
1071
|
+
List<JournalLine> lines = new ArrayList<>();
|
|
1072
|
+
|
|
1073
|
+
// 借方:製品
|
|
1074
|
+
lines.add(JournalLine.debit(
|
|
1075
|
+
AccountCode.FINISHED_GOODS,
|
|
1076
|
+
cost.getTotalCost(),
|
|
1077
|
+
"製造完成 " + event.workOrderId()
|
|
1078
|
+
));
|
|
1079
|
+
|
|
1080
|
+
// 貸方:仕掛品
|
|
1081
|
+
lines.add(JournalLine.credit(
|
|
1082
|
+
AccountCode.WORK_IN_PROCESS,
|
|
1083
|
+
cost.getTotalCost(),
|
|
1084
|
+
"仕掛品振替"
|
|
1085
|
+
));
|
|
1086
|
+
|
|
1087
|
+
JournalEntry journal = new JournalEntry(
|
|
1088
|
+
generateJournalId(),
|
|
1089
|
+
LocalDate.now(),
|
|
1090
|
+
JournalType.MANUFACTURING_COMPLETION,
|
|
1091
|
+
event.workOrderId(),
|
|
1092
|
+
lines
|
|
1093
|
+
);
|
|
1094
|
+
|
|
1095
|
+
journalRepository.save(journal);
|
|
1096
|
+
}
|
|
1097
|
+
}
|
|
1098
|
+
```
|
|
1099
|
+
|
|
1100
|
+
</details>
|
|
1101
|
+
|
|
1102
|
+
### 検収データの会計連携
|
|
1103
|
+
|
|
1104
|
+
仕入先からの購買品検収時に、買掛金を計上します。
|
|
1105
|
+
|
|
1106
|
+
```plantuml
|
|
1107
|
+
@startuml
|
|
1108
|
+
title 検収から仕訳への連携
|
|
1109
|
+
|
|
1110
|
+
|生産管理|
|
|
1111
|
+
start
|
|
1112
|
+
:入荷受入;
|
|
1113
|
+
:受入検査;
|
|
1114
|
+
|
|
1115
|
+
if (検査合格?) then (yes)
|
|
1116
|
+
:検収処理;
|
|
1117
|
+
:在庫計上;
|
|
1118
|
+
:検収イベント発行;
|
|
1119
|
+
else (no)
|
|
1120
|
+
:返品処理;
|
|
1121
|
+
stop
|
|
1122
|
+
endif
|
|
1123
|
+
|
|
1124
|
+
|財務会計|
|
|
1125
|
+
:検収イベント受信;
|
|
1126
|
+
:仕入仕訳生成;
|
|
1127
|
+
note right
|
|
1128
|
+
借方: 材料/仕掛品
|
|
1129
|
+
借方: 仮払消費税
|
|
1130
|
+
貸方: 買掛金
|
|
1131
|
+
end note
|
|
1132
|
+
|
|
1133
|
+
:仕訳登録;
|
|
1134
|
+
:買掛金残高更新;
|
|
1135
|
+
|
|
1136
|
+
stop
|
|
1137
|
+
|
|
1138
|
+
@enduml
|
|
1139
|
+
```
|
|
1140
|
+
|
|
1141
|
+
#### 検収仕訳のパターン
|
|
1142
|
+
|
|
1143
|
+
```plantuml
|
|
1144
|
+
@startuml
|
|
1145
|
+
title 検収仕訳のパターン
|
|
1146
|
+
|
|
1147
|
+
object "検収データ" as receipt {
|
|
1148
|
+
検収番号 = "RCV-2024-001"
|
|
1149
|
+
検収日 = "2024/01/15"
|
|
1150
|
+
仕入先 = "SUP-001"
|
|
1151
|
+
検収金額 = 55,000円
|
|
1152
|
+
消費税額 = 5,000円
|
|
1153
|
+
}
|
|
1154
|
+
|
|
1155
|
+
object "材料検収仕訳" as material_journal {
|
|
1156
|
+
借方: 材料 50,000円
|
|
1157
|
+
借方: 仮払消費税 5,000円
|
|
1158
|
+
貸方: 買掛金 55,000円
|
|
1159
|
+
}
|
|
1160
|
+
|
|
1161
|
+
object "外注検収仕訳" as subcontract_journal {
|
|
1162
|
+
借方: 外注加工費 50,000円
|
|
1163
|
+
借方: 仮払消費税 5,000円
|
|
1164
|
+
貸方: 買掛金 55,000円
|
|
1165
|
+
}
|
|
1166
|
+
|
|
1167
|
+
receipt --> material_journal : 材料の場合
|
|
1168
|
+
receipt --> subcontract_journal : 外注の場合
|
|
1169
|
+
|
|
1170
|
+
@enduml
|
|
1171
|
+
```
|
|
1172
|
+
|
|
1173
|
+
### 棚卸差異の会計処理
|
|
1174
|
+
|
|
1175
|
+
棚卸で発見された差異は、適切に会計処理する必要があります。
|
|
1176
|
+
|
|
1177
|
+
```plantuml
|
|
1178
|
+
@startuml
|
|
1179
|
+
title 棚卸差異の会計処理フロー
|
|
1180
|
+
|
|
1181
|
+
|生産管理|
|
|
1182
|
+
start
|
|
1183
|
+
:棚卸実施;
|
|
1184
|
+
:帳簿在庫と\n実地在庫の比較;
|
|
1185
|
+
|
|
1186
|
+
if (差異あり?) then (yes)
|
|
1187
|
+
:差異原因分析;
|
|
1188
|
+
|
|
1189
|
+
if (帳簿 > 実地?) then (棚卸減耗)
|
|
1190
|
+
:減耗損計上;
|
|
1191
|
+
:棚卸減耗\nイベント発行;
|
|
1192
|
+
else (帳簿 < 実地)
|
|
1193
|
+
:在庫増加調整;
|
|
1194
|
+
:棚卸増加\nイベント発行;
|
|
1195
|
+
endif
|
|
1196
|
+
else (no)
|
|
1197
|
+
:差異なし\n処理終了;
|
|
1198
|
+
stop
|
|
1199
|
+
endif
|
|
1200
|
+
|
|
1201
|
+
|財務会計|
|
|
1202
|
+
:棚卸イベント受信;
|
|
1203
|
+
|
|
1204
|
+
if (減耗?) then (yes)
|
|
1205
|
+
:減耗仕訳生成;
|
|
1206
|
+
note right
|
|
1207
|
+
借方: 棚卸減耗損
|
|
1208
|
+
貸方: 材料/製品
|
|
1209
|
+
end note
|
|
1210
|
+
else (no)
|
|
1211
|
+
:増加仕訳生成;
|
|
1212
|
+
note right
|
|
1213
|
+
借方: 材料/製品
|
|
1214
|
+
貸方: 雑収入
|
|
1215
|
+
end note
|
|
1216
|
+
endif
|
|
1217
|
+
|
|
1218
|
+
:仕訳登録;
|
|
1219
|
+
:在庫評価額更新;
|
|
1220
|
+
|
|
1221
|
+
stop
|
|
1222
|
+
|
|
1223
|
+
@enduml
|
|
1224
|
+
```
|
|
1225
|
+
|
|
1226
|
+
<details>
|
|
1227
|
+
<summary>Java 実装例</summary>
|
|
1228
|
+
|
|
1229
|
+
```java
|
|
1230
|
+
// 棚卸差異イベント
|
|
1231
|
+
public record InventoryAdjustmentEvent(
|
|
1232
|
+
String eventId,
|
|
1233
|
+
Instant timestamp,
|
|
1234
|
+
String productId,
|
|
1235
|
+
String warehouseId,
|
|
1236
|
+
BigDecimal bookQuantity,
|
|
1237
|
+
BigDecimal actualQuantity,
|
|
1238
|
+
BigDecimal differenceQuantity,
|
|
1239
|
+
BigDecimal unitCost,
|
|
1240
|
+
AdjustmentType type,
|
|
1241
|
+
String reason
|
|
1242
|
+
) {
|
|
1243
|
+
public enum AdjustmentType {
|
|
1244
|
+
SHRINKAGE, // 減耗(帳簿 > 実地)
|
|
1245
|
+
SURPLUS // 過剰(帳簿 < 実地)
|
|
1246
|
+
}
|
|
1247
|
+
|
|
1248
|
+
public BigDecimal getAdjustmentAmount() {
|
|
1249
|
+
return differenceQuantity.abs().multiply(unitCost);
|
|
1250
|
+
}
|
|
1251
|
+
}
|
|
1252
|
+
|
|
1253
|
+
// 棚卸仕訳サービス
|
|
1254
|
+
@Service
|
|
1255
|
+
public class InventoryAdjustmentJournalService {
|
|
1256
|
+
private final JournalRepository journalRepository;
|
|
1257
|
+
|
|
1258
|
+
@EventListener
|
|
1259
|
+
public void handleInventoryAdjustment(InventoryAdjustmentEvent event) {
|
|
1260
|
+
List<JournalLine> lines = new ArrayList<>();
|
|
1261
|
+
|
|
1262
|
+
if (event.type() == AdjustmentType.SHRINKAGE) {
|
|
1263
|
+
// 減耗の場合
|
|
1264
|
+
lines.add(JournalLine.debit(
|
|
1265
|
+
AccountCode.INVENTORY_SHRINKAGE_LOSS,
|
|
1266
|
+
event.getAdjustmentAmount(),
|
|
1267
|
+
"棚卸減耗 " + event.productId() + " " + event.reason()
|
|
1268
|
+
));
|
|
1269
|
+
lines.add(JournalLine.credit(
|
|
1270
|
+
determineInventoryAccount(event.productId()),
|
|
1271
|
+
event.getAdjustmentAmount(),
|
|
1272
|
+
"在庫減少"
|
|
1273
|
+
));
|
|
1274
|
+
} else {
|
|
1275
|
+
// 過剰の場合
|
|
1276
|
+
lines.add(JournalLine.debit(
|
|
1277
|
+
determineInventoryAccount(event.productId()),
|
|
1278
|
+
event.getAdjustmentAmount(),
|
|
1279
|
+
"在庫増加"
|
|
1280
|
+
));
|
|
1281
|
+
lines.add(JournalLine.credit(
|
|
1282
|
+
AccountCode.MISCELLANEOUS_INCOME,
|
|
1283
|
+
event.getAdjustmentAmount(),
|
|
1284
|
+
"棚卸差益 " + event.productId()
|
|
1285
|
+
));
|
|
1286
|
+
}
|
|
1287
|
+
|
|
1288
|
+
JournalEntry journal = new JournalEntry(
|
|
1289
|
+
generateJournalId(),
|
|
1290
|
+
LocalDate.now(),
|
|
1291
|
+
JournalType.INVENTORY_ADJUSTMENT,
|
|
1292
|
+
event.eventId(),
|
|
1293
|
+
lines
|
|
1294
|
+
);
|
|
1295
|
+
|
|
1296
|
+
journalRepository.save(journal);
|
|
1297
|
+
}
|
|
1298
|
+
|
|
1299
|
+
private String determineInventoryAccount(String productId) {
|
|
1300
|
+
// 製品か材料かで勘定科目を決定
|
|
1301
|
+
Product product = productRepository.findById(productId).orElseThrow();
|
|
1302
|
+
return switch (product.type()) {
|
|
1303
|
+
case FINISHED_GOODS -> AccountCode.FINISHED_GOODS;
|
|
1304
|
+
case WORK_IN_PROCESS -> AccountCode.WORK_IN_PROCESS;
|
|
1305
|
+
case RAW_MATERIAL -> AccountCode.RAW_MATERIALS;
|
|
1306
|
+
default -> AccountCode.SUPPLIES;
|
|
1307
|
+
};
|
|
1308
|
+
}
|
|
1309
|
+
}
|
|
1310
|
+
```
|
|
1311
|
+
|
|
1312
|
+
</details>
|
|
1313
|
+
|
|
1314
|
+
---
|
|
1315
|
+
|
|
1316
|
+
## 35.4 三システム統合の全体像
|
|
1317
|
+
|
|
1318
|
+
販売・生産・会計の3システムを統合した全体像を整理します。
|
|
1319
|
+
|
|
1320
|
+
```plantuml
|
|
1321
|
+
@startuml
|
|
1322
|
+
title 基幹業務システム統合の全体像
|
|
1323
|
+
|
|
1324
|
+
package "販売管理" as sales {
|
|
1325
|
+
rectangle "受注" as order
|
|
1326
|
+
rectangle "出荷" as shipment
|
|
1327
|
+
rectangle "売上" as sales_tx
|
|
1328
|
+
rectangle "請求" as billing
|
|
1329
|
+
rectangle "入金" as receipt
|
|
1330
|
+
}
|
|
1331
|
+
|
|
1332
|
+
package "生産管理" as production {
|
|
1333
|
+
rectangle "生産計画" as plan
|
|
1334
|
+
rectangle "購買" as purchase
|
|
1335
|
+
rectangle "製造" as manufacturing
|
|
1336
|
+
rectangle "在庫" as inventory
|
|
1337
|
+
rectangle "原価" as cost
|
|
1338
|
+
}
|
|
1339
|
+
|
|
1340
|
+
package "財務会計" as accounting {
|
|
1341
|
+
rectangle "仕訳" as journal
|
|
1342
|
+
rectangle "売掛金" as ar
|
|
1343
|
+
rectangle "買掛金" as ap
|
|
1344
|
+
rectangle "在庫資産" as inv_asset
|
|
1345
|
+
}
|
|
1346
|
+
|
|
1347
|
+
' 販売→生産
|
|
1348
|
+
order --> plan : 受注情報
|
|
1349
|
+
inventory --> shipment : 在庫引当
|
|
1350
|
+
|
|
1351
|
+
' 販売→会計
|
|
1352
|
+
sales_tx --> journal : 売上仕訳
|
|
1353
|
+
billing --> ar : 請求
|
|
1354
|
+
receipt --> ar : 入金消込
|
|
1355
|
+
|
|
1356
|
+
' 生産→会計
|
|
1357
|
+
purchase --> ap : 検収仕訳
|
|
1358
|
+
manufacturing --> inv_asset : 完成仕訳
|
|
1359
|
+
cost --> journal : 原価仕訳
|
|
1360
|
+
|
|
1361
|
+
' 在庫
|
|
1362
|
+
inventory --> inv_asset : 在庫評価
|
|
1363
|
+
|
|
1364
|
+
@enduml
|
|
1365
|
+
```
|
|
1366
|
+
|
|
1367
|
+
### イベントカタログ
|
|
1368
|
+
|
|
1369
|
+
```plantuml
|
|
1370
|
+
@startuml
|
|
1371
|
+
title システム間連携イベントカタログ
|
|
1372
|
+
|
|
1373
|
+
class "販売イベント" as sales_events {
|
|
1374
|
+
OrderConfirmed(受注確定)
|
|
1375
|
+
ShipmentCompleted(出荷完了)
|
|
1376
|
+
SalesCompleted(売上計上)
|
|
1377
|
+
BillingConfirmed(請求確定)
|
|
1378
|
+
PaymentReceived(入金確認)
|
|
1379
|
+
}
|
|
1380
|
+
|
|
1381
|
+
class "生産イベント" as prod_events {
|
|
1382
|
+
DemandRegistered(需要登録)
|
|
1383
|
+
WorkOrderReleased(製造指示)
|
|
1384
|
+
ProductionCompleted(製造完成)
|
|
1385
|
+
ReceiptConfirmed(検収確定)
|
|
1386
|
+
InventoryAdjusted(在庫調整)
|
|
1387
|
+
}
|
|
1388
|
+
|
|
1389
|
+
class "会計イベント" as acc_events {
|
|
1390
|
+
JournalPosted(仕訳計上)
|
|
1391
|
+
BalanceUpdated(残高更新)
|
|
1392
|
+
MonthEndClosed(月次締め)
|
|
1393
|
+
}
|
|
1394
|
+
|
|
1395
|
+
note right of sales_events
|
|
1396
|
+
【発行元】販売管理
|
|
1397
|
+
【購読者】生産計画、自動仕訳
|
|
1398
|
+
end note
|
|
1399
|
+
|
|
1400
|
+
note right of prod_events
|
|
1401
|
+
【発行元】生産管理
|
|
1402
|
+
【購読者】販売在庫、自動仕訳
|
|
1403
|
+
end note
|
|
1404
|
+
|
|
1405
|
+
note right of acc_events
|
|
1406
|
+
【発行元】財務会計
|
|
1407
|
+
【購読者】経営ダッシュボード
|
|
1408
|
+
end note
|
|
1409
|
+
|
|
1410
|
+
@enduml
|
|
1411
|
+
```
|
|
1412
|
+
|
|
1413
|
+
---
|
|
1414
|
+
|
|
1415
|
+
## 35.5 まとめ
|
|
1416
|
+
|
|
1417
|
+
本章では、基幹業務システムの具体的な連携パターンについて解説しました。
|
|
1418
|
+
|
|
1419
|
+
### 学んだ連携パターン
|
|
1420
|
+
|
|
1421
|
+
| 連携パターン | 発生元 | 連携先 | 主な処理 |
|
|
1422
|
+
|------------|-------|-------|---------|
|
|
1423
|
+
| 売上→仕訳 | 販売管理 | 財務会計 | 売掛金・売上計上 |
|
|
1424
|
+
| 入金→消込 | 販売管理 | 財務会計 | 売掛金消込 |
|
|
1425
|
+
| 受注→計画 | 販売管理 | 生産管理 | 需要登録・MRP |
|
|
1426
|
+
| 完成→在庫 | 生産管理 | 販売管理 | 在庫同期 |
|
|
1427
|
+
| 検収→仕訳 | 生産管理 | 財務会計 | 買掛金計上 |
|
|
1428
|
+
| 完成→仕訳 | 生産管理 | 財務会計 | 製品・仕掛品振替 |
|
|
1429
|
+
| 棚卸→仕訳 | 生産管理 | 財務会計 | 棚卸損益計上 |
|
|
1430
|
+
|
|
1431
|
+
### 連携設計のポイント
|
|
1432
|
+
|
|
1433
|
+
1. **イベント駆動の採用**
|
|
1434
|
+
|
|
1435
|
+
- システム間の疎結合を実現
|
|
1436
|
+
- 非同期処理による可用性向上
|
|
1437
|
+
- 監査証跡の確保
|
|
1438
|
+
|
|
1439
|
+
2. **自動仕訳パターンの標準化**
|
|
1440
|
+
|
|
1441
|
+
- 取引種別ごとの仕訳パターン定義
|
|
1442
|
+
- 柔軟な条件分岐(商品/顧客グループ)
|
|
1443
|
+
- 例外処理の明確化
|
|
1444
|
+
|
|
1445
|
+
3. **データ整合性の確保**
|
|
1446
|
+
|
|
1447
|
+
- イベント順序の保証
|
|
1448
|
+
- 補償トランザクション
|
|
1449
|
+
- 定期的な突合処理
|
|
1450
|
+
|
|
1451
|
+
### 次章の予告
|
|
1452
|
+
|
|
1453
|
+
第36章では、マスタデータ管理(MDM)について解説します。複数システムで共有されるマスタデータの一元管理方法と、MDMパターンの選択基準を学びます。
|