SCF_HANDLE_CREATE(3SCF) Service Configuration Facility Library Functions
NAME
scf_handle_create, scf_handle_destroy, scf_handle_decorate,
scf_handle_bind, scf_handle_unbind, scf_myname - Service
Configuration Facility handle functions
SYNOPSIS
cc [
flag... ]
file...
-lscf [
library... ]
#include <libscf.h>
scf_handle_t *scf_handle_create(
scf_version_t version);
void scf_handle_destroy(
scf_handle_t *handle);
int scf_handle_decorate(
scf_handle_t *handle,
const char *param,
scf_value_t *value);
int scf_handle_bind(
scf_handle_t *handle);
int scf_handle_unbind(
scf_handle_t *handle);
ssize_t scf_myname(
scf_handle_t *handle,
char *out,
size_t sz);
DESCRIPTION
The
scf_handle_create() function creates a new Service Configuration
Facility handle that is used as the base for all communication with
the configuration repository. The version argument must be
SCF_VERSION.
The
scf_handle_decorate() function sets a single connection-level
parameter,
param, to the supplied value. If
value is
SCF_DECORATE_CLEAR,
param is reset to its default state. Values
passed to
scf_handle_decorate() can be reset, reused, or destroyed.
The values set do not take effect until
scf_handle_bind() is called.
Any invalid values will not cause errors prior to the call to
scf_handle_bind(). The only available decorations is:
debug (count) Set the debugging flags.
The
scf_handle_bind() function binds the handle to a running
svc.configd(8) daemon, using the current decorations to modify the
connection. All states derived from the handle are reset immediately
after a successful binding.
The
scf_handle_unbind() function severs an existing repository
connection or clears the in-client state for a broken connection.
The
scf_handle_destroy() function destroys and frees an SCF handle.
It is illegal to use the handle after calling
scf_handle_destroy().
Actions on subordinate objects act as if the handle is unbound.
The
scf_myname() function retrieves the FMRI for the service of which
the connecting process is a part. If the full FMRI does not fit in
the provided buffer, it is truncated and, if
sz > 0, zero-terminated.
RETURN VALUES
Upon successful completion,
scf_handle_create() returns the new
handle. Otherwise, it returns
NULL.
Upon successful completion,
scf_handle_decorate(),
scf_handle_bind(),
and
scf_handle_unbind() return 0. Otherwise, they return -1.
The
scf_myname() function returns the length of the full FMRI.
Otherwise, it returns -1.
ERRORS
The
scf_handle_create() function will fail if:
SCF_ERROR_NO_MEMORY There is no memory available.
SCF_ERROR_VERSION_MISMATCH The version is invalid, or the
application was compiled against a
version of the library that is more
recent than the one on the system.
The
scf_handle_decorate() function will fail if:
SCF_ERROR_INVALID_ARGUMENT The
param argument is not a recognized
parameter.
SCF_ERROR_TYPE_MISMATCH The
value argument does not match the
expected type for param.
SCF_ERROR_NOT_SET The
value argument is not set.
SCF_ERROR_IN_USE The handle is currently bound.
SCF_ERROR_HANDLE_MISMATCH The
value argument is not derived from
handle.
The
scf_handle_bind() function will fail if:
SCF_ERROR_INVALID_ARGUMENT One of the decorations was invalid.
SCF_ERROR_NO_SERVER The repository server is not running.
SCF_ERROR_NO_RESOURCES The server does not have adequate
resources for a new connection.
SCF_ERROR_IN_USE The handle is already bound.
The
scf_handle_unbind() function will fail if:
SCF_ERROR_NOT_BOUND The handle is not bound.
The
scf_handle_myname() function will fail if:
SCF_ERROR_CONNECTION_BROKEN The connection to the repository was lost.
SCF_ERROR_NOT_BOUND The handle is not bound.
SCF_ERROR_NOT_SET This process is not marked as a SMF service.
The
scf_error(3SCF) function can be used to retrieve the error value.
ATTRIBUTES
See
attributes(7) for descriptions of the following attributes:
+--------------------+-----------------+
| ATTRIBUTE TYPE | ATTRIBUTE VALUE |
+--------------------+-----------------+
|Interface Stability | Committed |
+--------------------+-----------------+
|MT-Level | See below. |
+--------------------+-----------------+
Operations on a single handle (and the objects associated with it)
are Safe. Operations on different handles are MT-Safe. Objects
associated with different handles cannot be mixed, as this will lead
to an
SCF_ERROR_HANDLE_MISMATCH error.
SEE ALSO
libscf(3LIB),
scf_error(3SCF),
attributes(7) August 17, 2007 SCF_HANDLE_CREATE(3SCF)