/*1* Copyright (c) 2009 Kungliga Tekniska H�gskolan2* (Royal Institute of Technology, Stockholm, Sweden).3* All rights reserved.4*5* Portions Copyright (c) 2009 Apple Inc. All rights reserved.6*7* Redistribution and use in source and binary forms, with or without8* modification, are permitted provided that the following conditions9* are met:10*11* 1. Redistributions of source code must retain the above copyright12* notice, this list of conditions and the following disclaimer.13*14* 2. Redistributions in binary form must reproduce the above copyright15* notice, this list of conditions and the following disclaimer in the16* documentation and/or other materials provided with the distribution.17*18* 3. Neither the name of the Institute nor the names of its contributors19* may be used to endorse or promote products derived from this software20* without specific prior written permission.21*22* THIS SOFTWARE IS PROVIDED BY THE INSTITUTE AND CONTRIBUTORS ``AS IS'' AND23* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE24* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE25* ARE DISCLAIMED. IN NO EVENT SHALL THE INSTITUTE OR CONTRIBUTORS BE LIABLE26* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL27* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS28* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)29* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT30* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY31* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF32* SUCH DAMAGE.33*/3435#include "kcm_locl.h"3637#if 038#include <bsm/audit_session.h>39#endif4041void42kcm_session_add(pid_t session_id)43{44kcm_log(1, "monitor session: %d\n", session_id);45}4647void48kcm_session_setup_handler(void)49{50#if 051au_sdev_handle_t *h;52dispatch_queue_t bgq;5354h = au_sdev_open(AU_SDEVF_ALLSESSIONS);55if (h == NULL)56return;5758bgq = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_LOW, 0);5960dispatch_async(bgq, ^{61for (;;) {62auditinfo_addr_t aio;63int event;6465if (au_sdev_read_aia(h, &event, &aio) != 0)66continue;6768/*69* Ignore everything but END. This should relly be70* CLOSE but since that is delayed until the credential71* is reused, we can't do that72* */73if (event != AUE_SESSION_END)74continue;7576dispatch_async(dispatch_get_main_queue(), ^{77kcm_cache_remove_session(aio.ai_asid);78});79}80});81#endif82}838485