Changes for page Header line
                  Last modified by Erik Bakker on 2024/08/26 12:26
              
      
      From version  32.1 
    
    
              edited by Carlijn Kokkeler
        
on 2024/08/21 16:10
     on 2024/08/21 16:10
      Change comment:
              There is no comment for this version
          
         
      To version  26.1 
    
    
              edited by Erik Bakker
        
on 2022/06/10 13:05
     on 2022/06/10 13:05
      Change comment:
              Deleted image "novice-devops-perspectives-annotations--describe-crucial-part-of-cdm.png"
          
         Summary
- 
          Page properties (4 modified, 0 added, 0 removed)
- 
          Attachments (0 modified, 1 added, 0 removed)
Details
- Page properties
- 
      - Title
-   ... ... @@ -1,1 +1,1 @@ 1 - Header line1 +Annotations 
- Author
-   ... ... @@ -1,1 +1,1 @@ 1 -XWiki. CarlijnKokkeler1 +XWiki.ebakker 
- Default language
-   ... ... @@ -1,1 +1,0 @@ 1 -en 
- Content
-   ... ... @@ -1,8 +1,11 @@ 1 1 {{container}}{{container layoutStyle="columns"}}((( 2 -In this microlearning, we will learnhowyou candefineaheaderlineinwhichyouspecifythenamingof thevariouscolumns.Someexternalsystemsrequire a headerlinewhenyou supply themwithdataviaflatfile thatis placedsomewhere.2 +In this microlearning, we will focus on using annotations to clarify your thought process. In the annotation, you either describe a best practice everyone should follow when they change that flow (i.e. within the asynchronous routing), describe how the (more complex) parts of the flow work or describe (parts of) of your message definitions (i.e. CDM, API Gateway Data model, system message, etc.). This will help yourself and others every time changes are needed. 3 3 4 4 Should you have any questions, please contact [[academy@emagiz.com>>mailto:academy@emagiz.com]]. 5 5 6 +* Last update: May 9th, 2021 7 +* Required reading time: 5 minutes 8 + 6 6 == 1. Prerequisites == 7 7 8 8 * Basic knowledge of the eMagiz platform ... ... @@ -9,52 +9,66 @@ 9 9 10 10 == 2. Key concepts == 11 11 12 -This microlearning centers around learning how to place a header line on a flat-file output. 15 +This microlearning centers around using annotations. 16 +With annotations, we mean: A piece of text to explain something to yourself and others 13 13 14 - By header line we mean:Aline intheoutput thatdefinesthe namingof thevariouscolumns18 +Annotations can be used for: 15 15 16 -Some external parties require that the first line in the flat file output (i.e. CSV) is filled with column names (i.e. headers). In eMagiz, we call this line a header line. 20 +* Describing a best practice everyone should follow 21 +* Describing (more complex) parts of the flow 22 +* Describe (parts of) your message definitions 17 17 18 -== 3. Header line==24 +== 3. Annotations == 19 19 20 -In this microlearning, we will learn how youcandefineaheader lineinwhichyouspecify the naming ofthevariouscolumns.Someexternalsystemsequire aheaderlinewhenyousupplythemwithdatavia aflatfile thatisplacedsomewhere.Theheaderlineisthefirstlineinthe flatfileoutput.Withinthisline,the variouscolumnnames arespecifiedfor clarity.26 +In this microlearning, we will focus on using annotations on the flow level to clarify our thought process. In the annotation, you either describe a best practice everyone should follow when they change that flow (i.e. within the asynchronous routing) or describe how the (more complex) parts of the flow work. This will help yourself and others every time changes are needed within the flow. 21 21 22 - To add such a header line ineMagiz you needto navigate to the Create phase of eMagiz andopenthe exit flow in which you want to drop the file to a certain location. Within the context of thisflow, we need to add functionality that will ensurethat a header line is written to the outputbeforeany functional linesareadded.To do sofirst enter "Start Editing" mode on flow level. Afteryou have done so please add a file outbound channel adapter to the flow including an input channel. We will use this component to write our header line to the flat file output.28 +Annotations can be used for: 23 23 24 -Ensure that the directory to which you reference is the same as in your functional file outbound channel adapter. 30 +* Describing a best practice everyone should follow 31 +* Describing (more complex) parts of the flow 32 +* Describe (parts of) your message definitions 25 25 26 - [[image:Main.Images.Microlearning.WebHome@novice-file-based-connectivity-header-line--file-outbound-channel-header-line.png]]34 +To clarify the use cases let us take a look at how annotations can be added within the eMagiz platform. In our first example, we will take a look at asynchronous routing. In many eMagiz projects, a best practice is followed on how to add something to the asynchronous routing (or change something within the asynchronous routing). Because the best practice contains multiple steps it makes sense to use the annotation functionality of eMagiz to define all these steps and register them at the place you need them (i.e. the asynchronous routing). Having done so will result in something like this: 27 27 28 - Nowit is time to turn ourattentionto the Advanced tab.For theMode select Ignore. Select this option to ensure that the headerlineis only written down oncewhenthere is nooutputcreatedyet and notsomewhereinthe middle, inthe end,or everytime. Furthermore, select the optionAppend New Line toensurethatthe remainder ofthe information isappended to the same line.36 +[[image:Main.Images.Microlearning.WebHome@novice-devops-perspectives-annotations--annotation-best-practice-async-routing.png]] 29 29 30 - [[image:Main.Images.Microlearning.WebHome@novice-file-based-connectivity-header-line--file-outbound-channel-header-line-advanced.png]]38 +The second example is about using annotations on the flow level to describe parts of the flow. In this example, we will use the annotation to describe that we use a filter to determine which messages are picked up from a local directory and how we filter. That way anyway opening the flow has to merely read the annotation to get the context. Having done so will result in something like this: 31 31 32 - After you havedone so we need toadd a standard transformer that definesthe variouscolumn names to be writtento the flat file output.To do so add thestandard transformer component tothe canvasincluding an input channel. After you have doneso define the relevant SpELexpression. Inthis case, we adviseusingaproperty valuethat representsa string of column names. The value of thepropertyshould be something asfollows:40 +[[image:Main.Images.Microlearning.WebHome@novice-devops-perspectives-annotations--describe-parts-of-flow.png]] 33 33 34 - 'Header1;Header2;Header3;Header4'42 +The third example does not take place on the flow level but the message definition level. Therefore instead of going to Create, we go to Design. In Design when you navigate to the CDM, API Gateway Data model, Event Streaming Data model, message definitions, etc. you have the option to add annotations to the canvas. In this example, we want to make clear to all that make changes that a certain part of our CDM is used by a lot of integrations within eMagiz and therefore everyone should be careful and think twice before adjusting anything related to that part. Having done so will result in something like this: 35 35 36 - Do note that theseparator,inthis case, needsto match therequirementsof thexternalsystem. At the flowconfiguration level, thestandardtransformershould lookas follows.44 +[[image:Main.Images.Microlearning.WebHome@novice-devops-perspectives-annotations--describe-crucial-part-of-cdm.png]] 37 37 38 - [[image:Main.Images.Microlearning.WebHome@novice-file-based-connectivity-header-line--define-columns-names.png]]46 +Now that we saw some examples let us turn our attention to the how. How can I add an annotation and how can I link it. Adding the annotation is simple. You drag the annotation icon from the left context menu onto the canvas. As a result, an empty annotation will be shown on the canvas. By double-clicking on it you can type whatever you want. Note that you need to be in "Start Editing" mode to change anything, including annotations. 39 39 40 - Our last stepis to ensure that thispieceoflogic is tied to the mainflow andis executed before writingthefunctional line(s) to the output file. Tomakethat happenwe need toadd a wiretap to theflow. With the helpof thisfunctionality, you can define whichpart of thelogic takesrecedence overanother partof the logic. Todo so double click onthe channelon which you wantto place a wiretap, select the optionwiretap and select the correct wiretap channel. After you have donethis theresultshould be somethingas follows:48 +[[image:Main.Images.Microlearning.WebHome@novice-devops-perspectives-annotations--annotation-icon-context-menu.png]] 41 41 42 - [[image:Main.Images.Microlearning.WebHome@novice-file-based-connectivity-header-line--wiretap-result.png]]50 +When you are satisfied with what you have written down you can press the Save button. After you have done so you can rescale the annotation to ensure that the complete text is visible. To link the annotation to a component (on flow level) or an entity (on message definition level) you hover over the annotation until your mouse indicator changes to a + icon, execute a right-click and drag from the annotation to the component in question. 43 43 44 - With these coupleof steps,youhavenowsuccessfullyadded logictoyour flowthatwill ensurethat a headerlineis addedbeforeanyfunctional line(s)are written to theoutputile.52 +Now you know what annotations are good for and how you can add them within the eMagiz platform. 45 45 46 -== 4. Keytakeaways==54 +== 4. Assignment == 47 47 48 -* The header line contains the names of the columns of the flat file output 49 -* Use the Ignore mode to ensure the header line is created once 50 -* Use the wiretap to ensure the header line is created first 56 +Add annotation on the flow level that describes how (a part of) a flow works. 57 +This assignment can be completed with the help of the (Academy) project that you have created/used in the previous assignment. 51 51 52 -== 5. SuggestedAdditional Readings ==59 +== 5. Key takeaways == 53 53 54 -* [[Use Cases (Menu)>>doc:Main.eMagiz Academy.Use Cases.WebHome||target="blank"]] 55 -** [[File based Connectivity (Navigation)>>doc:Main.eMagiz Academy.Use Cases.File based Connectivity.WebHome||target="blank"]] 56 -* [[Intermediate (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.WebHome||target="blank"]] 57 -** [[File based Connectivity (Navigation)>>doc:Main.eMagiz Academy.Microlearnings.Intermediate Level.File based connectivity.WebHome||target="blank"]] 58 -* [[Advanced (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Advanced Level.WebHome||target="blank"]] 59 -** [[File based Connectivity (Menu)>>doc:Main.eMagiz Academy.Microlearnings.Advanced Level.File based Connectivity.WebHome||target="blank"]] 61 +* Annotations can be used for: 62 + * Describing a best practice everyone should follow 63 + * Describing (more complex) parts of the flow 64 + * Describe (parts of) your message definitions 65 +* You can add annotations by dragging and dropping the annotation icon on the canvas. 66 + 67 +== 6. Suggested Additional Readings == 68 + 69 +There are no suggested additional readings on this topic 70 + 71 +== 7. Silent demonstration video == 72 + 73 +This video demonstrates how you could have handled the assignment and gives you some context on what you have just learned. 74 + 75 +{{video attachment="novice-devops-perspectives-annotations.mp4" reference="Main.Videos.Microlearning.WebHome"/}} 76 + 60 60 )))((({{toc/}}))){{/container}}{{/container}} 
 
- novice-devops-perspectives-annotations--describe-parts-of-flow.png
-   - Author
-   ... ... @@ -1,0 +1,1 @@ 1 +XWiki.ebakker 
- Size
-   ... ... @@ -1,0 +1,1 @@ 1 +18.9 KB 
- Content
 
