Wiki source code of Setting Up the CDM
                  Version 29.3 by Danniar Firdausy on 2024/08/21 15:40
              
      Show last authors
| author | version | line-number | content | 
|---|---|---|---|
| 1 | {{container}}{{container layoutStyle="columns"}}((( | ||
| 2 | In the previous microlearning session, we explored the concept of the CDM (Canonical Data Model) and its role in messaging integrations. In this microlearning, we will dive deeper into the practical steps of setting up and maintaining your CDM within the eMagiz platform. By the end of this microlearning, you will have a clear understanding of how to create and manage your CDM effectively as your integration landscape evolves. | ||
| 3 | |||
| 4 | If you have any questions along the way, feel free to reach out to us at [[academy@emagiz.com>>mailto:academy@emagiz.com]]. | ||
| 5 | |||
| 6 | == 1. Prerequisites == | ||
| 7 | |||
| 8 | * Basic knowledge of the eMagiz platform | ||
| 9 | |||
| 10 | == 2. Key concepts == | ||
| 11 | |||
| 12 | This microlearning centers around setting up the CDM via eMagiz. | ||
| 13 | * With setting up we mean: Creating the CDM for the first time and maintaining it when changes occur | ||
| 14 | |||
| 15 | Key considerations when setting up the CDM are: | ||
| 16 | |||
| 17 | * When you throw something away that is already used in Create you also lose that | ||
| 18 | * Be careful with promoting to CDM. This can lead to replication of entities (i.e. Order and Order_1) | ||
| 19 | * Choose one naming convention and one language | ||
| 20 | * Discuss which characteristics (i.e. attributes) belong to which entities | ||
| 21 | |||
| 22 | == 3. Setting Up the CDM == | ||
| 23 | |||
| 24 | In the last microlearning, we learned what the CDM is and what it represents within the context of eMagiz. In this microlearning, we will take a closer look at the CDM in terms of how you can create the CDM and maintain the CDM when your integration landscape grows. | ||
| 25 | |||
| 26 | === 3.1 Delete behavior === | ||
| 27 | |||
| 28 | Before we start discussing how you should create the first contours of the CDM and how you can manage the CDM | ||
| 29 | properly we would like to first address the fact that when you delete something in the CDM it can impact a lot of integrations within your landscape. | ||
| 30 | |||
| 31 | So before deleting anything from the CDM always consult with at least one colleague before proceeding. | ||
| 32 | |||
| 33 | === 3.2 Promoting to CDM === | ||
| 34 | |||
| 35 | An easy way to start building your CDM is to use the Promote to CDM functionality. | ||
| 36 | However, this functionality has two downsides you need to be aware of before thinking of using this functionality: | ||
| 37 | |||
| 38 | * If you already have a CDM message for the message type for which you press Promote to CDM it will overwrite that CDM Message (which could lead to loss of data across your integration landscape) | ||
| 39 | * If a certain entity already exists in the CDM the Promote to CDM **won't** override it but will create a new entity with a \_1 behind it. So Order will become Order_1 | ||
| 40 | |||
| 41 | Having said that, when the CDM is still empty and you have a dominant system within your integration landscape that feeds most data this is a useful method to quickly start building your CDM. | ||
| 42 | |||
| 43 | === 3.3 One naming convention === | ||
| 44 | |||
| 45 | A third consideration before adding entities and attributes to the canvas is the naming convention that will be used. | ||
| 46 | This naming convention consists of two aspects: | ||
| 47 | |||
| 48 | * The language (choose one language and don't mix languages) | ||
| 49 | * The notation of the names of entities and attributes. Do you start each word with a capital for example (i.e. PaymentCompensation)? Or do you start each new word with capital with exception of the first word (i.e. paymentCompensation) | ||
| 50 | |||
| 51 | === 3.4 What belongs to what === | ||
| 52 | |||
| 53 | The fourth consideration you should take into account when setting up and maintaining your CDM is how you are going to assign certain attributes to certain entities. | ||
| 54 | For example, if you have an Order with the following attributes there are two distinct ways of creating this in your CDM: | ||
| 55 | |||
| 56 | * ID | ||
| 57 | * Name | ||
| 58 | * Description | ||
| 59 | * ExecutionDateTime | ||
| 60 | * ReceivedDateTime | ||
| 61 | |||
| 62 | The first option would be to add all these characteristics to the Order entity which will result in the following solution in your CDM. | ||
| 63 | |||
| 64 | [[image:Main.Images.Microlearning.WebHome@crashcourse-messaging-setting-up-the-cdm--first-option.png]] | ||
| 65 | |||
| 66 | A second option would be to create a separate entity for DateTime which has a Type and a Value. | ||
| 67 | |||
| 68 | [[image:Main.Images.Microlearning.WebHome@crashcourse-messaging-setting-up-the-cdm--second-option.png]] | ||
| 69 | |||
| 70 | Both options have their advantages and disadvantages. The point of the matter is that you should make consistent choices with regards to which option you choose for your CDM. | ||
| 71 | |||
| 72 | === 3.5 Building the CDM === | ||
| 73 | |||
| 74 | Now that we have discussed the key considerations let us turn our attention to actually learning how to build the CDM. There are two distinct methods of adding information to the CDM: | ||
| 75 | |||
| 76 | * Drag and drop entities to the canvas and manually add attributes (as we learned in the crash course platform) | ||
| 77 | * Use the promote CDM button on the message level | ||
| 78 | |||
| 79 | In this microlearning, we will not explain the dragging and dropping of entities and adding attributes again. | ||
| 80 | Instead, we will explain a new piece of functionality we have not explained yet called the Promote to CDM. | ||
| 81 | |||
| 82 | If you navigate to Design and access the context menu to get to the system message you will see a canvas in which the system message is filled in or not. | ||
| 83 | If it is filled in you can promote the structure that is represented in the system message to the CDM | ||
| 84 | |||
| 85 | [[image:Main.Images.Microlearning.WebHome@crashcourse-messaging-setting-up-the-cdm--promote-to-cdm.png]] | ||
| 86 | |||
| 87 | You can do so after you have left Start Editing Mode. By selecting this button any existing creation on the CDM message level will be wiped clean. | ||
| 88 | To remind you of that eMagiz shows you the following pop-up | ||
| 89 | |||
| 90 | [[image:Main.Images.Microlearning.WebHome@crashcourse-messaging-setting-up-the-cdm--promote-to-cdm-warning.png]] | ||
| 91 | |||
| 92 | When you are confident that this is the right move you can press the Promote button. | ||
| 93 | This will promote the system message to the CDM message and in turn, will add the entities and attributes to the CDM. | ||
| 94 | This behavior is shown below | ||
| 95 | |||
| 96 | [[image:Main.Images.Microlearning.WebHome@crashcourse-messaging-setting-up-the-cdm--promote-to-cdm-result.png]] | ||
| 97 | |||
| 98 | == 4. Key takeaways == | ||
| 99 | |||
| 100 | * Key considerations when setting up the CDM are: | ||
| 101 | ** Consistent Naming Conventions: Choose a single language and adhere to a consistent naming convention for entities and attributes to avoid confusion and maintain clarity. | ||
| 102 | ** Entity and Attribute Assignment: Decide carefully how to assign attributes to entities, whether grouping them under one entity or creating separate entities for specific attributes. Consistency in this approach is crucial for maintaining a well-organized CDM. | ||
| 103 | ** Promoting to CDM: The "Promote to CDM" feature can overwrite existing CDM messages or create new entities with suffixes (e.g., Order_1). Use this function with caution and ensure it's the right approach for your setup. | ||
| 104 | ** Impact of Deletion: Deleting elements from the CDM can affect multiple integrations. Always consult with a colleague before making deletions. | ||
| 105 | ** Maintenance Considerations: Regularly review and maintain your CDM with these considerations in mind to ensure its effectiveness and integration with your evolving landscape. | ||
| 106 | * Always take these considerations in mind when maintaining your CDM | ||
| 107 | |||
| 108 | == 5. Suggested Additional Readings == | ||
| 109 | |||
| 110 | If you are interested in this topic and want more information on it please read the help text provided by eMagiz and read the following link: | ||
| 111 | |||
| 112 | * [[Crash Courses (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.WebHome||target="blank"]] | ||
| 113 | ** [[Crash Course Platform (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.WebHome||target="blank"]] | ||
| 114 | *** [[Creating a message definition (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Platform.crashcourse-platform-design-creating-a-message-definition||target="blank"]] | ||
| 115 | ** [[Crash Course Messaging (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Messaging.WebHome||target="blank"]] | ||
| 116 | *** [[Understanding the eMagiz CDM (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Crash Course.Crash Course Messaging.crashcourse-messaging-what-is-cdm||target="blank"]] | ||
| 117 | * [[Intermediate Level (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.WebHome||target="blank"]] | ||
| 118 | ** [[Defining message structures (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Defining message structures.WebHome||target="blank"]] | ||
| 119 | *** [[Cleaning up the CDM (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Defining message structures.intermediate-defining-your-message-structures-cleaning-up-the-cdm||target="blank"]] | ||
| 120 | *** [[Control usage of CDM elements (Explanation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.Defining message structures.intermediate-defining-your-message-structures-control-usage-of-cdm-elements||target="blank"]] | ||
| 121 | * [[Setting Up the CDM (Search Results)>>url:https://docs.emagiz.com/bin/view/Main/Search?sort=score&sortOrder=desc&highlight=true&facet=true&r=1&f_space_facet=0%2FMain.&l_space_facet=10&f_type=DOCUMENT&f_locale=en&f_locale=&f_locale=en&text=%22setting+up+the+CDM%22||target="blank"]] | ||
| 122 | )))((({{toc/}}))){{/container}}{{/container}} | 
