mirror of https://github.com/tongzx/nt5src
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
869 lines
26 KiB
869 lines
26 KiB
// nntpdrv.idl : IDL source for nntpdrv.dll
|
|
//
|
|
|
|
// This file will be processed by the MIDL tool to
|
|
// produce the type library (nntpdrv.tlb) and marshalling code.
|
|
|
|
import "oaidl.idl";
|
|
import "ocidl.idl";
|
|
|
|
//
|
|
// -------------- Interfaces implemented by the Server --------------
|
|
//
|
|
|
|
interface INntpServer;
|
|
interface INNTPPropertyBag;
|
|
interface INewsTreeIterator;
|
|
interface INewsTree;
|
|
interface INntpComplete;
|
|
interface INntpDriver;
|
|
interface INntpDriverSearch;
|
|
interface INntpSearchResults;
|
|
|
|
//
|
|
// Server access request bits
|
|
//
|
|
cpp_quote("#define NNTP_ACCESS_READ 0x0001")
|
|
cpp_quote("#define NNTP_ACCESS_POST 0x0002")
|
|
cpp_quote("#define NNTP_ACCESS_CREATE_SUBFOLDER 0x0004")
|
|
cpp_quote("#define NNTP_ACCESS_REMOVE_SUBFOLDER 0x0008")
|
|
cpp_quote("#define NNTP_ACCESS_REMOVE_FOLDER 0x0010")
|
|
cpp_quote("#define NNTP_ACCESS_REMOVE 0x0020")
|
|
cpp_quote("#define NNTP_ACCESS_EDIT_FOLDER 0x0040")
|
|
cpp_quote("#define NNTP_ACCESS_EDIT 0x0080")
|
|
|
|
//
|
|
// Connect flag bits
|
|
//
|
|
cpp_quote("#define NNTP_CONNECT_UPGRADE 0x0001")
|
|
|
|
//
|
|
// Server mode, driver can inquire about server mode to determine'
|
|
// what he should do during DecorateNewsTree
|
|
//
|
|
cpp_quote("#define NNTP_SERVER_NORMAL 0x0001")
|
|
cpp_quote("#define NNTP_SERVER_STANDARD_REBUILD 0x0002")
|
|
cpp_quote("#define NNTP_SERVER_CLEAN_REBUILD 0x0003")
|
|
|
|
typedef struct
|
|
{
|
|
BYTE cLen;
|
|
BYTE pbStoreId[256];
|
|
} STOREID;
|
|
|
|
typedef DWORD GROUPID;
|
|
|
|
//
|
|
// This interface exposes server functionality
|
|
//
|
|
[
|
|
object,
|
|
uuid(c7bae7b4-dee3-11d1-94cf-00c04fa379f1),
|
|
helpstring("INntpDriver Interface"),
|
|
]
|
|
interface INntpServer : IUnknown {
|
|
|
|
//
|
|
// find the primary groupid/articleid for an article given the secondary
|
|
// groupid/articleid
|
|
//
|
|
// arguments:
|
|
// pgroupSecondary - the property bag for the secondary crosspost
|
|
// artidSecondary - the article ID for the secondary crosspost
|
|
// ppgroupPrimary - gets filled in with the property bag for the primary
|
|
// crosspost. the caller should Release() this when
|
|
// they are done with it.
|
|
// fStorePrimary - if TRUE then return the primary article for the store
|
|
// that owns pgroupSecondary
|
|
// partidPrimary - the article id for the primary crosspost
|
|
//
|
|
// returns (through completion object):
|
|
// S_OK - found primary
|
|
// S_FALSE - the values given were the primary
|
|
// or an error code
|
|
//
|
|
[local]
|
|
void FindPrimaryArticle([in] INNTPPropertyBag *pGroupSecondary,
|
|
[in] DWORD artidSecondary,
|
|
[out] INNTPPropertyBag **ppgroupPrimary,
|
|
[out] DWORD *partidPrimary,
|
|
[in] BOOL fStorePrimary,
|
|
[in] INntpComplete *pCompletion,
|
|
[in] INntpComplete *pProtocolComplete );
|
|
|
|
//
|
|
// Create the entries in the hash tables for a new article.
|
|
//
|
|
[local]
|
|
void CreatePostEntries([in] CHAR *pszMessageId,
|
|
[in] DWORD iHeaderLength,
|
|
[in] STOREID *pStoreId,
|
|
[in] BYTE cGroups,
|
|
[in] INNTPPropertyBag **rgpGroups,
|
|
[in,out] DWORD *rgArticleIds,
|
|
[in] BOOL fAllocArtId,
|
|
[in] INntpComplete *pCompletion);
|
|
|
|
//
|
|
// Create the entries in the hash tables for a new article.
|
|
//
|
|
[local]
|
|
void DeleteArticle([in] CHAR *pszMessageId,
|
|
[in] INntpComplete *pCompletion);
|
|
|
|
//
|
|
// This tells the driver what rebuild mode the server is in
|
|
// The returned value should be NNTP_SERVER_NORMAL, NNTP_SERVER
|
|
// _STANDARD_REBUILD or NNTP_SERVER_CLEAN_REBUILD
|
|
//
|
|
[local]
|
|
DWORD QueryServerMode();
|
|
|
|
//
|
|
// Tells whether should skip empty dir when rebuild
|
|
//
|
|
[local]
|
|
BOOL SkipNonLeafDirWhenRebuild();
|
|
|
|
//
|
|
// Should I continue the rebuild ? Anybody has cancelled the rebuild ?
|
|
//
|
|
[local]
|
|
BOOL ShouldContinueRebuild();
|
|
|
|
//
|
|
// Is this message id in the server ( article table ) ?
|
|
//
|
|
[local]
|
|
BOOL MessageIdExist( CHAR *szMessageId );
|
|
|
|
//
|
|
// Set rebuild last error
|
|
//
|
|
[local]
|
|
void SetRebuildLastError( DWORD err );
|
|
|
|
//
|
|
// Obtain article number for each newsgroups.
|
|
//
|
|
[local]
|
|
void AllocArticleNumber([in] BYTE cGroups,
|
|
[in] INNTPPropertyBag **rgpGroups,
|
|
[in,out] DWORD *rgArticleIds,
|
|
[in] INntpComplete *pCompletion);
|
|
|
|
|
|
//
|
|
// Return whether this is a Slave server, and the pickup dir
|
|
//
|
|
[local]
|
|
BOOL IsSlaveServer( [out] WCHAR* pwszPickupDir,
|
|
[out] LPVOID lpvContext);
|
|
|
|
};
|
|
|
|
//
|
|
// this property bag is used to represent data in the newsgroups
|
|
//
|
|
[
|
|
object,
|
|
uuid(f5ad0d78-af9f-11d1-862e-00c04fb960ea)
|
|
]
|
|
interface INNTPPropertyBag : IUnknown {
|
|
//
|
|
// put a BLOB property into the table. this is also used for string
|
|
// properties
|
|
//
|
|
[local]
|
|
HRESULT PutBLOB(
|
|
[in] DWORD dwID,
|
|
[in] DWORD cbValue,
|
|
[in,size_is(cbValue)] BYTE *pbValue);
|
|
|
|
//
|
|
// get a BLOB property from the table. this is also used for string
|
|
// properties
|
|
//
|
|
[local]
|
|
HRESULT GetBLOB(
|
|
[in] DWORD dwID,
|
|
[in] BYTE *pbValue,
|
|
[in,out] DWORD *pcbValue);
|
|
|
|
//
|
|
// put a dword property into the table
|
|
//
|
|
[local]
|
|
HRESULT PutDWord(
|
|
[in] DWORD dwID,
|
|
[in] DWORD dwValue);
|
|
|
|
//
|
|
// get a dword property from the table
|
|
//
|
|
[local]
|
|
HRESULT GetDWord(
|
|
[in] DWORD dwID,
|
|
[out] DWORD *pdwValue);
|
|
|
|
//
|
|
// put an interface pointer into the table
|
|
//
|
|
// interfaces can only be used with properties that are runtime only.
|
|
//
|
|
[local]
|
|
HRESULT PutInterface(
|
|
[in] DWORD dwID,
|
|
[in] IUnknown *punkValue);
|
|
|
|
//
|
|
// get an interface pointer from the table
|
|
//
|
|
[local]
|
|
HRESULT GetInterface(
|
|
[in] DWORD dwID,
|
|
[out] IUnknown **ppunkValue);
|
|
|
|
//
|
|
// put a bool to the table
|
|
//
|
|
[local]
|
|
HRESULT PutBool(
|
|
DWORD dwID,
|
|
BOOL fValue );
|
|
|
|
//
|
|
// get a bool from the table
|
|
//
|
|
HRESULT GetBool(
|
|
DWORD dwID,
|
|
BOOL *pfValue);
|
|
|
|
|
|
//
|
|
// remove a property from the property bag
|
|
//
|
|
[local]
|
|
HRESULT RemoveProperty(
|
|
[in] DWORD dwID);
|
|
};
|
|
|
|
[
|
|
object,
|
|
uuid(53f10148-afa8-11d1-862e-00c04fb960ea)
|
|
]
|
|
interface INewsTreeIterator : IUnknown {
|
|
//
|
|
// are we at the front or back of the list? returns S_OK if we are
|
|
// at the beginning or end, and S_FALSE otherwise.
|
|
//
|
|
[local]
|
|
BOOL IsBegin();
|
|
[local]
|
|
BOOL IsEnd();
|
|
|
|
//
|
|
// go to the next or previousgroup
|
|
//
|
|
[local]
|
|
void Next();
|
|
[local]
|
|
void Prev();
|
|
|
|
//
|
|
// get this group
|
|
//
|
|
[local]
|
|
HRESULT Current(
|
|
[out] INNTPPropertyBag **ppGroup,
|
|
INntpComplete *pProtocolComplete
|
|
);
|
|
};
|
|
|
|
[
|
|
object,
|
|
uuid(9d2de8dc-afc4-11d1-862e-00c04fb960ea)
|
|
]
|
|
interface INewsTree : IUnknown {
|
|
//
|
|
// given a group ID find the matching group
|
|
//
|
|
[local]
|
|
HRESULT FindGroupByID(
|
|
[in] DWORD dwGroupID,
|
|
[out] INNTPPropertyBag **ppNewsgroupProps,
|
|
[in] INntpComplete *pProtocolComplete
|
|
);
|
|
|
|
//
|
|
// given a group name find the matching group. if the group doesn't
|
|
// exist and fCreateIfNotExist is set then a new group will be created.
|
|
// the new group won't be available until CommitGroup() is called.
|
|
// if the group is Release'd before CommitGroup was called then it
|
|
// won't be added.
|
|
//
|
|
[local]
|
|
HRESULT FindOrCreateGroupByName(
|
|
[in] LPSTR pszGroupName,
|
|
[in] BOOL fCreateIfNotExist,
|
|
[out] INNTPPropertyBag **ppNewsgroupProps,
|
|
[in] INntpComplete *pProtocolComplete,
|
|
[in] GROUPID groupid,
|
|
[in] BOOL fSetGroupId
|
|
);
|
|
|
|
//
|
|
// add a new group to the newstree
|
|
//
|
|
[local]
|
|
HRESULT CommitGroup(
|
|
[in] INNTPPropertyBag *pNewsgroupProps
|
|
);
|
|
|
|
//
|
|
// remove an entry
|
|
//
|
|
[local]
|
|
HRESULT RemoveGroupByID(
|
|
[in] DWORD dwGroupID);
|
|
[local]
|
|
HRESULT RemoveGroupByName(
|
|
[in] LPSTR pszGroupName,
|
|
[in] LPVOID lpContext);
|
|
|
|
|
|
//
|
|
// enumerate across the list of keys.
|
|
//
|
|
[local]
|
|
HRESULT GetIterator(
|
|
[out] INewsTreeIterator **punkIterator
|
|
// BUGBUG -- need to add filtering options
|
|
);
|
|
|
|
//
|
|
// this function will be used by drivers to make sure that they
|
|
// are adding newsgroups that they properly own.
|
|
//
|
|
HRESULT LookupVRoot([in] LPSTR pszGroup,
|
|
[out] INntpDriver **ppDriver);
|
|
|
|
|
|
//
|
|
// Get a pointer to the owning server object
|
|
//
|
|
[local]
|
|
HRESULT GetNntpServer(
|
|
[out] INntpServer **ppNntpServer
|
|
);
|
|
};
|
|
|
|
//
|
|
// IIS side completion object interface
|
|
//
|
|
[
|
|
object,
|
|
uuid(5EFC52FC-EADF-11d1-9212-00C04FA322A5),
|
|
helpstring("INntpComplete Interface"),
|
|
]
|
|
interface INntpComplete : IUnknown
|
|
{
|
|
// This is the base interface for all IIS side completion
|
|
// objects. The base interface has only one interface
|
|
// method: SetResult. This method may be overwritten by
|
|
// derived class methods to carry out different implementation
|
|
// for different completions.
|
|
[local] void
|
|
SetResult( [in] HRESULT hr );
|
|
|
|
[local] void
|
|
ReleaseBag( INNTPPropertyBag *pPropBag );
|
|
};
|
|
|
|
//
|
|
// -------------- Interfaces implemented by the Driver --------------
|
|
//
|
|
|
|
//
|
|
// Driver implementaion interface that implements actual
|
|
// driver functionality.
|
|
// Returned by INntpDriverPrepare after successfully connected
|
|
// to Exchange store.
|
|
//
|
|
[
|
|
object,
|
|
uuid(ADD1050F-99C5-11D1-9128-00C04FC30A64),
|
|
helpstring("INntpDriver Interface"),
|
|
]
|
|
interface INntpDriver : IUnknown
|
|
{
|
|
typedef DWORD ARTICLEID;
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
|
// ***** initialize, terminate, config methods:
|
|
///////////////////////////////////////////////////////////////////////////
|
|
|
|
// Purpose:
|
|
// Initialize the driver
|
|
// Parameters:
|
|
// pszVRootPath - virtual root path this driver interface maps to
|
|
// ie. Nntpsvc/1/root/alt
|
|
// pLookup - a pointer to the server's ILookup interface
|
|
// pNewsTree - a pointer to the server's INewsTree interface
|
|
// pdwNDS - Return status of current NNTP driver after Initialize()
|
|
// Comments:
|
|
// o Register change notification (ie directory pickup)
|
|
// o Initialize Epoxy (once per Exchange store type)
|
|
// o Detect if the other side of NNTP DLL is running (Exchange only)
|
|
// o Initialize other global objects/interfaces (such as IMAIL, Async lib, etc)
|
|
// o strVRootPath to obtain directory path (FS) or store name (Exchange) from VRoot
|
|
// o Ilookup and InewsTree services are for notification operations on the store
|
|
// as well as expiration.
|
|
// o From metabase retrieve expiration policy
|
|
// o Setup expiration
|
|
// o WHAT OTHER PARAMETERS NEEDED/TASKS PERFORMED HERE - POSSIBLY:
|
|
// o May setup metabase change notification to pickup expiration policy changes
|
|
[local] HRESULT
|
|
Initialize( [in] LPCWSTR pszVRootPath,
|
|
[in] LPCSTR pszGroupPrefix,
|
|
[in] IUnknown *punkMetabase,
|
|
[in] INntpServer *pServer,
|
|
[in] INewsTree *pINewsTree,
|
|
[in] LPVOID lpvContext,
|
|
[out] DWORD *pdwNDS,
|
|
[in] HANDLE hToken );
|
|
|
|
// Purpose:
|
|
// Detach the driver from protocol and cleanup
|
|
// Parameters:
|
|
// None
|
|
// Comments:
|
|
// o Un-register change notification.
|
|
// o Un-initialize Epoxy, if last driver interface pointer to Terminate()
|
|
// o Terminate expiration
|
|
// o Other tasks?
|
|
HRESULT
|
|
Terminate( [out] DWORD *pdwNDS );
|
|
|
|
// Purpose:
|
|
// Get the status of current NNTP driver
|
|
// Parameters:
|
|
// pdwNDS - NNTP_DRIVER_STATUS code
|
|
// Comments:
|
|
// o Used to get status of current NNTP driver, include:
|
|
// STORE_UP, STORE_DOWN, EPOXY_ERROR, etc
|
|
HRESULT
|
|
GetDriverStatus( [out] DWORD *pdwNDS );
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
|
// ***** store change notification process method
|
|
///////////////////////////////////////////////////////////////////////////
|
|
|
|
// Purpose:
|
|
// Handle change notification from the store
|
|
// Parameters:
|
|
// punkSOCChangeList - List of changes originated from store
|
|
// Comment
|
|
// o Serve as change notification process function dispatcher
|
|
// o Owns a list of changes coming from the store
|
|
HRESULT
|
|
StoreChangeNotify( [in] IUnknown *punkSOCChangeList );
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
|
// ***** article posting methods:
|
|
///////////////////////////////////////////////////////////////////////////
|
|
|
|
// Purpose:
|
|
// Commit the post
|
|
// Parameters:
|
|
// See separate spec from awetmore
|
|
// Returned error code from completion object:
|
|
// S_OK - Success
|
|
// HRESULT_FROM_WIN32( ERROR_FILE_NOT_FOUND ) - Group Access Check Failed because file ( directory ) doesn't exist
|
|
// HRESULT_FROM_WIN32( ERROR_PATH_NOT_FOUND ) - Group doesn't physically exist ( during CreateFile )
|
|
// HRESULT_FROM_WIN32( ERROR_FILE_EXISTS) - The article with the same article id physically exists ( during CreateFile )
|
|
// HRESULT_FROM_WIN32( ERROR_ACCESS_DENIED ) - Access Denied
|
|
// Other - Other fatal errors that might cause UnsafeClose();
|
|
// Note:
|
|
// This also applies to AllocMessage. Since we have no access to IMailMsg
|
|
// IDL file, it's doc'd here
|
|
[local] void
|
|
CommitPost( [in] IUnknown *punkMessage, // IMsg pointer
|
|
[in] STOREID *pStoreId,
|
|
[in] STOREID *rgOtherStoreIDs,
|
|
[in] HANDLE hToken,
|
|
[in] INntpComplete *pICompletion,
|
|
[in] BOOL fAnonymous );
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
|
// ***** article retrieval, delete methods (ARTICLE, BODY, HEAD, etc):
|
|
///////////////////////////////////////////////////////////////////////////
|
|
|
|
// Purpose:
|
|
// Gets an article from the store
|
|
// Parameters:
|
|
// pNewsGroup - The INewsGroup where article is posted to
|
|
// artId - Article ID for this article
|
|
// StoreId - STOREID for this article
|
|
// It contains FID/MID for Exchange store, but nothing for FS.
|
|
// hFile - File handle for the article
|
|
// Comment:
|
|
// o FS uses pNewsGroup and artId to retrieve articles, no need for StoreId
|
|
// o Exchange needs StoreId to give a pair of FID/MID
|
|
// o If no FID/MID is found, get group properties from pNewsGroup and try
|
|
// to retrieve article by article number.
|
|
// o Return an hFile - NEED TO COMEUP WITH AN ASYNC MODEL.
|
|
// Return value from completion object:
|
|
// o S_OK - Succeeded
|
|
// o HRESULT_FROM_WIN32( ERROR_FILE_NOT_FOUND ) - Article doesn't exist
|
|
// o HRESULT_FROM_WIN32( ERROR_PATH_NOT_FOUND ) - Group doesn't exist
|
|
// o E_ACCESSDENIED - Access denied
|
|
// o OTHER: Fatal server error
|
|
[local] void
|
|
GetArticle( [in] INNTPPropertyBag *pPrimaryGroup,
|
|
[in] INNTPPropertyBag *pCurrentGroup,
|
|
[in] ARTICLEID PrimaryArtId,
|
|
[in] ARTICLEID CurrentArtId,
|
|
[in] STOREID StoreId,
|
|
[in] HANDLE hToken,
|
|
[out] void **pvFileHandleContext,
|
|
[in] INntpComplete *pICompletion,
|
|
[in] BOOL fAnonymous );
|
|
|
|
// Purpose:
|
|
// This is called when the protocol needs to cancel an article
|
|
// Parameters:
|
|
// pGroupBag - Group property bag
|
|
// cArticles - Number of articles to delete
|
|
// rgidArt - Array of article id's to delete ( used by exdriver )
|
|
// rgidStore - Array of store id's to delete ( used by fsdriver )
|
|
// hToken - Client's access token
|
|
// piFailed - To return the index into article array of the first
|
|
// failed article
|
|
// pICompletion - Completion object
|
|
// Return value in completion object:
|
|
// S_OK - Succeeded
|
|
// S_FASLE - Succeeded but protocol has asked to delete too many
|
|
// but the driver can not take them all, see pdwLastSuccess
|
|
// for the last successfully deleted article
|
|
// NNTP_E_PARTIAL_COMPLETE - No error, but not all messages are deleted
|
|
// deletion partly failed in store
|
|
// Otherwise, Failed
|
|
[local] void
|
|
DeleteArticle( [in] INNTPPropertyBag *pGroupBag,
|
|
[in] DWORD cArticles,
|
|
[in] ARTICLEID rgidArt[],
|
|
[in] STOREID rgidStore[],
|
|
[in] HANDLE hToken,
|
|
[out] DWORD *pdwLastSuccess,
|
|
[in] INntpComplete *pICompletion,
|
|
[in] BOOL fAnonymous );
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
|
// ***** XOVER, XHDR retrieval methods:
|
|
///////////////////////////////////////////////////////////////////////////
|
|
|
|
// Purpose:
|
|
// Gets the XOVER information for a range of articles
|
|
// Parameters:
|
|
// pNewsGroup - The NewsGroup object to get XOVER data from
|
|
// idMinArticle - the first article to get information for
|
|
// idMaxArticle - the last article to get information for
|
|
// idNextArticle - The next article id that you should start from, if you
|
|
// want
|
|
// pszHeader - contains a string of header to be retrieved.
|
|
// ie. "Subject", "From", For Xover, may use "@Xover", where
|
|
// any string started with "@" is special.
|
|
// pBuffer - where to put the information (ISSUE: what type is this?
|
|
// stream or char *)
|
|
// cbin - size of pBuffer
|
|
// cbout - total count bytes of returned XOVER data
|
|
// Return value from completion object:
|
|
// S_OK - Succeeded perfectly
|
|
// S_FALSE - Succeeded, but:
|
|
// 1. If *idNextArticle > idMaxArticle - no article found
|
|
// 2. If *idNextArticle <= idMaxArticle - Buffer too small,
|
|
// though some entries have been filled
|
|
// HRESULT_FROM_WIN32( ERROR_INSUFFICIENT_BUFFER )
|
|
// - Buffer too small, even first article can not be filled
|
|
// Other - Other fatal error
|
|
[local] void
|
|
GetXover( [in] INNTPPropertyBag *pGroupPropBag,
|
|
[in] ARTICLEID idMinArticle,
|
|
[in] ARTICLEID idMaxArticle,
|
|
[out] ARTICLEID *idNextArticle,
|
|
[out] CHAR* pBuffer,
|
|
[in] DWORD cbin,
|
|
[out] DWORD *cbout,
|
|
[in] HANDLE hToken,
|
|
[in] INntpComplete *pICompletion,
|
|
[in] BOOL fAnonymous );
|
|
|
|
[local] HRESULT
|
|
GetXoverCacheDirectory(
|
|
[in] INNTPPropertyBag* pGroupPropBag,
|
|
[out] CHAR* pBuffer,
|
|
[in] DWORD cbIn,
|
|
[out] DWORD *pcbOut,
|
|
[out] BOOL* fFlatDir
|
|
) ;
|
|
|
|
// Get XHdr information from the driver - similar to GetXover
|
|
[local] void
|
|
GetXhdr( [in] INNTPPropertyBag *pGroupPropBag,
|
|
[in] ARTICLEID idMinArticle,
|
|
[in] ARTICLEID idMaxArticle,
|
|
[out] ARTICLEID *idNextArticle,
|
|
[in] CHAR* pszHeader,
|
|
[out] CHAR* pBuffer,
|
|
[in] DWORD cbin,
|
|
[out] DWORD *cbOut,
|
|
[in] HANDLE hToken,
|
|
[in] INntpComplete *pICompletion,
|
|
[in] BOOL fAnonymous );
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
|
// ***** Store rebuild related methods:
|
|
///////////////////////////////////////////////////////////////////////////
|
|
|
|
// Purpose:
|
|
// Rebuild a news group: pick up every message, parse out its groups/
|
|
// articleid's and use INntpServer's post interface to insert xover/
|
|
// article entries. It updates group properties such as article counts,
|
|
// high/low watermarks too
|
|
[local] void
|
|
RebuildGroup( [in] INNTPPropertyBag *pPropBag,
|
|
[in] HANDLE hToken,
|
|
[in] INntpComplete *pIComplete );
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
|
// ***** Newsgroup manipulation methods:
|
|
///////////////////////////////////////////////////////////////////////////
|
|
|
|
// Purpose:
|
|
// Get properties from a group.
|
|
// Parameters:
|
|
// pNewsGroup - Property bag for the news group object
|
|
// cProperties - Number of properties to get
|
|
// rgidProperties - Array of properties to get
|
|
[local] void
|
|
DecorateNewsGroupObject( [in] INNTPPropertyBag *pNewsGroup,
|
|
[in] DWORD cProperties,
|
|
[in] DWORD *rgidProperties,
|
|
[in] INntpComplete *pICompletion );
|
|
|
|
// Purpose:
|
|
// Check if client has desired access to this group
|
|
// Parameters:
|
|
// pNewsGroup - Property bag to the news group
|
|
// hToken - The client's access token
|
|
// dwDesiredAccess - Access rights that the client desires
|
|
// pICompletion - Pointer to completion object
|
|
// Return value from completion object:
|
|
// S_OK - Client has access
|
|
// E_ACCESSDENIED - Access denied
|
|
[local] void
|
|
CheckGroupAccess( [in] INNTPPropertyBag *pNewsGroup,
|
|
[in] HANDLE hToken,
|
|
[in] DWORD dwDesiredAccess,
|
|
[in] INntpComplete *pICompletion );
|
|
|
|
// Purpose:
|
|
// Set Newsgroup properties into store
|
|
// Parameters:
|
|
// pNewsGroup - The news group property bag
|
|
// cProperties - Number of properties to set
|
|
// rgidProperties - Array of properties to set
|
|
// pICompletion - Completion object
|
|
// Return values:
|
|
[local] void
|
|
SetGroupProperties( [in] INNTPPropertyBag *pNewsGroup,
|
|
[in] DWORD cProperties,
|
|
[in] DWORD *rgidProperties,
|
|
[in] HANDLE hToken,
|
|
[in] INntpComplete *pICompletion,
|
|
[in] BOOL fAnonymous );
|
|
|
|
// Purpose:
|
|
// Decorate entire INewsTree object by going to the store and get
|
|
// all the necessary properties.
|
|
// Parameters:
|
|
// punkNewsTree - INewsTree to be decorated
|
|
// hToken - hToken for the user
|
|
// dwSessionKey - TCP session key
|
|
// lpvCompletionObj - Completion object in protocol to handle completion
|
|
// pdwNDS - NNTP driver status
|
|
[local] void
|
|
DecorateNewsTreeObject( [in] HANDLE hToken,
|
|
[in] INntpComplete *pICompletion );
|
|
|
|
// Purpose:
|
|
// Create a new group in the store (newgroup)
|
|
// Parameters:
|
|
// pszGroupName - the group to create
|
|
// Comment:
|
|
// o Lookup virtual root to construct full path name using pszGroupName
|
|
// o Create the directory structure with full path name
|
|
[local] void
|
|
CreateGroup( [in] INNTPPropertyBag* pGroupBag,
|
|
[in] HANDLE hToken,
|
|
[in] INntpComplete* pICompletion,
|
|
[in] BOOL fAnonymous );
|
|
|
|
// Purpose:
|
|
// Remove a group from the store (rmgroup). This should include a file
|
|
// scan operation in the store to delete all articles within the group.
|
|
// This may be done the same way as MCIS 2.0, when article cleanup is
|
|
// handled by expiration thread. Groups to be removed is queued up.
|
|
// Parameters:
|
|
// pNewsGroup - Newsgroup to be removed.
|
|
[local] void
|
|
RemoveGroup( [in] INNTPPropertyBag *pGroupBag,
|
|
[in] HANDLE hToken,
|
|
[in] INntpComplete *pICompletion,
|
|
[in] BOOL fAnonymous );
|
|
|
|
};
|
|
|
|
//
|
|
// Driver interface to establish connection to Exchange store
|
|
//
|
|
[
|
|
object,
|
|
uuid(D61569A0-D3F9-11d1-A58C-00C04FA375BA),
|
|
helpstring("INntpDriverPrepare Interface"),
|
|
]
|
|
interface INntpDriverPrepare : IUnknown
|
|
{
|
|
// Purpose:
|
|
// Initialize driver specific data structure, ie Epoxy connection, etc.
|
|
// Parameters:
|
|
// pszVRootPath - virtual root path this driver interface maps to
|
|
// ie. Nntpsvc/1/root/alt
|
|
// pLookup - a pointer to the server's ILookup interface
|
|
// pNewsTree - a pointer to the server's INewsTree interface
|
|
// pCompletion - a pointer to the server's ICompletion interface
|
|
// Comments:
|
|
// o This function is async and returns to the caller without blocking.
|
|
// o A seperate thread is spawned out to do any blocking operations.
|
|
[local] void
|
|
Connect( [in] LPCWSTR pszVRootPath,
|
|
[in] LPCSTR pszGroupPrefix,
|
|
[in] IUnknown *punkMetabase,
|
|
[in] INntpServer* pIServer,
|
|
[in] INewsTree* pINewsTree,
|
|
[out] INntpDriver** ppIGoodDriver,
|
|
[in] INntpComplete* pICompletion,
|
|
[in] HANDLE hToken,
|
|
[in] DWORD dwFlag );
|
|
|
|
// Purpose:
|
|
// Cancel the pending Connect request
|
|
// Parameters:
|
|
// None
|
|
// Comments:
|
|
// o Cancel any outstanding connection requests
|
|
// o Other tasks?
|
|
[local] HRESULT
|
|
CancelConnect();
|
|
|
|
};
|
|
|
|
[
|
|
object,
|
|
uuid(9E2D8DE8-6926-11d2-9F03-00C04F8EF2F1),
|
|
helpstring("INntpDriverSearch Interface")
|
|
]
|
|
interface INntpDriverSearch : IUnknown
|
|
{
|
|
|
|
[local]
|
|
void MakeSearchQuery (
|
|
[in] CHAR *pszSearchString,
|
|
[in] INNTPPropertyBag *pGroupBag,
|
|
[in] BOOL bDeepQuery,
|
|
[in] WCHAR *pwszColumns,
|
|
[in] WCHAR *pwszSortOrder,
|
|
[in] LCID LocaleID,
|
|
[in] DWORD cMaxRows,
|
|
[in] HANDLE hToken,
|
|
[in] BOOL fAnonymous,
|
|
[in] INntpComplete *pICompletion,
|
|
[out] INntpSearchResults **pINntpSearch,
|
|
[in] LPVOID lpvContext);
|
|
|
|
[local]
|
|
void MakeXpatQuery (
|
|
[in] CHAR *pszSearchString,
|
|
[in] INNTPPropertyBag *pGroupBag,
|
|
[in] BOOL bDeepQuery,
|
|
[in] WCHAR *pwszColumns,
|
|
[in] WCHAR *pwszSortOrder,
|
|
[in] LCID LocaleID,
|
|
[in] DWORD cMaxRows,
|
|
[in] HANDLE hToken,
|
|
[in] BOOL fAnonymous,
|
|
[in] INntpComplete *pICompletion,
|
|
[out] INntpSearchResults **pINntpSearch,
|
|
[out] DWORD *pLowArticleID,
|
|
[out] DWORD *pHighArticleID,
|
|
[in] LPVOID lpvContext);
|
|
|
|
[local]
|
|
BOOL UsesSameSearchDatabase(
|
|
[in] INntpDriverSearch *pDriver,
|
|
[in] LPVOID lpvContext
|
|
);
|
|
|
|
[local]
|
|
void GetDriverInfo(
|
|
[out] GUID *pDriverGUID,
|
|
[out] void **ppvDriverInfo,
|
|
[in] LPVOID lpvContext
|
|
);
|
|
};
|
|
|
|
[
|
|
object,
|
|
uuid(b72a754e-746c-11d2-9f04-00c04f8ef2f1),
|
|
helpstring("INntpSearch Interface")
|
|
]
|
|
interface INntpSearchResults : IUnknown
|
|
{
|
|
|
|
|
|
[local]
|
|
void GetResults (
|
|
[in,out] DWORD *pcResults,
|
|
[out] BOOL *pfMore,
|
|
[out] WCHAR **pGroupName,
|
|
[out] DWORD *pdwArticleID,
|
|
[in] INntpComplete *pICompletion,
|
|
[in] HANDLE hToken,
|
|
[in] BOOL fAnonymous,
|
|
[in] LPVOID lpvContext);
|
|
};
|
|
|
|
[
|
|
uuid(ADD104FE-99C5-11D1-9128-00C04FC30A64),
|
|
version(1.0),
|
|
helpstring("inntpdrv 1.0 Type Library")
|
|
]
|
|
library INNTPDRVLib
|
|
{
|
|
importlib("stdole2.tlb");
|
|
|
|
|
|
[
|
|
uuid(ADD10510-99C5-11D1-9128-00C04FC30A64),
|
|
helpstring("NntpDriverPrepare Class")
|
|
]
|
|
coclass NntpDriverPrepare
|
|
{
|
|
[default] interface INntpDriverPrepare;
|
|
};
|
|
|
|
};
|