#include "configd.h"
#include "session.h"
int
__SCDynamicStoreTouchValue(SCDynamicStoreRef store, CFStringRef key)
{
SCDynamicStorePrivateRef storePrivate = (SCDynamicStorePrivateRef)store;
int sc_status;
Boolean newValue = FALSE;
CFPropertyListRef value;
SCLog(_configd_verbose, LOG_DEBUG, CFSTR("__SCDynamicStoreTouchValue:"));
SCLog(_configd_verbose, LOG_DEBUG, CFSTR(" key = %@"), key);
if (!store || (storePrivate->server == MACH_PORT_NULL)) {
return kSCStatusNoStoreSession;
}
sc_status = __SCDynamicStoreLock(store, TRUE);
if (sc_status != kSCStatusOK) {
return sc_status;
}
sc_status = __SCDynamicStoreCopyValue(store, key, &value);
switch (sc_status) {
case kSCStatusNoKey :
value = CFDateCreate(NULL, CFAbsoluteTimeGetCurrent());
newValue = TRUE;
SCLog(_configd_verbose, LOG_DEBUG, CFSTR(" new time stamp = %@"), value);
break;
case kSCStatusOK :
if (CFGetTypeID(value) == CFDateGetTypeID()) {
CFRelease(value);
value = CFDateCreate(NULL, CFAbsoluteTimeGetCurrent());
newValue = TRUE;
SCLog(_configd_verbose, LOG_DEBUG, CFSTR(" new time stamp = %@"), value);
}
break;
default :
SCLog(_configd_verbose, LOG_DEBUG, CFSTR(" __SCDynamicStoreCopyValue(): %s"), SCErrorString(sc_status));
goto done;
}
sc_status = __SCDynamicStoreSetValue(store, key, value);
if (newValue) {
CFRelease(value);
}
done :
__SCDynamicStoreUnlock(store, TRUE);
return kSCStatusOK;
}
kern_return_t
_configtouch(mach_port_t server,
xmlData_t keyRef,
mach_msg_type_number_t keyLen,
int *sc_status
)
{
kern_return_t status;
serverSessionRef mySession = getSession(server);
CFDataRef xmlKey;
CFStringRef key;
CFStringRef xmlError;
SCLog(_configd_verbose, LOG_DEBUG, CFSTR("Touch key in configuration database."));
SCLog(_configd_verbose, LOG_DEBUG, CFSTR(" server = %d"), server);
xmlKey = CFDataCreate(NULL, keyRef, keyLen);
status = vm_deallocate(mach_task_self(), (vm_address_t)keyRef, keyLen);
if (status != KERN_SUCCESS) {
SCLog(_configd_verbose, LOG_DEBUG, CFSTR("vm_deallocate(): %s"), mach_error_string(status));
}
key = CFPropertyListCreateFromXMLData(NULL,
xmlKey,
kCFPropertyListImmutable,
&xmlError);
CFRelease(xmlKey);
if (!key) {
if (xmlError) {
SCLog(_configd_verbose, LOG_DEBUG,
CFSTR("CFPropertyListCreateFromXMLData() key: %@"),
xmlError);
CFRelease(xmlError);
}
*sc_status = kSCStatusFailed;
return KERN_SUCCESS;
} else if (!isA_CFString(key)) {
*sc_status = kSCStatusInvalidArgument;
return KERN_SUCCESS;
}
*sc_status = __SCDynamicStoreTouchValue(mySession->store, key);
CFRelease(key);
return KERN_SUCCESS;
}