'\" te .\" Copyright (c) 2007, Sun Microsystems, Inc. All Rights Reserved. .\" 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. .\" 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. .\" 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] .TH scf_transaction_create 3SCF "28 Aug 2007" "SunOS 5.11" "Service Configuration Facility Library Functions" .SH NAME scf_transaction_create, scf_transaction_handle, scf_transaction_reset, scf_transaction_reset_all, scf_transaction_destroy, scf_transaction_destroy_children, scf_transaction_start, scf_transaction_property_delete, scf_transaction_property_new, scf_transaction_property_change, scf_transaction_property_change_type, scf_transaction_commit \- create and manipulate transaction in the Service Configuration Facility .SH SYNOPSIS .LP .nf cc [ \fIflag\fR\&.\|.\|. ] \fIfile\fR\&.\|.\|. \fB-lscf\fR [ \fIlibrary\fR\&.\|.\|. ] #include \fBscf_transaction_t *\fR\fBscf_transaction_create\fR(\fBscf_handle_t *\fR\fIhandle\fR); .fi .LP .nf \fBscf_handle_t *\fR\fBscf_transaction_handle\fR(\fBscf_transaction_t *\fR\fItran\fR); .fi .LP .nf \fBvoid\fR \fBscf_transaction_reset\fR(\fBscf_transaction_t *\fR\fItran\fR); .fi .LP .nf \fBvoid\fR \fBscf_transaction_reset_all\fR(\fBscf_transaction_t *\fR\fItran\fR); .fi .LP .nf \fBvoid\fR \fBscf_transaction_destroy\fR(\fBscf_transaction_t *\fR\fItran\fR); .fi .LP .nf \fBvoid\fR \fBscf_transaction_destroy_children\fR(\fBscf_transaction_t *\fR\fItran\fR); .fi .LP .nf \fBint\fR \fBscf_transaction_start\fR(\fBscf_transaction_t *\fR\fItran\fR, \fBscf_propertygroup_t *\fR\fIpg\fR); .fi .LP .nf \fBint\fR \fBscf_transaction_property_delete\fR(\fBscf_transaction_t *\fR\fItran\fR, \fBscf_transaction_entry_t *\fR\fIentry\fR, \fBconst char *\fR\fIprop_name\fR); .fi .LP .nf \fBint\fR \fBscf_transaction_property_new\fR(\fBscf_transaction_t *\fR\fItran\fR, \fBscf_transaction_entry_t *\fR\fIentry\fR, \fBconst char *\fR\fIprop_name\fR, \fBscf_type_t\fR \fItype\fR); .fi .LP .nf \fBint\fR \fBscf_transaction_property_change\fR(\fBscf_transaction_t *\fR\fItran\fR, \fBscf_transaction_entry_t *\fR\fIentry\fR, \fBconst char *\fR\fIprop_name\fR, \fBscf_type_t\fR \fItype\fR); .fi .LP .nf \fBint\fR \fBscf_transaction_property_change_type\fR( \fBscf_transaction_t *\fR\fItran\fR, \fBscf_transaction_entry_t *\fR\fIentry\fR, \fBconst char *\fR\fIprop_name\fR, \fBscf_type_t\fR \fItype\fR); .fi .LP .nf \fBint\fR \fBscf_transaction_commit\fR(\fBscf_transaction_t *\fR\fItran\fR); .fi .SH DESCRIPTION .sp .LP Transactions are the mechanism for changing property groups. They act atomically, whereby either all of the updates occur or none of them do. An \fBscf_transaction_t\fR is always in one of the following states: .sp .ne 2 .mk .na \fBreset\fR .ad .RS 13n .rt The initial state. A successful return of \fBscf_transaction_start()\fR moves the transaction to the started state. .RE .sp .ne 2 .mk .na \fBstarted\fR .ad .RS 13n .rt The transaction has started. The \fBscf_transaction_property_delete()\fR, \fBscf_transaction_property_new()\fR, \fBscf_transaction_property_change()\fR, and \fBscf_transaction_property_change_type()\fR functions can be used to set up changes to properties. The \fBscf_transaction_reset()\fR and \fBscf_transaction_reset_all()\fR functions return the transaction to the reset state. .RE .sp .ne 2 .mk .na \fBcommitted\fR .ad .RS 13n .rt A call to \fBscf_transaction_commit()\fR (whether or not it is successful) moves the transaction to the committed state. Modifying, resetting, or destroying the entries and values associated with a transaction will move it to the invalid state. .RE .sp .ne 2 .mk .na \fBinvalid\fR .ad .RS 13n .rt The \fBscf_transaction_reset()\fR and \fBscf_transaction_reset_all()\fR functions return the transaction to the reset state. .RE .sp .LP The \fBscf_transaction_create()\fR function allocates and initializes an \fBscf_transaction_t\fR bound to \fIhandle\fR. The \fBscf_transaction_destroy()\fR function resets, destroys, and frees \fItran\fR. If there are any entries associated with the transaction, \fBscf_transaction_destroy()\fR also effects a call to \fBscf_transaction_reset()\fR. The \fBscf_transaction_destroy_children()\fR function resets, destroys, and frees all entries and values associated the transaction. .sp .LP The \fBscf_transaction_handle()\fR function gets the handle to which \fItran\fR is bound. .sp .LP The \fBscf_transaction_start()\fR function sets up the transaction to modify the property group to which \fIpg\fR is set. The time reference used by \fIpg\fR becomes the basis of the transaction. The transaction fails if the property group has been modified since the last update of \fIpg\fR at the time when \fBscf_transaction_commit()\fR is called. .sp .LP The \fBscf_transaction_property_delete()\fR, \fBscf_transaction_property_new()\fR, \fBscf_transaction_property_change()\fR, and \fBscf_transaction_property_change_type()\fR functions add a new transaction entry to the transaction. Each property the transaction affects must have a unique \fBscf_transaction_entry_t\fR. Each \fBscf_transaction_entry_t\fR can be associated with only a single transaction at a time. These functions all fail if the transaction is not in the started state, \fIprop_name\fR is not a valid property name, or \fIentry\fR is already associated with a transaction. These functions affect commit and failure as follows: .sp .ne 2 .mk .na \fB\fBscf_transaction_property_delete()\fR\fR .ad .sp .6 .RS 4n This function deletes the property \fIprop_name\fR in the property group. It fails if \fIprop_name\fR does not name a property in the property group. .RE .sp .ne 2 .mk .na \fB\fBscf_transaction_property_new()\fR\fR .ad .sp .6 .RS 4n This function adds a new property prop_name\fI\fR to the property group with a value list of type \fItype\fR. It fails if \fIprop_name\fR names an existing property in the property group. .RE .sp .ne 2 .mk .na \fB\fBscf_transaction_property_change()\fR\fR .ad .sp .6 .RS 4n This function changes the value list for an existing property \fIprop_name\fR in the property group. It fails if \fIprop_name\fR does not name an existing property in the property group or names an existing property with a different type. .RE .sp .ne 2 .mk .na \fB\fBscf_transaction_property_change_type()\fR\fR .ad .sp .6 .RS 4n This function changes the value list and type for an existing property \fIprop_name\fR in the property group. It fails if \fIprop_name\fR does not name an existing property in the property group. .RE .sp .LP If the function call is successful, \fIentry\fR remains active in the transaction until \fBscf_transaction_destroy()\fR, \fBscf_transaction_reset()\fR, or \fBscf_transaction_reset_all()\fR is called. The \fBscf_entry_add_value\fR(3SCF) manual page provides information for setting up the value list for entries that are not associated with \fBscf_transaction_property_delete()\fR. Resetting or destroying an entry or value active in a transaction will move it into the invalid state. .sp .LP The \fBscf_transaction_commit()\fR function attempts to commit \fItran\fR. .sp .LP The \fBscf_transaction_reset()\fR function returns the transaction to the reset state and releases all of the transaction entries that were added. .sp .LP The \fBscf_transaction_reset_all()\fR function returns the transaction to the reset state, releases all of the transaction entries, and calls \fBscf_value_reset\fR(3SCF) on all values associated with the entries. .SH RETURN VALUES .sp .LP Upon successful completion, \fBscf_transaction_create()\fR returns a new \fBscf_transaction_t\fR. Otherwise, it returns \fINULL\fR. .sp .LP Upon successful completion, \fBscf_transaction_handle()\fR returns the handle associated with the transaction. Otherwise, it returns \fINULL\fR. .sp .LP Upon successful completion, \fBscf_transaction_start()\fR, \fBscf_transaction_property_delete()\fR, \fBscf_transaction_property_new()\fR, \fBscf_transaction_property_change()\fR, and \fBscf_transaction_property_change_type()\fR return 0. Otherwise, they return \(mi1. .sp .LP The \fBscf_transaction_commit()\fR function returns 1 upon successful commit, 0 if the property group set in \fBscf_transaction_start()\fR is not the most recent, and -1 on failure. .SH ERRORS .sp .LP The \fBscf_transaction_create()\fR function will fail if: .sp .ne 2 .mk .na \fB\fBSCF_ERROR_INVALID_ARGUMENT\fR\fR .ad .RS 30n .rt The value of the \fIhandle\fR argument is \fINULL\fR. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_NO_MEMORY\fR\fR .ad .RS 30n .rt There is not enough memory to allocate an \fBscf_transaction_t\fR. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_NO_RESOURCES\fR\fR .ad .RS 30n .rt The server does not have adequate resources for a new transaction handle. .RE .sp .LP The \fBscf_transaction_handle()\fR function will fail if: .sp .ne 2 .mk .na \fB\fBSCF_ERROR_HANDLE_DESTROYED\fR\fR .ad .RS 30n .rt The handle associated with \fItran\fR has been destroyed. .RE .sp .LP The \fBscf_transaction_start()\fR function will fail if: .sp .ne 2 .mk .na \fB\fBSCF_ERROR_BACKEND_ACCESS\fR\fR .ad .sp .6 .RS 4n The repository backend refused the modification. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_BACKEND_READONLY\fR\fR .ad .sp .6 .RS 4n The repository backend refused modification because it is read-only. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_CONNECTION_BROKEN\fR\fR .ad .sp .6 .RS 4n The connection to the repository was lost. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_DELETED\fR\fR .ad .sp .6 .RS 4n The property group has been deleted. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_HANDLE_MISMATCH\fR\fR .ad .sp .6 .RS 4n The transaction and property group are not derived from the same handle. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_IN_USE\fR\fR .ad .sp .6 .RS 4n The transaction is not in the \fBreset\fR state. The \fBscf_transaction_reset()\fR and \fBscf_transaction_reset_all()\fR functions can be used to return the transaction to the \fBreset\fR state. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_NO_RESOURCES\fR\fR .ad .sp .6 .RS 4n The server does not have the resources to complete the request. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_NOT_BOUND\fR\fR .ad .sp .6 .RS 4n The handle was never bound or has been unbound. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_NOT_SET\fR\fR .ad .sp .6 .RS 4n The property group specified by \fIpg\fR is not set. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_PERMISSION_DENIED\fR\fR .ad .sp .6 .RS 4n The user does not have sufficient privileges to modify the property group. .RE .sp .LP The \fBscf_transaction_property_delete()\fR, \fBscf_transaction_property_new()\fR, \fBscf_transaction_property_change()\fR, and \fBscf_transaction_property_change_type()\fR functions will fail if: .sp .ne 2 .mk .na \fB\fBSCF_ERROR_BACKEND_ACCESS\fR\fR .ad .sp .6 .RS 4n The storage mechanism that the repository server (\fBsvc.configd\fR(1M)) chose for the operation denied access. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_CONNECTION_BROKEN\fR\fR .ad .sp .6 .RS 4n The connection to the repository was lost. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_DELETED\fR\fR .ad .sp .6 .RS 4n The property group the transaction is changing has been deleted. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_HANDLE_MISMATCH\fR\fR .ad .sp .6 .RS 4n The transaction and entry are not derived from the same handle. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_IN_USE\fR\fR .ad .sp .6 .RS 4n The property already has an entry in the transaction. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_INTERNAL\fR\fR .ad .sp .6 .RS 4n An internal error occurred. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_INVALID_ARGUMENT\fR\fR .ad .sp .6 .RS 4n The \fIprop_name\fR argument is not a valid property name. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_NO_RESOURCES\fR\fR .ad .sp .6 .RS 4n The server does not have the resources to complete the request. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_NOT_BOUND\fR\fR .ad .sp .6 .RS 4n The handle is not bound. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_NOT_SET\fR\fR .ad .sp .6 .RS 4n The transaction has not been started. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_TYPE_MISMATCH\fR\fR .ad .sp .6 .RS 4n The \fItran\fR argument is not of a type compatible with \fItype\fR. .RE .sp .LP The \fBscf_transaction_property_delete()\fR, \fBscf_transaction_property_change()\fR, and \fBscf_transaction_property_change_type()\fR functions will fail if: .sp .ne 2 .mk .na \fB\fBSCF_ERROR_EXISTS\fR\fR .ad .RS 23n .rt The object already exists. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_NOT_FOUND\fR\fR .ad .RS 23n .rt The property group does not contain a property named \fIprop_name\fR. .RE .sp .LP The \fBscf_transaction_property_new()\fR , \fBscf_transaction_property_change()\fR, and \fBscf_transaction_property_change_type()\fR functions will fail if: .sp .ne 2 .mk .na \fB\fBSCF_ERROR_INVALID_ARGUMENT\fR\fR .ad .RS 30n .rt The \fIprop_name\fR argument is not not a valid property name, or the \fItype\fR argument is an invalid type. .RE .sp .LP The \fBscf_transaction_property_new()\fR function will fail if: .sp .ne 2 .mk .na \fB\fBSCF_ERROR_EXISTS\fR\fR .ad .RS 23n .rt The property group already contains a property named \fIprop_name\fR. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_NOT_FOUND\fR\fR .ad .RS 23n .rt Nothing of that name was found. .RE .sp .LP The \fBscf_transaction_property_change()\fR function will fail if: .sp .ne 2 .mk .na \fB\fBSCF_ERROR_TYPE_MISMATCH\fR\fR .ad .RS 27n .rt The property \fIprop_name\fR is not of type \fItype\fR. .RE .sp .LP The \fBscf_transaction_commit()\fR function will fail if: .sp .ne 2 .mk .na \fB\fBSCF_ERROR_BACKEND_READONLY\fR\fR .ad .sp .6 .RS 4n The repository backend is read-only. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_BACKEND_ACCESS\fR\fR .ad .sp .6 .RS 4n The repository backend refused the modification. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_NOT_BOUND\fR\fR .ad .sp .6 .RS 4n The handle is not bound. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_CONNECTION_BROKEN\fR\fR .ad .sp .6 .RS 4n The connection to the repository was lost. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_INVALID_ARGUMENT\fR\fR .ad .sp .6 .RS 4n The transaction is in an invalid state. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_DELETED\fR\fR .ad .sp .6 .RS 4n The property group the transaction is acting on has been deleted. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_NOT_SET\fR\fR .ad .sp .6 .RS 4n The transaction has not been started. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_PERMISSION_DENIED\fR\fR .ad .sp .6 .RS 4n The user does not have sufficient privileges to modify the property group. .RE .sp .ne 2 .mk .na \fB\fBSCF_ERROR_NO_RESOURCES\fR\fR .ad .sp .6 .RS 4n The server does not have sufficient resources to commit the transaction. .RE .sp .LP The \fBscf_error\fR(3SCF) function can be used to retrieve the error value. .SH EXAMPLES .LP \fBExample 1 \fRSet an existing boolean value to true. .sp .in +2 .nf tx = scf_transaction_create(handle); e1 = scf_entry_create(handle); v1 = scf_value_create(handle); do { if (scf_pg_update(pg) == -1) goto fail; if (scf_transaction_start(tx, pg) == -1) goto fail; /* set up transaction entries */ if (scf_transaction_property_change(tx, e1, "property", SCF_TYPE_BOOLEAN) == -1) { scf_transaction_reset(tx); goto fail; } scf_value_set_boolean(v1, 1); scf_entry_add_value(e1, v1); result = scf_transaction_commit(tx); scf_transaction_reset(tx); } while (result == 0); if (result < 0) goto fail; /* success */ cleanup: scf_transaction_destroy(tx); scf_entry_destroy(e1); scf_value_destroy(v1); .fi .in -2 .SH ATTRIBUTES .sp .LP See \fBattributes\fR(5) for descriptions of the following attributes: .sp .sp .TS tab() box; cw(2.75i) |cw(2.75i) lw(2.75i) |lw(2.75i) . ATTRIBUTE TYPEATTRIBUTE VALUE _ Interface StabilityCommitted _ MT-LevelSafe .TE .SH SEE ALSO .sp .LP \fBlibscf\fR(3LIB), \fBscf_value_reset\fR(3SCF), \fBscf_error\fR(3SCF), \fBscf_pg_create\fR(3SCF), \fBattributes\fR(5)