Wiki source code of Receive emails

Version 32.1 by Eva Torken on 2023/09/22 15:53

Hide last authors
Erik Bakker 18.1 1 {{container}}{{container layoutStyle="columns"}}(((
Erik Bakker 30.1 2 We explained the MIME protocol in a previous [[microlearning>>doc:Main.eMagiz Academy.Microlearnings.Advanced Level.Mail based Connectivity.advanced-mail-connectivity-whatis-mime||target="blank"]]. In this microlearning, we will expand our knowledge by learning how to receive emails with the help of MIME messages via the eMagiz platform.
eMagiz 1.1 3
Erik Bakker 18.1 4 Should you have any questions, please get in touch with [[academy@emagiz.com>>mailto:academy@emagiz.com]].
eMagiz 1.1 5
6 == 1. Prerequisites ==
7
8 * Advanced knowledge of the eMagiz platform
9 * Understanding of the MIME concept
10
11 == 2. Key concepts ==
12
13 * There are two options when retrieving emails (IMAP and standard)
14 * Use IMAP when you want to listen and wait for emails to be pushed to eMagiz
15 * Use standard mail when you actively want to poll for messages
16 * Both options have a MIME output that should be transformed to XML for further processing
17
18 == 3. Receive emails ==
19
Erik Bakker 30.1 20 We explained the MIME protocol in a previous [[microlearning>>doc:Main.eMagiz Academy.Microlearnings.Advanced Level.Mail based Connectivity.advanced-mail-connectivity-whatis-mime||target="blank"]]. In this microlearning, we will expand our knowledge by learning how to receive emails with the help of MIME messages via the eMagiz platform.
eMagiz 1.1 21
22 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.
23
24 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.
25
26 In the remainder of this microlearning, we will zoom in on how you should configure both options within a flow in eMagiz.
27
28 === 3.1 IMAP ===
29
30 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.
31
Erik Bakker 18.1 32 [[image:Main.Images.Microlearning.WebHome@advanced-mail-connectivity-receive-email-mailserver-imap-components.png]]
eMagiz 1.1 33
34 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.
35
36 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.
37
Erik Bakker 18.1 38 [[image:Main.Images.Microlearning.WebHome@advanced-mail-connectivity-receive-email-mailserver-imap-basic-filled-in.png]]
eMagiz 1.1 39
40 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.
41
Erik Bakker 18.1 42 [[image:Main.Images.Microlearning.WebHome@advanced-mail-connectivity-receive-email-mailserver-imap-advanced-default.png]]
eMagiz 1.1 43
44 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.
45
46 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.
47
Erik Bakker 18.1 48 [[image:Main.Images.Microlearning.WebHome@advanced-mail-connectivity-receive-email-mailserver-imap-solution.png]]
eMagiz 1.1 49
50 === 3.2 "Standard" mail ===
51
52 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.
53
Erik Bakker 18.1 54 [[image:Main.Images.Microlearning.WebHome@advanced-mail-connectivity-receive-email-mailserver-mail-components-inbound.png]]
eMagiz 1.1 55
56 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.
57
58 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.
59
Erik Bakker 18.1 60 [[image:Main.Images.Microlearning.WebHome@advanced-mail-connectivity-receive-email-mailserver-mail-basic-filled-in.png]]
eMagiz 1.1 61
62 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.
63
Erik Bakker 18.1 64 [[image:Main.Images.Microlearning.WebHome@advanced-mail-connectivity-receive-email-mailserver-mail-advanced-default.png]]
eMagiz 1.1 65
66 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.
67
68 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.
69
Erik Bakker 18.1 70 [[image:Main.Images.Microlearning.WebHome@advanced-mail-connectivity-receive-email-mailserver-mail-solution.png]]
eMagiz 1.1 71
Eva Torken 32.1 72 == 4. Key takeaways ==
eMagiz 1.1 73
74 * There are two options when retrieving emails (IMAP and standard)
75 * Use IMAP when you want to listen and wait for emails to be pushed to eMagiz
76 * Use standard mail when you actively want to poll for messages
77 * Both options have a MIME output that should be transformed to XML for further processing
78
Eva Torken 32.1 79 == 5. Suggested Additional Readings ==
eMagiz 1.1 80
81 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:
82
Erik Bakker 31.1 83 * [[Mail inbound reference (Spring)>>https://docs.spring.io/spring-integration/docs/2.1.x/reference/html/mail.html#mail-inbound||target="blank"]]
84 * [[Mail reference (Spring)>>https://docs.spring.io/spring-integration/reference/html/mail.html||target="blank"]]
eMagiz 1.1 85
Eva Torken 32.1 86 )))((({{toc/}}))){{/container}}{{/container}}