discourse-legacysite-perl/site/glist/templates/help/GT/Mail/Parts.html

571 lines
16 KiB
HTML
Raw Permalink Normal View History

2024-06-17 12:24:05 +00:00
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>GT::Mail::Parts - Data storage class for MIME parts</title>
<link rev="made" href="mailto:root@penguin.office.gossamer-threads.com" />
<style type="text/css">
/* $MVD$:fontset("Untitled Font Set 1","ARIEL","HELVETICA","HELV","SANSERIF") */
/* $MVD$:fontset("Arial","Arial") */
/* $MVD$:fontset("Arial Black","Arial Black") */
/* $MVD$:fontset("Algerian","Algerian") */
body {
background-color: white;
font-family: Verdana, Arial, sans-serif;
font-size: small;
color: black;
}
p {
background-color : white;
font-family : Verdana, Arial, sans-serif;
font-size : small;
color : black;
}
h1 {
font-family : Verdana, Arial, sans-serif;
font-weight : bold;
font-size : medium;
background-color : white;
color : maroon;
}
h2 {
font-family : Verdana, Arial, sans-serif;
font-size : medium;
font-weight : bold;
color : blue;
background-color : white;
}
h3 {
font-family : Verdana, Arial, sans-serif;
font-weight : bold;
font-size : medium;
color : black;
background-color : white;
}
h4 {
font-family : Verdana, Arial, sans-serif;
font-weight : bold;
font-size : small;
color : maroon;
background-color : white;
}
h5 {
font-family : Verdana, Arial, sans-serif;
font-weight : bold;
font-size : small;
color : blue;
background-color : white;
}
h6 {
font-family : Verdana, Arial, sans-serif;
font-weight : bold;
font-size : small;
color : black;
background-color : white;
}
ul {
font-family : Verdana, Arial, sans-serif;
font-size : small;
color : black;
}
ol {
font-family : Verdana, Arial, sans-serif;
font-size : small;
color : black;
}
dl {
font-family : Verdana, Arial, sans-serif;
font-size : small;
color : black;
}
li {
font-family : Verdana, Arial, sans-serif;
font-size : small;
color : black;
}
th {
font-family : Verdana, Arial, sans-serif;
font-size : small;
color : black;
}
td {
font-family : Verdana, Arial, sans-serif;
font-size : small;
color : black;
}
dl {
font-family : Verdana, Arial, sans-serif;
font-size : small;
color : black;
}
dd {
font-family : Verdana, Arial, sans-serif;
font-size : small;
color : black;
}
dt {
font-family : Verdana, Arial, sans-serif;
font-size : small;
color : black;
}
code {
font-family : Courier;
font-size : small;
color : black;
}
pre {
font-family : Courier;
font-size : small;
color : black;
}
.mvd-H1 {
font-family : Verdana, Arial, sans-serif;
font-weight : bold;
font-size : 14.0pt;
background-color : transparent;
background-image : none;
color : maroon;
}
.mvd-H2 {
font-family : Verdana, Arial, sans-serif;
font-size : 12.0pt;
color : blue;
}
p.indent {
font-family : "Verdana, Arial, sans-serif";
list-style-type : circle;
list-style-position : inside;
color : black;
margin-left : 16.0pt;
}
.mvd-P-indent {
font-family : Verdana, Arial, sans-serif;
list-style-type : circle;
list-style-position : inside;
color : black;
margin-left : 16.0pt;
}
pre.programlisting {
font-size : 9.0pt;
list-style-type : disc;
margin-left : 16.0pt;
margin-top : -14.0pt;
}
.mvd-PRE-programlisting {
font-size : 9.0pt;
list-style-type : disc;
margin-left : 16.0pt;
margin-top : -14.0pt;
}
.mvd-PRE {
font-size : 9.0pt;
}
p.note {
margin-left : 28.0pt;
}
.mvd-P-note {
margin-left : 28.0pt;
}
.mvd-H4 {
font-family : Verdana, Arial, sans-serif;
font-weight : normal;
font-size : 9.0pt;
color : black;
margin-left : 6.0pt;
margin-top : -14.0pt;
}
.mvd-P {
font-family : Verdana, Arial, sans-serif;
font-size : 10.0pt;
color : black;
}
.mvd-BODY {
font-family : Verdana, Arial, sans-serif;
background-color : white;
}
p.indentnobullet {
font-family : Verdana, Arial, sans-serif;
list-style-type : none;
}
.mvd-P-indentnobullet {
font-family : Verdana, Arial, sans-serif;
list-style-type : none;
}
</style>
</head>
<body style="background-color: white">
<p><a name="__index__"></a></p>
<!-- INDEX BEGIN -->
<ul>
<li><a href="#name">NAME</a></li>
<li><a href="#synopsis">SYNOPSIS</a></li>
<li><a href="#description">DESCRIPTION</a></li>
<ul>
<li><a href="#effective_type__access_the_effective_mime_type">effective_type - Access the effective MIME type</a></li>
<li><a href="#get__access_header_tags_">get - Access header tags.</a></li>
<li><a href="#set__set_a_header_tag_">set - Set a header tag.</a></li>
<li><a href="#delete__remove_a_header_tag_">delete - Remove a header tag.</a></li>
<li><a href="#size__access_the_total_size_">size - Access the total size.</a></li>
<li><a href="#preamble__set_or_get_the_preamble_">preamble - Set or get the preamble.</a></li>
<li><a href="#epilogue__set_or_get_the_epilogue_">epilogue - Set or get the epilogue.</a></li>
<li><a href="#mime_type__set_or_get_the_mime_type_">mime_type - Set or get the MIME type.</a></li>
<li><a href="#is_multipart__see_if_you_have_a_multipart_part_">is_multipart - See if you have a multi-part part.</a></li>
<li><a href="#parts__access_sub_parts_">parts - Access sub parts.</a></li>
<li><a href="#multipart_boundary__set_or_get_the_multipart_boundary_">multipart_boundary - Set or get the multi-part boundary.</a></li>
<li><a href="#header_as_string__access_the_whole_header_">header_as_string - Access the whole header.</a></li>
<li><a href="#split_field__retrieve_the_emails_split_up_into_an_array_">split_field - Retrieve the emails split up into an array.</a></li>
<li><a href="#suggest_encoding__get_a_suggestion_for_encoding_">suggest_encoding - Get a suggestion for encoding.</a></li>
<li><a href="#recommended_filename__figure_out_the_file_name_">recommended_filename - Figure out the file name.</a></li>
<li><a href="#body_as_string__get_the_body_as_a_string_">body_as_string - Get the body as a string.</a></li>
<li><a href="#body_in__find_the_body_">body_in - Find the body.</a></li>
<li><a href="#body_data__get_the_in_memory_body_">body_data - Get the in memory body.</a></li>
<li><a href="#body_handle__get_an_io_handle_to_the_body_">body_handle - Get an IO handle to the body.</a></li>
<li><a href="#body_path__get_the_location_of_the_file_the_body_is_in_">body_path - Get the location of the file the body is in.</a></li>
</ul>
<li><a href="#copyright">COPYRIGHT</a></li>
<li><a href="#version">VERSION</a></li>
</ul>
<!-- INDEX END -->
<hr />
<p>
</p>
<h1><a name="name">NAME</a></h1>
<p>GT::Mail::Parts - Data storage class for MIME parts</p>
<p>
</p>
<hr />
<h1><a name="synopsis">SYNOPSIS</a></h1>
<pre>
use GT::Mail;</pre>
<pre>
my $mail = new GT::Mail;</pre>
<pre>
my $top_part = $mail-&gt;parse('/path/to/email');</pre>
<pre>
# Access the emails as an array
my @to = $top_part-&gt;split_field('to');
my @from = $top_part-&gt;split_field('from');</pre>
<pre>
# Access to the header fields
my $mailer = $top_part-&gt;get('X-Mailer');
my $subject = $top_part-&gt;get('Subject');</pre>
<pre>
# Access to this parts sub part
if ($top_part-&gt;is_multipart) {
my @parts = $top_parts-&gt;parts;
for my $part (@parts) {</pre>
<pre>
# Access parts of the header
print &quot;Filename: &quot;, $part-&gt;recommended_filename, &quot;\n&quot;;
print &quot;Part is multi-part\n&quot; if $part-&gt;is_multipart;</pre>
<pre>
# Get the body as a string
my $body = $part-&gt;body_as_string;
}
}</pre>
<pre>
# Change who it is to
$top_part-&gt;set('to', 'scott@gossamer-threads.com');</pre>
<pre>
# Remove the bcc line
$top_part-&gt;delete('bcc');</pre>
<p>
</p>
<hr />
<h1><a name="description">DESCRIPTION</a></h1>
<p>GT::Mail::Parts is a class to provide methods to change and
access a MIME messages. The object for this class is meant to
be istansiated from <a href="glist.cgi?do=admin_gtdoc&topic=/GT/Mail.html">the GT::Mail manpage</a>.</p>
<p>
</p>
<h2><a name="effective_type__access_the_effective_mime_type">effective_type - Access the effective MIME type</a></h2>
<pre>
my $type = $obj-&gt;effective_type;</pre>
<pre>
if ($type eq 'application/octet-stream') {
...
}</pre>
<p>This method returns the effective MIME Type of this objects part.</p>
<p>
</p>
<h2><a name="get__access_header_tags_">get - Access header tags.</a></h2>
<pre>
my $subj = $obj-&gt;get('Subject');</pre>
<pre>
# or if there is more than one
my @recv = $obj-&gt;get('Received');</pre>
<p>Used to access any of the tags in the header of the MIME part. If the
tag requested is not present returns false. The first argument to this
method is the name of he tag you want to extract. This is case insensitive.</p>
<p>
</p>
<h2><a name="set__set_a_header_tag_">set - Set a header tag.</a></h2>
<pre>
# Change who the email is to
$obj-&gt;set('to', 'scott@gossamer-threads.com');</pre>
<pre>
# Change the second Received tag
$obj-&gt;set('Received', 'from unknown', 1);</pre>
<p>Set any of the tags in the header. If the tag does not exist this will create
it. This method takes three arguments. The first is the name of the tag to
change or add, this is case insensitive. The second argument is the value for
the tag. The third zero based optional argument is the position. The position
will default to zero if it is not specified.</p>
<p>
</p>
<h2><a name="delete__remove_a_header_tag_">delete - Remove a header tag.</a></h2>
<pre>
# Delete who the message is from
$obj-&gt;delete('from');</pre>
<p>This method deletes the tag specified by the first argument from this MIME
part.</p>
<p>
</p>
<h2><a name="size__access_the_total_size_">size - Access the total size.</a></h2>
<pre>
my $size = $obj-&gt;size;</pre>
<p>This method returns the total size of this part. This includes the header and
the body.</p>
<p>
</p>
<h2><a name="preamble__set_or_get_the_preamble_">preamble - Set or get the preamble.</a></h2>
<pre>
# Retrieve the preamble
my $pre = $obj-&gt;preamble;</pre>
<pre>
# Set the preamble
$obj-&gt;preamble('This is a multi-part message in MIME format.');</pre>
<p>This is a set get method for the preamble. The preamble is the part after the
head but before the first MIME boundary. This method makes no since if this
is not a multi-part part.</p>
<p>
</p>
<h2><a name="epilogue__set_or_get_the_epilogue_">epilogue - Set or get the epilogue.</a></h2>
<pre>
# Retrieve the epilogue
my $ep = $obj-&gt;epilogue;</pre>
<pre>
# Set the epilogue
$obj-&gt;epilogue('This is my cool epilogue');</pre>
<p>This is a set get method for the epilogue. The epilogue is the part of the
MIME part after the MIME boundary and before the next head. This method makes
no since if this is not a multi-part part.</p>
<p>
</p>
<h2><a name="mime_type__set_or_get_the_mime_type_">mime_type - Set or get the MIME type.</a></h2>
<pre>
my ($type, $subtype) = split('/', $obj-&gt;mime_type);</pre>
<p>This method returns the MIME type of this part. You can pass in an argument
to change the MIME type as well. So you could do</p>
<pre>
$obj-&gt;mime_type('text/plain');</pre>
<p>This is probably not such a good idea unless you are constructing the email from
scratch.</p>
<p>
</p>
<h2><a name="is_multipart__see_if_you_have_a_multipart_part_">is_multipart - See if you have a multi-part part.</a></h2>
<pre>
if ($obj-&gt;is_multipart) {
# do some multi-part stuff
}</pre>
<p>Returns true is this part is a multi-part MIME part.</p>
<p>
</p>
<h2><a name="parts__access_sub_parts_">parts - Access sub parts.</a></h2>
<pre>
my @parts = $obj-&gt;parts;</pre>
<p>Returns the parts object this part contains. Returns false if this part does
no have any sub parts. The parts objects that returns are from this same class.
Any parts that are milti-part should contain parts.</p>
<p>
</p>
<h2><a name="multipart_boundary__set_or_get_the_multipart_boundary_">multipart_boundary - Set or get the multi-part boundary.</a></h2>
<pre>
my $boundary = $obj-&gt;multipart_boundary;</pre>
<p>This returns the multi-part boundary for this part. Setting this is never needed
and may be removed in the future. This method only makes since if you are working
with a multi-part pert.</p>
<p>
</p>
<h2><a name="header_as_string__access_the_whole_header_">header_as_string - Access the whole header.</a></h2>
<pre>
my $head = $obj-&gt;header_as_string;</pre>
<p>This method creates and returns the header for this part. The returned header should
be fully rfc822 compliant. Avoid calling this method more than once, as it will build
the header from an internal data structure each time.</p>
<p>
</p>
<h2><a name="split_field__retrieve_the_emails_split_up_into_an_array_">split_field - Retrieve the emails split up into an array.</a></h2>
<pre>
my @to = $obj-&gt;split_field; # Defaults to 'to'
my @bcc = $obj-&gt;split_field('bcc');</pre>
<p>This is mostly a utility method. It takes an option argument as to the field you want
the email address from (default is to), it then splits the emails on '\s*,\s*' that is
not inside quotes. Returns an array of the split up string.</p>
<p>
</p>
<h2><a name="suggest_encoding__get_a_suggestion_for_encoding_">suggest_encoding - Get a suggestion for encoding.</a></h2>
<pre>
my $encode = $obj-&gt;suggest_encoding;</pre>
<p>Returns a suggested encoding for the body of this message. This is useful to decide
what encoding you should use for the body when building an email. This is used in
<a href="glist.cgi?do=admin_gtdoc&topic=/GT/Mail/Parse.html">the GT::Mail::Parse manpage</a> to decide how to encode the message body.</p>
<p>
</p>
<h2><a name="recommended_filename__figure_out_the_file_name_">recommended_filename - Figure out the file name.</a></h2>
<pre>
my $file = $obj-&gt;recommended_filename;
if ($file) {
...
}</pre>
<p>This method tries to figure out the file name of this part. This does not make much
since if this part is not an attachment of some kind. Returns an empty string on
failure.</p>
<p>
</p>
<h2><a name="body_as_string__get_the_body_as_a_string_">body_as_string - Get the body as a string.</a></h2>
<p>This method returns the entire body of the MIME message as a string. You should not
use this method if the body could be large.</p>
<p>
</p>
<h2><a name="body_in__find_the_body_">body_in - Find the body.</a></h2>
<pre>
my $in = $obj-&gt;body_in;
my $body;</pre>
<pre>
if ($in eq 'MEMORY') {
$body = $obj-&gt;body_data;
}
elsif ($in eq 'HANDLE') {
$body = $obj-&gt;body_handle;
}
elsif ($in eq 'FILE') {
$body = $obj-&gt;body_path;
}</pre>
<p>This method returns the location of the body. The location can be one of three things:</p>
<dl>
<dt><strong><a name="item_memory">MEMORY</a></strong><br />
</dt>
<dd>
The body is in a string.
</dd>
<p></p>
<dt><strong><a name="item_handle">HANDLE</a></strong><br />
</dt>
<dd>
The body is in an IO handle.
</dd>
<p></p>
<dt><strong><a name="item_file">FILE</a></strong><br />
</dt>
<dd>
The body is in a file.
</dd>
<p></p></dl>
<p>You would use this to decide what method to use to access the body. If the MIME message
was parsed into GT::Mail::Parts using <a href="glist.cgi?do=admin_gtdoc&topic=/GT/Mail/Parser.html">the GT::Mail::Parser manpage</a> the body will always be in
a FILE.</p>
<p>
</p>
<h2><a name="body_data__get_the_in_memory_body_">body_data - Get the in memory body.</a></h2>
<p>This method returns the body if it is stored in memory. Returns undefined if the body is
not in memory.</p>
<p>
</p>
<h2><a name="body_handle__get_an_io_handle_to_the_body_">body_handle - Get an IO handle to the body.</a></h2>
<p>This method returns a handle to the body if the body is stored in a handle for this part.
Returns undefined if not.</p>
<p>
</p>
<h2><a name="body_path__get_the_location_of_the_file_the_body_is_in_">body_path - Get the location of the file the body is in.</a></h2>
<p>This method returns the file path to the file the body is located in if the body for this
part is stored in a file. Returns undefined if not.</p>
<p>
</p>
<hr />
<h1><a name="copyright">COPYRIGHT</a></h1>
<p>Copyright (c) 2004 Gossamer Threads Inc. All Rights Reserved.
<a href="http://www.gossamer-threads.com/">http://www.gossamer-threads.com/</a></p>
<p>
</p>
<hr />
<h1><a name="version">VERSION</a></h1>
<p>$Revision: 1.77 $</p>
</body>
</html>