|  |  |  | libnm-util Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | Properties | ||||
#include <nm-setting-connection.h>
                    NMSettingConnection;
                    NMSettingConnectionClass;
enum                NMSettingConnectionError;
#define             NM_SETTING_CONNECTION_AUTOCONNECT
#define             NM_SETTING_CONNECTION_ERROR
#define             NM_SETTING_CONNECTION_ID
#define             NM_SETTING_CONNECTION_MASTER
#define             NM_SETTING_CONNECTION_PERMISSIONS
#define             NM_SETTING_CONNECTION_READ_ONLY
#define             NM_SETTING_CONNECTION_SECONDARIES
#define             NM_SETTING_CONNECTION_SETTING_NAME
#define             NM_SETTING_CONNECTION_SLAVE_TYPE
#define             NM_SETTING_CONNECTION_TIMESTAMP
#define             NM_SETTING_CONNECTION_TYPE
#define             NM_SETTING_CONNECTION_UUID
#define             NM_SETTING_CONNECTION_ZONE
gboolean            nm_setting_connection_add_permission
                                                        (NMSettingConnection *setting,
                                                         const char *ptype,
                                                         const char *pitem,
                                                         const char *detail);
gboolean            nm_setting_connection_add_secondary (NMSettingConnection *setting,
                                                         const char *sec_uuid);
GQuark              nm_setting_connection_error_quark   (void);
gboolean            nm_setting_connection_get_autoconnect
                                                        (NMSettingConnection *setting);
const char *        nm_setting_connection_get_connection_type
                                                        (NMSettingConnection *setting);
const char *        nm_setting_connection_get_id        (NMSettingConnection *setting);
const char *        nm_setting_connection_get_master    (NMSettingConnection *setting);
guint32             nm_setting_connection_get_num_permissions
                                                        (NMSettingConnection *setting);
guint32             nm_setting_connection_get_num_secondaries
                                                        (NMSettingConnection *setting);
gboolean            nm_setting_connection_get_permission
                                                        (NMSettingConnection *setting,
                                                         guint32 idx,
                                                         const char **out_ptype,
                                                         const char **out_pitem,
                                                         const char **out_detail);
gboolean            nm_setting_connection_get_read_only (NMSettingConnection *setting);
const char *        nm_setting_connection_get_secondary (NMSettingConnection *setting,
                                                         guint32 idx);
const char *        nm_setting_connection_get_slave_type
                                                        (NMSettingConnection *setting);
guint64             nm_setting_connection_get_timestamp (NMSettingConnection *setting);
const char *        nm_setting_connection_get_uuid      (NMSettingConnection *setting);
const char *        nm_setting_connection_get_zone      (NMSettingConnection *setting);
gboolean            nm_setting_connection_is_slave_type (NMSettingConnection *setting,
                                                         const char *type);
NMSetting *         nm_setting_connection_new           (void);
gboolean            nm_setting_connection_permissions_user_allowed
                                                        (NMSettingConnection *setting,
                                                         const char *uname);
void                nm_setting_connection_remove_permission
                                                        (NMSettingConnection *setting,
                                                         guint32 idx);
void                nm_setting_connection_remove_secondary
                                                        (NMSettingConnection *setting,
                                                         guint32 idx);
GObject +----NMSetting +----NMSettingConnection
GEnum +----NMSettingConnectionError
"autoconnect" gboolean : Read / Write / Construct "id" gchar* : Read / Write "master" gchar* : Read / Write "permissions" GSList_gchararray_* : Read / Write "read-only" gboolean : Read / Write / Construct "secondaries" GSList_gchararray_* : Read / Write "slave-type" gchar* : Read / Write "timestamp" guint64 : Read / Write / Construct "type" gchar* : Read / Write "uuid" gchar* : Read / Write "zone" gchar* : Read / Write / Construct
The NMSettingConnection object is a NMSetting subclass that describes properties that apply to all NMConnection objects, regardless of what type of network connection they describe. Each NMConnection object must contain a NMSettingConnection setting.
typedef struct _NMSettingConnection NMSettingConnection;
The NMSettingConnection struct contains only private data. It should only be accessed through the functions described below.
typedef struct {
	NMSettingClass parent;
	/* Padding for future expansion */
	void (*_reserved1) (void);
	void (*_reserved2) (void);
	void (*_reserved3) (void);
	void (*_reserved4) (void);
} NMSettingConnectionClass;
typedef enum {
	NM_SETTING_CONNECTION_ERROR_UNKNOWN = 0,            /*< nick=UnknownError >*/
	NM_SETTING_CONNECTION_ERROR_INVALID_PROPERTY,       /*< nick=InvalidProperty >*/
	NM_SETTING_CONNECTION_ERROR_MISSING_PROPERTY,       /*< nick=MissingProperty >*/
	NM_SETTING_CONNECTION_ERROR_TYPE_SETTING_NOT_FOUND, /*< nick=TypeSettingNotFound >*/
	NM_SETTING_CONNECTION_ERROR_IP_CONFIG_NOT_ALLOWED,  /*< nick=IpConfigNotAllowed >*/
} NMSettingConnectionError;
Describes errors that may result from operations involving a NMSettingConnection.
| unknown or unclassified error | |
| the property's value is invalid | |
| a required property is not present | |
| the NMSetting object referenced by the setting name contained in the "type" property was not present in the NMConnection | |
| ip configuration is not allowed to be present. | 
#define NM_SETTING_CONNECTION_ERROR nm_setting_connection_error_quark ()
gboolean nm_setting_connection_add_permission (NMSettingConnection *setting,const char *ptype,const char *pitem,const char *detail);
Adds a permission to the connection's permission list.  At this time, only
the "user" permission type is supported, and pitem must be a username. See
"permissions": for more details.
| 
 | the NMSettingConnection | 
| 
 | the permission type; at this time only "user" is supported | 
| 
 | the permission item formatted as required for ptype | 
| 
 | unused at this time; must be NULL. [allow-none] | 
| Returns : | TRUE if the permission was unique and was successfully added to the
list, FALSE if ptypeorpitemwas invalid or it the permission was already
present in the list | 
gboolean nm_setting_connection_add_secondary (NMSettingConnection *setting,const char *sec_uuid);
Adds a new secondary connetion UUID to the setting.
| 
 | the NMSettingConnection | 
| 
 | the secondary connection UUID to add | 
| Returns : | TRUEif the secondary connection UUID was added;FALSEif the UUID
was already present | 
Since 0.9.8
GQuark              nm_setting_connection_error_quark   (void);
Registers an error quark for NMSettingConnection if necessary.
| Returns : | the error quark used for NMSettingConnection errors. | 
gboolean            nm_setting_connection_get_autoconnect
                                                        (NMSettingConnection *setting);
Returns the "autoconnect" property of the connection.
| 
 | the NMSettingConnection | 
| Returns : | the connection's autoconnect behavior | 
const char *        nm_setting_connection_get_connection_type
                                                        (NMSettingConnection *setting);
Returns the "type" property of the connection.
| 
 | the NMSettingConnection | 
| Returns : | the connection type | 
const char *        nm_setting_connection_get_id        (NMSettingConnection *setting);
Returns the "id" property of the connection.
| 
 | the NMSettingConnection | 
| Returns : | the connection ID | 
const char *        nm_setting_connection_get_master    (NMSettingConnection *setting);
Returns the "master" property of the connection.
| 
 | the NMSettingConnection | 
| Returns : | interface name of the master device or UUID of the master connection. | 
guint32             nm_setting_connection_get_num_permissions
                                                        (NMSettingConnection *setting);
Returns the number of entires in the "permissions" property of this setting.
| 
 | the NMSettingConnection | 
| Returns : | the number of permissions entires | 
guint32             nm_setting_connection_get_num_secondaries
                                                        (NMSettingConnection *setting);
| 
 | the NMSettingConnection | 
| Returns : | the number of configured secondary connection UUIDs | 
Since 0.9.8
gboolean nm_setting_connection_get_permission (NMSettingConnection *setting,guint32 idx,const char **out_ptype,const char **out_pitem,const char **out_detail);
Retrieve one of the entries of the "permissions" property of this setting.
| 
 | the NMSettingConnection | 
| 
 | the zero-based index of the permissions entry | 
| 
 | on return, the permission type (at this time, always "user") | 
| 
 | on return, the permission item (formatted accoring to ptype, see
"permissions" for more detail | 
| 
 | on return, the permission detail (at this time, always NULL) | 
| Returns : | TRUEif a permission was returned,FALSEifidxwas invalid | 
gboolean            nm_setting_connection_get_read_only (NMSettingConnection *setting);
Returns the "read-only" property of the connection.
| 
 | the NMSettingConnection | 
| Returns : | TRUEif the connection is read-only,FALSEif it is not | 
const char * nm_setting_connection_get_secondary (NMSettingConnection *setting,guint32 idx);
| 
 | the NMSettingConnection | 
| 
 | the zero-based index of the secondary connection UUID entry | 
| Returns : | the secondary connection UUID at index idx | 
Since 0.9.8
const char *        nm_setting_connection_get_slave_type
                                                        (NMSettingConnection *setting);
Returns the "slave-type" property of the connection.
| 
 | the NMSettingConnection | 
| Returns : | the type of slave this connection is, if any | 
guint64             nm_setting_connection_get_timestamp (NMSettingConnection *setting);
Returns the "timestamp" property of the connection.
| 
 | the NMSettingConnection | 
| Returns : | the connection's timestamp | 
const char *        nm_setting_connection_get_uuid      (NMSettingConnection *setting);
Returns the "uuid" property of the connection.
| 
 | the NMSettingConnection | 
| Returns : | the connection UUID | 
const char *        nm_setting_connection_get_zone      (NMSettingConnection *setting);
Returns the "zone" property of the connection.
| 
 | the NMSettingConnection | 
| Returns : | the trust level of a connection | 
gboolean nm_setting_connection_is_slave_type (NMSettingConnection *setting,const char *type);
| 
 | the NMSettingConnection | 
| 
 | the setting name (ie NM_SETTING_BOND_SETTING_NAME) to be matched
against setting's slave type | 
| Returns : | TRUE if connection is of the given slave type | 
NMSetting *         nm_setting_connection_new           (void);
Creates a new NMSettingConnection object with default values.
| Returns : | the new empty NMSettingConnection object | 
gboolean nm_setting_connection_permissions_user_allowed (NMSettingConnection *setting,const char *uname);
Checks whether the given username is allowed to view/access this connection.
| 
 | the NMSettingConnection | 
| 
 | the user name to check permissions for | 
| Returns : | TRUEif the requested user is allowed to view this connection,FALSEif the given user is not allowed to view this connection | 
void nm_setting_connection_remove_permission (NMSettingConnection *setting,guint32 idx);
Removes the permission at index idx from the connection.
| 
 | the NMSettingConnection | 
| 
 | the zero-based index of the permission to remove | 
void nm_setting_connection_remove_secondary (NMSettingConnection *setting,guint32 idx);
Removes the secondary coonnection UUID at index idx.
| 
 | the NMSettingConnection | 
| 
 | index number of the secondary connection UUID | 
Since 0.9.8
"autoconnect" property"autoconnect" gboolean : Read / Write / Construct
Whether or not the connection should be automatically connected by
NetworkManager when the resources for the connection are available.
TRUE to automatically activate the connection, FALSE to require manual
intervention to activate the connection.  Defaults to TRUE.
Default value: TRUE
"id" property"id" gchar* : Read / Write
A human readable unique idenfier for the connection, like "Work WiFi" or "T-Mobile 3G".
Default value: NULL
"master" property"master" gchar* : Read / Write
Interface name of the master device or UUID of the master connection.
Default value: NULL
"permissions" property  "permissions"              GSList_gchararray_*   : Read / Write
An array of strings defining what access a given user has to this connection. If this is NULL or empty, all users are allowed to access this connection. Otherwise a user is allowed to access this connection if and only if they are in this list. Each entry is of the form "[type]:[id]:[reserved]", for example:
user:dcbw:blah
At this time only the 'user' [type] is allowed. Any other values are ignored and reserved for future use. [id] is the username that this permission refers to, which may not contain the ':' character. Any [reserved] information present must be ignored and is reserved for future use. All of [type], [id], and [reserved] must be valid UTF-8.
"read-only" property"read-only" gboolean : Read / Write / Construct
TRUE if the connection can be modified using the providing settings
service's D-Bus interface with the right privileges, or FALSE
if the connection is read-only and cannot be modified.
Default value: FALSE
"secondaries" property  "secondaries"              GSList_gchararray_*   : Read / Write
List of connection UUIDs that should be activated when the base connection itself is activated.
Since 0.9.8
"slave-type" property"slave-type" gchar* : Read / Write
Setting name describing the type of slave device (ie NM_SETTING_BOND_SETTING_NAME) or NULL if this connection is not a slave.
Default value: NULL
"timestamp" property"timestamp" guint64 : Read / Write / Construct
The time, in seconds since the Unix Epoch, that the connection was last _successfully_ fully activated.
Default value: 0
"type" property"type" gchar* : Read / Write
The general hardware type of the device used for the network connection, contains the name of the NMSetting object that describes that hardware type's parameters. For example, for WiFi devices, the name of the NMSettingWireless setting.
Default value: NULL
"uuid" property"uuid" gchar* : Read / Write
A universally unique idenfier for the connection, for example generated with libuuid. Should be assigned when the connection is created, and never changed as long as the connection still applies to the same network. For example, should not be changed when the "id" or NMSettingIP4Config changes, but might need to be re-created when the WiFi SSID, mobile broadband network provider, or "type" changes.
The UUID must be in the format '2815492f-7e56-435e-b2e9-246bd7cdc664'
(ie, contains only hexadecimal characters and '-').  A suitable UUID may
be generated by nm_utils_uuid_generate() or
nm_utils_uuid_generate_from_string().
Default value: NULL
"zone" property"zone" gchar* : Read / Write / Construct
The trust level of a the connection. Free form case-insensitive string (for example "Home", "Work", "Public"). NULL or unspecified zone means the connection will be placed in the default zone as defined by the firewall.
Default value: NULL