libscf_priv.h revision 3175:5903f61aa150
1/*
2 * CDDL HEADER START
3 *
4 * The contents of this file are subject to the terms of the
5 * Common Development and Distribution License (the "License").
6 * You may not use this file except in compliance with the License.
7 *
8 * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
9 * or http://www.opensolaris.org/os/licensing.
10 * See the License for the specific language governing permissions
11 * and limitations under the License.
12 *
13 * When distributing Covered Code, include this CDDL HEADER in each
14 * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
15 * If applicable, add the following below this CDDL HEADER, with the
16 * fields enclosed by brackets "[]" replaced with your own identifying
17 * information: Portions Copyright [yyyy] [name of copyright owner]
18 *
19 * CDDL HEADER END
20 */
21/*
22 * Copyright 2006 Sun Microsystems, Inc.  All rights reserved.
23 * Use is subject to license terms.
24 */
25
26#ifndef	_LIBSCF_PRIV_H
27#define	_LIBSCF_PRIV_H
28
29#pragma ident	"%Z%%M%	%I%	%E% SMI"
30
31#include <libscf.h>
32#include <unistd.h>
33
34#ifdef	__cplusplus
35extern "C" {
36#endif
37
38/*
39 * NOTE
40 *
41 * The contents of this file are private to the implementation of Solaris
42 * and are subject to change at any time without notice.
43 */
44
45#define	SCF_PG_GENERAL_TYPE		SCF_GROUP_FRAMEWORK
46#define	SCF_PG_GENERAL_FLAGS		0
47
48#define	SCF_PG_GENERAL_OVR_TYPE		SCF_GROUP_FRAMEWORK
49#define	SCF_PG_GENERAL_OVR_FLAGS	SCF_PG_FLAG_NONPERSISTENT
50
51#define	SCF_PG_OPTIONS_TYPE		SCF_GROUP_FRAMEWORK
52#define	SCF_PG_OPTIONS_FLAGS		0
53
54#define	SCF_PG_OPTIONS_OVR_TYPE		SCF_GROUP_FRAMEWORK
55#define	SCF_PG_OPTIONS_OVR_FLAGS	SCF_PG_FLAG_NONPERSISTENT
56
57#define	SCF_PG_RESTARTER_TYPE		SCF_GROUP_FRAMEWORK
58#define	SCF_PG_RESTARTER_FLAGS		SCF_PG_FLAG_NONPERSISTENT
59
60#define	SCF_PG_RESTARTER_ACTIONS_TYPE	SCF_GROUP_FRAMEWORK
61#define	SCF_PG_RESTARTER_ACTIONS_FLAGS	SCF_PG_FLAG_NONPERSISTENT
62
63#define	SCF_PROPERTY_LOGFILE		((const char *)"logfile")
64#define	SCF_PROPERTY_ALT_LOGFILE	((const char *)"alt_logfile")
65
66#define	SCF_LEGACY_SERVICE		((const char *)"smf/legacy_run")
67
68#define	SCF_LEGACY_PROPERTY_NAME	((const char *)"name")
69#define	SCF_LEGACY_PROPERTY_INODE	((const char *)"inode")
70#define	SCF_LEGACY_PROPERTY_SUFFIX	((const char *)"suffix")
71
72#define	SCF_FMRI_TYPE_SVC		0x1
73#define	SCF_FMRI_TYPE_FILE		0x2
74
75typedef struct scf_decoration_info {
76	const char *sdi_name;
77	scf_type_t sdi_type;
78	scf_value_t *sdi_value;		/* can be SCF_DECORATE_CLEAR */
79} scf_decoration_info_t;
80
81typedef int (*scf_decoration_func)(const scf_decoration_info_t *, void *);
82
83/*
84 * calls a callback function for each decoration on the handle.  If the
85 * callback returns 0, the iteration stops and returns 0.  If the callback
86 * returns a non-zero value, the iteration continues.  After full completion,
87 * 1 is returned.  On error, -1 is returned.
88 */
89int _scf_handle_decorations(scf_handle_t *, scf_decoration_func *,
90    scf_value_t *, void *);
91
92/*
93 * wait for a change to the propertygroup -- may return early.
94 * For now, only one of these can be outstanding at a time.
95 *
96 * The second argument is how long, in seconds, to wait for a response.
97 *
98 * Returns SCF_COMPLETE on timeout, -1 on error, and SCF_SUCCESS in every
99 * other case.  You must call scf_pg_update() to see if the object has
100 * actually changed.
101 */
102int _scf_pg_wait(scf_propertygroup_t *, int);
103
104/*
105 * set up notifications for changes to a class of property groups (by name
106 * and type)
107 *
108 * Only one thread can be sleeping in _scf_notify_wait() -- others will
109 * fail.  Deletions give an fmri in the output path.
110 *
111 * These do not survive unbind()->bind() -- in fact, that is currently the
112 * only way to clear them.
113 */
114int _scf_notify_add_pgname(scf_handle_t *, const char *);
115int _scf_notify_add_pgtype(scf_handle_t *, const char *);
116int _scf_notify_wait(scf_propertygroup_t *, char *, size_t);
117
118/*
119 * Internal interfaces for snapshot creation:
120 *	_scf_snapshot_take_new(), _scf_snapshot_take_new_named(), and
121 *	_scf_snapshot_take_attach() create a set of snaplevels
122 *	containing frozen versions of both the instance's property groups and
123 *	its parent service's property groups. _scf_snapshot_take_new() and
124 *	_scf_snapshot_take_new_named() create a new snapshot to which the
125 *	new snaplevels are attached, while _scf_snapshot_take_attach()
126 *	attaches the new snaplevels to a pre-existing snapshot.
127 *
128 *	_scf_snapshot_take_new_named() records the passed in names into the
129 *	snaplevel instead of the instance and service name.  This creates
130 *	an inconsistency, which should be resolved by using
131 *	_scf_snapshot_attach() to attach the new snaplevels to a snapshot
132 *	underneath the appropriate instance.  The first snapshot can
133 *	then be deleted.
134 *
135 *	_scf_snapshot_attach(snap1, snap2) points snap2 at the snaplevels
136 *	pointed to by snap1.  After a call to either
137 *	_scf_snapshot_take_attach(snap1, snap2) or
138 *	_scf_snapshot_attach(inst, snap), scf_snapshot_update() will be
139 *	required for any open references to snap or snap2 to see the new
140 *	snaplevels.
141 *
142 *	_scf_snapshot_delete() deletes the snapshot object.  While
143 *	snaplevels, being only loosely connected to snapshots, stay
144 *	around until they are no longer referenced, any references *through
145 *	this snapshot object* will be invalidated.
146 *
147 * _scf_snapshot_take_new() can fail with at least _HANDLE_MISMATCH,
148 * _CONNECTION_BROKEN, _INVALID_ARGUMENT, _NO_RESOURCES, _PERMISSION_DENIED,
149 * _NOT_SET, _EXISTS.
150 *
151 * _scf_snapshot_take_new_named() can fail with at least _HANDLE_MISMATCH,
152 * _CONNECTION_BROKEN, _INVALID_ARGUMENT, _NO_RESOURCES, _PERMISSION_DENIED,
153 * _NOT_SET, _EXISTS.
154 *
155 * _scf_snapshot_take_attach() can fail with _CONNECTION_BROKEN, _NOT_SET,
156 * _PERMISSION_DENIED, _NO_RESOURCES, _INVALID_ARGUMENT.
157 *
158 * _scf_snapshot_attach() can fail with _HANDLE_MISMATCH, _CONNECTION_BROKEN,
159 * _NOT_SET, _NO_RESOURCES, _PERMISSION_DENIED.
160 */
161int _scf_snapshot_take_new(scf_instance_t *, const char *, scf_snapshot_t *);
162int _scf_snapshot_take_new_named(scf_instance_t *,
163    const char *, const char *, const char *, scf_snapshot_t *);
164int _scf_snapshot_take_attach(scf_instance_t *, scf_snapshot_t *);
165int _scf_snapshot_attach(scf_snapshot_t *, scf_snapshot_t *);
166int _scf_snapshot_delete(scf_snapshot_t *);
167
168/*
169 * Destructively portions up the first argument into the different portions
170 * of a svc: fmri, and returns pointers to the applicable portions.  Omitted
171 * portions are set to NULL, except for the scope, which is set to the
172 * default local scope if not specified.
173 *
174 * Parsing is attempted in the order of: svc:, file:. The identified type
175 * of the service is returned in the second argument and may take a value
176 * of: SCF_FMRI_TYPE_SVC or SCF_FMRI_TYPE_FILE.
177 *
178 * Note that some of the returned pointers (in particular the scope) may not
179 * point into the passed buffer.
180 */
181int scf_parse_fmri(char *, int *, const char **, const char **, const char **,
182    const char **, const char **);
183
184int scf_parse_svc_fmri(char *, const char **, const char **, const char **,
185    const char **, const char **);
186
187int scf_parse_file_fmri(char *fmri, const char **scope, const char **path);
188
189ssize_t scf_canonify_fmri(const char *, char *, size_t);
190
191const char *scf_type_to_string(scf_type_t);
192scf_type_t scf_string_to_type(const char *);
193
194int _smf_refresh_instance_i(scf_instance_t *);
195
196/*
197 * Walks all the instances matching a given fmri list.  Each fmri in the array
198 * can be one of the following:
199 *
200 * 	- Full instance name
201 * 	- Full service name
202 * 	- Full property group or property name
203 * 	- Partial service or instance name
204 * 	- A globbed pattern
205 *
206 * The matching rules for partial fmris are a slightly more complex.  We allow
207 * for any substring anchored at the end of the instance or service name,
208 * provided it begins with a complete element in the fmri.  For example, given
209 * the fmri "svc:/system/filesystem/local:default", any of the following would
210 * be acceptable matches: 'default', 'local', 'local:default',
211 * 'filesystem/local'.  The following would not be acceptable:
212 * 'system/filesystem', 'filesystem/loc', 'system/local'.  Possible flag values:
213 *
214 * 	SCF_WALK_MULTIPLE	Allow individual arguments to correspond to
215 * 				multiple instances.
216 *
217 * 	SCF_WALK_LEGACY		Walk legacy services (indicated by a non-NULL
218 * 				propery group).
219 *
220 * 	SCF_WALK_SERVICE	If the user specifies a service, pass the
221 * 				service to the callback without iterating over
222 * 				its instances.
223 *
224 * 	SCF_WALK_PROPERTY	Allow FMRIs which match property groups or
225 * 				individual properties.  Incompatible with
226 * 				SCF_WALK_LEGACY.
227 *
228 * 	SCF_WALK_NOINSTANCE	Walk only services.  Must be used in
229 * 				conjunction with SCF_WALK_SERVICE.
230 *
231 * 	SCF_WALK_EXPLICIT	Walk only services if the match is exact
232 *				else return instances. Must be used in
233 *				conjunction with SCF_WALK_SERVICE.
234 *
235 * If no arguments are given, then all instances in the service graph are
236 * walked.
237 *
238 * The second to last parameter is set to UU_EXIT_FATAL if one of the arguments
239 * is an invalid FMRI or matches multiple FMRIs when SCF_WALK_MULTIPLE is not
240 * set.
241 *
242 * The last parameter is a user-supplied error function that is called when
243 * reporting invalid arguments.
244 */
245
246#define	SCF_WALK_MULTIPLE	0x01
247#define	SCF_WALK_LEGACY		0x02
248#define	SCF_WALK_SERVICE	0x04
249#define	SCF_WALK_PROPERTY	0x08
250#define	SCF_WALK_NOINSTANCE	0x10
251#define	SCF_WALK_EXPLICIT	0x20
252
253typedef struct scf_walkinfo {
254	const char		*fmri;
255	scf_scope_t		*scope;
256	scf_service_t		*svc;
257	scf_instance_t		*inst;
258	scf_propertygroup_t	*pg;
259	scf_property_t		*prop;
260	int			count;	/* svcprop special */
261} scf_walkinfo_t;
262
263typedef int (*scf_walk_callback)(void *, scf_walkinfo_t *);
264
265scf_error_t scf_walk_fmri(scf_handle_t *, int, char **, int,
266    scf_walk_callback, void *, int *, void (*)(const char *, ...));
267
268/*
269 * Requests a backup of the repository with a particular name, which
270 * can be any alphabetic string.  Only privileged users can do this.
271 *
272 * Can fail with:
273 *	_NOT_BOUND, _CONNECTION_BROKEN, _PERMISSION_DENIED, _INVALID_ARGUMENT,
274 *	_INTERNAL (path too long, or the backup failed for an odd reason),
275 *	_BACKEND_READONLY (filesystem is still read-only)
276 */
277int _scf_request_backup(scf_handle_t *, const char *);
278
279/*
280 * scf_pattern_t
281 */
282typedef struct scf_pattern {
283	enum	{
284		PATTERN_INVALID,	/* Uninitialized state */
285		PATTERN_EXACT,
286		PATTERN_GLOB,
287		PATTERN_PARTIAL
288	} sp_type;
289	char			*sp_arg;	/* Original argument */
290	struct scf_match	*sp_matches;	/* List of matches */
291	int			sp_matchcount;	/* # of matches */
292} scf_pattern_t;
293
294int scf_cmp_pattern(char *, scf_pattern_t *);
295
296int gen_filenms_from_fmri(const char *, const char *, char *, char *);
297
298#ifdef	__cplusplus
299}
300#endif
301
302#endif	/* _LIBSCF_PRIV_H */
303