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

📄 pgpsdkprefs.c

📁 vc环境下的pgp源码
💻 C
字号:
/*____________________________________________________________________________
	Copyright (C) 1997 Network Associates Inc. and affiliated companies.
	All rights reserved.

	$Id: pgpSDKPrefs.c,v 1.24 1999/04/26 11:35:21 wprice Exp $
____________________________________________________________________________*/
#include "pgpConfig.h"

#if HAVE_STDLIB_H
#include <stdlib.h>
#endif

#include "pgpFileSpec.h"
#include "pflPrefs.h"
#include "pgpMem.h"
#include "pgpErrors.h"
#include "pgpEnv.h"
#include "pgpContext.h"
#include "pgpUtilitiesPriv.h"

#if PGP_MACINTOSH
#include "pgpFileSpecMac.h"
#elif PGP_WIN32
#include "windows.h"
#endif

#include "pgpSDKPrefs.h"




/*____________________________________________________________________________
	If prefs for the various file locations do not exist, then create a
	file spec for the location and set it in the prefs.
____________________________________________________________________________*/
typedef struct DefaultLocInfo
{
	PGPsdkPrefSelector	selector;
	const char *		defaultName;
} DefaultLocInfo;

	static PGPError
sSetDefaultFileLocations(
	PGPContextRef	context,
	PGPBoolean *	didAddPrefs )
{
	static const DefaultLocInfo	sInfo[] =
	{
#if PGP_MACINTOSH		/* [ */
		{ kPGPsdkPref_PublicKeyring,	"PGP Public Keys" },
		{ kPGPsdkPref_PrivateKeyring,	"PGP Private Keys" },
		{ kPGPsdkPref_RandomSeedFile,	"PGP Random Seed" },
		{ kPGPsdkPref_GroupsFile,		"PGP Groups" }
#else					/* ] PGP_MACINTOSH [ */
		{ kPGPsdkPref_PublicKeyring,	"pubring.pkr" },
		{ kPGPsdkPref_PrivateKeyring,	"secring.skr" },
		{ kPGPsdkPref_RandomSeedFile,	"randseed.rnd" },
		{ kPGPsdkPref_GroupsFile,		"PGPgroup.pgr" }
#endif					/* ] PGP_MACINTOSH */
	};
	#define kNumLocations	sizeof( sInfo ) / sizeof( sInfo[ 0 ] )
	PFLFileSpecRef	locSpec;
	PGPError		err	= kPGPError_NoErr;
	
	*didAddPrefs	= FALSE;
	
	/* by default, we'll place the files in the same directory
	as the prefs file itself */
	err	= pgpGetPrefsSpec( PGPGetContextMemoryMgr( context ), &locSpec );
	if ( IsntPGPError( err ) )
	{
		PGPUInt32		infoIndex;
		
		for( infoIndex = 0; infoIndex < kNumLocations; ++infoIndex )
		{
			PGPFileSpecRef			tempRef;
			const DefaultLocInfo *	info;
			
			info	= &sInfo[ infoIndex ];
			
			err	= PGPsdkPrefGetFileSpec( context, info->selector, &tempRef );
		#if PGP_MACINTOSH
			if( IsntPGPError( err ) )
			{
				/*
				** On the Mac, a file spec can become invalid, and
				** "unrecoverable", if the directory ID containing the file 
				** no longer exists. To fix this, we validate the existence 
				** of the dir ID and revert to the default location if the 
				** directory no longer exists. Note that we only do this for 
				** the random seed and groups files.
				*/
				
				if( info->selector == kPGPsdkPref_RandomSeedFile ||
					info->selector == kPGPsdkPref_GroupsFile )
				{
					FSSpec	macSpec;
					
					err = PFLGetFSSpecFromFileSpec( (PFLFileSpecRef) tempRef,
								&macSpec );
					if( IsntPGPError( err ) )
					{
						CInfoPBRec	cpb;
						
						pgpClearMemory( &cpb, sizeof( cpb ) );
						
						cpb.dirInfo.ioVRefNum 	= macSpec.vRefNum;
						cpb.dirInfo.ioDrDirID 	= macSpec.parID;
						cpb.dirInfo.ioFDirIndex = -1;
						
						if( IsErr( PBGetCatInfoSync( &cpb ) ) )
						{
							PFLFreeFileSpec( (PFLFileSpecRef) tempRef );
							tempRef = kInvalidPGPFileSpecRef;
							
							err = kPGPError_PrefNotFound;
						}
					}
				}
			}
		#endif	/* PGP_MACINTOSH */

			if ( err == kPGPError_PrefNotFound )
			{
			#if PGP_WIN32
				if( info->selector == kPGPsdkPref_RandomSeedFile )
				{
					char	winpath[MAX_PATH];
					
					/*
					** Special case. The randseed file default location in Windows
					** is the system directory, _not_ the same location as the 
					** prefs file. This facilitates Windows services which may not be able
					** to initially seed the file but can rely on other apps to do so
					*/
				
					pgpAssert( IsNull( tempRef ) );

					if( GetWindowsDirectory( winpath, sizeof(winpath) ) == 0 )
						strcpy( winpath, "." );

					if( winpath[strlen( winpath ) -1] != '\\' ) 
						strcat (winpath, "\\");

					strcat( winpath, info->defaultName );

					err	= PFLNewFileSpecFromFullPath( PGPGetContextMemoryMgr( context ),
								winpath, (PFLFileSpecRef *) &tempRef );
					if ( IsntPGPError( err ) )
					{
						PGPsdkPrefSetFileSpec( context,
							info->selector, (PGPFileSpecRef)tempRef );
						*didAddPrefs	= TRUE;
						
						PFLFreeFileSpec( (PFLFileSpecRef)tempRef );
					}
				}
				else
			#endif
				{
					/* one doesn't exist yet */
					pgpAssert( IsNull( tempRef ) );
					err	= PFLSetFileSpecName( locSpec, info->defaultName );
					if ( IsntPGPError( err ) )
					{
						PGPsdkPrefSetFileSpec( context,
							info->selector, (PGPFileSpecRef)locSpec );
						*didAddPrefs	= TRUE;
					}
				}
			}
			else if ( IsntPGPError( err ) )
			{
				/* no error; there is one already set */
				PFLFreeFileSpec( (PFLFileSpecRef)tempRef );
			}
		}
		
		PFLFreeFileSpec( locSpec );
	}
	
	return( err );
}



	PGPError
PGPsdkLoadPrefs(
	PGPContextRef	context,
	PGPFileSpecRef	prefsSpecIn )
{
	PGPError		err	= kPGPError_NoErr;
	PGPPrefRef		prefsRef	= NULL;
	PFLFileSpecRef	prefsSpec	= (PFLFileSpecRef)prefsSpecIn;
	
	PGPValidateContext( context );
	PFLValidateFileSpec( prefsSpec );
		
	err	= PGPOpenPrefFile( prefsSpec, NULL, 0, &prefsRef );
	if ( IsntPGPError( err ) )
	{
		PGPPrefRef		oldPrefs	= NULL;
		PGPBoolean		didAddPrefs;
	
		oldPrefs	= pgpContextGetPrefs( context );
		if ( IsntNull( oldPrefs ) )
		{
			PGPClosePrefFile( oldPrefs );
			pgpContextSetPrefs( context, NULL );
		}
	
		pgpContextSetPrefs( context, prefsRef );
		
		(void)sSetDefaultFileLocations( context, &didAddPrefs );
		if ( didAddPrefs )
		{
			/* prefs were added so save them now */
			PGPsdkSavePrefs( context );
		}
	}
	
	return( err );
}


	PGPError
PGPsdkLoadDefaultPrefs( PGPContextRef context )
{
	PGPError		err	= kPGPError_NoErr;
	PFLFileSpecRef	prefsSpec	= NULL;
	
	PGPValidateContext( context );
	
	err	= pgpGetPrefsSpec( PGPGetContextMemoryMgr( context ), &prefsSpec);
	if ( IsntPGPError( err ) )
	{
		err	= PGPsdkLoadPrefs( context, (PGPFileSpecRef)prefsSpec );
		
		PFLFreeFileSpec( prefsSpec );
	}
	return( err );
}

	PGPError
PGPsdkSavePrefs( PGPContextRef context )
{
	PGPError	err	= kPGPError_NoErr;
	PGPPrefRef	prefsRef	= NULL;
	
	PGPValidateContext( context );
	
	prefsRef	= pgpContextGetPrefs( context );
	if ( IsNull( prefsRef ) )
		err	= kPGPError_ImproperInitialization;
	else
		err	= PGPSavePrefFile( prefsRef );
	
	return( err );
}


/*____________________________________________________________________________
	Set the prefs to contain data representing a PFLFileSpecRef
____________________________________________________________________________*/
	PGPError
PGPsdkPrefSetFileSpec(
	PGPContextRef		context,
	PGPsdkPrefSelector	selector,
	PGPFileSpecRef		fileSpecIn )
{
	PGPError		err	= kPGPError_NoErr;
	PGPPrefRef		prefsRef	= NULL;
	PGPByte *		data	= NULL;
	PGPSize			dataLength;
	PGPMemoryMgrRef	memoryMgr;
	PFLConstFileSpecRef	fileSpec	= (PFLConstFileSpecRef)fileSpecIn;
	
	PGPValidateContext( context );
	PGPValidateParam(
		selector == kPGPsdkPref_PublicKeyring ||
		selector == kPGPsdkPref_PrivateKeyring ||
		selector == kPGPsdkPref_RandomSeedFile ||
		selector == kPGPsdkPref_GroupsFile );
	PFLValidateFileSpec( fileSpec );
	
	prefsRef	= pgpContextGetPrefs( context );
	if ( IsNull( prefsRef ) )
		return( kPGPError_ImproperInitialization );
	
	memoryMgr	= PGPGetContextMemoryMgr( context );
	
	err	= PFLExportFileSpec( fileSpec, &data, &dataLength );
	if ( IsntPGPError( err ) )
	{
		err	= PGPSetPrefData( prefsRef,
				(PGPPrefIndex)selector, dataLength, data );
		
		PGPFreeData( data );
	}
	
	return( err );
}


/*____________________________________________________________________________
	Construct a PFLFileSpecRef from prefs data and return it.
____________________________________________________________________________*/
	PGPError
PGPsdkPrefGetFileSpec(
	PGPContextRef		context,
	PGPsdkPrefSelector	selector,
	PGPFileSpecRef *	outSpec )
{
	PGPError		err	= kPGPError_NoErr;
	PGPPrefRef		prefsRef	= NULL;
	PGPByte *		data	= NULL;
	PGPSize			dataLength;
	PGPMemoryMgrRef	memoryMgr;
	
	PGPValidatePtr( outSpec );
	*outSpec	= NULL;
	PGPValidateContext( context );
	PGPValidateParam(
		selector == kPGPsdkPref_PublicKeyring ||
		selector == kPGPsdkPref_PrivateKeyring ||
		selector == kPGPsdkPref_RandomSeedFile ||
		selector == kPGPsdkPref_GroupsFile );
	
	prefsRef	= pgpContextGetPrefs( context );
	if ( IsNull( prefsRef ) )
		return( kPGPError_ImproperInitialization );
	
	memoryMgr	= PGPGetContextMemoryMgr( context );
	
	err	= PGPGetPrefData( prefsRef,
			(PGPPrefIndex)selector, &dataLength, (void**)&data );
		
	if ( IsntPGPError( err ) )
	{
		PFLFileSpecRef	tempRef;
		
		err	= PFLImportFileSpec( memoryMgr, data, dataLength, &tempRef );
		*outSpec	= (PGPFileSpecRef)tempRef;
		
		PGPDisposePrefData( prefsRef, data );
	}
	
	pgpAssertErrWithPtr( err, *outSpec );
	return( err );
}


/*____________________________________________________________________________
	Get raw pref data.
	
	Caller must dispose of data with PGPFreeData.
____________________________________________________________________________*/
	PGPError
PGPsdkPrefGetData(
	PGPContextRef		context,
	PGPsdkPrefSelector	selector,
	void **				outData,
	PGPSize *			outSize )
{
	PGPError		err	= kPGPError_NoErr;
	PGPPrefRef		prefsRef	= NULL;
	void *			data	= NULL;
	void *			prefData = NULL;
	PGPSize			dataLength;
	PGPMemoryMgrRef	mgr;
	
	if ( IsntNull( outSize ) )
		*outSize	= 0;
	if ( IsntNull( outData ) )
		*outData	= NULL;
	PGPValidatePtr( outData );
	PGPValidatePtr( outSize );
	PGPValidateContext( context );
	PGPValidateParam( selector == kPGPsdkPref_DefaultKeyID );
	
	prefsRef	= pgpContextGetPrefs( context );
	if ( IsNull( prefsRef ) )
		return( kPGPError_ImproperInitialization );
	
	mgr	= PGPGetContextMemoryMgr( context );
	
	err	= PGPGetPrefData( prefsRef,
			(PGPPrefIndex)selector, &dataLength, &prefData );
		
	if ( IsntPGPError( err ) )
	{
		/* we must allocate data with PGPNewData */
		data	= PGPNewData( mgr, dataLength, 0);
		if ( IsNull( data ) )
		{
			err	= kPGPError_OutOfMemory;
			dataLength	= 0;
		}
		else
		{
			pgpCopyMemory( prefData, data, dataLength );
		}
			
		PGPDisposePrefData( prefsRef, prefData );
	}
	
	*outData	= data;
	*outSize	= dataLength;
	
	pgpAssertErrWithPtr( err, *outData );
	return( err );
}



/*____________________________________________________________________________
	Get raw pref data.
	
	Caller must dispose of data with PGPFreeData.
____________________________________________________________________________*/
	PGPError
PGPsdkPrefSetData(
	PGPContextRef		context,
	PGPsdkPrefSelector	selector,
	void const *		data,
	PGPSize				dataSize )
{
	PGPError		err	= kPGPError_NoErr;
	PGPPrefRef		prefsRef	= NULL;
	
	PGPValidatePtr( data );
	PGPValidateParam( dataSize != 0 );
	PGPValidateContext( context );
	PGPValidateParam( selector == kPGPsdkPref_DefaultKeyID );
	
	prefsRef	= pgpContextGetPrefs( context );
	if ( IsNull( prefsRef ) )
		return( kPGPError_ImproperInitialization );
	
	err	= PGPSetPrefData( prefsRef,
			(PGPPrefIndex)selector, dataSize, data );
	
	return( err );
}






























/*__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 + -