gecko-dev/mailnews/compose/public/nsISmtpService.h

68 lines
3.0 KiB
C++

/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
*
* The contents of this file are subject to the Netscape Public License
* Version 1.0 (the "NPL"); you may not use this file except in
* compliance with the NPL. You may obtain a copy of the NPL at
* http://www.mozilla.org/NPL/
*
* Software distributed under the NPL is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the NPL
* for the specific language governing rights and limitations under the
* NPL.
*
* The Initial Developer of this code under the NPL is Netscape
* Communications Corporation. Portions created by Netscape are
* Copyright (C) 1998 Netscape Communications Corporation. All Rights
* Reserved.
*/
#ifndef nsISmtpService_h___
#define nsISmtpService_h___
#include "nscore.h"
#include "nsISupports.h"
#include "nsFileSpec.h"
/* FBAF0F10-CA9B-11d2-8063-006008128C4E */
#define NS_ISMTPSERVICE_IID \
{ 0xfbaf0f10, 0xca9b, 0x11d2, \
{ 0x80, 0x63, 0x0, 0x60, 0x8, 0x12, 0x8c, 0x4e } }
#define NS_SMTPSERVICE_CID \
{ /* 5B6419F1-CA9B-11d2-8063-006008128C4E */ \
0x5b6419f1, 0xca9b, 0x11d2, \
{0x80, 0x63, 0x0, 0x60, 0x8, 0x12, 0x8c, 0x4e}}
////////////////////////////////////////////////////////////////////////////////////////
// The Smtp Service is an interfaced designed to make building and running mail to urls
// easier. I'm not sure if this service will go away when the new networking model comes
// on line (as part of the N2 project). So I reserve the right to change my mind and take
// this service away =).
////////////////////////////////////////////////////////////////////////////////////////
class nsIURL;
class nsIUrlListener;
class nsISmtpService : public nsISupports
{
public:
static const nsIID& GetIID() { static nsIID iid = NS_ISMTPSERVICE_IID; return iid; }
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// SendMailMessage requires the file name of the message to send, the sender, a comma delimited list of recipients.
// It builds an Smtp url, makes an smtp connection and runs the url. If you want a handle on the running task, pass in
// a valid nsIURL ptr. You can later interrupt this action by asking the netlib service manager to interrupt the url you
// are given back. Remember to release aURL when you are done with it. Pass nsnull in for aURL if you don't care about
// the returned URL.
//
// mscott - until we have a mail session, we need to pass in the host name to use....this will go away when we can
// read it directly from prefs...
// If you don't care about listening to the url, feel free to pass in nsnull for that argument.
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
NS_IMETHOD SendMailMessage(const nsFilePath& aFilePath, const nsString& aRecipients,
nsIUrlListener * aUrlListener, nsIURL ** aURL) = 0;
};
#endif /* nsISmtpService_h___ */