Wiki source code of IMAP-Plugin


Hide last authors
gru 52.2 1 [[**Plugin-Download**>>url:https://customer.formcycle.eu/index.php/apps/files/?dir=/FORMCYCLE%20-%20Plugins%20Customer/IMAP%26SMTP%20Mail-Proxy&fileid=3263||rel="noopener noreferrer" target="_blank"]] (requires login)
awa 34.21 2
MKO 30.1 3 {{content/}}
4
gru 52.2 5 The {{smallcaps}}Imap{{/smallcaps}} plug-in for {{formcycle/}} lets you view the data submitted forms in your email client. This way you are notified of new submissions immediately. You can also move form records to different inboxes or delete them. This plugin is subject to additional charge.
MKO 1.2 6
gru 52.2 7 Technically speaking, this plugin provides an {{smallcaps}}Imap{{/smallcaps}} and {{smallcaps}}Smtp{{/smallcaps}} server to which most common email client can connect.
MKO 5.1 8
gru 52.2 9 == Features ==
MKO 5.1 10
gru 52.2 11 ; Immediate notification
12 : Immediately notifies users about newly submitted forms via the {{smallcaps}}Imap{{/smallcaps}} protocol
13 ; Configurable content
14 : The content of the notifications as well as the subject, sender and recipient can be configured freely using corresponding templates. You can also use [[variables>>doc:Formcycle.UserInterface.Variables||target="_blank"]] and insert links to the submitted form and values from the submitted form.
15 : Users can upload files in the form, and backend users can also attach files in the inbox. These files are attached automatically to the email message, so that you can open them in your email client. Starting from version {{{version major="2" minor="1"/}}} it is alternatively also possible to define limits, starting from which files should only be listed in an attached text file.
16 ; Mapped inboxes
17 : All inboxes to which you have access are created in your email client. In addition, the folder //Inbox// always points to the default inbox and contains all available form records.
18 ; Manage form entries
19 : Other than just viewing submitted forms, you can also perform several actions such as moving form records to different inboxes. When you have read an email, the form record in the {{formcycle/}} inbox is also marked as read; and when you delete an email by moving it to the trash, the form record is deleted as well. Please note that when you lack permission to do so, the deleted email will reappear in the inbox.
MKO 15.1 20
gru 52.2 21 The provided {{smallcaps}}Smtp{{/smallcaps}} server is a stub, and messages send to it are discarded and not processed any further.
22
awa 34.14 23 == Installation ==
MKO 1.2 24
gru 52.2 25 Install the plugin as a system plugin in the backend. Please note that the initial installation may take up to several minutes, depending on the number of form records, as they need to be prepared for the {{smallcaps}}Imap{{/smallcaps}} server.
MKO 1.2 26
MKO 13.1 27 {{info}}
gru 52.2 28 The {{smallcaps}}Imap{{/smallcaps}} plugin does not consider the client scope where it is installed when logging in and delivering messages. It is always available to all users. Therefore it is recommended to install the plugin as a system plugin. This also avoids possible issues with duplicate ports and allows for the plugon to be configured centrally.
MKO 13.1 29 {{/info}}
30
gru 52.2 31 == Plugin configuration . It contains settings for the email server connection and lets you define how the emails should look like. ==
MKO 1.2 32
gru 52.2 33 {{figure image="config_en.png"}}
34 The configuration page of the plugin
MKO 2.4 35 {{/figure}}
MKO 1.2 36
gru 52.2 37 After installing the plugin, the configuration parameters shown in the figure are available. The following configuration options are possible:
MKO 2.3 38
gru 52.2 39 === Configuration of the mail servers ===
MKO 1.2 40
MKO 35.1 41 {{id name="server_config"/}}
MKO 1.3 42
awa 34.2 43 ; smtp.binding.address
gru 52.2 44 : Default: //0.0.0.0//. Specifies the {{smallcaps}}ip{{/smallcaps}} address of the {{smallcaps}}Smtp{{/smallcaps}} server to use. The default value is //0.0.0.0//, which attempts to detect the {{smallcaps}}ip{{/smallcaps}} automatically. Changing this value is only necessary if multiple network adapters are in use or if the automatic detection fails.
awa 34.2 45 ; smtp.binding.port
gru 52.2 46 : Default: //25//. Specifies the port of the {{smallcaps}}Smtp{{/smallcaps}} server to use. The default value should only be changed if the default port is not available.
awa 34.2 47 ; imap.binding.address
gru 52.2 48 : Default: //0.0.0.0//. Specifies the {{smallcaps}}ip{{/smallcaps}} address to use for the {{smallcaps}}Imap{{/smallcaps}} server. The default value is //0.0.0.0//, which also uses an automatically detected {{smallcaps}}ip{{/smallcaps}}. Changing this value is only necessary if multiple network adapters are in use or the automatic detection fails.
awa 34.2 49 ; imap.binding.port
gru 52.2 50 : Default: //143//. Specifies the port of the {{smallcaps}}Imap{{/smallcaps}} server to use. The default value should only be changed if the default port is not available.
51 ; imap.batch.size (starting from {{version major="2" minor="1"/}})
52 : Default: //50//. Specifies the number of messages to be delivered simultaneously. A lower value will reduces the memory usage but also the performance.
MKO 1.2 53
gru 52.2 54 === Configuration of the mail messages ===
MKO 1.2 55
MKO 35.1 56 {{id name="message_files_config"/}}
MKO 1.2 57
awa 34.2 58 ; mail.to.template
gru 52.2 59 : Default: //mail_to.txt//. Specifies the name of a client or form file to be used as a template for the email recipient.
awa 34.2 60 ; mail.from.template
gru 52.2 61 : Default: //mail_from.txt//. Specifies the name of a client or form file to be used as a template for the email sender.
awa 34.2 62 ; mail.subject.template
gru 52.2 63 : Default: //mail_subject.txt//. Specifies the name of a client or form file to be used as a template for the email subject.
awa 34.2 64 ; mail.body.template
gru 52.2 65 : Default: //mail_body.txt//. Specifies the name of a client or form file to be used as a template for the email content.
66 ; mail.attachment.limit (starting from {{version major="2" minor="1"/}})
67 : Default: //10//. Maximum size of a file (in MB) above which it should not be attached, but listed in a text file (-1 = deactivated, 0 = lists all attachments).
68 ; mail.attachment.sum.limit (starting from {{version major="2" minor="1"/}})
69 : Default: //-1//. Maximum sum of all file sizes (in MB) above which they should not be attached but listed in a text file (-1 = deactivated, 0 = always list all attachments).
MKO 1.3 70
gru 52.2 71 === Configuration of the synchronization ===
MKO 45.1 72
gru 52.2 73 ; sync.max.threads (starting from {{version major="2" minor="1"/}})
74 : Default: //4//. Number of threads with which the synchronization of messages should be performed.
75 ; sync.page.size (starting from {{version major="2" minor="1"/}})
76 : Default: //50//. Number of messages with which a thread should perform the synchronization.
MKO 45.1 77
gru 52.2 78 === Configuration of the cache ===
MKO 45.1 79
gru 52.2 80 ; cache.heap.size (starting from {{version major="2" minor="1"/}})
81 : Default: //200//. Size of the RAM to be used in M.
82 ; cache.disk.size (starting from {{version major="2" minor="1"/}})
83 : Default: //500//. Size of the hard drive memory to be used in MB.
84 ; cache.tti (starting from {{version major="2" minor="1"/}})
85 : Default: //900//. Maximum age of a cache entry in seconds.
MKO 45.1 86
gru 52.2 87 == Email contents and fields ==
MKO 5.2 88
gru 52.2 89 A template mechanism is used for the configuration of the content and fields of the email message that is sent.
MKO 5.2 90
gru 52.2 91 The templates are specified by the [[email message configuration>>||anchor="message_files_config"]]. When an email is sent, the plugin first looks for a template in the form files of the current form, and if none is found, it looks for a template in the client files. This lets you create global templates as client files and override them for specific forms, if neccessary.
awa 34.4 92
gru 52.2 93 You can use [[variables>>doc:Formcycle.UserInterface.Variables||target="_blank"]] in all templates, such as when you want to insert data from the submitted form and would like to include a link to the form record.
94
95 The following templates can be configured:
96
97 ; Content
98 : Default value: //mail_body.txt//. Specifies the content of the email message. This template allows you to use {{smallcaps}}Html{{/smallcaps}} For example:
99
awa 34.4 100 {{code language="html"}}
MKO 36.1 101 <html>
gru 52.2 102 <head></head>
103 <body>
104 <p><a href="[%$FORM_INBOX_LINK%]">Link</a> to form entry ([%$PROCESS_ID%]).</p>
105 </body>
awa 34.4 106 </html>
107 {{/code}}
awa 34.8 108
gru 52.2 109 ; Subject
110 : Default value: //mail_subject.txt//. Specifies the subject of the message and must not contain {{smallcaps}}Html{{/smallcaps}}. For example:
MKO 5.2 111
awa 34.4 112 {{code language="none"}}
gru 52.2 113 ID: [%$RECORD_ID%] - [%$STATUS_NAME%]
awa 34.4 114 {{/code}}
awa 34.8 115
gru 52.2 116 ; Recipient
117 : Default value: //mail_to.txt//. Specifies the recipient of the message and must not contain {{smallcaps}}Html{{/smallcaps}}. This is to be entered according to the pattern //name <user@example.com>// and has no effect on the actual receipt of the message. Example:
awa 34.4 118
119 {{code language="none"}}
120 XIMA FORMCYCLE <no-reply@example.com>
121 {{/code}}
awa 34.8 122
gru 52.2 123 ; Sender
124 : Default value: //mail_from.txt//. Specifies the sender of the message and must not contain {{smallcaps}}Html{{/smallcaps}}. You need to enter the sender using the pattern //Name <user@example.com>//. The sender has no effect on how the message is sent. Example:
awa 34.4 125
126 {{code language="none"}}
127 [%$PROJECT_NAME%] <[%$PROJECT_NAME%]@example.com>
128 {{/code}}
129
gru 52.2 130 == Email client configuration ==
MKO 5.2 131
gru 52.2 132 Use the the address and port of the email server, as configured in the [[plugin configuration>>||anchor="server_config"]] must be used. Below you can find a list of all settings:
MKO 5.2 133
gru 52.2 134 ; {{smallcaps}}Smtp{{/smallcaps}} server
135 : //<server address>//
136 ; {{smallcaps}}Smtp{{/smallcaps}} port
137 : see [[email server service configuration>>||anchor="server_config"]]
138 ; {{smallcaps}}Imap{{/smallcaps}} server
139 : //<server address>//
140 ; {{smallcaps}}Imap{{/smallcaps}} port
141 : see [[email server service configuration>>||anchor="server_config"]]
142 ; Username
143 : //<FORMCYCLE-user>@<FORMCYCLE-clientname>//
144 ; Password
145 : //<FORMCYCLE-user-password>//
146 ; Authentication
147 : Normal password
148 ; SSL encryption and connection security
149 : None
MKO 11.2 150
gru 52.2 151 == Example configuration for Thunderbird ==
MKO 18.3 152
gru 52.2 153 1. Open the email account management via //Preferences// > //Account Settings//.{{lightbox image="thunderbird_1_en.png" group="g0" width="300"/}}
154 1. Click on //Account Actions// > //Add Mail Account...// to open the dialog for adding a new account.{{lightbox image="thunderbird_2_en.png" group="g0" width="500"/}}
155 1. Initially, Thunderbird tries to determine the email server automatically based on the entered email address (here //user@imap.com//). Since this is not possible here, you can cancel that attempt by clicking on the //Manual config// button.{{lightbox image="thunderbird_3_en.png" group="g0" width="500"/}}
156 1. Fill out the email server settings. See above for what you should enter in each field. In the example, the client name is //imap.com// and the user name //user// and the standard ports are used.{{lightbox image="thunderbird_4_en.png" group="g0" width="500"/}}
157 1. After you complete the configuration, the user's mailboxes now appear as folders (here //central mailbox// and //demo mailbox//) and contain the messages of the existing form records.{{lightbox image="thunderbird_5_en.png" group="g0" width="700"/}}
MKO 51.1 158
gru 52.2 159 == Version history ==
MKO 51.1 160
161 **Version 2.1.0**
162
gru 52.2 163 * Switching to {{formcycle/}} version 6.5.5
164 * Updated the used libraries
165 * Optimization of memory consumption and database queries
166 * Integration of a cache for the header and body of messages
167 * Correction of errors when reading the IMAP BODYSTRUCTURE
168 * Reintegration of the configuration of the attachment limits
169 * Extension of the configurability of IMAP batch size and synchronization
MKO 51.1 170
171 **Version 2.0.0**
172
gru 52.2 173 * Modifications for compatibility with {{formcycle/}} version 6.0.2
MKO 51.1 174
175 **Version 1.0.1**
176
gru 52.2 177 * Optimizations and extensions of the configurability
MKO 51.1 178
179 **Version 1.0.0**
180
gru 52.2 181 * Initial release
Copyright 2000-2025