282 lines
7.5 KiB
C++
282 lines
7.5 KiB
C++
|
//****************************************************************************
|
||
|
//
|
||
|
// Module: INETCFG.DLL
|
||
|
// File: iclient.c
|
||
|
// Content: This file contains all the functions that handle importing
|
||
|
// client information.
|
||
|
// History:
|
||
|
// Sat 10-Mar-1996 23:50:40 -by- Mark MacLin [mmaclin]
|
||
|
// 96/03/13 markdu Assimilated with inetcfg.dll.
|
||
|
// 96/03/20 markdu Combined export.h and iclient.h into inetcfg.h
|
||
|
// 96/04/18 markdu NASH BUG 18443
|
||
|
//
|
||
|
// Copyright (c) Microsoft Corporation 1991-1996
|
||
|
//
|
||
|
//****************************************************************************
|
||
|
|
||
|
//#include "wizard.h"
|
||
|
//#include "inetcfg.h"
|
||
|
#include "obcomglb.h"
|
||
|
|
||
|
#define REGSTR_PATH_INTERNET_CLIENT L"Software\\Microsoft\\Internet ClientX"
|
||
|
|
||
|
#pragma data_seg(".rdata")
|
||
|
|
||
|
// registry constants
|
||
|
static const WCHAR cszRegPathInternetClient[] = REGSTR_PATH_INTERNET_CLIENT;
|
||
|
|
||
|
static const WCHAR cszRegValEMailName[] = L"EMail_Name";
|
||
|
static const WCHAR cszRegValEMailAddress[] = L"EMail_Address";
|
||
|
static const WCHAR cszRegValPOPLogonRequired[] = L"POP_Logon_Required";
|
||
|
static const WCHAR cszRegValPOPLogonName[] = L"POP_Logon_Name";
|
||
|
static const WCHAR cszRegValPOPLogonPassword[] = L"POP_Logon_Password";
|
||
|
static const WCHAR cszRegValPOPServer[] = L"POP_Server";
|
||
|
static const WCHAR cszRegValSMTPServer[] = L"SMTP_Server";
|
||
|
static const WCHAR cszRegValNNTPLogonRequired[] = L"NNTP_Logon_Required";
|
||
|
static const WCHAR cszRegValNNTPLogonName[] = L"NNTP_Logon_Name";
|
||
|
static const WCHAR cszRegValNNTPLogonPassword[] = L"NNTP_Logon_Password";
|
||
|
static const WCHAR cszRegValNNTPServer[] = L"NNTP_Server";
|
||
|
static const WCHAR cszNull[] = L"";
|
||
|
static const WCHAR cszYes[] = L"yes";
|
||
|
static const WCHAR cszNo[] = L"no";
|
||
|
|
||
|
#pragma data_seg()
|
||
|
|
||
|
//*******************************************************************
|
||
|
//
|
||
|
// FUNCTION: InetGetClientInfo
|
||
|
//
|
||
|
// PURPOSE: This function will get the internet client params
|
||
|
// from the registry
|
||
|
//
|
||
|
// PARAMETERS: lpClientInfo - on return, this structure will contain
|
||
|
// the internet client params as set in the registry.
|
||
|
// lpszProfileName - Name of client info profile to
|
||
|
// retrieve. If this is NULL, the default profile is used.
|
||
|
//
|
||
|
// RETURNS: HRESULT code, ERROR_SUCCESS if no errors occurred
|
||
|
//
|
||
|
//*******************************************************************
|
||
|
|
||
|
extern HRESULT WINAPI InetGetClientInfo(
|
||
|
LPCWSTR lpszProfileName,
|
||
|
LPINETCLIENTINFO lpClientInfo)
|
||
|
{
|
||
|
HKEY hKey;
|
||
|
DWORD dwRet;
|
||
|
DWORD dwSize;
|
||
|
DWORD dwType;
|
||
|
DWORD dwVal;
|
||
|
|
||
|
if (sizeof(INETCLIENTINFO) > lpClientInfo->dwSize)
|
||
|
{
|
||
|
return ERROR_INSUFFICIENT_BUFFER;
|
||
|
}
|
||
|
|
||
|
dwRet = RegOpenKey(HKEY_CURRENT_USER, cszRegPathInternetClient, &hKey);
|
||
|
if (ERROR_SUCCESS != dwRet)
|
||
|
{
|
||
|
return dwRet;
|
||
|
}
|
||
|
|
||
|
lpClientInfo->dwFlags = 0;
|
||
|
|
||
|
dwSize = sizeof(dwVal);
|
||
|
dwType = REG_DWORD;
|
||
|
RegQueryValueEx(
|
||
|
hKey,
|
||
|
cszRegValPOPLogonRequired,
|
||
|
0L,
|
||
|
&dwType,
|
||
|
(LPBYTE)&dwVal,
|
||
|
&dwSize);
|
||
|
|
||
|
if (dwVal)
|
||
|
{
|
||
|
lpClientInfo->dwFlags |= INETC_LOGONMAIL;
|
||
|
}
|
||
|
|
||
|
dwSize = sizeof(dwVal);
|
||
|
dwType = REG_DWORD;
|
||
|
RegQueryValueEx(
|
||
|
hKey,
|
||
|
cszRegValNNTPLogonRequired,
|
||
|
0L,
|
||
|
&dwType,
|
||
|
(LPBYTE)&dwVal,
|
||
|
&dwSize);
|
||
|
|
||
|
if (dwVal)
|
||
|
{
|
||
|
lpClientInfo->dwFlags |= INETC_LOGONNEWS;
|
||
|
}
|
||
|
|
||
|
dwSize = sizeof(lpClientInfo->szEMailName);
|
||
|
dwType = REG_SZ;
|
||
|
RegQueryValueEx(
|
||
|
hKey,
|
||
|
cszRegValEMailName,
|
||
|
0L,
|
||
|
&dwType,
|
||
|
(LPBYTE)lpClientInfo->szEMailName,
|
||
|
&dwSize);
|
||
|
|
||
|
dwSize = sizeof(lpClientInfo->szEMailAddress);
|
||
|
dwType = REG_SZ;
|
||
|
RegQueryValueEx(
|
||
|
hKey,
|
||
|
cszRegValEMailAddress,
|
||
|
0L,
|
||
|
&dwType,
|
||
|
(LPBYTE)lpClientInfo->szEMailAddress,
|
||
|
&dwSize);
|
||
|
|
||
|
dwSize = sizeof(lpClientInfo->szPOPServer);
|
||
|
dwType = REG_SZ;
|
||
|
RegQueryValueEx(
|
||
|
hKey,
|
||
|
cszRegValPOPServer,
|
||
|
0L,
|
||
|
&dwType,
|
||
|
(LPBYTE)lpClientInfo->szPOPServer,
|
||
|
&dwSize);
|
||
|
|
||
|
dwSize = sizeof(lpClientInfo->szSMTPServer);
|
||
|
dwType = REG_SZ;
|
||
|
RegQueryValueEx(
|
||
|
hKey,
|
||
|
cszRegValSMTPServer,
|
||
|
0L,
|
||
|
&dwType,
|
||
|
(LPBYTE)lpClientInfo->szSMTPServer,
|
||
|
&dwSize);
|
||
|
|
||
|
dwSize = sizeof(lpClientInfo->szNNTPServer);
|
||
|
dwType = REG_SZ;
|
||
|
RegQueryValueEx(
|
||
|
hKey,
|
||
|
cszRegValNNTPServer,
|
||
|
0L,
|
||
|
&dwType,
|
||
|
(LPBYTE)lpClientInfo->szNNTPServer,
|
||
|
&dwSize);
|
||
|
|
||
|
RegCloseKey(hKey);
|
||
|
|
||
|
return ERROR_SUCCESS;
|
||
|
}
|
||
|
|
||
|
|
||
|
//*******************************************************************
|
||
|
//
|
||
|
// FUNCTION: InetSetClientInfo
|
||
|
//
|
||
|
// PURPOSE: This function will set the internet client params
|
||
|
//
|
||
|
// PARAMETERS: lpClientInfo - pointer to struct with info to set
|
||
|
// in the registry.
|
||
|
// lpszProfileName - Name of client info profile to
|
||
|
// modify. If this is NULL, the default profile is used.
|
||
|
//
|
||
|
// RETURNS: HRESULT code, ERROR_SUCCESS if no errors occurred
|
||
|
//
|
||
|
//*******************************************************************
|
||
|
|
||
|
HRESULT WINAPI InetSetClientInfo(
|
||
|
LPCWSTR lpszProfileName,
|
||
|
LPINETCLIENTINFO lpClientInfo)
|
||
|
{
|
||
|
HKEY hKey;
|
||
|
DWORD dwRet;
|
||
|
DWORD dwSize;
|
||
|
DWORD dwType;
|
||
|
DWORD dwVal;
|
||
|
|
||
|
if (sizeof(INETCLIENTINFO) > lpClientInfo->dwSize)
|
||
|
{
|
||
|
return ERROR_INSUFFICIENT_BUFFER;
|
||
|
}
|
||
|
|
||
|
dwRet = RegCreateKey(HKEY_CURRENT_USER, cszRegPathInternetClient, &hKey);
|
||
|
if (ERROR_SUCCESS != dwRet)
|
||
|
{
|
||
|
return dwRet;
|
||
|
}
|
||
|
|
||
|
dwVal = lpClientInfo->dwFlags & INETC_LOGONMAIL ? 1 : 0;
|
||
|
dwSize = sizeof(dwVal);
|
||
|
dwType = REG_DWORD;
|
||
|
RegSetValueEx(
|
||
|
hKey,
|
||
|
cszRegValPOPLogonRequired,
|
||
|
0L,
|
||
|
dwType,
|
||
|
(LPBYTE)&dwVal,
|
||
|
dwSize);
|
||
|
|
||
|
dwVal = lpClientInfo->dwFlags & INETC_LOGONNEWS ? 1 : 0;
|
||
|
dwSize = sizeof(dwVal);
|
||
|
dwType = REG_DWORD;
|
||
|
RegSetValueEx(
|
||
|
hKey,
|
||
|
cszRegValNNTPLogonRequired,
|
||
|
0L,
|
||
|
dwType,
|
||
|
(LPBYTE)&dwVal,
|
||
|
dwSize);
|
||
|
|
||
|
dwSize = sizeof(lpClientInfo->szEMailName);
|
||
|
dwType = REG_SZ;
|
||
|
RegSetValueEx(
|
||
|
hKey,
|
||
|
cszRegValEMailName,
|
||
|
0L,
|
||
|
dwType,
|
||
|
(LPBYTE)lpClientInfo->szEMailName,
|
||
|
dwSize);
|
||
|
|
||
|
dwSize = sizeof(lpClientInfo->szEMailAddress);
|
||
|
dwType = REG_SZ;
|
||
|
RegSetValueEx(
|
||
|
hKey,
|
||
|
cszRegValEMailAddress,
|
||
|
0L,
|
||
|
dwType,
|
||
|
(LPBYTE)lpClientInfo->szEMailAddress,
|
||
|
dwSize);
|
||
|
|
||
|
dwSize = sizeof(lpClientInfo->szPOPServer);
|
||
|
dwType = REG_SZ;
|
||
|
RegSetValueEx(
|
||
|
hKey,
|
||
|
cszRegValPOPServer,
|
||
|
0L,
|
||
|
dwType,
|
||
|
(LPBYTE)lpClientInfo->szPOPServer,
|
||
|
dwSize);
|
||
|
|
||
|
dwSize = sizeof(lpClientInfo->szSMTPServer);
|
||
|
dwType = REG_SZ;
|
||
|
RegSetValueEx(
|
||
|
hKey,
|
||
|
cszRegValSMTPServer,
|
||
|
0L,
|
||
|
dwType,
|
||
|
(LPBYTE)lpClientInfo->szSMTPServer,
|
||
|
dwSize);
|
||
|
|
||
|
dwSize = sizeof(lpClientInfo->szNNTPServer);
|
||
|
dwType = REG_SZ;
|
||
|
RegSetValueEx(
|
||
|
hKey,
|
||
|
cszRegValNNTPServer,
|
||
|
0L,
|
||
|
dwType,
|
||
|
(LPBYTE)lpClientInfo->szNNTPServer,
|
||
|
dwSize);
|
||
|
|
||
|
RegCloseKey(hKey);
|
||
|
|
||
|
return dwRet;
|
||
|
}
|