/* * Copyright (c) 2000 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.1 (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@ */ /* * Modification History * * June 1, 2001 Allan Nathanson * - public API conversion * * March 24, 2000 Allan Nathanson * - initial revision */ #include #include #include #include #include "SCDynamicStoreInternal.h" #include "config.h" /* MiG generated file */ Boolean SCDynamicStoreSetMultiple(SCDynamicStoreRef store, CFDictionaryRef keysToSet, CFArrayRef keysToRemove, CFArrayRef keysToNotify) { SCDynamicStorePrivateRef storePrivate = (SCDynamicStorePrivateRef)store; kern_return_t status; CFDataRef xmlSet = NULL; /* key/value pairs to set (XML serialized) */ xmlData_t mySetRef = NULL; /* key/value pairs to set (serialized) */ CFIndex mySetLen = 0; CFDataRef xmlRemove = NULL; /* keys to remove (XML serialized) */ xmlData_t myRemoveRef = NULL; /* keys to remove (serialized) */ CFIndex myRemoveLen = 0; CFDataRef xmlNotify = NULL; /* keys to notify (XML serialized) */ xmlData_t myNotifyRef = NULL; /* keys to notify (serialized) */ CFIndex myNotifyLen = 0; int sc_status; SCLog(_sc_verbose, LOG_DEBUG, CFSTR("SCDynamicStoreSetMultiple:")); SCLog(_sc_verbose, LOG_DEBUG, CFSTR(" keysToSet = %@"), keysToSet); SCLog(_sc_verbose, LOG_DEBUG, CFSTR(" keysToRemove = %@"), keysToRemove); SCLog(_sc_verbose, LOG_DEBUG, CFSTR(" keysToNotify = %@"), keysToNotify); if (!store) { /* sorry, you must provide a session */ _SCErrorSet(kSCStatusNoStoreSession); return NULL; } if (storePrivate->server == MACH_PORT_NULL) { _SCErrorSet(kSCStatusNoStoreServer); return NULL; /* you must have an open session to play */ } /* serialize the key/value pairs to set*/ if (keysToSet) { xmlSet = CFPropertyListCreateXMLData(NULL, keysToSet); mySetRef = (xmlData_t)CFDataGetBytePtr(xmlSet); mySetLen = CFDataGetLength(xmlSet); } /* serialize the keys to remove */ if (keysToRemove) { xmlRemove = CFPropertyListCreateXMLData(NULL, keysToRemove); myRemoveRef = (xmlData_t)CFDataGetBytePtr(xmlRemove); myRemoveLen = CFDataGetLength(xmlRemove); } /* serialize the keys to notify */ if (keysToNotify) { xmlNotify = CFPropertyListCreateXMLData(NULL, keysToNotify); myNotifyRef = (xmlData_t)CFDataGetBytePtr(xmlNotify); myNotifyLen = CFDataGetLength(xmlNotify); } /* send the keys and patterns, fetch the associated result from the server */ status = configset_m(storePrivate->server, mySetRef, mySetLen, myRemoveRef, myRemoveLen, myNotifyRef, myNotifyLen, (int *)&sc_status); /* clean up */ if (xmlSet) CFRelease(xmlSet); if (xmlRemove) CFRelease(xmlRemove); if (xmlNotify) CFRelease(xmlNotify); if (status != KERN_SUCCESS) { if (status != MACH_SEND_INVALID_DEST) SCLog(_sc_verbose, LOG_DEBUG, CFSTR("configset_m(): %s"), mach_error_string(status)); (void) mach_port_destroy(mach_task_self(), storePrivate->server); storePrivate->server = MACH_PORT_NULL; _SCErrorSet(status); return FALSE; } if (sc_status != kSCStatusOK) { _SCErrorSet(sc_status); return FALSE; } return TRUE; } Boolean SCDynamicStoreSetValue(SCDynamicStoreRef store, CFStringRef key, CFPropertyListRef value) { SCDynamicStorePrivateRef storePrivate = (SCDynamicStorePrivateRef)store; kern_return_t status; CFDataRef xmlKey; /* serialized key */ xmlData_t myKeyRef; CFIndex myKeyLen; CFDataRef xmlData; /* serialized data */ xmlData_t myDataRef; CFIndex myDataLen; int sc_status; int newInstance; SCLog(_sc_verbose, LOG_DEBUG, CFSTR("SCDynamicStoreSetValue:")); SCLog(_sc_verbose, LOG_DEBUG, CFSTR(" key = %@"), key); SCLog(_sc_verbose, LOG_DEBUG, CFSTR(" value = %@"), value); if (!store) { /* sorry, you must provide a session */ _SCErrorSet(kSCStatusNoStoreSession); return FALSE; } if (storePrivate->server == MACH_PORT_NULL) { /* sorry, you must have an open session to play */ _SCErrorSet(kSCStatusNoStoreServer); return FALSE; } /* serialize the key and data */ xmlKey = CFPropertyListCreateXMLData(NULL, key); myKeyRef = (xmlData_t)CFDataGetBytePtr(xmlKey); myKeyLen = CFDataGetLength(xmlKey); xmlData = CFPropertyListCreateXMLData(NULL, value); myDataRef = (xmlData_t)CFDataGetBytePtr(xmlData); myDataLen = CFDataGetLength(xmlData); /* send the key & data to the server, get new instance id */ status = configset(storePrivate->server, myKeyRef, myKeyLen, myDataRef, myDataLen, 0, &newInstance, (int *)&sc_status); /* clean up */ CFRelease(xmlKey); CFRelease(xmlData); if (status != KERN_SUCCESS) { if (status != MACH_SEND_INVALID_DEST) SCLog(_sc_verbose, LOG_DEBUG, CFSTR("configset(): %s"), mach_error_string(status)); (void) mach_port_destroy(mach_task_self(), storePrivate->server); storePrivate->server = MACH_PORT_NULL; _SCErrorSet(status); return FALSE; } if (sc_status != kSCStatusOK) { _SCErrorSet(sc_status); return FALSE; } return TRUE; }