NAME

Sietima::MailStore - interface for mail stores

VERSION

version 1.0.0

DESCRIPTION

This role defines the interface that all mail stores must adhere to. It does not provide any implementation.

REQUIRED METHODS

store

my $id = $ms->store($email_mime_object,@tags);

Must persistently store the given email message (as an Email::Simple object or similar), associating it with the gives tags (which must be strings). Must return a unique identifier for the stored message. It is acceptable if identical messages are indistinguishable by the storage.

retrieve_by_id

my $email_mime_object = $ms->retrieve_by_id($id);

Given an identifier returned by "store", this method must return the email message (as an Email::Simple or Email::MIME object).

If the message has been deleted, or the identifier is not recognised, this method must return undef in scalar context.

retrieve_ids_by_tags

my @ids = $ms->retrieve_ids_by_tags(@tags)->@*;

Given a list of tags (which must be strings), this method must return an arrayref containing the identifiers of all (and only) the messages that were stored associated with (at least) all those tags. The order of the returned identifiers is not important.

If there are no messages associated with the given tags, this method must return an empty arrayref.

For example:

my $id1 = $ms->store($msg1,'t1');
my $id2 = $ms->store($msg2,'t2');
my $id3 = $ms->store($msg3,'t1','t2');

$ms->retrieve_ids_by_tags('t1') ==> [ $id3, $id1 ]
$ms->retrieve_ids_by_tags('t2') ==> [ $id2, $id3 ]
$ms->retrieve_ids_by_tags('t1','t2') ==> [ $id3 ]
$ms->retrieve_ids_by_tags('t3') ==> [ ]

retrieve_by_tags

my @email_mime_objects = $ms->retrieve_by_tags(@tags)->@*;

This method is similar to "retrieve_ids_by_tags", but it must return an arrayref of hashrefs. For example:

my $id1 = $ms->store($msg1,'t1');
my $id2 = $ms->store($msg2,'t2');
my $id3 = $ms->store($msg3,'t1','t2');

$ms->retrieve_ids_by_tags('t1') ==> [
  { id => $id3, mail => $msg3 },
  { id => $id1, mail => $msg1 },
 ]

remove

$ms->remove($id);

This method must remove the message corresponding to the given identifier from the persistent storage. Removing a non-existent message must succeed, and do nothing.

clear

$ms->clear();

This method must remove all messages from the persistent storage. Clearing an empty store must succeed, and do nothing.

AUTHOR

Gianni Ceccarelli <dakkar@thenautilus.net>

COPYRIGHT AND LICENSE

This software is copyright (c) 2017 by Gianni Ceccarelli <dakkar@thenautilus.net>.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.