This file is indexed.

/usr/share/perl5/Mail/Box-Cookbook.pod is in libmail-box-perl 3.004-1.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
=encoding utf8

=head1 NAME

Mail::Box-Cookbook - Examples how to use Mail::Box

=head1 DESCRIPTION

The Mail::Box package is a suite of classes for accessing and managing
email folders in a folder-independent manner.  This manual demonstrates
a few simple applications.  Please contribute with examples and fixes.
It may also help to have a look at the programs included in the
C<scripts/> and the C<examples/> directories of the distribution.

=head2 The Manager

For more details about all the packages which are involved in the
Mail::Box suite you have to read L<Mail::Box-Overview|Mail::Box-Overview>.  But you
do not need to know much if you want to use the Mail::Box suite.

Please use the manager to open your folders.  You will certainly
benefit from it.  The manager takes care of detecting which folder
type you are using, and which folders are open.  The latter avoids
the accidental re-opening of an already open folder.

The C<examples/open.pl> script contains mainly

 my $mgr    = Mail::Box::Manager->new;
 my $folder = $mgr->open($filename);
 foreach my $message ($folder->messages) {
     print $message->get('Subject') || '<no subject>', "\n";
 }
 $folder->close;

which shows all the most important functions.  It will cause all
subjects of the messages in the indicated folder to be listed.  So:
although the number of packages included in the Mail::Box module
is huge, only little is needed for normal programs.

In stead of calling C<close> on the folder, you may also call

 $mgr->closeAllFolders;

If you forget to close a folder, changes will not be written.  This
may change in the future.

=head2 Multi part messages

In early days of Internet, multi-part messages where very rare.
However, in recent years, a large deal of all transmitted message have
attachments.  This makes handling of the bodies of messages a bit harder:
when a message contains more than one part, which part is then the most
important to read?

To complicate life, multi-parts can be nested: each part may be a
multi-part by itself.  This means that programs handling the message
content must be recursive or skip multi-parts.

The central part of the C<examples/multipart.pl> script reads:

 foreach my $message ($folder->messages) {
     show_type($message);
 }

 show_type($) {
     my $msg = shift;
     print $msg->get('Content-Type'), "\n";

     if($msg->isMultipart) {
         foreach my $part ($msg->parts) {
             show_type($part);
         }
     }
 }

Each part is a message by itself. It has a header and a body.  A multipart
message has a special body: it contains a list of parts and optionally
also a preamble and an epilogue, which are respectively the lines before
and after the parts.  These texts may be ignored, because they are only
descriptive on how the multi-part was created.

=head2 Filter

The target is to select a few messages from one folder, to move them
to an other.  The C<examples/takelarge.pl> script demonstrates how
to achieve this.  B<Be warned:> it will replace your input folder!

As abstract of the crucial part:

 my $inbox = $mgr->open('inbox', access => 'rw');
 my $large = $mgr->open('large', access => 'a', create => 1);

 foreach my $message ($inbox->messages) {
     next if $message->size < $size;
     $mgr->moveMessage($large, $message);
 }

 $inbox->close;
 $large->close;

The C<inbox> is opened for read and write: first read all messages, and
then write the smaller folder without moved messages back.  The C<large>
folder is created if the file does not exist yet.  In any case, messages
will be added to the end of the folder.

The manager is needed to move the message: to unregister the message from
the first folder, and reregister it in the second.  You can move more
messages at once, if you like.  When you move to a folder which is not
open, you even better do that: it will be faster:

 my @move = grep {$_->size >= $size} $inbox->messages;
 $mgr->moveMessage($large, @move);

In this example, the C<size> of the message determines whether the message
is moved or not.  Of course, there are many other criteria you can use.
For instance, use C<timestamp> to find old messages:

 use constant YEAR => 365 * 24 * 60 * 60;
 my $now = time;
 my @old = grep {$_->timestamp - $now > YEAR} $inbox->messages;
 $mgr->moveMessage($oldbox, @old);

=head2 Create a reply

The complex message treatment is implemented in L<Mail::Message::Construct|Mail::Message::Construct>
and automatically loaded when needed.  It is sufficient to simply call
C<reply> on any message:

 my $folder  = ...;
 my $message = $folder->message(8);
 my $reply   = $message->reply;

 $folder->addMessage($reply);
 $reply->print;

The method is quite complex, as demonstrated by C<examples/reply.pl>, in
which the construction of a reply-message is shown.

Three kinds of reply messages can be made: one which does not include
the original message at all (NO), then one which inlines the original
message quoted (INLINE), and as third possibility the original message as
attachment (ATTACH).

The C<include> parameter selects the kind of reply.  When you reply
to binary or multi-part messages, INLINE will automatically promoted
to ATTACH.  By default text will be stripped from the original senders
signature.  Multi-part messages are stripped from attachments which
qualify as signature.  In case a multi-part (after stripping) only
contains one part, and that INLINE is requested, it will be 'flattened':
the reply may be a single-part.

Have a look at the parameters which can be passed to reply in
L<Mail::Message::Construct|Mail::Message::Construct>.  For a single-part reply, the return
will be

 prelude
 quoted original
 postlude
 --
 signature

A multipart body will be

 part 1: prelude
         [ see attachment ]
         postlude
 part 2: stripped original multipart
 part 3: signature

=head2 Build a message

There are three ways to create a message which is not a reply:

=over 4

=item * L<Mail::Message::buildFromBody()|Mail::Message::Construct::Build/"Constructing a message">

Start with creating a body, and transform that into a message.

=item * L<Mail::Message::build()|Mail::Message::Construct::Build/"Constructing a message">

create the whole message at once.

=item * L<Mail::Message::read()|Mail::Message::Construct::Read/"Constructing a message">

read a message from a file-handle, scalar, or array of lines.

=back

All three methods are implemented in L<Mail::Message::Construct|Mail::Message::Construct>.  Please,
do yourself a favor, and give preference to the C<build*> methods, over
the C<read>, because they are much more powerful.  Use the C<read> only
when you have the message on STDIN or an array of lines which is supplied
by an external program.

Very important to remember from now on: information about the content of
the body (the C<Content-*> lines in the header) is stored within the body
object, for as long as the body is not contained with a message object.

For instance, C<$message> method C<decoded> returns the decoded body of the
C<$message>.  It is a body object by itself, however outside a real
message.  Then you may want to play around with it, by concatenating
some texts: again resulting in a new body.  Each body contains the
right C<Content-*> information.  Then, finally, you create a message
specifying the body and extra header lines.  At that moment you need
to specify the source and destination addresses (the C<From> and C<To> lines>).
At that moment, the body will automatically be encoded to be acceptable for
mail folders and transmission programs.

 my $body = Mail::Message::Body->new
  ( mime_type         => 'text/css'
  , transfer_encoding => '8bit'
  , data              => \@lines
  );

Above example creates a body, with explicitly stating what kind of data
is stored in it.  The default mime type is C<text/plain>.  The transfer
encoding defaults to C<none>.  Each message will get encoded on the moment
it is added to a message.  The default encoding depends on the mime type.

To start with the first way to create a message.  This solution provides
maximum control over the message creation.  Quite some work is hidden for
you when executing the next line.

 my $message = Mail::Message->buildFromBody
   ( $body
   , From => 'me@example.com'
   , To   => 'you@anywhere.net'
   , Cc   => [ Mail::Address->parse($groupalias) ]
   );

For header lines, you may specify a string, an address object
(L<Mail::Address|Mail::Address>), or an array of such addresses.  If you want to create
multi-part messages, you need to create a multi-part body yourself first.

The second way of constructing a message uses the C<build> method.  A
demonstration can be found in C<examples/build.pl>.  In only one
class method call the header and the (possible multi-parted) body
is created.

With the C<data> option, you can specify one scalar which
contains a whole body or an array of lines.  Using the C<file> option,
a file-handle or filename specifies a body.  The C<attach> option
refers to construed bodies and messages.  Each option can be used as
often as needed.  If more than one source of data is provided, a
multi-part message is produced.

 my $message = Mail::Message->build
  ( From       => 'me@example.com'
  , To         => 'you@anywhere.net'
  , 'X-Mailer' => 'Automatic mailing system'
  , data       => \@lines
  , file       => 'logo.jpg'
  , attach     => $signature_body
  );

=head1 SEE ALSO

This module is part of Mail-Box distribution version 3.004,
built on December 22, 2017.

Do not forget to read
L<Mail::Box-Overview>,
L<Mail::Box-Cookbook>, and
L<Mail::Box-Index>.
Examples are included in the Mail-Box distribution, directories 'examples'
and 'scripts'.

Browseable manuals, papers, and other released material van be found
at  Website: F<http://perl.overmeer.net/mailbox/>

The central modules (in separate distributions) in the MailBox suite are:
L<Mail::Message>,
L<Mail::Box>,
L<Mail::Box::IMAP4>,
L<Mail::Box::POP3>,
L<Mail::Box::Parser::C>,
L<Mail::Box::Dbx> (unpublished),
L<Mail::Transport>,
L<Object::Realize::Later>, and
L<User::Identity>.

Please post questions or ideas to the author F<markov@cpan.org>.

=head1 LICENSE

Copyrights 2001-2017 by [Mark Overmeer]. For other contributors see ChangeLog.

This program is free software; you can redistribute it and/or modify it
under the same terms as Perl itself.
See F<http://dev.perl.org/licenses/>