2 .\" Copyright (c) 2008, Sun Microsystems Inc. All Rights Reserved.
3 .\" The contents of this file are subject to the terms of the Common Development and Distribution License (the "License"). You may not use this file except in compliance with the License.
4 .\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing. See the License for the specific language governing permissions and limitations under the License.
5 .\" When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE. If applicable, add the following below this CDDL HEADER, with the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
6 .TH SCF_TMPL_PG_NAME 3SCF "Oct 28, 2008"
8 scf_tmpl_pg_name, scf_tmpl_pg_type, scf_tmpl_pg_target, scf_tmpl_pg_required,
9 scf_tmpl_pg_common_name, scf_tmpl_pg_description \- retrieve the metadata about
10 a specific property group
14 cc [ \fIflag\fR\&.\|.\|. ] \fIfile\fR\&.\|.\|. \fB-lscf\fR [ \fIlibrary\fR\&.\|.\|. ]
17 \fBssize_t\fR \fBscf_tmpl_pg_name\fR(\fBconst scf_pg_tmpl_t *\fR\fIpg_tmpl\fR,
18 \fBchar **\fR\fIout\fR);
23 \fBssize_t\fR \fBscf_tmpl_pg_type\fR(\fBconst scf_pg_tmpl_t *\fR\fIpg_tmpl\fR,
24 \fBchar **\fR\fIout\fR);
29 \fBssize_t\fR \fBscf_tmpl_pg_target\fR(\fBconst scf_pg_tmpl_t *\fR\fIpg_tmpl\fR,
30 \fBchar **\fR\fIout\fR);
35 \fBint\fR \fBscf_tmpl_pg_required\fR(\fBconst scf_pg_tmpl_t *\fR\fIpg_tmpl\fR,
36 \fBuint8_t *\fR\fIout\fR)
41 \fBssize_t\fR \fBscf_tmpl_pg_common_name\fR(\fBconst scf_pg_tmpl_t *\fR\fIpg_tmpl\fR,
42 \fBchar *\fR \fIlocale\fR, \fBchar **\fR\fIout\fR);
47 \fBssize_t\fR \fBscf_tmpl_pg_description\fR(\fBconst scf_pg_tmpl_t *\fR\fIpg_tmpl\fR,
48 \fBchar *\fR \fIlocale\fR, \fBchar **\fR\fIout\fR);
54 These functions retrieve the metadata about a specific property group. They
55 require that the template for the property group has already been located by
56 one of the \fBscf_tmpl_pg_create\fR(3SCF) suite of functions.
59 The \fBscf_tmpl_pg_name()\fR function retrieves the name of the property group
60 template and place it in *\fIout\fR. If the property group name is implicitly
61 wildcarded (see \fBsmf_template\fR(5)) in the template, this function will
62 return a string containing \fBSCF_TMPL_WILDCARD\fR ("*") in *\fIout\fR. The
63 caller is responsible for freeing the *\fIout\fR buffer on success.
66 The \fBscf_tmpl_pg_type()\fR function will retrieve the type of the property
67 group template and place it in *\fIout\fR. If the property group type is
68 implicitly wildcarded (see \fBsmf_template\fR(5)) in the template, this
69 function will return a string containing \fBSCF_TMPL_WILDCARD\fR ("*") in
70 *\fIout\fR. The caller is responsible for freeing the *\fIout\fR buffer on
74 The \fBscf_tmpl_pg_target()\fR function will retrieve the target of the
75 property group template and place it in *\fIout\fR. The caller is responsible
76 for freeing the *\fIout\fR buffer on success.
79 The \fBscf_tmpl_pg_required()\fR function will determine whether the property
80 group is required and place the result of that check in *\fIout\fR. If required
81 is unset, \fIout\fR will be the default value of 0. If the property is
82 explicitly set to required, \fIout\fR will be 1.
85 The \fBscf_tmpl_pg_common_name()\fR function will retrieve the property group's
86 localized common name as currently templated and place it in *\fIout\fR. A
87 locale (as described in \fBsetlocale\fR(3C)) may be specified, or if the
88 supplied locale is NULL, the current locale will be used. If a common_name in
89 the specified locale is not found, the function will also look for a
90 common_name in the C locale. Some templates will not specify the property group
91 common name. The caller is responsible for freeing the *\fIout\fR buffer on
95 The \fBscf_tmpl_pg_description()\fR function will retrieve the property group's
96 localized description as currently templated and place it in *\fIout\fR. A
97 locale (as described in \fBsetlocale\fR(3C)) may be specified, or if the
98 supplied locale is NULL, the current locale will be used. If a description in
99 the specified locale is not found, the function will also look for a
100 description in the C locale. Some templates will not specify the property group
101 description. The caller is responsible for freeing the *\fIout\fR buffer on
106 Upon successful completion, \fBscf_tmpl_pg_name()\fR,
107 \fBscf_tmpl_pg_common_name()\fR, \fBscf_tmpl_pg_description()\fR,
108 \fBscf_tmpl_pg_target()\fR, and \fBscf_tmpl_pg_type()\fR return the length of
109 the string written, not including the terminating null byte. Otherwise, they
113 Upon successful completion, \fBscf_tmpl_pg_required()\fR returns 0. Otherwise,
118 The \fBscf_tmpl_pg_name()\fR, \fBscf_tmpl_pg_common_name()\fR,
119 \fBscf_tmpl_pg_description()\fR, \fBscf_tmpl_pg_required()\fR,
120 \fBscf_tmpl_pg_target()\fR, and \fBscf_tmpl_pg_type()\fR functions will fail
125 \fB\fBSCF_ERROR_BACKEND_ACCESS\fR\fR
129 The storage mechanism that the repository server (\fBsvc.configd\fR(1M)) chose
130 for the operation denied access.
136 \fB\fBSCF_ERROR_CONNECTION_BROKEN\fR\fR
140 The connection to the repository was lost.
146 \fB\fBSCF_ERROR_DELETED\fR\fR
150 The template property group has been deleted.
156 \fB\fBSCF_ERROR_HANDLE_DESTROYED\fR\fR
160 The handle passed in has been destroyed.
166 \fB\fBSCF_ERROR_INTERNAL\fR\fR
170 An internal error occurred.
176 \fB\fBSCF_ERROR_NO_MEMORY\fR\fR
180 There is not enough memory to populate the \fBscf_pg_tmpl_t\fR.
186 \fB\fBSCF_ERROR_NO_RESOURCES\fR\fR
190 The server does not have adequate resources to complete the request.
196 \fB\fBSCF_ERROR_NOT_BOUND\fR\fR
200 The handle is not currently bound.
206 \fB\fBSCF_ERROR_PERMISSION_DENIED\fR\fR
210 The template could not be read due to access restrictions.
216 \fB\fBSCF_ERROR_TEMPLATE_INVALID\fR\fR
220 The template data is invalid.
225 The \fBscf_tmpl_pg_common_name()\fR and \fBscf_tmpl_pg_description()\fR
226 functions will fail if:
230 \fB\fBSCF_ERROR_NOT_FOUND\fR\fR
233 The property does not exist or exists and has no value.
239 \fB\fBSCF_ERROR_INVALID_ARGUMENT\fR\fR
242 The locale string is too long.
248 See \fBattributes\fR(5) for descriptions of the following attributes:
256 ATTRIBUTE TYPE ATTRIBUTE VALUE
258 Interface Stability Committed
266 \fBsvc.configd\fR(1M), \fBscf_tmpl_pg_create\fR(3SCF), \fBsetlocale\fR(3C),
267 \fBattributes\fR(5), \fBsmf_template\fR(5)