⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 pgpclientprefs.h

📁 vc环境下的pgp源码
💻 H
字号:
/*____________________________________________________________________________
	Copyright (C) 1997 Network Associates Inc. and affiliated companies.
	All rights reserved.
	
	$Id: pgpClientPrefs.h,v 1.63 1999/05/19 07:25:41 wprice Exp $
____________________________________________________________________________*/
#ifndef Included_pgpClientPrefs_h	/* [ */
#define Included_pgpClientPrefs_h

#if PGP_MACINTOSH
#include <Menus.h>
#endif

enum
{
	kPGPPrefMacBinaryOff	= 1,
	kPGPPrefMacBinarySmart	= 2,
	kPGPPrefMacBinaryOn		= 3
};

typedef enum _PGPClientPrefsBool
{
	kPGPPrefBoolFirst							=	0,
	kPGPPrefEncryptToSelf = kPGPPrefBoolFirst,
	kPGPPrefWordWrapEnable						=	1,
	kPGPPrefDecryptCacheEnable					=	2,
	kPGPPrefSignCacheEnable						=	3,
	kPGPPrefMailEncryptPGPMIME					=	4,
	kPGPPrefMailSignPGPMIME						=	5,
	kPGPPrefFastKeyGen							=	6,
	kPGPPrefWarnOnMixRSAElGamal					=	7,
	kPGPPrefMailEncryptDefault					=	8,
	kPGPPrefMailSignDefault						=	9,
	kPGPPrefMarginalIsInvalid					=	10,
	kPGPPrefDisplayMarginalValidity				=	11,
	kPGPPrefFirstKeyGenerated					=	12,
	kPGPPrefWarnOnRSARecipAndNonRSASigner		=	13,
	kPGPPrefKeyServerSyncUnknownKeys			=	14,
	kPGPPrefKeyServerSyncOnAdd					=	15,
	kPGPPrefKeyServerSyncOnKeySign				=	16,
	kPGPPrefKeyServerSyncOnRevocation			=	17,
	kPGPPrefWarnOnReadOnlyKeyRings				=	18,
	kPGPPrefWarnOnWipe							=	19,
	kPGPPrefAutoDecrypt							=	20,
	kPGPPrefWarnOnADK							=	21,
	kPGPPrefKeyServerSyncOnVerify				=	22,		/* 6.0 */
	kPGPPrefPGPkeysMacShowToolbar				=	23,		/* 6.0 */
	kPGPPrefWarnOnMemLockFailure				=	24,		/* 6.0 */
	kPGPPrefExportKeysCompatible				=	25,		/* 6.0 */
	kPGPPrefAlwaysUseSecureViewer				=	26,		/* 6.5 */
	kPGPPrefUseHexFingerprint					=	27,		/* 6.5 */
	kPGPPrefDiskAutoUnmountOnTime				=	28,		/* 7.0 */ 
	kPGPPrefDiskAutoUnmountOnSleep				=	29,		/* 7.0 */ 
	kPGPPrefDiskNoSleepIfFailAU					=	30,		/* 7.0 */
	kPGPPrefTrashIntegration					=	31,		/* 6.5 */
	kPGPPrefBoolLast
} PGPClientPrefsBool;

typedef enum _PGPClientPrefsNumber
{
	kPGPPrefNumberFirst							=	200,
	kPGPPrefVersion = kPGPPrefNumberFirst,
	kPGPPrefWordWrapWidth						=	201,
	kPGPPrefDecryptCacheSeconds					=	202,
	kPGPPrefSignCacheSeconds					=	203,
	kPGPPrefDateOfLastSplashScreen				=	204,	/* PGPTime */
	kPGPPrefPreferredAlgorithm					=	205,
	kPGPPrefAllowedAlgorithms					=	206,	/* OBSOLETE */
	kPGPPrefMacBinaryDefault					=	207,
	kPGPPrefDateOfLastFreewareNotice			=	208,	/* OBSOLETE */
	kPGPPrefFileWipePasses						=	209,	/* 6.0 */
	kPGPPrefDiskWipePasses						=	210,	/* 6.0 */
	kPGPPrefLastSearchWindowSelection			=	211,	/* 6.0 */
	kPGPPrefLastAllKeysUpdate					=	212,	/* 6.5(moved from admin)*/
	kPGPPrefLastTrustedIntroducersUpdate		=	213,	/* 6.5(moved from admin)*/
	kPGPPrefCAType								=	214,	/* 6.5 */
	kPGPPrefCARootKeyAlg						=	215,	/* 6.5 */
	kPGPPrefCAServerAuthKeyAlg					=	216,	/* 6.5 */
	kPGPPrefCARevocationServerAuthKeyAlg		=	217,	/* 6.5 */
	kPGPPrefNextAutoCRLUpdate					=	218,	/* 6.5 */	
	kPGPPrefDiskLastCreateSize					=	219,	/* 7.0 */ 
	kPGPPrefDiskLastCreateScale					=	220,	/* 7.0 */ 
	kPGPPrefDiskAutoUnmountTimeout				=	221,	/* 7.0 */ 
	kPGPPrefNumberLast
} PGPClientPrefsNumber;

typedef enum _PGPClientPrefsString
{
	kPGPPrefStringFirst							=	400,
	kPGPPrefOwnerName = kPGPPrefStringFirst,
	kPGPPrefCompanyName							=	401,
	kPGPPrefLicenseNumber						=	402,
	kPGPPrefComment								=	403,
	kPGPPrefCAServerURL							=	405,	/* 6.5 */
	kPGPPrefCARevocationServerURL				=	406,	/* 6.5 */
	kPGPPrefDiskLastOpenDir						=	407,	/* 7.0 */
	kPGPPrefDiskLastSaveDir						=	408,	/* 7.0 */ 
	kPGPPrefStringLast
} PGPClientPrefsString;

typedef enum _PGPClientPrefsByte
{
	kPGPPrefByteFirst							=	600,
	kPGPPrefPGPtoolsMacPrivateData = kPGPPrefByteFirst,
	kPGPPrefPGPmenuMacAppSignatures				=	601,
	kPGPPrefPGPkeysMacMainWinPos				=	602,
	kPGPPrefPGPkeysMacColumnData				=	603,
	kPGPPrefKeyServerList						=	604,
	kPGPPrefPGPkeysWinMainWinPos				=	605,
	kPGPPrefPGPkeysWinColumnData				=	606,
	kPGPPrefPGPkeysWinGroupsData				=	607,
	kPGPPrefAllowedAlgorithmsList				=	608,	/* 5.5.1 */
	kPGPPrefPGPdiskWin32PrivateData				=	609,	/* 6.5 */
	kPGPPrefCARootKeyID							=	610,	/* 6.5 */
	kPGPPrefCARootX509IASN						=	611,	/* 6.5 */
	kPGPPrefCAServerAuthKeyID					=	612,	/* 6.5 */
	kPGPPrefCARevocationServerAuthKeyID			=	613,	/* 6.5 */
	kPGPPrefPGPdiskMacPrivateData				=	614,	/* 6.5 */
	kPGPPrefHotKeyData							=	615,	/* 6.5 */
	kPGPPrefByteLast
	
} PGPClientPrefsByte;

#include "pgpBase.h"
#include "pgpPFLErrors.h"
#include "pflPrefs.h"
#include "pgpSymmetricCipher.h"
#include "pgpKeyServerPrefs.h"
#include "pgpKeyServer.h"

static const PGPKeyServerEntry sDefaultKeyServer[] =
{
	{ sizeof(PGPKeyServerEntry), kPGPKeyServerType_HTTP, "", 
		"keys.pgpi.net", 11371, "", kPGPPublicKeyAlgorithm_Invalid,
	    (kKeyServerListed|kKeyServerIsRoot), "" },
	{ sizeof(PGPKeyServerEntry), kPGPKeyServerType_LDAP, "", 
		"keys.pgpi.net", 11370, "", kPGPPublicKeyAlgorithm_Invalid,
		(kKeyServerListed), "" },
	{ sizeof(PGPKeyServerEntry), kPGPKeyServerType_LDAPS, "", 
		"keys.pgpi.net", 11369, "", kPGPPublicKeyAlgorithm_Invalid,
		(kKeyServerListed), "" },
	{ sizeof(PGPKeyServerEntry), kPGPKeyServerType_HTTP, "", 
		"keys.nai.com", 11371, "", kPGPPublicKeyAlgorithm_Invalid,
	    (kKeyServerListed), "" },
	{ sizeof(PGPKeyServerEntry), kPGPKeyServerType_LDAP, "", 
		"keys.nai.com", 0, "", kPGPPublicKeyAlgorithm_Invalid,
		(kKeyServerListed), "" },
	{ sizeof(PGPKeyServerEntry), kPGPKeyServerType_HTTP, "", 
		"wwwkeys.at.pgp.net", 11371, "", kPGPPublicKeyAlgorithm_Invalid,
		(kKeyServerListed), "" },
	{ sizeof(PGPKeyServerEntry), kPGPKeyServerType_HTTP, "", 
		"wwwkeys.ch.pgp.net", 11371, "", kPGPPublicKeyAlgorithm_Invalid,
		(kKeyServerListed), "" },
	{ sizeof(PGPKeyServerEntry), kPGPKeyServerType_HTTP, "", 
		"wwwkeys.cz.pgp.net", 11371, "", kPGPPublicKeyAlgorithm_Invalid,
		(kKeyServerListed), "" },
	{ sizeof(PGPKeyServerEntry), kPGPKeyServerType_HTTP, "", 
		"wwwkeys.de.pgp.net", 11371, "", kPGPPublicKeyAlgorithm_Invalid,
  	    (kKeyServerListed), "" },
	{ sizeof(PGPKeyServerEntry), kPGPKeyServerType_HTTP, "", 
		"wwwkeys.dk.pgp.net", 11371, "", kPGPPublicKeyAlgorithm_Invalid,
  	    (kKeyServerListed), "" },
	{ sizeof(PGPKeyServerEntry), kPGPKeyServerType_HTTP, "", 
		"wwwkeys.uk.pgp.net", 11371, "", kPGPPublicKeyAlgorithm_Invalid,
  	    (kKeyServerListed), "" },
	{ sizeof(PGPKeyServerEntry), kPGPKeyServerType_HTTP, "", 
		"wwwkeys.us.pgp.net", 11371, "", kPGPPublicKeyAlgorithm_Invalid,
  	    (kKeyServerListed), "" },
	{ sizeof(PGPKeyServerEntry), kPGPKeyServerType_HTTP, "", 
		"belgium.keyserver.net", 11371, "", kPGPPublicKeyAlgorithm_Invalid,
  	    (kKeyServerListed), "" },
	{ sizeof(PGPKeyServerEntry), kPGPKeyServerType_HTTP, "", 
		"germany.keyserver.net", 11371, "", kPGPPublicKeyAlgorithm_Invalid,
  	    (kKeyServerListed), "" },
	{ sizeof(PGPKeyServerEntry), kPGPKeyServerType_HTTP, "", 
		"seattle.keyserver.net", 11371, "", kPGPPublicKeyAlgorithm_Invalid,
  	    (kKeyServerListed), "" },
	{ sizeof(PGPKeyServerEntry), kPGPKeyServerType_HTTP, "", 
		"thailand.keyserver.net", 11371, "", kPGPPublicKeyAlgorithm_Invalid,
	    (kKeyServerListed), "" }
};

static const PGPCipherAlgorithm sAllowedAlgorithms[] =
{
	kPGPCipherAlgorithm_CAST5,
	kPGPCipherAlgorithm_3DES,
	kPGPCipherAlgorithm_IDEA/*,
	kPGPCipherAlgorithm_Twofish256*/
};

#if	PGP_MACINTOSH	/* [ */

#if PRAGMA_ALIGN_SUPPORTED
#pragma options align=mac68k
#endif

typedef struct PGPmenuApps
{
	PGPBoolean	privateScrap;
	PGPBoolean	useOutputDialog;
	OSType		creator;
	Str31		appName;
} PGPmenuApps;

typedef struct PGPmenuHotkeys
{
	UInt8		encryptModifiers;
	UInt8		encryptKey;
	UInt8		signModifiers;
	UInt8		signKey;
	UInt8		encryptSignModifiers;
	UInt8		encryptSignKey;
	UInt8		decryptModifiers;
	UInt8		decryptKey;
	UInt8		purgeModifiers;
	UInt8		purgeKey;
} PGPmenuHotkeys;

#if PRAGMA_ALIGN_SUPPORTED
#pragma options align=reset
#endif

static const PGPmenuHotkeys	sInitPGPmenuHotkeys[] =
{
	kMenuOptionModifier,		'E',
	kMenuOptionModifier,		'S',
	kMenuOptionModifier,		'C',
	kMenuOptionModifier,		'D',
	kMenuOptionModifier,		'P'
};	

static const PGPmenuApps	sInitPGPmenuApps[] =
{
	{TRUE,	TRUE,	'AOp3', "\pAmerica Online"},		/* Verified -> 3.01 */
	{TRUE,	FALSE,	'R*ch', "\pBBEdit"},				/* Verified -> 4.5	*/
	{FALSE,	FALSE,	'MMan', "\pEmailer"},
	{TRUE,	TRUE,	'MOSS', "\pNetscape Communicator"},	/* Verified -> 4.01 */
	{TRUE,	TRUE,	'MSNM', "\pOutlook Express"},
	{FALSE,	FALSE,	'ttxt', "\pSimpleText"}
};	

#endif	/* ] */

static const PGPPrefDefault clientDefaults[] =
{
{kPGPPrefEncryptToSelf,					kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefWordWrapEnable,				kPGPPrefType_Boolean, (void *) TRUE},
{kPGPPrefDecryptCacheEnable,			kPGPPrefType_Boolean, (void *) TRUE},
{kPGPPrefSignCacheEnable,				kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefMailEncryptPGPMIME,			kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefMailSignPGPMIME,				kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefFastKeyGen,					kPGPPrefType_Boolean, (void *) TRUE},
{kPGPPrefWarnOnMixRSAElGamal,			kPGPPrefType_Boolean, (void *) TRUE},
{kPGPPrefMailEncryptDefault,			kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefMailSignDefault,				kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefMarginalIsInvalid,				kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefDisplayMarginalValidity,		kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefFirstKeyGenerated,				kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefWarnOnRSARecipAndNonRSASigner,	kPGPPrefType_Boolean, (void *) TRUE},
{kPGPPrefKeyServerSyncUnknownKeys,		kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefKeyServerSyncOnAdd,			kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefKeyServerSyncOnKeySign,		kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefKeyServerSyncOnRevocation,		kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefKeyServerSyncOnVerify,			kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefWarnOnReadOnlyKeyRings,		kPGPPrefType_Boolean, (void *) TRUE},
{kPGPPrefWarnOnWipe,					kPGPPrefType_Boolean, (void *) TRUE},
{kPGPPrefAutoDecrypt,					kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefWarnOnADK,						kPGPPrefType_Boolean, (void *) TRUE},
{kPGPPrefPGPkeysMacShowToolbar,			kPGPPrefType_Boolean, (void *) TRUE},
{kPGPPrefWarnOnMemLockFailure,			kPGPPrefType_Boolean, (void *) TRUE},
{kPGPPrefExportKeysCompatible,			kPGPPrefType_Boolean, (void *) TRUE},
{kPGPPrefAlwaysUseSecureViewer,			kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefUseHexFingerprint,				kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefDiskAutoUnmountOnTime,			kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefDiskAutoUnmountOnSleep,		kPGPPrefType_Boolean, (void *) FALSE},
{kPGPPrefDiskNoSleepIfFailAU,			kPGPPrefType_Boolean, (void *) FALSE},	
{kPGPPrefTrashIntegration,				kPGPPrefType_Boolean, (void *) FALSE},

{kPGPPrefWordWrapWidth,				kPGPPrefType_Number, (void *) 70},
{kPGPPrefDecryptCacheSeconds,		kPGPPrefType_Number, (void *) 120},
{kPGPPrefSignCacheSeconds,			kPGPPrefType_Number, (void *) 120},
{kPGPPrefDateOfLastSplashScreen,	kPGPPrefType_Number, (void *) 0},
{kPGPPrefPreferredAlgorithm,		kPGPPrefType_Number,
									(void *) kPGPCipherAlgorithm_CAST5},
{kPGPPrefAllowedAlgorithms,			kPGPPrefType_Number, (void *) 0xE0000000},
{kPGPPrefMacBinaryDefault,			kPGPPrefType_Number, 
									(void *) kPGPPrefMacBinaryOn},
{kPGPPrefDateOfLastFreewareNotice,	kPGPPrefType_Number, (void *) 0},
{kPGPPrefFileWipePasses,			kPGPPrefType_Number, (void *) 8},
{kPGPPrefDiskWipePasses,			kPGPPrefType_Number, (void *) 3},
{kPGPPrefLastAllKeysUpdate,				kPGPPrefType_Number, (void *) 0},
{kPGPPrefLastTrustedIntroducersUpdate,	kPGPPrefType_Number, (void *) 0},
{kPGPPrefCAType,					kPGPPrefType_Number,
										(void *) kPGPKeyServerClass_Invalid},
{kPGPPrefCARootKeyAlg,				kPGPPrefType_Number,
										(void *) kPGPPublicKeyAlgorithm_DSA},
{kPGPPrefCAServerAuthKeyAlg,		kPGPPrefType_Number,
										(void *) kPGPPublicKeyAlgorithm_Invalid},
{kPGPPrefCARevocationServerAuthKeyAlg,	kPGPPrefType_Number,
										(void *) kPGPPublicKeyAlgorithm_Invalid},
{kPGPPrefNextAutoCRLUpdate,			kPGPPrefType_Number, (void *) 0},
{kPGPPrefDiskLastCreateSize,		kPGPPrefType_Number, (void *) 0},
{kPGPPrefDiskLastCreateScale,		kPGPPrefType_Number, (void *) 0},
{kPGPPrefDiskAutoUnmountTimeout,	kPGPPrefType_Number, (void *) 15},

#if	PGP_MACINTOSH	/* [ */
{kPGPPrefLastSearchWindowSelection,	kPGPPrefType_Number, (void *) 3},
#elif PGP_WIN32
{kPGPPrefLastSearchWindowSelection,	kPGPPrefType_Number, (void *) 2},
#endif	/* ] */

{kPGPPrefOwnerName,					kPGPPrefType_String, (void *) ""},
{kPGPPrefCompanyName,				kPGPPrefType_String, (void *) ""},
{kPGPPrefLicenseNumber,				kPGPPrefType_String, (void *) ""},
{kPGPPrefComment,					kPGPPrefType_String, (void *) ""},
{kPGPPrefCAServerURL,				kPGPPrefType_String, (void *) ""},
{kPGPPrefCARevocationServerURL,		kPGPPrefType_String, (void *) ""},
{kPGPPrefDiskLastOpenDir,			kPGPPrefType_String, (void *) ""},
{kPGPPrefDiskLastSaveDir,			kPGPPrefType_String, (void *) ""},
	
#if	PGP_MACINTOSH	/* [ */

{kPGPPrefPGPmenuMacAppSignatures, kPGPPrefType_Byte, 
	(void *) sInitPGPmenuApps, sizeof(sInitPGPmenuApps)},
{kPGPPrefHotKeyData, kPGPPrefType_Byte, 
	(void *) sInitPGPmenuHotkeys, sizeof(sInitPGPmenuHotkeys)},

#endif	/* ] */

{kPGPPrefKeyServerList, kPGPPrefType_Byte, 
	(void *) sDefaultKeyServer, sizeof(sDefaultKeyServer)},
{kPGPPrefAllowedAlgorithmsList, kPGPPrefType_Byte, 
	(void *) sAllowedAlgorithms, sizeof(sAllowedAlgorithms)},
};

static const PGPSize clientDefaultsSize = 
						sizeof(clientDefaults) / sizeof(PGPPrefDefault);


#endif /* ] Included_pgpClientPrefs_h */


/*__Editor_settings____

	Local Variables:
	tab-width: 4
	End:
	vi: ts=4 sw=4
	vim: si
_____________________*/

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -