SecKeychainAPI.cpp   [plain text]


/*
 * Copyright (c) 2000-2002 Apple Computer, Inc. All Rights Reserved.
 * 
 * The contents of this file constitute Original Code as defined in and are
 * subject to the Apple Public Source License Version 1.2 (the 'License').
 * You may not use this file except in compliance with the License. Please obtain
 * a copy of the License at http://www.apple.com/publicsource and read it before
 * using this file.
 * 
 * This Original Code and all software distributed under the License are
 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS
 * OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, INCLUDING WITHOUT
 * LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR
 * PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. Please see the License for the
 * specific language governing rights and limitations under the License.
 */

/*
 *  SecKeychainAPI.h
 *  SecurityCore
 *
 *    Copyright:  (c) 2000-2002 by Apple Computer, Inc., all rights reserved
 *
 */

/*!
	@header SecKeychainAPI The Security Keychain API contains all the APIs need to create a client and Keychain management application. It also contains a certificate, policy, identity and trust management API.
	 
	NOTE: Any function with Create or Copy in the name returns an object that must be released.
*/

#if !defined(SECURITY_USE_LEGACY_HEADER)
#define SECURITY_USE_LEGACY_HEADER
#define UNDEFINE_SECURITY_USE_LEGACY_HEADER
#endif

#include <Security/SecKeychainAPI.h>

#ifdef UNDEFINE_SECURITY_USE_LEGACY_HEADER
#undef SECURITY_USE_LEGACY_HEADER
#undef UNDEFINE_SECURITY_USE_LEGACY_HEADER
#endif

#include <Security/SecKeychainSearch.h>
#include <Security/logging.h>

OSStatus SecKeychainRelease(SecKeychainRef keychainRef)
{
	if (!keychainRef)
		return errSecInvalidKeychain;

	CFRelease(keychainRef);
	return noErr;
}

OSStatus SecKeychainItemRelease(SecKeychainItemRef itemRef)
{
	if (!itemRef)
		return errSecInvalidItemRef;

	CFRelease(itemRef);
	return noErr;
}

OSStatus SecKeychainSearchRelease(SecKeychainSearchRef searchRef)
{
	if (!searchRef)
		return errSecInvalidSearchRef;

	CFRelease(searchRef);
	return noErr;
}

OSStatus SecKeychainCopySearchNextItem(SecKeychainSearchRef searchRef, SecKeychainItemRef *itemRef)
{
	static bool warnonce;
	if (!warnonce)
	{
		warnonce = true;
		Syslog::warning("Calling OBSOLETE SecKeychainCopySearchNextItem please use SecKeychainSearchCopyNext instead");
	}

	return SecKeychainSearchCopyNext(searchRef, itemRef);
}