Wiki source code of advanced-mail-connectivity-receive-email-mailserver
                  Version 19.3 by Erik Bakker on 2022/06/13 10:58
              
      Show last authors
| author | version | line-number | content | 
|---|---|---|---|
| 1 | {{container}}{{container layoutStyle="columns"}}((( | ||
| 2 | = Receive emails = | ||
| 3 | |||
| 4 | We explained the MIME protocol in a previous [microlearning](advanced-mail-connectivity-whatis-mime.md). In this microlearning, we will expand our knowledge by learning how to receive emails with the help of MIME messages via the eMagiz platform. | ||
| 5 | |||
| 6 | Should you have any questions, please get in touch with [[academy@emagiz.com>>mailto:academy@emagiz.com]]. | ||
| 7 | |||
| 8 | * Last update: January 27th, 2022 | ||
| 9 | * Required reading time: 6 minutes | ||
| 10 | |||
| 11 | == 1. Prerequisites == | ||
| 12 | |||
| 13 | * Advanced knowledge of the eMagiz platform | ||
| 14 | * Understanding of the MIME concept | ||
| 15 | |||
| 16 | == 2. Key concepts == | ||
| 17 | |||
| 18 | * There are two options when retrieving emails (IMAP and standard) | ||
| 19 | * Use IMAP when you want to listen and wait for emails to be pushed to eMagiz | ||
| 20 | * Use standard mail when you actively want to poll for messages | ||
| 21 | * Both options have a MIME output that should be transformed to XML for further processing | ||
| 22 | |||
| 23 | |||
| 24 | |||
| 25 | == 3. Receive emails == | ||
| 26 | |||
| 27 | We explained the MIME protocol in a previous [microlearning](advanced-mail-connectivity-whatis-mime.md). In this microlearning, we will expand our knowledge by learning how to receive emails with the help of MIME messages via the eMagiz platform. | ||
| 28 | |||
| 29 | When you want to receive emails from an email server, you have two options in eMagiz. The two options are IMAP and "standard" mail. The difference between the two is that you listen to a particular mailbox with the IMAP component and wait till email messages are pushed to you. However, the "standard" mail component allows you to actively poll at a frequency most suited to you to see whether there are new mails that need to be processed. | ||
| 30 | |||
| 31 | Regardless of which of the two options you end up choosing, note that both have a MIME message as output. To further process the information within the MIME message, you most likely will need a MIME to XML transformation. Exceptions to this might be any mail solution in which the attachments are significant for data processing. In those cases, you might need to consider a different approach. | ||
| 32 | |||
| 33 | In the remainder of this microlearning, we will zoom in on how you should configure both options within a flow in eMagiz. | ||
| 34 | |||
| 35 | === 3.1 IMAP === | ||
| 36 | |||
| 37 | As stated above, the IMAP option allows you to listen to a specific mailbox and wait till mail messages are pushed to eMagiz. To configure this in eMagiz, we need to open a flow in eMagiz and enter "Start Editing" mode. The first component we need is an IMAP idle channel adapter. Search for the component by typing in IMAP to select the suitable component. Once you have found the component, please drag it onto the canvas. | ||
| 38 | |||
| 39 | [[image:Main.Images.Microlearning.WebHome@advanced-mail-connectivity-receive-email-mailserver-imap-components.png]] | ||
| 40 | |||
| 41 | Once you have added the component to the canvas, we need to add a channel to the flow that will serve as the output channel for our component. This is necessary because we want to transform the MIME message to XML before further processing the message. | ||
| 42 | |||
| 43 | Once you open the component, you will see a basic and advanced tab. For our configuration, we start at the basic tab. Here we need to select the proper output channel and define the Store URI. The Store URI describes which mailbox at which mail server you want to connect to and which username and password you need to authenticate yourself. Please check out the help text when configuring the component to identify the correct structure. | ||
| 44 | |||
| 45 | [[image:Main.Images.Microlearning.WebHome@advanced-mail-connectivity-receive-email-mailserver-imap-basic-filled-in.png]] | ||
| 46 | |||
| 47 | Once you have defined the correct information elements on the basic tab, it has become time to shift our attention to the advanced tab. In most cases, the default setting will suffice; however, it is good to know that you have specific options to customize the component's behavior when a message is processed. Below you see the default setting eMagiz provides you. | ||
| 48 | |||
| 49 | [[image:Main.Images.Microlearning.WebHome@advanced-mail-connectivity-receive-email-mailserver-imap-advanced-default.png]] | ||
| 50 | |||
| 51 | The help text will explain what the setting does for every option. Based on that explanation, you should be able to determine whether it is wise to deviate from the standard in your particular setup or not. Once you are satisfied with your chosen settings, press Save. | ||
| 52 | |||
| 53 | To ensure that we can validate and transform the mail message further upstream, we need to transform the MIME message to an XML message. Then, drag the "MIME message transformer to XML" on the canvas and select the correct input and output channel. As a result, your solution should look as follows. | ||
| 54 | |||
| 55 | [[image:Main.Images.Microlearning.WebHome@advanced-mail-connectivity-receive-email-mailserver-imap-solution.png]] | ||
| 56 | |||
| 57 | === 3.2 "Standard" mail === | ||
| 58 | |||
| 59 | As stated above, the "standard" mail option allows you to poll at your interval to check whether new messages have arrived. To configure this in eMagiz, we need to open a flow in eMagiz and enter "Start Editing" mode. The first component we need is a "Mail inbound channel adapter." Select the category inbound channel adapter and search for mail. Once you have the component, please drag it onto the canvas. | ||
| 60 | |||
| 61 | [[image:Main.Images.Microlearning.WebHome@advanced-mail-connectivity-receive-email-mailserver-mail-components-inbound.png]] | ||
| 62 | |||
| 63 | Once you have added the component to the canvas, we need to add a channel to the flow that will serve as the output channel for our component. This is required because we want to transform the MIME message to XML before further processing the message. | ||
| 64 | |||
| 65 | Once you open the component, you will see a basic and advanced tab. For our configuration, we start at the basic tab. Here we need to select the correct output channel, define the Store URI and define our poller. The Store URI describes which mailbox at which mail server you want to connect to and which username and password you need to authenticate yourself. Please check out the help text when configuring the component to identify the correct structure. Finally, the poller defines the frequency with which you will check the mailbox for new messages. Finally, we advise using the cron trigger option for the poller, as that gives you the flexibility to define this dynamically across environments. | ||
| 66 | |||
| 67 | [[image:Main.Images.Microlearning.WebHome@advanced-mail-connectivity-receive-email-mailserver-mail-basic-filled-in.png]] | ||
| 68 | |||
| 69 | Once you have defined the correct information elements on the basic tab, it has become time to shift our attention to the advanced tab. In most cases, the default setting will suffice; however, it is good to know that you have specific options to customize the component's behavior when a message is processed. Below you see the default setting eMagiz provides you. | ||
| 70 | |||
| 71 | [[image:Main.Images.Microlearning.WebHome@advanced-mail-connectivity-receive-email-mailserver-mail-advanced-default.png]] | ||
| 72 | |||
| 73 | The help text will explain what the setting does for every option. Based on that explanation, you should be able to determine whether it is wise to deviate from the standard in your particular setup or not. Once you are satisfied with your chosen settings, press Save. | ||
| 74 | |||
| 75 | To ensure that we can validate and transform the mail message further upstream, we need to transform the MIME message to an XML message. Drag the "MIME message transformer to XML" on the canvas and select the correct input and output channel. As a result, your solution should look as follows. | ||
| 76 | |||
| 77 | [[image:Main.Images.Microlearning.WebHome@advanced-mail-connectivity-receive-email-mailserver-mail-solution.png]] | ||
| 78 | |||
| 79 | |||
| 80 | |||
| 81 | == 4. Assignment == | ||
| 82 | |||
| 83 | Build two flows that can receive emails. One flow should use the IMAP configuration, and the other should use the "standard" configuration. This assignment can be completed with the help of the (Academy) project that you have created/used in the previous assignment. | ||
| 84 | |||
| 85 | == 5. Key takeaways == | ||
| 86 | |||
| 87 | * There are two options when retrieving emails (IMAP and standard) | ||
| 88 | * Use IMAP when you want to listen and wait for emails to be pushed to eMagiz | ||
| 89 | * Use standard mail when you actively want to poll for messages | ||
| 90 | * Both options have a MIME output that should be transformed to XML for further processing | ||
| 91 | |||
| 92 | |||
| 93 | |||
| 94 | == 6. Suggested Additional Readings == | ||
| 95 | |||
| 96 | If you are interested in this topic and want more information, please read the release notes and help texts provided by eMagiz. Furthermore, check out the following links: | ||
| 97 | |||
| 98 | * https://docs.spring.io/spring-integration/docs/2.1.x/reference/html/mail.html#mail-inbound | ||
| 99 | * https://docs.spring.io/spring-integration/reference/html/mail.html | ||
| 100 | |||
| 101 | == 7. Silent demonstration video == | ||
| 102 | |||
| 103 | This video demonstrates a working solution and how you can validate whether you have completed the assignment. | ||
| 104 | |||
| 105 | {{video attachment="advanced-mail-connectivity-receive-email-mailserver.mp4" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>)))((({{toc/}}))){{/container}}{{/container}} | 
