2020-09-30 16:53:55 +02:00

388 lines
12 KiB
C++

/*++
Copyright (c) 1995 Microsoft Corporation
Module Name:
exports.cpp
Abstract:
Provides APIs to enter and remove license certificates from the system.
The clientele consists of LICCPA.CPL (the licensing control panel applet)
and LLSMGR.EXE (License Manager), and it may also be used directly by setup
programs.
Author:
Jeff Parham (jeffparh) 13-Dec-1995
Revision History:
--*/
#include "stdafx.h"
#include "ccfapi.h"
#ifdef OBSOLETE
#include "paper.h"
#endif // OBSOLETE
#include "nlicdlg.h"
///////////////////////////////////////////////////////////////////////////////
// CCF API //
///////////////
DWORD APIENTRY CCFCertificateEnterUI( HWND hWndParent, LPCSTR pszServerName, LPCSTR pszProductName, LPCSTR pszVendor, DWORD dwFlags, LPCSTR pszSourceToUse )
/*++
Routine Description:
Display a dialog allowing the user to enter a license certificate
into the system.
Arguments:
hWndParent (HWND)
HWND to the client's main window, for use as the parent window to any
opened dialogs. May be NULL.
pszServerName (LPCSTR)
Name of the server for which licenses are to be installed. Note that
this may not be the same as the server on which licenses are actually
installed, as, for example, per seat licenses are always installed on
the enterprise server. A NULL value indicates the local server.
pszProductName (LPCSTR)
Product for which licenses are to be installed. A NULL value indicates
that the user should be allowed to choose.
pszVendor (LPCSTR)
Name of the vendor of the product. This value should be NULL if
pszProductName is NULL, and should be non-NULL if pszProductName is
non-NULL.
dwFlags (DWORD)
A bitfield containing one or more of the following:
CCF_ENTER_FLAG_PER_SEAT_ONLY
Allow the user to enter only per seat licenses. Not valid in
combination with CCF_ENTER_FLAG_PER_SERVER_ONLY.
CCF_ENTER_FLAG_PER_SERVER_ONLY
Allow the user to enter only per server licenses. Not valid in
combination with CCF_ENTER_FLAG_PER_SEAT_ONLY.
pszSourceToUse (LPCSTR)
Name of the secure certificate source to use to install the certificate,
e.g., "Paper". A NULL value indicates that the user should be allowed
to choose.
Return Value:
ERROR_SUCCESS (A certificate was successfully entered into the system.)
ERROR_CANCELLED (The user cancelled without installing a certificate.)
other Win error
--*/
{
AFX_MANAGE_STATE( AfxGetStaticModuleState() );
DWORD dwError;
dwError = theApp.CertificateEnter( hWndParent, pszServerName, pszProductName, pszVendor, dwFlags, pszSourceToUse );
return dwError;
}
//////////////////////////////////////////////////////////////////////////////
DWORD APIENTRY CCFCertificateRemoveUI( HWND hWndParent, LPCSTR pszServerName, LPCSTR pszProductName, LPCSTR pszVendor, DWORD dwFlags, LPCSTR pszSourceToUse )
/*++
Routine Description:
Display a dialog allowing the user to remove one or more license
certificates from the system.
Arguments:
hWndParent (HWND)
HWND to the client's main window, for use as the parent window to any
opened dialogs. May be NULL.
pszServerName (LPCSTR)
Name of the server on which licenses are to be removed. A NULL value
indicates the local server.
pszProductName (LPCSTR)
Product for which licenses are to be removed. A NULL value indicates
that the user should be allowed to remove licenses from any product.
pszVendor (LPCSTR)
Name of the vendor of the product. This value should be NULL if
pszProductName is NULL, and should be non-NULL if pszProductName is
non-NULL.
dwFlags (DWORD)
Certificate removal options. As of this writing, no flags are
supported.
pszSourceToUse (LPCSTR)
Name of the secure certificate source by which licenses are to be
removed, e.g., "Paper". A NULL value indicates that the user should
be allowed to remove licenses that were installed with any source.
Return Value:
ERROR_SUCCESS
Win error
--*/
{
AFX_MANAGE_STATE( AfxGetStaticModuleState() );
DWORD dwError;
dwError = theApp.CertificateRemove( hWndParent, pszServerName, pszProductName, pszVendor, dwFlags, pszSourceToUse );
return dwError;
}
///////////////////////////////////////////////////////////////////////////////
// Certificate Source -- No Certificate //
////////////////////////////////////////////
DWORD APIENTRY NoCertificateEnter( HWND hWnd,
LPCSTR pszServerName,
LPCSTR pszProductName,
LPCSTR pszVendor,
DWORD dwFlags )
/*++
Routine Description:
Display a dialog allowing the user to enter a license certificate
into the system with no certificate (3.51-style).
Arguments:
hWndParent (HWND)
HWND to the client's main window, for use as the parent window to any
opened dialogs. May be NULL.
pszServerName (LPCSTR)
Name of the server for which licenses are to be installed. Note that
this may not be the same as the server on which licenses are actually
installed, as, for example, per seat licenses are always installed on
the enterprise server. A NULL value indicates the local server.
pszProductName (LPCSTR)
Product for which licenses are to be installed. A NULL value indicates
that the user should be allowed to choose.
pszVendor (LPCSTR)
Name of the vendor of the product. This value should be NULL if
pszProductName is NULL, and should be non-NULL if pszProductName is
non-NULL.
dwFlags (DWORD)
A bitfield containing one or more of the following:
CCF_ENTER_FLAG_PER_SEAT_ONLY
Allow the user to enter only per seat licenses. Not valid in
combination with CCF_ENTER_FLAG_PER_SERVER_ONLY.
CCF_ENTER_FLAG_PER_SERVER_ONLY
Allow the user to enter only per server licenses. Not valid in
combination with CCF_ENTER_FLAG_PER_SEAT_ONLY.
Return Value:
ERROR_SUCCESS (A certificate was successfully entered into the system.)
ERROR_CANCELLED (The user cancelled without installing a certificate.)
other Win error
--*/
{
AFX_MANAGE_STATE( AfxGetStaticModuleState() );
CNewLicenseDialog dlg( CWnd::FromHandle( hWnd ) );
return dlg.CertificateEnter( pszServerName, pszProductName, pszVendor, dwFlags );
}
//////////////////////////////////////////////////////////////////////////////
DWORD APIENTRY NoCertificateRemove( HWND hWnd,
LPCSTR pszServerName,
DWORD dwFlags,
DWORD dwLicenseLevel,
LPVOID pvLicenseInfo )
/*++
Routine Description:
Remove licenses previously installed via 3.51 or NoCertificateEnter().
Arguments:
hWndParent (HWND)
HWND to the client's main window, for use as the parent window to any
opened dialogs. May be NULL.
pszServerName (LPCSTR)
Name of the server on which licenses are to be removed. A NULL value
indicates the local server.
dwFlags (DWORD)
Certificate removal options. As of this writing, no flags are
supported.
dwLicenseLevel (DWORD)
Level of the LLS_LICENSE_INFO_X structure pointed to by pvLicenseInfo.
pvLicenseInfo (LPVOID)
Points to a LLS_LICENSE_INFO_X (where X is determined by dwLicenseLevel)
describing the licenses to be removed.
Return Value:
ERROR_SUCCESS
Win error
--*/
{
AFX_MANAGE_STATE( AfxGetStaticModuleState() );
DWORD dwError;
if ( 1 != dwLicenseLevel )
{
dwError = ERROR_INVALID_LEVEL;
}
else
{
CNewLicenseDialog dlg( CWnd::FromHandle( hWnd ) );
dwError = dlg.CertificateRemove( pszServerName, dwFlags, (PLLS_LICENSE_INFO_1) pvLicenseInfo );
}
return dwError;
}
#ifdef OBSOLETE
///////////////////////////////////////////////////////////////////////////////
// Certificate Source -- Paper Certificate //
///////////////////////////////////////////////
DWORD APIENTRY PaperCertificateEnter( HWND hWnd,
LPCSTR pszServerName,
LPCSTR pszProductName,
LPCSTR pszVendor,
DWORD dwFlags )
/*++
Routine Description:
Display a dialog allowing the user to enter a license certificate
into the system with a paper certificate.
Arguments:
hWndParent (HWND)
HWND to the client's main window, for use as the parent window to any
opened dialogs. May be NULL.
pszServerName (LPCSTR)
Name of the server for which licenses are to be installed. Note that
this may not be the same as the server on which licenses are actually
installed, as, for example, per seat licenses are always installed on
the enterprise server. A NULL value indicates the local server.
pszProductName (LPCSTR)
Product for which licenses are to be installed. A NULL value indicates
that the user should be allowed to choose.
pszVendor (LPCSTR)
Name of the vendor of the product. This value should be NULL if
pszProductName is NULL, and should be non-NULL if pszProductName is
non-NULL.
dwFlags (DWORD)
A bitfield containing one or more of the following:
CCF_ENTER_FLAG_PER_SEAT_ONLY
Allow the user to enter only per seat licenses. Not valid in
combination with CCF_ENTER_FLAG_PER_SERVER_ONLY.
CCF_ENTER_FLAG_PER_SERVER_ONLY
Allow the user to enter only per server licenses. Not valid in
combination with CCF_ENTER_FLAG_PER_SEAT_ONLY.
Return Value:
ERROR_SUCCESS (A certificate was successfully entered into the system.)
ERROR_CANCELLED (The user cancelled without installing a certificate.)
other Win error
--*/
{
AFX_MANAGE_STATE( AfxGetStaticModuleState() );
DWORD dwError;
if ( !!pszProductName != !!pszVendor )
{
// they must both be NULL or both have values
dwError = ERROR_INVALID_PARAMETER;
}
else
{
CPaperSourceDlg dlg( CWnd::FromHandle( hWnd ) );
dwError = dlg.CertificateEnter( pszServerName, pszProductName, pszVendor, dwFlags );
}
return dwError;
}
//////////////////////////////////////////////////////////////////////////////
DWORD APIENTRY PaperCertificateRemove( HWND hWnd,
LPCSTR pszServerName,
DWORD dwFlags,
DWORD dwLicenseLevel,
LPVOID pvLicenseInfo )
/*++
Routine Description:
Remove licenses previously installed via PaperCertificateEnter().
Arguments:
hWndParent (HWND)
HWND to the client's main window, for use as the parent window to any
opened dialogs. May be NULL.
pszServerName (LPCSTR)
Name of the server on which licenses are to be removed. A NULL value
indicates the local server.
dwFlags (DWORD)
Certificate removal options. As of this writing, no flags are
supported.
dwLicenseLevel (DWORD)
Level of the LLS_LICENSE_INFO_X structure pointed to by pvLicenseInfo.
pvLicenseInfo (LPVOID)
Points to a LLS_LICENSE_INFO_X (where X is determined by dwLicenseLevel)
describing the licenses to be removed.
Return Value:
ERROR_SUCCESS
Win error
--*/
{
AFX_MANAGE_STATE( AfxGetStaticModuleState() );
DWORD dwError;
if ( 1 != dwLicenseLevel )
{
dwError = ERROR_INVALID_LEVEL;
}
else
{
CPaperSourceDlg dlg( CWnd::FromHandle( hWnd ) );
dwError = dlg.CertificateRemove( pszServerName, dwFlags, (PLLS_LICENSE_INFO_1) pvLicenseInfo );
}
return dwError;
}
#endif // OBSOLETE