Email module, how to add header to the top of an email?

D

David Erickson

I have been using the Email module and Message class for awhile,
however I have been unable to find a way to add a header to the top of
the email similar to what is done with Received: headers... the
add_header method only appends to the bottom. Is there someway this
can be done?

Thanks
David
 
M

Martin Marcher

I have been using the Email module and Message class for awhile,
however I have been unable to find a way to add a header to the top of
the email similar to what is done with Received: headers... the
add_header method only appends to the bottom.  Is there someway this
can be done?


if by bottom you mean added as the "new last" header than you don't have to
care, afaik email headers do not have a notion of order

e.g

To: (e-mail address removed)
From: (e-mail address removed)

is equal to

From: (e-mail address removed)
To: (e-mail address removed)


if by bottom you mean it's appended to the body...well that is a problem :)

hth
martin

--
http://noneisyours.marcher.name
http://feeds.feedburner.com/NoneIsYours

You are not free to read this message,
by doing so, you have violated my licence
and are required to urinate publicly. Thank you.
 
D

David Erickson

if by bottom you mean added as the "new last" header than you don't have to
care, afaik email headers do not have a notion of order

e.g

To: (e-mail address removed)
From: (e-mail address removed)

is equal to

From: (e-mail address removed)
To: (e-mail address removed)

if by bottom you mean it's appended to the body...well that is a problem :)

hth
martin

Bottom of the headers... but I am looking to insert at the top, and re-
ordering/inserting does matter depending on what type of header you
are, received headers for example must be inserted at the top of the
header list so you can watch the progression of the email. I was
unable to find a clean way to do this via the API which seems very
strange to me.. but perhaps I am just missing something?

Thanks,
-David
 
K

Karlheinz Klingbeil

Bottom of the headers... but I am looking to insert at the top, and re-
ordering/inserting does matter depending on what type of header you
are, received headers for example must be inserted at the top of the
header list so you can watch the progression of the email. I was
unable to find a clean way to do this via the API which seems very
strange to me.. but perhaps I am just missing something?

I think your are really missing something. First, Email-headers are
unordered
and every relay can, and probably will, rearrange them, add or delete
headers.
You therefore most definitely should not add any headers which are
position-dependent.
If you want to track mails somehow, add headers with timestamps.
This way you can watch the progression of an email without being
dependend on "sorted" headerlines.
 
D

David Erickson

I think your are really missing something. First, Email-headers are
unordered
and every relay can, and probably will, rearrange them, add or delete
headers.
You therefore most definitely should not add any headers which are
position-dependent.
If you want to track mails somehow, add headers with timestamps.
This way you can watch the progression of an email without being
dependend on "sorted" headerlines.

This is incorrect, quoting directly from RFC 2822:

It is important to note that the header fields are not guaranteed
to
be in a particular order. They may appear in any order, and they
have been known to be reordered occasionally when transported over
the Internet. However, for the purposes of this standard, header
fields SHOULD NOT be reordered when a message is transported or
transformed. More importantly, the trace header fields and resent
header fields MUST NOT be reordered, and SHOULD be kept in blocks
prepended to the message. See sections 3.6.6 and 3.6.7 for more
information.

Trace header fields are not to be ordered, and should be prepended
when added to a message. Now that said I am not trying to track
anything, I simply want to prepend my additional headers onto the top
of the email, and seem to be unable to do that via the API, which I
think ought to be possible. If for example I was writing some kind of
an SMTP server with Python and needed to add said trace headers they
would need to be prepended, and currently cannot be (without doing it
by hand).

-David
 
K

Karlheinz Klingbeil

It is important to note that the header fields are not guaranteed
to
be in a particular order. They may appear in any order, and they
have been known to be reordered occasionally when transported over
the Internet. However, for the purposes of this standard, header
fields SHOULD NOT be reordered when a message is transported or
transformed. More importantly, the trace header fields and resent
header fields MUST NOT be reordered, and SHOULD be kept in blocks
prepended to the message. See sections 3.6.6 and 3.6.7 for more
information.

Trace header fields are not to be ordered, and should be prepended
when added to a message. Now that said I am not trying to track
anything, I simply want to prepend my additional headers onto the top
of the email, and seem to be unable to do that via the API, which I
think ought to be possible. If for example I was writing some kind of
an SMTP server with Python and needed to add said trace headers they
would need to be prepended, and currently cannot be (without doing it
by hand).

-David
You're right on that point, though it says clearly "It is important to
note that the header fields are not guaranteed to be in a particular
order."

So it's in my opinion a good idea not to expect headers to be ordered and
add headers in a way which doesn't conflict with a *possible* reordering.
 
D

Dennis Lee Bieber

You're right on that point, though it says clearly "It is important to
note that the header fields are not guaranteed to be in a particular
order."

So it's in my opinion a good idea not to expect headers to be ordered and
add headers in a way which doesn't conflict with a *possible* reordering.

And, from what I've seen, the only headers that do show order are
those added in "passing" mail -- something easily done during the
streaming of the message... Add a "received" header, then copy the rest
of the message as-is, with no interpretation of the contents.

I have the impression most of the email libraries for Python are
aimed at the user clients, not transfer utilities.
--
Wulfraed Dennis Lee Bieber KD6MOG
(e-mail address removed) (e-mail address removed)
HTTP://wlfraed.home.netcom.com/
(Bestiaria Support Staff: (e-mail address removed))
HTTP://www.bestiaria.com/
 

Ask a Question

Want to reply to this thread or ask your own question?

You'll need to choose a username for the site, which only take a couple of moments. After that, you can post your question and our members will help you out.

Ask a Question

Members online

No members online now.

Forum statistics

Threads
473,982
Messages
2,570,185
Members
46,736
Latest member
AdolphBig6

Latest Threads

Top