]> git.saurik.com Git - apple/configd.git/blob - SystemConfiguration.fproj/SCDGet.c
configd-204.tar.gz
[apple/configd.git] / SystemConfiguration.fproj / SCDGet.c
1 /*
2 * Copyright (c) 2000-2005 Apple Computer, Inc. All rights reserved.
3 *
4 * @APPLE_LICENSE_HEADER_START@
5 *
6 * This file contains Original Code and/or Modifications of Original Code
7 * as defined in and that are subject to the Apple Public Source License
8 * Version 2.0 (the 'License'). You may not use this file except in
9 * compliance with the License. Please obtain a copy of the License at
10 * http://www.opensource.apple.com/apsl/ and read it before using this
11 * file.
12 *
13 * The Original Code and all software distributed under the License are
14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
18 * Please see the License for the specific language governing rights and
19 * limitations under the License.
20 *
21 * @APPLE_LICENSE_HEADER_END@
22 */
23
24 /*
25 * Modification History
26 *
27 * June 1, 2001 Allan Nathanson <ajn@apple.com>
28 * - public API conversion
29 *
30 * March 24, 2000 Allan Nathanson <ajn@apple.com>
31 * - initial revision
32 */
33
34 #include <mach/mach.h>
35 #include <mach/mach_error.h>
36
37 #include <SystemConfiguration/SystemConfiguration.h>
38 #include <SystemConfiguration/SCPrivate.h>
39 #include "SCDynamicStoreInternal.h"
40 #include "config.h" /* MiG generated file */
41
42
43 CFDictionaryRef
44 SCDynamicStoreCopyMultiple(SCDynamicStoreRef store,
45 CFArrayRef keys,
46 CFArrayRef patterns)
47 {
48 SCDynamicStorePrivateRef storePrivate = (SCDynamicStorePrivateRef)store;
49 kern_return_t status;
50 CFDataRef xmlKeys = NULL; /* keys (XML serialized) */
51 xmlData_t myKeysRef = NULL; /* keys (serialized) */
52 CFIndex myKeysLen = 0;
53 CFDataRef xmlPatterns = NULL; /* patterns (XML serialized) */
54 xmlData_t myPatternsRef = NULL; /* patterns (serialized) */
55 CFIndex myPatternsLen = 0;
56 xmlDataOut_t xmlDictRef; /* dict (serialized) */
57 mach_msg_type_number_t xmlDictLen;
58 CFDictionaryRef dict = NULL; /* dict (un-serialized) */
59 CFDictionaryRef expDict = NULL; /* dict (un-serialized / expanded) */
60 int sc_status;
61
62 if (store == NULL) {
63 /* sorry, you must provide a session */
64 _SCErrorSet(kSCStatusNoStoreSession);
65 return NULL;
66 }
67
68 if (storePrivate->server == MACH_PORT_NULL) {
69 _SCErrorSet(kSCStatusNoStoreServer);
70 return NULL; /* you must have an open session to play */
71 }
72
73 /* serialize the keys */
74 if (keys) {
75 if (!_SCSerialize(keys, &xmlKeys, (void **)&myKeysRef, &myKeysLen)) {
76 _SCErrorSet(kSCStatusFailed);
77 return NULL;
78 }
79 }
80
81 /* serialize the patterns */
82 if (patterns) {
83 if (!_SCSerialize(patterns, &xmlPatterns, (void **)&myPatternsRef, &myPatternsLen)) {
84 CFRelease(xmlKeys);
85 _SCErrorSet(kSCStatusFailed);
86 return NULL;
87 }
88 }
89
90 /* send the keys and patterns, fetch the associated result from the server */
91 status = configget_m(storePrivate->server,
92 myKeysRef,
93 myKeysLen,
94 myPatternsRef,
95 myPatternsLen,
96 &xmlDictRef,
97 &xmlDictLen,
98 (int *)&sc_status);
99
100 /* clean up */
101 if (xmlKeys) CFRelease(xmlKeys);
102 if (xmlPatterns) CFRelease(xmlPatterns);
103
104 if (status != KERN_SUCCESS) {
105 #ifdef DEBUG
106 if (status != MACH_SEND_INVALID_DEST)
107 SCLog(_sc_verbose, LOG_DEBUG, CFSTR("SCDynamicStoreCopyMultiple configget_m(): %s"), mach_error_string(status));
108 #endif /* DEBUG */
109 (void) mach_port_destroy(mach_task_self(), storePrivate->server);
110 storePrivate->server = MACH_PORT_NULL;
111 _SCErrorSet(status);
112 return NULL;
113 }
114
115 if (sc_status != kSCStatusOK) {
116 status = vm_deallocate(mach_task_self(), (vm_address_t)xmlDictRef, xmlDictLen);
117 #ifdef DEBUG
118 if (status != KERN_SUCCESS) {
119 SCLog(TRUE, LOG_DEBUG, CFSTR("SCDynamicStoreCopyMultiple vm_deallocate(): %s"), mach_error_string(status));
120 /* non-fatal???, proceed */
121 }
122 #endif /* DEBUG */
123 _SCErrorSet(sc_status);
124 return NULL;
125 }
126
127 /* un-serialize the dictionary */
128 if (!_SCUnserialize((CFPropertyListRef *)&dict, NULL, xmlDictRef, xmlDictLen)) {
129 _SCErrorSet(kSCStatusFailed);
130 return NULL;
131 }
132
133 expDict = _SCUnserializeMultiple(dict);
134 CFRelease(dict);
135
136 return expDict;
137 }
138
139
140 CFPropertyListRef
141 SCDynamicStoreCopyValue(SCDynamicStoreRef store, CFStringRef key)
142 {
143 SCDynamicStorePrivateRef storePrivate = (SCDynamicStorePrivateRef)store;
144 kern_return_t status;
145 CFDataRef utfKey; /* key (XML serialized) */
146 xmlData_t myKeyRef; /* key (serialized) */
147 CFIndex myKeyLen;
148 xmlDataOut_t xmlDataRef; /* data (serialized) */
149 mach_msg_type_number_t xmlDataLen;
150 CFPropertyListRef data; /* data (un-serialized) */
151 int newInstance;
152 int sc_status;
153
154 if (store == NULL) {
155 /* sorry, you must provide a session */
156 _SCErrorSet(kSCStatusNoStoreSession);
157 return NULL;
158 }
159
160 if (storePrivate->server == MACH_PORT_NULL) {
161 _SCErrorSet(kSCStatusNoStoreServer);
162 return NULL; /* you must have an open session to play */
163 }
164
165 /* serialize the key */
166 if (!_SCSerializeString(key, &utfKey, (void **)&myKeyRef, &myKeyLen)) {
167 _SCErrorSet(kSCStatusFailed);
168 return NULL;
169 }
170
171 /* send the key & fetch the associated data from the server */
172 status = configget(storePrivate->server,
173 myKeyRef,
174 myKeyLen,
175 &xmlDataRef,
176 &xmlDataLen,
177 &newInstance,
178 (int *)&sc_status);
179
180 /* clean up */
181 CFRelease(utfKey);
182
183 if (status != KERN_SUCCESS) {
184 #ifdef DEBUG
185 if (status != MACH_SEND_INVALID_DEST)
186 SCLog(_sc_verbose, LOG_DEBUG, CFSTR("SCDynamicStoreCopyValue configget(): %s"), mach_error_string(status));
187 #endif /* DEBUG */
188 (void) mach_port_destroy(mach_task_self(), storePrivate->server);
189 storePrivate->server = MACH_PORT_NULL;
190 _SCErrorSet(status);
191 return NULL;
192 }
193
194 if (sc_status != kSCStatusOK) {
195 status = vm_deallocate(mach_task_self(), (vm_address_t)xmlDataRef, xmlDataLen);
196 #ifdef DEBUG
197 if (status != KERN_SUCCESS) {
198 SCLog(TRUE, LOG_DEBUG, CFSTR("SCDynamicStoreCopyValue vm_deallocate(): %s"), mach_error_string(status));
199 /* non-fatal???, proceed */
200 }
201 #endif /* DEBUG */
202 _SCErrorSet(sc_status);
203 return NULL;
204 }
205
206 /* un-serialize the data */
207 if (!_SCUnserialize(&data, NULL, xmlDataRef, xmlDataLen)) {
208 _SCErrorSet(kSCStatusFailed);
209 return NULL;
210 }
211
212 return data;
213 }