This example looks up email messages with specific keywords in subject or body.
@Inject
private EmailClient emailClient;
public void execute() {
List<String> LOOKUP_KEYWORDS = Arrays.asList("database", "storage");
List<EmailMessage> messages = emailClient.fetchMessages(msg -> {
boolean subjectContainsKeywords = LOOKUP_KEYWORDS.stream().anyMatch(msg.getSubject()::contains);
boolean bodyContainsKeywords = LOOKUP_KEYWORDS.stream().anyMatch(msg.getText()::contains);
return subjectContainsKeywords || bodyContainsKeywords;
});
log.info("List fetched messages:");
messages.forEach(msg -> {
log.info("'{}' from '{}'", msg.getSubject(), msg.getSender().getPersonal());
});
}
See the full source of this example for more details or check following instructions to run it.
⚠️ To be able to build and run this example it's necessary to have an access to some instance of EasyRPA Control Server.
Its a fully workable process. To play around with it and run do the following:
-
Download this example using link.
-
Unpack it somewhere on local file system.
-
Specify URL to the available instance of EasyRPA Control Server in the
pom.xml
of this example:<repositories> <repository> <id>easy-rpa-repository</id> <url>[Replace with EasyRPA Control Server URL]/nexus/repository/easyrpa/</url> </repository> </repositories>
-
If necessary, change version of
easy-rpa-engine-parent
in the samepom.xml
to corresponding version of EasyRPA Control Server:<parent> <groupId>eu.ibagroup</groupId> <artifactId>easy-rpa-engine-parent</artifactId> <version>[Replace with version of EasyRPA Control Server]</version> </parent>
-
Build it using
mvn clean install
command. This command should be run within directory of this example. -
Run
main()
method ofLookupMessagesWithKeywords
class.
All necessary configuration files can be found in src/main/resources
directory.
apm_run.properties
Parameter | Value |
---|---|
inbound.email.server | The host name or IP-address of inbound email server. |
inbound.email.protocol | The name of protocol which should be used for interaction with inbound email server. |
inbound.email.secret |
The alias of secret vault entry with credentials for authentication on the inbound email server. In case of
running of this example without EasyRPA Control Server, secret vault entries can be specified in the
vault.properties file. The value of secret vault entry in this case should be a JSON string with
following structure encoded with Base64:{ "user": "user@example.com", "password": "passphrase" }
|