mailnews/compose/public/nsIMsgComposeSecure.idl
author Joshua Cranmer <Pidgeot18@gmail.com>
Sun, 03 Mar 2013 16:46:26 -0600
changeset 14312 3044a67220c7cc9927cc1aed9096854495756472
parent 13421 1122b90aa47999efea1c682595c76c07503f866a
child 28469 12a18e736fca9a9ac8e0866caf470fa9342af842
permissions -rw-r--r--
Followup to bug 846524 to fix --enable-extensions on comm-central, rs=Callek.

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
 *
 * This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

#include "nsIMsgSendReport.idl"
#include "nsISupports.idl"

interface nsIMsgCompFields;
interface nsIMsgIdentity;
interface nsIOutputStream;

/* Security interface */
[scriptable, uuid(245f2adc-410e-4bdb-91e2-a7bb42d61787)]
interface nsIMsgComposeSecure : nsISupports 
{
    // requiresCryptoEncapsulation --> returns true if the current message send requires us to go through
	// some encryption work. In the case of false, you can disregard the compose secure object.
    boolean requiresCryptoEncapsulation(in nsIMsgIdentity aIdentity, in nsIMsgCompFields aCompFields);

    void beginCryptoEncapsulation(in nsIOutputStream aStream, in string aRecipients, in nsIMsgCompFields aCompFields, in nsIMsgIdentity aIdentity, in nsIMsgSendReport sendReport, in boolean aIsDraft);
    void finishCryptoEncapsulation(in boolean aAbort, in nsIMsgSendReport sendReport);
    void mimeCryptoWriteBlock(in string aBuf, in long aLen);
};