{
    "componentChunkName": "component---src-templates-post-template-js",
    "path": "/pl/on-mashing-up-modelling-techniques/",
    "result": {"data":{"post":{"id":"fc3f1753-7345-53c1-bed1-d4f4567c4ae3","html":"<p>Many people believe there should be one, and only one, way to model software. I think differently, I like to mix different techniques.</p>\n<p>For instance, I believe there’s a strong synergy between <a href=\"https://c4model.com/\">C4 Model</a>, <a href=\"https://github.com/ddd-crew/context-mapping\">Context Maps</a>, and <a href=\"https://www.eventstorming.com/\">EventStorming</a>. They all allow us to look at the system from a different angle and act as simulations, providing different feedback on whether our model will fly.</p>\n<p>Look below for the diagram I prepared for my upcoming <a href=\"https://event-driven.io/en/training/\">workshop</a>.</p>\n<p><span\n      class=\"gatsby-resp-image-wrapper\"\n      style=\"position: relative; display: block; margin-left: auto; margin-right: auto; max-width: 800px; height: auto\"\n    >\n      <a\n    class=\"gatsby-resp-image-link\"\n    href=\"/static/5ed088d85a6e4f737c6da5b2c7eaabca/ba096/2026-05-18-cover.jpg\"\n    style=\"display: block\"\n    target=\"_blank\"\n    rel=\"noopener\"\n  >\n    <span\n    class=\"gatsby-resp-image-background-image\"\n    style=\"padding-bottom: 63.5%; position: relative; bottom: 0; left: 0; background-image: url('data:image/jpeg;base64,/9j/2wBDABALDA4MChAODQ4SERATGCgaGBYWGDEjJR0oOjM9PDkzODdASFxOQERXRTc4UG1RV19iZ2hnPk1xeXBkeFxlZ2P/2wBDARESEhgVGC8aGi9jQjhCY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2P/wgARCAANABQDASIAAhEBAxEB/8QAGAAAAgMAAAAAAAAAAAAAAAAAAAIBAwX/xAAVAQEBAAAAAAAAAAAAAAAAAAABAv/aAAwDAQACEAMQAAAB3FgRywl//8QAGBAAAwEBAAAAAAAAAAAAAAAAAAERIRD/2gAIAQEAAQUCb5pCaf/EABQRAQAAAAAAAAAAAAAAAAAAABD/2gAIAQMBAT8BP//EABQRAQAAAAAAAAAAAAAAAAAAABD/2gAIAQIBAT8BP//EABYQAQEBAAAAAAAAAAAAAAAAAAEQAP/aAAgBAQAGPwLFJ//EABsQAQADAAMBAAAAAAAAAAAAAAEAESEQMUFx/9oACAEBAAE/IQ3Zb0S/YGvsQUd77KGBx//aAAwDAQACAAMAAAAQOz//xAAWEQEBAQAAAAAAAAAAAAAAAAAAESH/2gAIAQMBAT8Q1X//xAAWEQEBAQAAAAAAAAAAAAAAAAAAEQH/2gAIAQIBAT8QmI//xAAdEAEAAgICAwAAAAAAAAAAAAABESEAMRBBUXGB/9oACAEBAAE/EGARIxCVOJAuihA+YyZL0vrFYLWbr9yHm561x//Z'); background-size: cover; display: block;\"\n  ></span>\n  <img\n        class=\"gatsby-resp-image-image\"\n        alt=\"cover\"\n        title=\"cover\"\n        src=\"/static/5ed088d85a6e4f737c6da5b2c7eaabca/c60e9/2026-05-18-cover.jpg\"\n        srcset=\"/static/5ed088d85a6e4f737c6da5b2c7eaabca/37402/2026-05-18-cover.jpg 200w,\n/static/5ed088d85a6e4f737c6da5b2c7eaabca/4cda9/2026-05-18-cover.jpg 400w,\n/static/5ed088d85a6e4f737c6da5b2c7eaabca/c60e9/2026-05-18-cover.jpg 800w,\n/static/5ed088d85a6e4f737c6da5b2c7eaabca/6c738/2026-05-18-cover.jpg 1200w,\n/static/5ed088d85a6e4f737c6da5b2c7eaabca/56dca/2026-05-18-cover.jpg 1600w,\n/static/5ed088d85a6e4f737c6da5b2c7eaabca/ba096/2026-05-18-cover.jpg 8788w\"\n        sizes=\"(max-width: 800px) 100vw, 800px\"\n        style=\"width:100%;height:100%;margin:0;vertical-align:middle;position:absolute;top:0;left:0;\"\n        loading=\"lazy\"\n        decoding=\"async\"\n      />\n  </a>\n    </span></p>\n<p>It’s a C4 diagram showing containers in a hospitality system (so-called Property Management, where property means hotel).</p>\n<p>A container gives quick feedback on how many pieces I’ll potentially need to manage and deploy, and it also shows me boundaries.</p>\n<p><a href=\"https://github.com/ddd-crew/context-mapping\">Context Maps</a> help in understanding how they relate to each other, which module or team has bigger leverage, and can force more on others. It can also show me the information flow and simulate which module will expose the API.</p>\n<p>I can then take some business process and have a look at how the message flow will look. This can happen as an early simulation or after <a href=\"https://www.eventstorming.com/\">EventStorming</a> sessions.</p>\n<p>Then C4 allow me to also look inside the container, show components if I need to understand more details. I can group containers if my bounded context has more of them.</p>\n<p>How to start with it? Let me show you an example.</p>\n<p>The starting point could be understanding the system’s overall view; integrations with external systems usually introduce the most complexity. C4 System Diagram works well for that.</p>\n<p><span\n      class=\"gatsby-resp-image-wrapper\"\n      style=\"position: relative; display: block; margin-left: auto; margin-right: auto; max-width: 800px; height: auto\"\n    >\n      <a\n    class=\"gatsby-resp-image-link\"\n    href=\"/static/a97c45c352616574aaaf4c06f1901aa6/20aff/2026-05-18-system-view.jpg\"\n    style=\"display: block\"\n    target=\"_blank\"\n    rel=\"noopener\"\n  >\n    <span\n    class=\"gatsby-resp-image-background-image\"\n    style=\"padding-bottom: 99%; position: relative; bottom: 0; left: 0; background-image: url('data:image/jpeg;base64,/9j/2wBDABALDA4MChAODQ4SERATGCgaGBYWGDEjJR0oOjM9PDkzODdASFxOQERXRTc4UG1RV19iZ2hnPk1xeXBkeFxlZ2P/2wBDARESEhgVGC8aGi9jQjhCY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2P/wgARCAAUABQDASIAAhEBAxEB/8QAGAABAQEBAQAAAAAAAAAAAAAAAAMBAgX/xAAVAQEBAAAAAAAAAAAAAAAAAAAAAf/aAAwDAQACEAMQAAAB97ikzpNVsIwH/8QAGRABAAMBAQAAAAAAAAAAAAAAAQACERIi/9oACAEBAAEFAllcyrpHzWicxNMCf//EABQRAQAAAAAAAAAAAAAAAAAAACD/2gAIAQMBAT8BH//EABYRAQEBAAAAAAAAAAAAAAAAAAEAEP/aAAgBAgEBPwGTf//EABkQAAMAAwAAAAAAAAAAAAAAAAAQEQEhUf/aAAgBAQAGPwIuNlXHF//EAB0QAQEAAQQDAAAAAAAAAAAAAAERABAhQVExYYH/2gAIAQEAAT8hghHfnrE6/hyHEukLsAOMMTr1oTLw4EgZ/9oADAMBAAIAAwAAABA7z77/xAAUEQEAAAAAAAAAAAAAAAAAAAAg/9oACAEDAQE/EB//xAAYEQEBAQEBAAAAAAAAAAAAAAABACERMf/aAAgBAgEBPxDHLgx7Lf/EABwQAQADAQADAQAAAAAAAAAAAAEAESExEEFxYf/aAAgBAQABPxDTotY59Si4I6qM9LDkeNQbInGb+EsGrlReLSaKalQIfOz/2Q=='); background-size: cover; display: block;\"\n  ></span>\n  <img\n        class=\"gatsby-resp-image-image\"\n        alt=\"cover\"\n        title=\"cover\"\n        src=\"/static/a97c45c352616574aaaf4c06f1901aa6/c60e9/2026-05-18-system-view.jpg\"\n        srcset=\"/static/a97c45c352616574aaaf4c06f1901aa6/37402/2026-05-18-system-view.jpg 200w,\n/static/a97c45c352616574aaaf4c06f1901aa6/4cda9/2026-05-18-system-view.jpg 400w,\n/static/a97c45c352616574aaaf4c06f1901aa6/c60e9/2026-05-18-system-view.jpg 800w,\n/static/a97c45c352616574aaaf4c06f1901aa6/6c738/2026-05-18-system-view.jpg 1200w,\n/static/a97c45c352616574aaaf4c06f1901aa6/56dca/2026-05-18-system-view.jpg 1600w,\n/static/a97c45c352616574aaaf4c06f1901aa6/20aff/2026-05-18-system-view.jpg 4021w\"\n        sizes=\"(max-width: 800px) 100vw, 800px\"\n        style=\"width:100%;height:100%;margin:0;vertical-align:middle;position:absolute;top:0;left:0;\"\n        loading=\"lazy\"\n        decoding=\"async\"\n      />\n  </a>\n    </span></p>\n<p>We see actors representing our system users and interactions with external systems. We can decide what integration is out of scope for now, and may come as the second step, but not for now. We can also show the current state as is, then in the second diagram show our vision of what we want it to be. Be creative, this is not a relational database, we don’t need to normalise it.</p>\n<p>Then we may decide to dive into what we need to build to facilitate that, make a bet based on our current knowledge, zoom in and check the C4 Container view.</p>\n<p><span\n      class=\"gatsby-resp-image-wrapper\"\n      style=\"position: relative; display: block; margin-left: auto; margin-right: auto; max-width: 800px; height: auto\"\n    >\n      <a\n    class=\"gatsby-resp-image-link\"\n    href=\"/static/abf135832c0f3e18d6895ebf55323fce/cdcc8/2026-05-18-container-view.png\"\n    style=\"display: block\"\n    target=\"_blank\"\n    rel=\"noopener\"\n  >\n    <span\n    class=\"gatsby-resp-image-background-image\"\n    style=\"padding-bottom: 73.5%; position: relative; bottom: 0; left: 0; background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAPCAIAAABr+ngCAAAACXBIWXMAAAsTAAALEwEAmpwYAAACKklEQVQoz22TS28TMRDH89n4LL1w58QViTsqghMckJB4HqhULvTQt9LAQhFpRBulbUhCkmaT3eyuH+N5od20aQuMrJHt0c+e/3hc08pElMjOL/aFbbUUVe10OlEU1ev1KIqsvd5fWk1VEZGIVAXAEuEyxkx4ZVKa8g1WpIQloBOVEKgwFgKyKLOUvrpIREXLeQlcTS5v9lZGAwhBSGTjEO6/cIMpetTMhdHFUZqNxpPjHNiTbrdws0mBWFXiMf7uUe28HV4/y6YxoEirL+/3wyTjwnMBFCfDJJvN5hdzix7p8bp/tAbExIKtQ/dl19WYhUg9QFqEKhJs0KQIc4tzK9MMC9Akh9RQ5jXz6oLcKphWSgrPgxl3J2iCppYtwNs9ePjGT7OQOTJBkMB4NkDe0u4n2z/HS7hMhenJR//glXeBE0O5C40TWG/41LBD6cX8chO6k1JzAP5Wd6P+EiYxIO0htXpkgxagBtj6ABhyRx75Zx/vPYdmNyCj99TYsb2zK7jMXNWT5BbmlnLQwQxnhmcFD6aY+8Vxpb+lefFsx91kbedXnFPmxAKdjmll1UUdbrR5ZdV1JwKkOZTDVvCCKqutqk/fNe/c/XA6NJ608BJntP3DjlIZprLXgsSoqbQs4VvVTnI4H2aAXJ3KWHZCkEVPKpTPycKslf8HXmZyegLNr85ZOdgyWcqzmHY3jLPXqf79MW7C/bPQPgLv5PtnX+ScxHSwZb37P/wHgW1W9ePyE9EAAAAASUVORK5CYII='); background-size: cover; display: block;\"\n  ></span>\n  <img\n        class=\"gatsby-resp-image-image\"\n        alt=\"cover\"\n        title=\"cover\"\n        src=\"/static/abf135832c0f3e18d6895ebf55323fce/a331c/2026-05-18-container-view.png\"\n        srcset=\"/static/abf135832c0f3e18d6895ebf55323fce/36ca5/2026-05-18-container-view.png 200w,\n/static/abf135832c0f3e18d6895ebf55323fce/a3397/2026-05-18-container-view.png 400w,\n/static/abf135832c0f3e18d6895ebf55323fce/a331c/2026-05-18-container-view.png 800w,\n/static/abf135832c0f3e18d6895ebf55323fce/8537d/2026-05-18-container-view.png 1200w,\n/static/abf135832c0f3e18d6895ebf55323fce/1a152/2026-05-18-container-view.png 1600w,\n/static/abf135832c0f3e18d6895ebf55323fce/cdcc8/2026-05-18-container-view.png 4669w\"\n        sizes=\"(max-width: 800px) 100vw, 800px\"\n        style=\"width:100%;height:100%;margin:0;vertical-align:middle;position:absolute;top:0;left:0;\"\n        loading=\"lazy\"\n        decoding=\"async\"\n      />\n  </a>\n    </span></p>\n<p>As mentioned, this can already be used both for static documentation and for discussions during a workshop, simulating the potential complexity and boundaries. Important to note: until it’s settled, it’s more than fine to show different versions, discuss them, and add notes and questions.</p>\n<p>We may have concluded that C4 is fine, but it doesn’t capture all the important reasons we modelled it this way. Or during the workshop, it may not be clear how to discuss precisely how to break it down. <a href=\"https://github.com/ddd-crew/context-mapping\">Context Maps</a> can help in that.</p>\n<p>They can give us information on which module is generic (Open Host), which module (or team) is more important (upstream), and which module or team has less leverage (Downstream). Which provides api or data (Supplier) and which one is using it (Consumer).</p>\n<p>We could have a dedicated model only focusing, on that, but we could also capture it in the same one. It could look as follows:</p>\n<p><span\n      class=\"gatsby-resp-image-wrapper\"\n      style=\"position: relative; display: block; margin-left: auto; margin-right: auto; max-width: 800px; height: auto\"\n    >\n      <a\n    class=\"gatsby-resp-image-link\"\n    href=\"/static/8868dc9788df58b92f6e7e2ba0720f9b/36626/2026-05-18-context-map.png\"\n    style=\"display: block\"\n    target=\"_blank\"\n    rel=\"noopener\"\n  >\n    <span\n    class=\"gatsby-resp-image-background-image\"\n    style=\"padding-bottom: 74%; position: relative; bottom: 0; left: 0; background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAPCAIAAABr+ngCAAAACXBIWXMAAAsTAAALEwEAmpwYAAACPUlEQVQoz3VSTWsUQRTc/+pF7+JBz4oXDyKIB0UPRlQkoCaEqJhE/HY3BjKyS742y37OzkzPznT3dL/ufu/JrCbkQ+vQzet+RVVBNXgORA7BltMvFDQzExEzx3HcarWazWYURX9ezqDBzGEOZjJWBu+O/zAEAAsADqAeiek82XtLiD6gD8F7P9+rlXC+QXyKc9JBAyxNx2ABVVVtRO7aY2j3i8qxtD5O2oWMp8lO5cIkg+Wm2+lbcAG8S2JfzrDRP/AL9/LOXgKMUdc9XE57qZEmSBuSbCTKNM1jZSCKxlfu63cfJsbYqRDvV4v2lmsgsndkwWUStLa2yE3gXEFpggTMJJSWcwna08yw8gyBTmWuYwesgLpT3RlJG7gwlCXi6avh9Weqsz/SjrUjpFBUzjgcTsTG23LY80dkYiXEnUVx9YkapnmufSbk69XOwlLvcJBowMORfv7R7fc1eC9mavOrjofhLzkgGUdRr/rUnkmLClgCpaWUSmpHyrjNrfHlB7a5OTFgx0n+eV0OusfKiNJS5VAZV5v0vNseFBVlyu+OZwq4QlaOdWB7PjMxB2YFJKSTxkW/Jhdv5d/3qHWAF26rbkIQuLZja4NHDeQGzu/Ftf0bj35mKuh6gyfCrqwNhwJHAlfXxpmuZSVwCWz8CWXEerj7Irp0c2Om6noFQghUauER6zgmd4GsZ+vr05+3fdy73h5ELWMqerMyLUQQaVh6OTEVnSnmv8mDQ9fZBmto+4eTBc4y/LZu/0f+DfBKUIC2iZvfAAAAAElFTkSuQmCC'); background-size: cover; display: block;\"\n  ></span>\n  <img\n        class=\"gatsby-resp-image-image\"\n        alt=\"cover\"\n        title=\"cover\"\n        src=\"/static/8868dc9788df58b92f6e7e2ba0720f9b/a331c/2026-05-18-context-map.png\"\n        srcset=\"/static/8868dc9788df58b92f6e7e2ba0720f9b/36ca5/2026-05-18-context-map.png 200w,\n/static/8868dc9788df58b92f6e7e2ba0720f9b/a3397/2026-05-18-context-map.png 400w,\n/static/8868dc9788df58b92f6e7e2ba0720f9b/a331c/2026-05-18-context-map.png 800w,\n/static/8868dc9788df58b92f6e7e2ba0720f9b/8537d/2026-05-18-context-map.png 1200w,\n/static/8868dc9788df58b92f6e7e2ba0720f9b/1a152/2026-05-18-context-map.png 1600w,\n/static/8868dc9788df58b92f6e7e2ba0720f9b/36626/2026-05-18-context-map.png 4656w\"\n        sizes=\"(max-width: 800px) 100vw, 800px\"\n        style=\"width:100%;height:100%;margin:0;vertical-align:middle;position:absolute;top:0;left:0;\"\n        loading=\"lazy\"\n        decoding=\"async\"\n      />\n  </a>\n    </span></p>\n<p>We can even use colours, e.g., upstream as green and downstream as red. This can already give us feedback, e.g., that Cashiering is an important module for financial processing and that it is downstream of multiple modules. Maybe we can change it and redefine boundaries, or maybe live with it, but take some corrective actions.</p>\n<p>We can also put more data and use a specific example of a process and have a look at the specific process, as shown in the original diagram:</p>\n<p><span\n      class=\"gatsby-resp-image-wrapper\"\n      style=\"position: relative; display: block; margin-left: auto; margin-right: auto; max-width: 800px; height: auto\"\n    >\n      <a\n    class=\"gatsby-resp-image-link\"\n    href=\"/static/5ed088d85a6e4f737c6da5b2c7eaabca/ba096/2026-05-18-cover.jpg\"\n    style=\"display: block\"\n    target=\"_blank\"\n    rel=\"noopener\"\n  >\n    <span\n    class=\"gatsby-resp-image-background-image\"\n    style=\"padding-bottom: 63.5%; position: relative; bottom: 0; left: 0; background-image: url('data:image/jpeg;base64,/9j/2wBDABALDA4MChAODQ4SERATGCgaGBYWGDEjJR0oOjM9PDkzODdASFxOQERXRTc4UG1RV19iZ2hnPk1xeXBkeFxlZ2P/2wBDARESEhgVGC8aGi9jQjhCY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2NjY2P/wgARCAANABQDASIAAhEBAxEB/8QAGAAAAgMAAAAAAAAAAAAAAAAAAAIBAwX/xAAVAQEBAAAAAAAAAAAAAAAAAAABAv/aAAwDAQACEAMQAAAB3FgRywl//8QAGBAAAwEBAAAAAAAAAAAAAAAAAAERIRD/2gAIAQEAAQUCb5pCaf/EABQRAQAAAAAAAAAAAAAAAAAAABD/2gAIAQMBAT8BP//EABQRAQAAAAAAAAAAAAAAAAAAABD/2gAIAQIBAT8BP//EABYQAQEBAAAAAAAAAAAAAAAAAAEQAP/aAAgBAQAGPwLFJ//EABsQAQADAAMBAAAAAAAAAAAAAAEAESEQMUFx/9oACAEBAAE/IQ3Zb0S/YGvsQUd77KGBx//aAAwDAQACAAMAAAAQOz//xAAWEQEBAQAAAAAAAAAAAAAAAAAAESH/2gAIAQMBAT8Q1X//xAAWEQEBAQAAAAAAAAAAAAAAAAAAEQH/2gAIAQIBAT8QmI//xAAdEAEAAgICAwAAAAAAAAAAAAABESEAMRBBUXGB/9oACAEBAAE/EGARIxCVOJAuihA+YyZL0vrFYLWbr9yHm561x//Z'); background-size: cover; display: block;\"\n  ></span>\n  <img\n        class=\"gatsby-resp-image-image\"\n        alt=\"cover\"\n        title=\"cover\"\n        src=\"/static/5ed088d85a6e4f737c6da5b2c7eaabca/c60e9/2026-05-18-cover.jpg\"\n        srcset=\"/static/5ed088d85a6e4f737c6da5b2c7eaabca/37402/2026-05-18-cover.jpg 200w,\n/static/5ed088d85a6e4f737c6da5b2c7eaabca/4cda9/2026-05-18-cover.jpg 400w,\n/static/5ed088d85a6e4f737c6da5b2c7eaabca/c60e9/2026-05-18-cover.jpg 800w,\n/static/5ed088d85a6e4f737c6da5b2c7eaabca/6c738/2026-05-18-cover.jpg 1200w,\n/static/5ed088d85a6e4f737c6da5b2c7eaabca/56dca/2026-05-18-cover.jpg 1600w,\n/static/5ed088d85a6e4f737c6da5b2c7eaabca/ba096/2026-05-18-cover.jpg 8788w\"\n        sizes=\"(max-width: 800px) 100vw, 800px\"\n        style=\"width:100%;height:100%;margin:0;vertical-align:middle;position:absolute;top:0;left:0;\"\n        loading=\"lazy\"\n        decoding=\"async\"\n      />\n  </a>\n    </span></p>\n<p>This can also pinpoint some issues, e.g., a generic module, which is more likely to expose commands (see more on why in my article on Passive-Aggressive Events). We can see if we have all the needed ACLs defined, or which module acts as a coordinator.</p>\n<p>Of course, keeping it all on the same diagram is not perfect; it’d be great if we had a tool that would enable zoom-in/zoom-out, link and enable/disable some of the details and notation. Then we can even better play with what we have. Maybe I should vibe such?</p>\n<p>Nevertheless, I encourage you to try different techniques, experiment, and combine them. For instance, Example Mapping would, imho, play great here as an extension. I know that some use Wardley Maps or Domain Storytelling.</p>\n<p>Start small, use existing techniques and tools, and try to see how you could benefit from mixing them. Show it to your friends and try to collaborate and have fun together.</p>\n<p><a href=\"https://www.linkedin.com/feed/update/urn:li:activity:7461032293072195585?commentUrn=urn%3Ali%3Acomment%3A%28activity%3A7461032293072195585%2C7461050717479346176%29&#x26;dashCommentUrn=urn%3Ali%3Afsd_comment%3A%287461050717479346176%2Curn%3Ali%3Aactivity%3A7461032293072195585%29\">I even learned from Richard Gross that this has an even name: Model Storming</a>. So, crunching your design with different modelling techniques and coming up with some useful variations.</p>\n<p>I have even more mashups like that. Tell me if you’d like me to expand on it or this part in the follow-up articles!</p>\n<p>Also, if you did such experiments, please share them with me and others. Happy to see what you came up with.</p>\n<p>Cheers!</p>\n<p>Oskar</p>\n<p>p.s. <strong>Ukraine is still under brutal Russian invasion. A lot of Ukrainian people are hurt, without shelter and need help.</strong> You can help in various ways, for instance, directly helping refugees, spreading awareness, putting pressure on your local government or companies. You can also support Ukraine by donating e.g. to <a href=\"https://www.icrc.org/en/donate/ukraine\">Red Cross</a>, <a href=\"https://savelife.in.ua/en/donate/\">Ukraine humanitarian organisation</a> or <a href=\"https://www.gofundme.com/f/help-to-save-the-lives-of-civilians-in-a-war-zone\">donate Ambulances for Ukraine</a>.</p>","excerpt":"Many people believe there should be one, and only one, way to model software. I think differently, I like to mix different techniques. For…","fields":{"slug":"/on-mashing-up-modelling-techniques/","prefix":"2026-05-18","langKey":"pl"},"frontmatter":{"title":"On mashing up modelling techniques for fun and profit","author":"oskar dudycz","category":"Software Architecture","disqusId":null,"useDefaultLangCanonical":true,"cover":{"childImageSharp":{"resize":{"src":"/static/5ed088d85a6e4f737c6da5b2c7eaabca/4fe8c/2026-05-18-cover.jpg"}}}}},"authornote":{"id":"295c4649-a20b-5147-9ca5-5cb77fbcfe66","html":"<p><span\n      class=\"gatsby-resp-image-wrapper\"\n      style=\"position: relative; display: block; margin-left: auto; margin-right: auto; max-width: 800px; height: auto\"\n    >\n      <a\n    class=\"gatsby-resp-image-link\"\n    href=\"/static/f748655e118b2b9d5ce6b7dd6f9f4f85/d2429/2021-10-13-cover.png\"\n    style=\"display: block\"\n    target=\"_blank\"\n    rel=\"noopener\"\n  >\n    <span\n    class=\"gatsby-resp-image-background-image\"\n    style=\"padding-bottom: 55.99999999999999%; position: relative; bottom: 0; left: 0; background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAALCAIAAADwazoUAAAACXBIWXMAAA6cAAAOnAEHlFPdAAAChUlEQVQozyXOTU/acBwA4J+FFmgp/5RCX2AlFVgUgxTCYZNA6KZMooPSiAoaZ8bLjTmEbALRePAygyaLBEl0lyWePGji1YsnT8YDBxMTE+9+iiXu+QQPPDw8nJ2dtVqtZrNZr9cbjUYul8tkMvl8vt1un5yc3Nzc3N7eDofDu7u74+Pj+/v7x8fH6+vr8/NzGA6HOzs73W53f3+/0+mUSqVisbi3t3d0dNTv9w8PDy8uLnq93sHBQblcrtfrp6enl5eXrVarUqnA8/OzruvLy8uDwUDTtJmZmWw22+12Nzc3q9VqKpUqFovT09OFQsHr9SaTyZWVlVgspmlaoVCAl5cXRVE4jotGowghiqJIkpybm/N4PAsLCwghRVF0Xff5fHa7HQDi8Xg6nQaASCQCT09PwWAQXrEsa7VaZVlOp9NjY2Nut1uWZYIgWJYVRZEkSYZhLBaL0WgkCCIUCkGv1xMEAcMwo9EIABRFEQQhSVI0GhUEwWAw0DQ9OjqK4zhFUQzD2O12HMc5jhMEAa6urmRZRgglEgmHwzEyMuJyuXZ3d2u12tTUFAAQBOF0Onmep2mae2V6heM4bG1tIYR4nk8kEqIoAkAgEOh0OvF4XJIkADCZTDzPu1wuk8lks9kQQhiGmc1mkiTB65U5zun3+xFCPp+P5znaRquqGg6HcdyIYRiO4+VyeWlp6f+CpmmDwWAxm0VRAFX9kM3mVlfXJidDPv/bN24pHI4kkyrDMCRJjo8HJMnz6dNsq9W2WmmzhWRZB2W1BSaCmqbDxrfK9naj/r2az2fWvxTfvY98La2pakxRJuY/zy4u5jLZtPox/uPnxvp6YTalLurz7WZt8PvX3z/9f7APp/oT02NdAAAAAElFTkSuQmCC'); background-size: cover; display: block;\"\n  ></span>\n  <img\n        class=\"gatsby-resp-image-image\"\n        alt=\"cover\"\n        title=\"cover\"\n        src=\"/static/f748655e118b2b9d5ce6b7dd6f9f4f85/a331c/2021-10-13-cover.png\"\n        srcset=\"/static/f748655e118b2b9d5ce6b7dd6f9f4f85/36ca5/2021-10-13-cover.png 200w,\n/static/f748655e118b2b9d5ce6b7dd6f9f4f85/a3397/2021-10-13-cover.png 400w,\n/static/f748655e118b2b9d5ce6b7dd6f9f4f85/a331c/2021-10-13-cover.png 800w,\n/static/f748655e118b2b9d5ce6b7dd6f9f4f85/d2429/2021-10-13-cover.png 805w\"\n        sizes=\"(max-width: 800px) 100vw, 800px\"\n        style=\"width:100%;height:100%;margin:0;vertical-align:middle;position:absolute;top:0;left:0;\"\n        loading=\"lazy\"\n        decoding=\"async\"\n      />\n  </a>\n    </span></p>\n<p>Through my window, I see the result of good plans but poor execution. Opposite my flat, there is a partially completed construction place. Buildings were supposed to be eye-catching Mediterranean style apartments.  Delivery date? Two years ago. Actual? More and more unknown.</p>\n<p>Some time ago, I heard that using Event Sourcing makes creating Event-Driven Architecture easier. The arguments were correct, that if we’re already publishing events to trigger business workflows, then at some point, we may want to also store events to not lose information. Agreed. However, I also heard that keeping the state as events will simplify things. We’ll have a source of truth with a record of the system behaviour. This will allow, e.g. to confront the results of the operations with the recorded state. I’d agree with that, with one distinction. It’s easier as long as you already know Event Sourcing.</p>\n<p>Many people in the DDD community claim that the essential is to properly break down the system into autonomous parts called bounded contexts. Once we have it, the rest is secondary and will sort itself out. For sure.</p>\n<p>Many seasoned programmers speak similarly about new technologies. They claim that they can translate past experience into new technologies. That’s true that by analogy, they can catch the big picture quicker. But isn’t it a bold assumption to say that Win.Forms specialist will learn Angular quickly?</p>\n<p>The end result may differ a lot from the initial ideas. I saw the plan of those buildings next to me. Now I can see the effects of the execution. Or actually, the lack.</p>\n<p>I believe that we should carefully acknowledge not only the point of view of our authorities but also their seating point. If we want to find out how to form a wall, do we ask an architect or a foreman? An architect may know the theory, but the practice is what we’re looking for. On the other hand, if you want to know where to put the wall, you prefer the architect to do measurements. At least if you don’t want to have the roof falling to your head.</p>\n<p>After I had torn a ligament in my knee, I went to two qualified orthopedists. One said I should have surgery and do a reconstruction. The second stated that there is no need for that; rehabilitation should be enough. Guess which one had a specialization in surgery and which in rehabilitation?</p>\n<p>People usually give us advice from the point where they’re currently standing. They are entitled to a biased view. An architect who rarely does programming will tend to downplay the value of implementation and tactical patterns. Midlevel developers will focus on technicalities instead of the global system impact. The team manager or consultant will emphasize the importance of soft skills (or esoteric techniques known only to them).</p>\n<p>The truth is that we need all of them. The excellent plan will fall on the bad execution. The best execution for the wrong case will be just a waste of time. We should carefully evaluate the advice considering what we need and what an expert can give us.</p>\n<p>Therefore, when we’re reading an article, watching a talk, let’s also pay attention to the place where the person is standing. The perspective from there may be much different from where we are right now. That can be good, as it may push us in the right direction. But it may also be misleading, as we accidentally take biases of this person without understanding the tradeoffs. Personally, I prefer to follow not only people from pedestal but also those that are closer to my position. A bit further in the journey, but not too far. That helps me to calibrate my view as those people are more relative to my daily struggles.</p>\n<p>Polish historical leader <a href=\"https://en.wikipedia.org/wiki/J%C3%B3zef_Pi%C5%82sudski\">Józef Piłsudzki</a> reportedly used to say: <em>“Right is like an ass, everyone has its own”</em>.</p>\n<p>Cheers!</p>\n<p>Oskar</p>"},"site":{"siteMetadata":{"facebook":{"appId":""}}}},"pageContext":{"slug":"/on-mashing-up-modelling-techniques/","lang":"pl","langKey":"pl","prev":{"id":"1dcd1d37-05f5-5f2d-8858-247c94faa3ad","fields":{"slug":"/should_we_trust_domain_experts/","prefix":"2026-05-11","source":"posts","langKey":"pl"},"frontmatter":{"title":"Don't overestimate domain expertise","category":"Software Architecture"}},"source":"posts"}},
    "staticQueryHashes": ["2742854296"]}