1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /* ***** BEGIN LICENSE BLOCK *****
3 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
4 *
5 * The contents of this file are subject to the Mozilla Public License Version
6 * 1.1 (the "License"); you may not use this file except in compliance with
7 * the License. You may obtain a copy of the License at
8 * http://www.mozilla.org/MPL/
9 *
10 * Software distributed under the License is distributed on an "AS IS" basis,
11 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
12 * for the specific language governing rights and limitations under the
13 * License.
14 *
15 * The Original Code is mozilla.org code.
16 *
17 * The Initial Developer of the Original Code is
18 * Netscape Communications Corporation.
19 * Portions created by the Initial Developer are Copyright (C) 1998
20 * the Initial Developer. All Rights Reserved.
21 *
22 * Contributor(s):
23 *
24 * Alternatively, the contents of this file may be used under the terms of
25 * either of the GNU General Public License Version 2 or later (the "GPL"),
26 * or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
27 * in which case the provisions of the GPL or the LGPL are applicable instead
28 * of those above. If you wish to allow use of your version of this file only
29 * under the terms of either the GPL or the LGPL, and not to allow others to
30 * use your version of this file under the terms of the MPL, indicate your
31 * decision by deleting the provisions above and replace them with the notice
32 * and other provisions required by the GPL or the LGPL. If you do not delete
33 * the provisions above, a recipient may use your version of this file under
34 * the terms of any one of the MPL, the GPL or the LGPL.
35 *
36 * ***** END LICENSE BLOCK ***** */
37
38 /*
39 I've created this interface to contain mailnews mime specific information
40 for stream converters. Most of this code is just stuff that has been moved out
41 of nsIStreamConverter.idl to make it more generic.
42 */
43
44 #include "nsISupports.idl"
45 #include "nsrootidl.idl"
46 #include "nsIMimeHeaders.idl"
47 #include "nsIMsgIdentity.idl"
48
49 interface nsIURI;
50
51 typedef long nsMimeOutputType;
52
53 [scriptable, uuid(fdc2956e-d558-43fb-bfdd-fb9511229aa5)]
54 interface nsMimeOutput
55 {
56 const long nsMimeMessageSplitDisplay = 0;
57 const long nsMimeMessageHeaderDisplay = 1;
58 const long nsMimeMessageBodyDisplay = 2;
59 const long nsMimeMessageQuoting = 3;
60 const long nsMimeMessageBodyQuoting = 4;
61 const long nsMimeMessageRaw = 5;
62 const long nsMimeMessageDraftOrTemplate = 6;
63 const long nsMimeMessageEditorTemplate = 7;
64 const long nsMimeMessagePrintOutput = 9;
65 const long nsMimeMessageSaveAs = 10;
66 const long nsMimeMessageSource = 11;
67 const long nsMimeMessageFilterSniffer = 12;
68 const long nsMimeMessageDecrypt = 13;
69 const long nsMimeMessageAttach = 14;
70 const long nsMimeUnknown = 15;
71 };
72
73 [scriptable, uuid(FA81CAA0-6261-11d3-8311-00805F2A0107)]
74 interface nsIMimeStreamConverterListener : nsISupports{
75 void onHeadersReady(in nsIMimeHeaders headers);
76 };
77
78 [scriptable, uuid(E4ED8892-3F9E-11d3-9896-001083010E9B)]
79 interface nsIMimeStreamConverter : nsISupports {
80
81 /*
82 * This is used to set the desired mime output type on the converer.
83 */
84
85 void SetMimeOutputType(in nsMimeOutputType aType);
86
87 void GetMimeOutputType(out nsMimeOutputType aOutFormat);
88
89 /*
90 * This is needed by libmime for MHTML link processing...the url is the URL string associated
91 * with this input stream
92 */
93 void SetStreamURI(in nsIURI aURI);
94
95 /*
96 * This is used to extract headers while parsing a message
97 */
98 void SetMimeHeadersListener(in nsIMimeStreamConverterListener listener, in nsMimeOutputType aType);
99
100 /*
101 * This is used for forward inline
102 */
103 attribute PRBool forwardInline;
104
105 /*
106 * This is used for OpenDraft, OpenEditorTemplate and Forward inline (which use OpenDraft)
107 */
108 attribute nsIMsgIdentity identity;
109 attribute string originalMsgURI;
110 };