[
Home
]
[ Index:
by date
|
by threads
]
[ Message by date: previous | next ] [ Message in thread: previous | next ] [ Thread: previous | next ]
[ Message by date: previous | next ] [ Message in thread: previous | next ] [ Thread: previous | next ]
| Date: | -- (:) |
| From: | Gerd Stolpmann <info@g...> |
| Subject: | Re: [Caml-list] Netmime: splitting email attachments |
Am Die, 2004-01-20 um 14.12 schrieb Johann Spies:
> I have asked a similar question on ocaml_beginners, but did not get
> any reaction.
>
> I want to split attachments containing messages I want to feed to
> SA-learn into different files. I have spent hours now to try and
> understand the documentation of netmime and family of classes/modules.
> I would appreciate some help please. Fortunately I saw one or two
> examples in the documentation which helped me so far.
>
> I have come so far:
>
> # let readmessage f = Netmime.read_mime_message (new Netstream.input_stream (new Netchannels.input_channel (open_in f)));;
> val readmessage : string -> Netmime.complex_mime_message = <fun>
> # let ss = readmessage "/tmp/aa" ;;
> val ss : Netmime.complex_mime_message =
> (<obj>,
> `Parts
> [(<obj>, `Body <obj>); (<obj>, `Body <obj>); (<obj>, `Body <obj>);
> (<obj>, `Body <obj>); (<obj>, `Body <obj>)])
> # let a,b = ss;;
> val a : Netmime.mime_header = <obj>
> val b : Netmime.complex_mime_body =
> `Parts
> [(<obj>, `Body <obj>); (<obj>, `Body <obj>); (<obj>, `Body <obj>);
> (<obj>, `Body <obj>); (<obj>, `Body <obj>)]
>
> What I want to do is to save each of the "Parts" in "b" in a seperate
> file. But I don't know how to proceed to get the contents of the
> list. In other words how do I get the tuples in "b" as strings?
The core of a solution for your problem:
let parts =
match b with `Parts l -> l | _ -> failwith "No attachments found";;
List.iter
(function
(head, `Body body) ->
let ch_rd = body # open_value_rd() in
let ch_wr = new Netchannels.output_channel (open_out "filename") in
ch_wr # output_channel ch_rd;
ch_wr # close_out();
ch_rd # close_in();
| _ ->
(* Nested multipart message *)
()
)
parts
It is assumed that you are only interested in the bodies of the parts,
and not in the headers (otherwise one would use write_mime_message to
create the files). Of course, there is still the problem how to get the
filenames, which is a constant here.
Last but not least, there is the phenomenon of nested multipart
messages. By default, read_mime_message performs a deep analysis of the
message, and returns nested parts as nested values. You can change that
with the argument ~multipart_style:`Flat, which leaves inner multipart
parts unparsed.
Hope this helps,
Gerd
--
------------------------------------------------------------
Gerd Stolpmann * Viktoriastr. 45 * 64293 Darmstadt * Germany
gerd@gerd-stolpmann.de http://www.gerd-stolpmann.de
------------------------------------------------------------
-------------------
To unsubscribe, mail caml-list-request@inria.fr Archives: http://caml.inria.fr
Bug reports: http://caml.inria.fr/bin/caml-bugs FAQ: http://caml.inria.fr/FAQ/
Beginner's list: http://groups.yahoo.com/group/ocaml_beginners