/* * Copyright (c) 2003 Apple Computer, Inc. All rights reserved. * * @APPLE_LICENSE_HEADER_START@ * * 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 OR NON-INFRINGEMENT. Please see the * License for the specific language governing rights and limitations * under the License. * * @APPLE_LICENSE_HEADER_END@ */ /* * keychain_lock.c * security * * Created by Michael Brouwer on Tue May 06 2003. * Copyright (c) 2003 Apple Computer, Inc. All rights reserved. * */ #include "keychain_lock.h" #include "keychain_utilities.h" #include "readline.h" #include #include #include #include #include static int do_lock_all(void) { OSStatus result = SecKeychainLockAll(); if (result) fprintf(stderr, "SecKeychainLockAll() returned %ld (0x%lx)\n", result, result); return result; } static int do_lock(const char *keychainName) { SecKeychainRef keychain = NULL; OSStatus result; if (keychainName) { keychain = keychain_open(keychainName); if (!keychain) { result = 1; goto loser; } } result = SecKeychainLock(keychain); if (result) { fprintf(stderr, "SecKeychainLock %s returned %ld(0x%lx)\n", keychainName ? keychainName : "", result, result); } loser: if (keychain) CFRelease(keychain); return result; } int keychain_lock(int argc, char * const *argv) { char *keychainName = NULL; int ch, result = 0; Boolean lockAll = FALSE; while ((ch = getopt(argc, argv, "ah")) != -1) { switch (ch) { case 'a': lockAll = TRUE; break; case '?': default: return 2; /* @@@ Return 2 triggers usage message. */ } } argc -= optind; argv += optind; if (argc == 1 && !lockAll) { keychainName = argv[0]; if (*keychainName == '\0') { result = 2; goto loser; } } else if (argc != 0) return 2; if (lockAll) result = do_lock_all(); else result = do_lock(keychainName); loser: return result; }