dwww Home | Manual pages | Find package

NM-SETTINGS-NMCLI(5)             Configuration            NM-SETTINGS-NMCLI(5)

NAME
       nm-settings-nmcli - Description of settings and properties of
       NetworkManager connection profiles for nmcli

DESCRIPTION
       NetworkManager is based on a concept of connection profiles, sometimes
       referred to as connections only. These connection profiles contain a
       network configuration. When NetworkManager activates a connection
       profile on a network device the configuration will be applied and an
       active network connection will be established. Users are free to create
       as many connection profiles as they see fit. Thus they are flexible in
       having various network configurations for different networking needs.

       NetworkManager provides an API for configuring connection profiles, for
       activating them to configure the network, and inspecting the current
       network configuration. The command line tool nmcli is a client
       application to NetworkManager that uses this API. See nmcli(1) for
       details.

       With commands like nmcli connection add, nmcli connection modify and
       nmcli connection show, connection profiles can be created, modified and
       inspected. A profile consists of properties. On D-Bus this follows the
       format as described by nm-settings-dbus(5), while this manual page
       describes the settings format how they are expected by nmcli.

       The settings and properties shown in tables below list all available
       connection configuration options. However, note that not all settings
       are applicable to all connection types.  nmcli connection editor has
       also a built-in describe command that can display description of
       particular settings and properties of this page.

       The setting and property can be abbreviated provided they are unique.
       The list below also shows aliases that can be used unqualified instead
       of the full name. For example connection.interface-name and ifname
       refer to the same property.

   connection setting
       General Connection Profile Settings.

       Properties:

       auth-retries
           The number of retries for the authentication. Zero means to try
           indefinitely; -1 means to use a global default. If the global
           default is not set, the authentication retries for 3 times before
           failing the connection. Currently, this only applies to 802-1x
           authentication.

           Format: int32

       autoconnect
           Alias: autoconnect

           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. Autoconnect happens
           when the circumstances are suitable. That means for example that
           the device is currently managed and not active. Autoconnect thus
           never replaces or competes with an already active profile. Note
           that autoconnect is not implemented for VPN profiles. See
           "secondaries" as an alternative to automatically connect VPN
           profiles.

           Format: boolean

       autoconnect-priority
           The autoconnect priority in range -999 to 999. If the connection is
           set to autoconnect, connections with higher priority will be
           preferred. The higher number means higher priority. Defaults to 0.
           Note that this property only matters if there are more than one
           candidate profile to select for autoconnect. In case of equal
           priority, the profile used most recently is chosen.

           Format: int32

       autoconnect-retries
           The number of times a connection should be tried when
           autoactivating before giving up. Zero means forever, -1 means the
           global default (4 times if not overridden). Setting this to 1 means
           to try activation only once before blocking autoconnect. Note that
           after a timeout, NetworkManager will try to autoconnect again.

           Format: int32

       autoconnect-slaves
           Whether or not slaves of this connection should be automatically
           brought up when NetworkManager activates this connection. This only
           has a real effect for master connections. The properties
           "autoconnect", "autoconnect-priority" and "autoconnect-retries" are
           unrelated to this setting. The permitted values are: 0: leave slave
           connections untouched, 1: activate all the slave connections with
           this connection, -1: default. If -1 (default) is set, global
           connection.autoconnect-slaves is read to determine the real value.
           If it is default as well, this fallbacks to 0.

           Format: NMSettingConnectionAutoconnectSlaves (int32)

       dns-over-tls
           Whether DNSOverTls (dns-over-tls) is enabled for the connection.
           DNSOverTls is a technology which uses TLS to encrypt dns traffic.
           The permitted values are: "yes" (2) use DNSOverTls and disabled
           fallback, "opportunistic" (1) use DNSOverTls but allow fallback to
           unencrypted resolution, "no" (0) don't ever use DNSOverTls. If
           unspecified "default" depends on the plugin used. Systemd-resolved
           uses global setting. This feature requires a plugin which supports
           DNSOverTls. Otherwise, the setting has no effect. One such plugin
           is dns-systemd-resolved.

           Format: int32

       gateway-ping-timeout
           If greater than zero, delay success of IP addressing until either
           the timeout is reached, or an IP gateway replies to a ping.

           Format: uint32

       id
           Alias: con-name

           A human readable unique identifier for the connection, like "Work
           Wi-Fi" or "T-Mobile 3G".

           Format: string

       interface-name
           Alias: ifname

           The name of the network interface this connection is bound to. If
           not set, then the connection can be attached to any interface of
           the appropriate type (subject to restrictions imposed by other
           settings). For software devices this specifies the name of the
           created device. For connection types where interface names cannot
           easily be made persistent (e.g. mobile broadband or USB Ethernet),
           this property should not be used. Setting this property restricts
           the interfaces a connection can be used with, and if interface
           names change or are reordered the connection may be applied to the
           wrong interface.

           Format: string

       lldp
           Whether LLDP is enabled for the connection.

           Format: int32

       llmnr
           Whether Link-Local Multicast Name Resolution (LLMNR) is enabled for
           the connection. LLMNR is a protocol based on the Domain Name System
           (DNS) packet format that allows both IPv4 and IPv6 hosts to perform
           name resolution for hosts on the same local link. The permitted
           values are: "yes" (2) register hostname and resolving for the
           connection, "no" (0) disable LLMNR for the interface, "resolve" (1)
           do not register hostname but allow resolving of LLMNR host names If
           unspecified, "default" ultimately depends on the DNS plugin (which
           for systemd-resolved currently means "yes"). This feature requires
           a plugin which supports LLMNR. Otherwise, the setting has no
           effect. One such plugin is dns-systemd-resolved.

           Format: int32

       master
           Alias: master

           Interface name of the master device or UUID of the master
           connection.

           Format: string

       mdns
           Whether mDNS is enabled for the connection. The permitted values
           are: "yes" (2) register hostname and resolving for the connection,
           "no" (0) disable mDNS for the interface, "resolve" (1) do not
           register hostname but allow resolving of mDNS host names and
           "default" (-1) to allow lookup of a global default in
           NetworkManager.conf. If unspecified, "default" ultimately depends
           on the DNS plugin (which for systemd-resolved currently means
           "no"). This feature requires a plugin which supports mDNS.
           Otherwise, the setting has no effect. One such plugin is
           dns-systemd-resolved.

           Format: int32

       metered
           Whether the connection is metered. When updating this property on a
           currently activated connection, the change takes effect
           immediately.

           Format: NMMetered (int32)

       mud-url
           If configured, set to a Manufacturer Usage Description (MUD) URL
           that points to manufacturer-recommended network policies for IoT
           devices. It is transmitted as a DHCPv4 or DHCPv6 option. The value
           must be a valid URL starting with "https://". The special value
           "none" is allowed to indicate that no MUD URL is used. If the
           per-profile value is unspecified (the default), a global connection
           default gets consulted. If still unspecified, the ultimate default
           is "none".

           Format: string

       multi-connect
           Specifies whether the profile can be active multiple times at a
           particular moment. The value is of type NMConnectionMultiConnect.

           Format: int32

       permissions
           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 users are allowed if and only if
           they are in this list. When this is not empty, the connection can
           be active only when one of the specified users is logged into an
           active session. 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.

           Format: array of string

       read-only
           FALSE if the connection can be modified using the provided settings
           service's D-Bus interface with the right privileges, or TRUE if the
           connection is read-only and cannot be modified.

           Format: boolean

       secondaries
           List of connection UUIDs that should be activated when the base
           connection itself is activated. Currently, only VPN connections are
           supported.

           Format: array of string

       slave-type
           Alias: slave-type

           Setting name of the device type of this slave's master connection
           (eg, "bond"), or NULL if this connection is not a slave.

           Format: string

       stable-id
           This represents the identity of the connection used for various
           purposes. It allows to configure multiple profiles to share the
           identity. Also, the stable-id can contain placeholders that are
           substituted dynamically and deterministically depending on the
           context. The stable-id is used for generating IPv6 stable private
           addresses with ipv6.addr-gen-mode=stable-privacy. It is also used
           to seed the generated cloned MAC address for
           ethernet.cloned-mac-address=stable and
           wifi.cloned-mac-address=stable. It is also used as DHCP client
           identifier with ipv4.dhcp-client-id=stable and to derive the DHCP
           DUID with ipv6.dhcp-duid=stable-[llt,ll,uuid]. Note that depending
           on the context where it is used, other parameters are also seeded
           into the generation algorithm. For example, a per-host key is
           commonly also included, so that different systems end up generating
           different IDs. Or with ipv6.addr-gen-mode=stable-privacy, also the
           device's name is included, so that different interfaces yield
           different addresses. The per-host key is the identity of your
           machine and stored in /var/lib/NetworkManager/secret-key. The '$'
           character is treated special to perform dynamic substitutions at
           runtime. Currently, supported are "${CONNECTION}", "${DEVICE}",
           "${MAC}", "${BOOT}", "${RANDOM}". These effectively create unique
           IDs per-connection, per-device, per-boot, or every time. Note that
           "${DEVICE}" corresponds to the interface name of the device and
           "${MAC}" is the permanent MAC address of the device. Any
           unrecognized patterns following '$' are treated verbatim, however
           are reserved for future use. You are thus advised to avoid '$' or
           escape it as "$$". For example, set it to
           "${CONNECTION}-${BOOT}-${DEVICE}" to create a unique id for this
           connection that changes with every reboot and differs depending on
           the interface where the profile activates. If the value is unset, a
           global connection default is consulted. If the value is still
           unset, the default is similar to "${CONNECTION}" and uses a unique,
           fixed ID for the connection.

           Format: string

       timestamp
           The time, in seconds since the Unix Epoch, that the connection was
           last _successfully_ fully activated. NetworkManager updates the
           connection timestamp periodically when the connection is active to
           ensure that an active connection has the latest timestamp. The
           property is only meant for reading (changes to this property will
           not be preserved).

           Format: uint64

       type
           Alias: type

           Base type of the connection. For hardware-dependent connections,
           should contain the setting name of the hardware-type specific
           setting (ie, "802-3-ethernet" or "802-11-wireless" or "bluetooth",
           etc), and for non-hardware dependent connections like VPN or
           otherwise, should contain the setting name of that setting type
           (ie, "vpn" or "bridge", etc).

           Format: string

       uuid
           A universally unique identifier for the connection, for example
           generated with libuuid. It should be assigned when the connection
           is created, and never changed as long as the connection still
           applies to the same network. For example, it should not be changed
           when the "id" property or NMSettingIP4Config changes, but might
           need to be re-created when the Wi-Fi SSID, mobile broadband network
           provider, or "type" property changes. The UUID must be in the
           format "2815492f-7e56-435e-b2e9-246bd7cdc664" (ie, contains only
           hexadecimal characters and "-").

           Format: string

       wait-device-timeout
           Timeout in milliseconds to wait for device at startup. During boot,
           devices may take a while to be detected by the driver. This
           property will cause to delay NetworkManager-wait-online.service and
           nm-online to give the device a chance to appear. This works by
           waiting for the given timeout until a compatible device for the
           profile is available and managed. The value 0 means no wait time.
           The default value is -1, which currently has the same meaning as no
           wait time.

           Format: int32

       zone
           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. When updating this property on a currently
           activated connection, the change takes effect immediately.

           Format: string

   6lowpan setting
       6LoWPAN Settings.

       Properties:

       parent
           Alias: dev

           If given, specifies the parent interface name or parent connection
           UUID from which this 6LowPAN interface should be created.

           Format: string

   802-1x setting
       IEEE 802.1x Authentication Settings.

       Properties:

       altsubject-matches
           List of strings to be matched against the altSubjectName of the
           certificate presented by the authentication server. If the list is
           empty, no verification of the server certificate's altSubjectName
           is performed.

           Format: array of string

       anonymous-identity
           Anonymous identity string for EAP authentication methods. Used as
           the unencrypted identity with EAP types that support different
           tunneled identity like EAP-TTLS.

           Format: string

       auth-timeout
           A timeout for the authentication. Zero means the global default; if
           the global default is not set, the authentication timeout is 25
           seconds.

           Format: int32

       ca-cert
           Contains the CA certificate if used by the EAP method specified in
           the "eap" property. Certificate data is specified using a "scheme";
           three are currently supported: blob, path and pkcs#11 URL. When
           using the blob scheme this property should be set to the
           certificate's DER encoded data. When using the path scheme, this
           property should be set to the full UTF-8 encoded path of the
           certificate, prefixed with the string "file://" and ending with a
           terminating NUL byte. This property can be unset even if the EAP
           method supports CA certificates, but this allows man-in-the-middle
           attacks and is NOT recommended. Note that enabling
           NMSetting8021x:system-ca-certs will override this setting to use
           the built-in path, if the built-in path is not a directory.

           Format: byte array

       ca-cert-password
           The password used to access the CA certificate stored in "ca-cert"
           property. Only makes sense if the certificate is stored on a
           PKCS#11 token that requires a login.

           Format: string

       ca-cert-password-flags
           Flags indicating how to handle the "ca-cert-password" property. See
           the section called “Secret flag types:” for flag values.

           Format: NMSettingSecretFlags (uint32)

       ca-path
           UTF-8 encoded path to a directory containing PEM or DER formatted
           certificates to be added to the verification chain in addition to
           the certificate specified in the "ca-cert" property. If
           NMSetting8021x:system-ca-certs is enabled and the built-in CA path
           is an existing directory, then this setting is ignored.

           Format: string

       client-cert
           Contains the client certificate if used by the EAP method specified
           in the "eap" property. Certificate data is specified using a
           "scheme"; two are currently supported: blob and path. When using
           the blob scheme (which is backwards compatible with NM 0.7.x) this
           property should be set to the certificate's DER encoded data. When
           using the path scheme, this property should be set to the full
           UTF-8 encoded path of the certificate, prefixed with the string
           "file://" and ending with a terminating NUL byte.

           Format: byte array

       client-cert-password
           The password used to access the client certificate stored in
           "client-cert" property. Only makes sense if the certificate is
           stored on a PKCS#11 token that requires a login.

           Format: string

       client-cert-password-flags
           Flags indicating how to handle the "client-cert-password" property.
           See the section called “Secret flag types:” for flag values.

           Format: NMSettingSecretFlags (uint32)

       domain-match
           Constraint for server domain name. If set, this list of FQDNs is
           used as a match requirement for dNSName element(s) of the
           certificate presented by the authentication server. If a matching
           dNSName is found, this constraint is met. If no dNSName values are
           present, this constraint is matched against SubjectName CN using
           the same comparison. Multiple valid FQDNs can be passed as a ";"
           delimited list.

           Format: string

       domain-suffix-match
           Constraint for server domain name. If set, this FQDN is used as a
           suffix match requirement for dNSName element(s) of the certificate
           presented by the authentication server. If a matching dNSName is
           found, this constraint is met. If no dNSName values are present,
           this constraint is matched against SubjectName CN using same suffix
           match comparison. Since version 1.24, multiple valid FQDNs can be
           passed as a ";" delimited list.

           Format: string

       eap
           The allowed EAP method to be used when authenticating to the
           network with 802.1x. Valid methods are: "leap", "md5", "tls",
           "peap", "ttls", "pwd", and "fast". Each method requires different
           configuration using the properties of this setting; refer to
           wpa_supplicant documentation for the allowed combinations.

           Format: array of string

       identity
           Identity string for EAP authentication methods. Often the user's
           user or login name.

           Format: string

       optional
           Whether the 802.1X authentication is optional. If TRUE, the
           activation will continue even after a timeout or an authentication
           failure. Setting the property to TRUE is currently allowed only for
           Ethernet connections. If set to FALSE, the activation can continue
           only after a successful authentication.

           Format: boolean

       pac-file
           UTF-8 encoded file path containing PAC for EAP-FAST.

           Format: string

       password
           UTF-8 encoded password used for EAP authentication methods. If both
           the "password" property and the "password-raw" property are
           specified, "password" is preferred.

           Format: string

       password-flags
           Flags indicating how to handle the "password" property. See the
           section called “Secret flag types:” for flag values.

           Format: NMSettingSecretFlags (uint32)

       password-raw
           Password used for EAP authentication methods, given as a byte array
           to allow passwords in other encodings than UTF-8 to be used. If
           both the "password" property and the "password-raw" property are
           specified, "password" is preferred.

           Format: byte array

       password-raw-flags
           Flags indicating how to handle the "password-raw" property. See the
           section called “Secret flag types:” for flag values.

           Format: NMSettingSecretFlags (uint32)

       phase1-auth-flags
           Specifies authentication flags to use in "phase 1" outer
           authentication using NMSetting8021xAuthFlags options. The
           individual TLS versions can be explicitly disabled. If a certain
           TLS disable flag is not set, it is up to the supplicant to allow or
           forbid it. The TLS options map to tls_disable_tlsv1_x settings. See
           the wpa_supplicant documentation for more details.

           Format: uint32

       phase1-fast-provisioning
           Enables or disables in-line provisioning of EAP-FAST credentials
           when FAST is specified as the EAP method in the "eap" property.
           Recognized values are "0" (disabled), "1" (allow unauthenticated
           provisioning), "2" (allow authenticated provisioning), and "3"
           (allow both authenticated and unauthenticated provisioning). See
           the wpa_supplicant documentation for more details.

           Format: string

       phase1-peaplabel
           Forces use of the new PEAP label during key derivation. Some RADIUS
           servers may require forcing the new PEAP label to interoperate with
           PEAPv1. Set to "1" to force use of the new PEAP label. See the
           wpa_supplicant documentation for more details.

           Format: string

       phase1-peapver
           Forces which PEAP version is used when PEAP is set as the EAP
           method in the "eap" property. When unset, the version reported by
           the server will be used. Sometimes when using older RADIUS servers,
           it is necessary to force the client to use a particular PEAP
           version. To do so, this property may be set to "0" or "1" to force
           that specific PEAP version.

           Format: string

       phase2-altsubject-matches
           List of strings to be matched against the altSubjectName of the
           certificate presented by the authentication server during the inner
           "phase 2" authentication. If the list is empty, no verification of
           the server certificate's altSubjectName is performed.

           Format: array of string

       phase2-auth
           Specifies the allowed "phase 2" inner authentication method when an
           EAP method that uses an inner TLS tunnel is specified in the "eap"
           property. For TTLS this property selects one of the supported
           non-EAP inner methods: "pap", "chap", "mschap", "mschapv2" while
           "phase2-autheap" selects an EAP inner method. For PEAP this selects
           an inner EAP method, one of: "gtc", "otp", "md5" and "tls". Each
           "phase 2" inner method requires specific parameters for successful
           authentication; see the wpa_supplicant documentation for more
           details. Both "phase2-auth" and "phase2-autheap" cannot be
           specified.

           Format: string

       phase2-autheap
           Specifies the allowed "phase 2" inner EAP-based authentication
           method when TTLS is specified in the "eap" property. Recognized
           EAP-based "phase 2" methods are "md5", "mschapv2", "otp", "gtc",
           and "tls". Each "phase 2" inner method requires specific parameters
           for successful authentication; see the wpa_supplicant documentation
           for more details.

           Format: string

       phase2-ca-cert
           Contains the "phase 2" CA certificate if used by the EAP method
           specified in the "phase2-auth" or "phase2-autheap" properties.
           Certificate data is specified using a "scheme"; three are currently
           supported: blob, path and pkcs#11 URL. When using the blob scheme
           this property should be set to the certificate's DER encoded data.
           When using the path scheme, this property should be set to the full
           UTF-8 encoded path of the certificate, prefixed with the string
           "file://" and ending with a terminating NUL byte. This property can
           be unset even if the EAP method supports CA certificates, but this
           allows man-in-the-middle attacks and is NOT recommended. Note that
           enabling NMSetting8021x:system-ca-certs will override this setting
           to use the built-in path, if the built-in path is not a directory.

           Format: byte array

       phase2-ca-cert-password
           The password used to access the "phase2" CA certificate stored in
           "phase2-ca-cert" property. Only makes sense if the certificate is
           stored on a PKCS#11 token that requires a login.

           Format: string

       phase2-ca-cert-password-flags
           Flags indicating how to handle the "phase2-ca-cert-password"
           property. See the section called “Secret flag types:” for flag
           values.

           Format: NMSettingSecretFlags (uint32)

       phase2-ca-path
           UTF-8 encoded path to a directory containing PEM or DER formatted
           certificates to be added to the verification chain in addition to
           the certificate specified in the "phase2-ca-cert" property. If
           NMSetting8021x:system-ca-certs is enabled and the built-in CA path
           is an existing directory, then this setting is ignored.

           Format: string

       phase2-client-cert
           Contains the "phase 2" client certificate if used by the EAP method
           specified in the "phase2-auth" or "phase2-autheap" properties.
           Certificate data is specified using a "scheme"; two are currently
           supported: blob and path. When using the blob scheme (which is
           backwards compatible with NM 0.7.x) this property should be set to
           the certificate's DER encoded data. When using the path scheme,
           this property should be set to the full UTF-8 encoded path of the
           certificate, prefixed with the string "file://" and ending with a
           terminating NUL byte. This property can be unset even if the EAP
           method supports CA certificates, but this allows man-in-the-middle
           attacks and is NOT recommended.

           Format: byte array

       phase2-client-cert-password
           The password used to access the "phase2" client certificate stored
           in "phase2-client-cert" property. Only makes sense if the
           certificate is stored on a PKCS#11 token that requires a login.

           Format: string

       phase2-client-cert-password-flags
           Flags indicating how to handle the "phase2-client-cert-password"
           property. See the section called “Secret flag types:” for flag
           values.

           Format: NMSettingSecretFlags (uint32)

       phase2-domain-match
           Constraint for server domain name. If set, this list of FQDNs is
           used as a match requirement for dNSName element(s) of the
           certificate presented by the authentication server during the inner
           "phase 2" authentication. If a matching dNSName is found, this
           constraint is met. If no dNSName values are present, this
           constraint is matched against SubjectName CN using the same
           comparison. Multiple valid FQDNs can be passed as a ";" delimited
           list.

           Format: string

       phase2-domain-suffix-match
           Constraint for server domain name. If set, this FQDN is used as a
           suffix match requirement for dNSName element(s) of the certificate
           presented by the authentication server during the inner "phase 2"
           authentication. If a matching dNSName is found, this constraint is
           met. If no dNSName values are present, this constraint is matched
           against SubjectName CN using same suffix match comparison. Since
           version 1.24, multiple valid FQDNs can be passed as a ";" delimited
           list.

           Format: string

       phase2-private-key
           Contains the "phase 2" inner private key when the "phase2-auth" or
           "phase2-autheap" property is set to "tls". Key data is specified
           using a "scheme"; two are currently supported: blob and path. When
           using the blob scheme and private keys, this property should be set
           to the key's encrypted PEM encoded data. When using private keys
           with the path scheme, this property should be set to the full UTF-8
           encoded path of the key, prefixed with the string "file://" and
           ending with a terminating NUL byte. When using PKCS#12 format
           private keys and the blob scheme, this property should be set to
           the PKCS#12 data and the "phase2-private-key-password" property
           must be set to password used to decrypt the PKCS#12 certificate and
           key. When using PKCS#12 files and the path scheme, this property
           should be set to the full UTF-8 encoded path of the key, prefixed
           with the string "file://" and ending with a terminating NUL byte,
           and as with the blob scheme the "phase2-private-key-password"
           property must be set to the password used to decode the PKCS#12
           private key and certificate.

           Format: byte array

       phase2-private-key-password
           The password used to decrypt the "phase 2" private key specified in
           the "phase2-private-key" property when the private key either uses
           the path scheme, or is a PKCS#12 format key.

           Format: string

       phase2-private-key-password-flags
           Flags indicating how to handle the "phase2-private-key-password"
           property. See the section called “Secret flag types:” for flag
           values.

           Format: NMSettingSecretFlags (uint32)

       phase2-subject-match
           Substring to be matched against the subject of the certificate
           presented by the authentication server during the inner "phase 2"
           authentication. When unset, no verification of the authentication
           server certificate's subject is performed. This property provides
           little security, if any, and its use is deprecated in favor of
           NMSetting8021x:phase2-domain-suffix-match.

           Format: string

       pin
           PIN used for EAP authentication methods.

           Format: string

       pin-flags
           Flags indicating how to handle the "pin" property. See the section
           called “Secret flag types:” for flag values.

           Format: NMSettingSecretFlags (uint32)

       private-key
           Contains the private key when the "eap" property is set to "tls".
           Key data is specified using a "scheme"; two are currently
           supported: blob and path. When using the blob scheme and private
           keys, this property should be set to the key's encrypted PEM
           encoded data. When using private keys with the path scheme, this
           property should be set to the full UTF-8 encoded path of the key,
           prefixed with the string "file://" and ending with a terminating
           NUL byte. When using PKCS#12 format private keys and the blob
           scheme, this property should be set to the PKCS#12 data and the
           "private-key-password" property must be set to password used to
           decrypt the PKCS#12 certificate and key. When using PKCS#12 files
           and the path scheme, this property should be set to the full UTF-8
           encoded path of the key, prefixed with the string "file://" and
           ending with a terminating NUL byte, and as with the blob scheme the
           "private-key-password" property must be set to the password used to
           decode the PKCS#12 private key and certificate. WARNING:
           "private-key" is not a "secret" property, and thus unencrypted
           private key data using the BLOB scheme may be readable by
           unprivileged users. Private keys should always be encrypted with a
           private key password to prevent unauthorized access to unencrypted
           private key data.

           Format: byte array

       private-key-password
           The password used to decrypt the private key specified in the
           "private-key" property when the private key either uses the path
           scheme, or if the private key is a PKCS#12 format key.

           Format: string

       private-key-password-flags
           Flags indicating how to handle the "private-key-password" property.
           See the section called “Secret flag types:” for flag values.

           Format: NMSettingSecretFlags (uint32)

       subject-match
           Substring to be matched against the subject of the certificate
           presented by the authentication server. When unset, no verification
           of the authentication server certificate's subject is performed.
           This property provides little security, if any, and its use is
           deprecated in favor of NMSetting8021x:domain-suffix-match.

           Format: string

       system-ca-certs
           When TRUE, overrides the "ca-path" and "phase2-ca-path" properties
           using the system CA directory specified at configure time with the
           --system-ca-path switch. The certificates in this directory are
           added to the verification chain in addition to any certificates
           specified by the "ca-cert" and "phase2-ca-cert" properties. If the
           path provided with --system-ca-path is rather a file name (bundle
           of trusted CA certificates), it overrides "ca-cert" and
           "phase2-ca-cert" properties instead (sets ca_cert/ca_cert2 options
           for wpa_supplicant).

           Format: boolean

   adsl setting
       ADSL Settings.

       Properties:

       encapsulation
           Alias: encapsulation

           Encapsulation of ADSL connection. Can be "vcmux" or "llc".

           Format: string

       password
           Alias: password

           Password used to authenticate with the ADSL service.

           Format: string

       password-flags
           Flags indicating how to handle the "password" property. See the
           section called “Secret flag types:” for flag values.

           Format: NMSettingSecretFlags (uint32)

       protocol
           Alias: protocol

           ADSL connection protocol. Can be "pppoa", "pppoe" or "ipoatm".

           Format: string

       username
           Alias: username

           Username used to authenticate with the ADSL service.

           Format: string

       vci
           VCI of ADSL connection

           Format: uint32

       vpi
           VPI of ADSL connection

           Format: uint32

   bluetooth setting
       Bluetooth Settings.

       Properties:

       bdaddr
           Alias: addr

           The Bluetooth address of the device.

           Format: byte array

       type
           Alias: bt-type

           Either "dun" for Dial-Up Networking connections or "panu" for
           Personal Area Networking connections to devices supporting the NAP
           profile.

           Format: string

   bond setting
       Bonding Settings.

       Properties:

       options
           Dictionary of key/value pairs of bonding options. Both keys and
           values must be strings. Option names must contain only alphanumeric
           characters (ie, [a-zA-Z0-9]).

           Format: dict of string to string

   bridge setting
       Bridging Settings.

       Properties:

       ageing-time
           Alias: ageing-time

           The Ethernet MAC address aging time, in seconds.

           Format: uint32

       forward-delay
           Alias: forward-delay

           The Spanning Tree Protocol (STP) forwarding delay, in seconds.

           Format: uint32

       group-address
           If specified, The MAC address of the multicast group this bridge
           uses for STP. The address must be a link-local address in standard
           Ethernet MAC address format, ie an address of the form
           01:80:C2:00:00:0X, with X in [0, 4..F]. If not specified the
           default value is 01:80:C2:00:00:00.

           Format: byte array

       group-forward-mask
           Alias: group-forward-mask

           A mask of group addresses to forward. Usually, group addresses in
           the range from 01:80:C2:00:00:00 to 01:80:C2:00:00:0F are not
           forwarded according to standards. This property is a mask of 16
           bits, each corresponding to a group address in that range that must
           be forwarded. The mask can't have bits 0, 1 or 2 set because they
           are used for STP, MAC pause frames and LACP.

           Format: uint32

       hello-time
           Alias: hello-time

           The Spanning Tree Protocol (STP) hello time, in seconds.

           Format: uint32

       mac-address
           Alias: mac

           If specified, the MAC address of bridge. When creating a new
           bridge, this MAC address will be set. If this field is left
           unspecified, the "ethernet.cloned-mac-address" is referred instead
           to generate the initial MAC address. Note that setting
           "ethernet.cloned-mac-address" anyway overwrites the MAC address of
           the bridge later while activating the bridge. Hence, this property
           is deprecated. Deprecated: 1

           Format: byte array

       max-age
           Alias: max-age

           The Spanning Tree Protocol (STP) maximum message age, in seconds.

           Format: uint32

       multicast-hash-max
           Set maximum size of multicast hash table (value must be a power of
           2).

           Format: uint32

       multicast-last-member-count
           Set the number of queries the bridge will send before stopping
           forwarding a multicast group after a "leave" message has been
           received.

           Format: uint32

       multicast-last-member-interval
           Set interval (in deciseconds) between queries to find remaining
           members of a group, after a "leave" message is received.

           Format: uint64

       multicast-membership-interval
           Set delay (in deciseconds) after which the bridge will leave a
           group, if no membership reports for this group are received.

           Format: uint64

       multicast-querier
           Enable or disable sending of multicast queries by the bridge. If
           not specified the option is disabled.

           Format: boolean

       multicast-querier-interval
           If no queries are seen after this delay (in deciseconds) has
           passed, the bridge will start to send its own queries.

           Format: uint64

       multicast-query-interval
           Interval (in deciseconds) between queries sent by the bridge after
           the end of the startup phase.

           Format: uint64

       multicast-query-response-interval
           Set the Max Response Time/Max Response Delay (in deciseconds) for
           IGMP/MLD queries sent by the bridge.

           Format: uint64

       multicast-query-use-ifaddr
           If enabled the bridge's own IP address is used as the source
           address for IGMP queries otherwise the default of 0.0.0.0 is used.

           Format: boolean

       multicast-router
           Sets bridge's multicast router. Multicast-snooping must be enabled
           for this option to work. Supported values are: 'auto', 'disabled',
           'enabled' to which kernel assigns the numbers 1, 0, and 2,
           respectively. If not specified the default value is 'auto' (1).

           Format: string

       multicast-snooping
           Alias: multicast-snooping

           Controls whether IGMP snooping is enabled for this bridge. Note
           that if snooping was automatically disabled due to hash collisions,
           the system may refuse to enable the feature until the collisions
           are resolved.

           Format: boolean

       multicast-startup-query-count
           Set the number of IGMP queries to send during startup phase.

           Format: uint32

       multicast-startup-query-interval
           Sets the time (in deciseconds) between queries sent out at startup
           to determine membership information.

           Format: uint64

       priority
           Alias: priority

           Sets the Spanning Tree Protocol (STP) priority for this bridge.
           Lower values are "better"; the lowest priority bridge will be
           elected the root bridge.

           Format: uint32

       stp
           Alias: stp

           Controls whether Spanning Tree Protocol (STP) is enabled for this
           bridge.

           Format: boolean

       vlan-default-pvid
           The default PVID for the ports of the bridge, that is the VLAN id
           assigned to incoming untagged frames.

           Format: uint32

       vlan-filtering
           Control whether VLAN filtering is enabled on the bridge.

           Format: boolean

       vlan-protocol
           If specified, the protocol used for VLAN filtering. Supported
           values are: '802.1Q', '802.1ad'. If not specified the default value
           is '802.1Q'.

           Format: string

       vlan-stats-enabled
           Controls whether per-VLAN stats accounting is enabled.

           Format: boolean

       vlans
           Array of bridge VLAN objects. In addition to the VLANs specified
           here, the bridge will also have the default-pvid VLAN configured by
           the bridge.vlan-default-pvid property. In nmcli the VLAN list can
           be specified with the following syntax: $vid [pvid] [untagged] [,
           $vid [pvid] [untagged]]... where $vid is either a single id between
           1 and 4094 or a range, represented as a couple of ids separated by
           a dash.

           Format: array of vardict

   bridge-port setting
       Bridge Port Settings.

       Properties:

       hairpin-mode
           Alias: hairpin

           Enables or disables "hairpin mode" for the port, which allows
           frames to be sent back out through the port the frame was received
           on.

           Format: boolean

       path-cost
           Alias: path-cost

           The Spanning Tree Protocol (STP) port cost for destinations via
           this port.

           Format: uint32

       priority
           Alias: priority

           The Spanning Tree Protocol (STP) priority of this bridge port.

           Format: uint32

       vlans
           Array of bridge VLAN objects. In addition to the VLANs specified
           here, the port will also have the default-pvid VLAN configured on
           the bridge by the bridge.vlan-default-pvid property. In nmcli the
           VLAN list can be specified with the following syntax: $vid [pvid]
           [untagged] [, $vid [pvid] [untagged]]... where $vid is either a
           single id between 1 and 4094 or a range, represented as a couple of
           ids separated by a dash.

           Format: array of vardict

   cdma setting
       CDMA-based Mobile Broadband Settings.

       Properties:

       mtu
           If non-zero, only transmit packets of the specified size or
           smaller, breaking larger packets up into multiple frames.

           Format: uint32

       number
           The number to dial to establish the connection to the CDMA-based
           mobile broadband network, if any. If not specified, the default
           number (#777) is used when required.

           Format: string

       password
           Alias: password

           The password used to authenticate with the network, if required.
           Many providers do not require a password, or accept any password.
           But if a password is required, it is specified here.

           Format: string

       password-flags
           Flags indicating how to handle the "password" property. See the
           section called “Secret flag types:” for flag values.

           Format: NMSettingSecretFlags (uint32)

       username
           Alias: user

           The username used to authenticate with the network, if required.
           Many providers do not require a username, or accept any username.
           But if a username is required, it is specified here.

           Format: string

   dcb setting
       Data Center Bridging Settings.

       Properties:

       app-fcoe-flags
           Specifies the NMSettingDcbFlags for the DCB FCoE application. Flags
           may be any combination of NM_SETTING_DCB_FLAG_ENABLE (0x1),
           NM_SETTING_DCB_FLAG_ADVERTISE (0x2), and
           NM_SETTING_DCB_FLAG_WILLING (0x4).

           Format: NMSettingDcbFlags (uint32)

       app-fcoe-mode
           The FCoE controller mode; either "fabric" or "vn2vn". Since 1.34,
           NULL is the default and means "fabric". Before 1.34, NULL was
           rejected as invalid and the default was "fabric".

           Format: string

       app-fcoe-priority
           The highest User Priority (0 - 7) which FCoE frames should use, or
           -1 for default priority. Only used when the "app-fcoe-flags"
           property includes the NM_SETTING_DCB_FLAG_ENABLE (0x1) flag.

           Format: int32

       app-fip-flags
           Specifies the NMSettingDcbFlags for the DCB FIP application. Flags
           may be any combination of NM_SETTING_DCB_FLAG_ENABLE (0x1),
           NM_SETTING_DCB_FLAG_ADVERTISE (0x2), and
           NM_SETTING_DCB_FLAG_WILLING (0x4).

           Format: NMSettingDcbFlags (uint32)

       app-fip-priority
           The highest User Priority (0 - 7) which FIP frames should use, or
           -1 for default priority. Only used when the "app-fip-flags"
           property includes the NM_SETTING_DCB_FLAG_ENABLE (0x1) flag.

           Format: int32

       app-iscsi-flags
           Specifies the NMSettingDcbFlags for the DCB iSCSI application.
           Flags may be any combination of NM_SETTING_DCB_FLAG_ENABLE (0x1),
           NM_SETTING_DCB_FLAG_ADVERTISE (0x2), and
           NM_SETTING_DCB_FLAG_WILLING (0x4).

           Format: NMSettingDcbFlags (uint32)

       app-iscsi-priority
           The highest User Priority (0 - 7) which iSCSI frames should use, or
           -1 for default priority. Only used when the "app-iscsi-flags"
           property includes the NM_SETTING_DCB_FLAG_ENABLE (0x1) flag.

           Format: int32

       priority-bandwidth
           An array of 8 uint values, where the array index corresponds to the
           User Priority (0 - 7) and the value indicates the percentage of
           bandwidth of the priority's assigned group that the priority may
           use. The sum of all percentages for priorities which belong to the
           same group must total 100 percents.

           Format: array of uint32

       priority-flow-control
           An array of 8 boolean values, where the array index corresponds to
           the User Priority (0 - 7) and the value indicates whether or not
           the corresponding priority should transmit priority pause.

           Format: array of uint32

       priority-flow-control-flags
           Specifies the NMSettingDcbFlags for DCB Priority Flow Control
           (PFC). Flags may be any combination of NM_SETTING_DCB_FLAG_ENABLE
           (0x1), NM_SETTING_DCB_FLAG_ADVERTISE (0x2), and
           NM_SETTING_DCB_FLAG_WILLING (0x4).

           Format: NMSettingDcbFlags (uint32)

       priority-group-bandwidth
           An array of 8 uint values, where the array index corresponds to the
           Priority Group ID (0 - 7) and the value indicates the percentage of
           link bandwidth allocated to that group. Allowed values are 0 - 100,
           and the sum of all values must total 100 percents.

           Format: array of uint32

       priority-group-flags
           Specifies the NMSettingDcbFlags for DCB Priority Groups. Flags may
           be any combination of NM_SETTING_DCB_FLAG_ENABLE (0x1),
           NM_SETTING_DCB_FLAG_ADVERTISE (0x2), and
           NM_SETTING_DCB_FLAG_WILLING (0x4).

           Format: NMSettingDcbFlags (uint32)

       priority-group-id
           An array of 8 uint values, where the array index corresponds to the
           User Priority (0 - 7) and the value indicates the Priority Group
           ID. Allowed Priority Group ID values are 0 - 7 or 15 for the
           unrestricted group.

           Format: array of uint32

       priority-strict-bandwidth
           An array of 8 boolean values, where the array index corresponds to
           the User Priority (0 - 7) and the value indicates whether or not
           the priority may use all of the bandwidth allocated to its assigned
           group.

           Format: array of uint32

       priority-traffic-class
           An array of 8 uint values, where the array index corresponds to the
           User Priority (0 - 7) and the value indicates the traffic class (0
           - 7) to which the priority is mapped.

           Format: array of uint32

   ethtool setting
       Ethtool Ethernet Settings.

       Properties:

       coalesce-adaptive-rx

       coalesce-adaptive-tx

       coalesce-pkt-rate-high

       coalesce-pkt-rate-low

       coalesce-rx-frames

       coalesce-rx-frames-high

       coalesce-rx-frames-irq

       coalesce-rx-frames-low

       coalesce-rx-usecs

       coalesce-rx-usecs-high

       coalesce-rx-usecs-irq

       coalesce-rx-usecs-low

       coalesce-sample-interval

       coalesce-stats-block-usecs

       coalesce-tx-frames

       coalesce-tx-frames-high

       coalesce-tx-frames-irq

       coalesce-tx-frames-low

       coalesce-tx-usecs

       coalesce-tx-usecs-high

       coalesce-tx-usecs-irq

       coalesce-tx-usecs-low

       feature-esp-hw-offload

       feature-esp-tx-csum-hw-offload

       feature-fcoe-mtu

       feature-gro

       feature-gso

       feature-highdma

       feature-hw-tc-offload

       feature-l2-fwd-offload

       feature-loopback

       feature-lro

       feature-macsec-hw-offload

       feature-ntuple

       feature-rx

       feature-rx-all

       feature-rx-fcs

       feature-rx-gro-hw

       feature-rx-gro-list

       feature-rx-udp-gro-forwarding

       feature-rx-udp_tunnel-port-offload

       feature-rx-vlan-filter

       feature-rx-vlan-stag-filter

       feature-rx-vlan-stag-hw-parse

       feature-rxhash

       feature-rxvlan

       feature-sg

       feature-tls-hw-record

       feature-tls-hw-rx-offload

       feature-tls-hw-tx-offload

       feature-tso

       feature-tx

       feature-tx-checksum-fcoe-crc

       feature-tx-checksum-ip-generic

       feature-tx-checksum-ipv4

       feature-tx-checksum-ipv6

       feature-tx-checksum-sctp

       feature-tx-esp-segmentation

       feature-tx-fcoe-segmentation

       feature-tx-gre-csum-segmentation

       feature-tx-gre-segmentation

       feature-tx-gso-list

       feature-tx-gso-partial

       feature-tx-gso-robust

       feature-tx-ipxip4-segmentation

       feature-tx-ipxip6-segmentation

       feature-tx-nocache-copy

       feature-tx-scatter-gather

       feature-tx-scatter-gather-fraglist

       feature-tx-sctp-segmentation

       feature-tx-tcp-ecn-segmentation

       feature-tx-tcp-mangleid-segmentation

       feature-tx-tcp-segmentation

       feature-tx-tcp6-segmentation

       feature-tx-tunnel-remcsum-segmentation

       feature-tx-udp-segmentation

       feature-tx-udp_tnl-csum-segmentation

       feature-tx-udp_tnl-segmentation

       feature-tx-vlan-stag-hw-insert

       feature-txvlan

       pause-autoneg
           Whether to automatically negotiate on pause frame of flow control
           mechanism defined by IEEE 802.3x standard.

       pause-rx
           Whether RX pause should be enabled. Only valid when automatic
           negotiation is disabled

       pause-tx
           Whether TX pause should be enabled. Only valid when automatic
           negotiation is disabled

       ring-rx

       ring-rx-jumbo

       ring-rx-mini

       ring-tx

   gsm setting
       GSM-based Mobile Broadband Settings.

       Properties:

       apn
           Alias: apn

           The GPRS Access Point Name specifying the APN used when
           establishing a data session with the GSM-based network. The APN
           often determines how the user will be billed for their network
           usage and whether the user has access to the Internet or just a
           provider-specific walled-garden, so it is important to use the
           correct APN for the user's mobile broadband plan. The APN may only
           be composed of the characters a-z, 0-9, ., and - per GSM 03.60
           Section 14.9.

           Format: string

       auto-config
           When TRUE, the settings such as APN, username, or password will
           default to values that match the network the modem will register to
           in the Mobile Broadband Provider database.

           Format: boolean

       device-id
           The device unique identifier (as given by the WWAN management
           service) which this connection applies to. If given, the connection
           will only apply to the specified device.

           Format: string

       home-only
           When TRUE, only connections to the home network will be allowed.
           Connections to roaming networks will not be made.

           Format: boolean

       mtu
           If non-zero, only transmit packets of the specified size or
           smaller, breaking larger packets up into multiple frames.

           Format: uint32

       network-id
           The Network ID (GSM LAI format, ie MCC-MNC) to force specific
           network registration. If the Network ID is specified,
           NetworkManager will attempt to force the device to register only on
           the specified network. This can be used to ensure that the device
           does not roam when direct roaming control of the device is not
           otherwise possible.

           Format: string

       number
           Legacy setting that used to help establishing PPP data sessions for
           GSM-based modems. Deprecated: 1

           Format: string

       password
           Alias: password

           The password used to authenticate with the network, if required.
           Many providers do not require a password, or accept any password.
           But if a password is required, it is specified here.

           Format: string

       password-flags
           Flags indicating how to handle the "password" property. See the
           section called “Secret flag types:” for flag values.

           Format: NMSettingSecretFlags (uint32)

       pin
           If the SIM is locked with a PIN it must be unlocked before any
           other operations are requested. Specify the PIN here to allow
           operation of the device.

           Format: string

       pin-flags
           Flags indicating how to handle the "pin" property. See the section
           called “Secret flag types:” for flag values.

           Format: NMSettingSecretFlags (uint32)

       sim-id
           The SIM card unique identifier (as given by the WWAN management
           service) which this connection applies to. If given, the connection
           will apply to any device also allowed by "device-id" which contains
           a SIM card matching the given identifier.

           Format: string

       sim-operator-id
           A MCC/MNC string like "310260" or "21601" identifying the specific
           mobile network operator which this connection applies to. If given,
           the connection will apply to any device also allowed by "device-id"
           and "sim-id" which contains a SIM card provisioned by the given
           operator.

           Format: string

       username
           Alias: user

           The username used to authenticate with the network, if required.
           Many providers do not require a username, or accept any username.
           But if a username is required, it is specified here.

           Format: string

   infiniband setting
       Infiniband Settings.

       Properties:

       mac-address
           Alias: mac

           If specified, this connection will only apply to the IPoIB device
           whose permanent MAC address matches. This property does not change
           the MAC address of the device (i.e. MAC spoofing).

           Format: byte array

       mtu
           Alias: mtu

           If non-zero, only transmit packets of the specified size or
           smaller, breaking larger packets up into multiple frames.

           Format: uint32

       p-key
           Alias: p-key

           The InfiniBand P_Key to use for this device. A value of -1 means to
           use the default P_Key (aka "the P_Key at index 0"). Otherwise, it
           is a 16-bit unsigned integer, whose high bit is set if it is a
           "full membership" P_Key.

           Format: int32

       parent
           Alias: parent

           The interface name of the parent device of this device. Normally
           NULL, but if the "p_key" property is set, then you must specify the
           base device by setting either this property or "mac-address".

           Format: string

       transport-mode
           Alias: transport-mode

           The IP-over-InfiniBand transport mode. Either "datagram" or
           "connected".

           Format: string

   ipv4 setting
       IPv4 Settings.

       Properties:

       addresses
           Alias: ip4

           A list of IPv4 addresses and their prefix length. Multiple
           addresses can be separated by comma. For example "192.168.1.5/24,
           10.1.0.5/24". The addresses are listed in decreasing priority,
           meaning the first address will be the primary address.

           Format: a comma separated list of addresses

       dad-timeout
           Timeout in milliseconds used to check for the presence of duplicate
           IP addresses on the network. If an address conflict is detected,
           the activation will fail. A zero value means that no duplicate
           address detection is performed, -1 means the default value (either
           configuration ipvx.dad-timeout override or zero). A value greater
           than zero is a timeout in milliseconds. The property is currently
           implemented only for IPv4.

           Format: int32

       dhcp-client-id
           A string sent to the DHCP server to identify the local machine
           which the DHCP server may use to customize the DHCP lease and
           options. When the property is a hex string ('aa:bb:cc') it is
           interpreted as a binary client ID, in which case the first byte is
           assumed to be the 'type' field as per RFC 2132 section 9.14 and the
           remaining bytes may be an hardware address (e.g.
           '01:xx:xx:xx:xx:xx:xx' where 1 is the Ethernet ARP type and the
           rest is a MAC address). If the property is not a hex string it is
           considered as a non-hardware-address client ID and the 'type' field
           is set to 0. The special values "mac" and "perm-mac" are supported,
           which use the current or permanent MAC address of the device to
           generate a client identifier with type ethernet (01). Currently,
           these options only work for ethernet type of links. The special
           value "ipv6-duid" uses the DUID from "ipv6.dhcp-duid" property as
           an RFC4361-compliant client identifier. As IAID it uses
           "ipv4.dhcp-iaid" and falls back to "ipv6.dhcp-iaid" if unset. The
           special value "duid" generates a RFC4361-compliant client
           identifier based on "ipv4.dhcp-iaid" and uses a DUID generated by
           hashing /etc/machine-id. The special value "stable" is supported to
           generate a type 0 client identifier based on the stable-id (see
           connection.stable-id) and a per-host key. If you set the stable-id,
           you may want to include the "${DEVICE}" or "${MAC}" specifier to
           get a per-device key. If unset, a globally configured default is
           used. If still unset, the default depends on the DHCP plugin.

           Format: string

       dhcp-fqdn
           If the "dhcp-send-hostname" property is TRUE, then the specified
           FQDN will be sent to the DHCP server when acquiring a lease. This
           property and "dhcp-hostname" are mutually exclusive and cannot be
           set at the same time.

           Format: string

       dhcp-hostname
           If the "dhcp-send-hostname" property is TRUE, then the specified
           name will be sent to the DHCP server when acquiring a lease. This
           property and "dhcp-fqdn" are mutually exclusive and cannot be set
           at the same time.

           Format: string

       dhcp-hostname-flags
           Flags for the DHCP hostname and FQDN. Currently, this property only
           includes flags to control the FQDN flags set in the DHCP FQDN
           option. Supported FQDN flags are
           NM_DHCP_HOSTNAME_FLAG_FQDN_SERV_UPDATE (0x1),
           NM_DHCP_HOSTNAME_FLAG_FQDN_ENCODED (0x2) and
           NM_DHCP_HOSTNAME_FLAG_FQDN_NO_UPDATE (0x4). When no FQDN flag is
           set and NM_DHCP_HOSTNAME_FLAG_FQDN_CLEAR_FLAGS (0x8) is set, the
           DHCP FQDN option will contain no flag. Otherwise, if no FQDN flag
           is set and NM_DHCP_HOSTNAME_FLAG_FQDN_CLEAR_FLAGS (0x8) is not set,
           the standard FQDN flags are set in the request:
           NM_DHCP_HOSTNAME_FLAG_FQDN_SERV_UPDATE (0x1),
           NM_DHCP_HOSTNAME_FLAG_FQDN_ENCODED (0x2) for IPv4 and
           NM_DHCP_HOSTNAME_FLAG_FQDN_SERV_UPDATE (0x1) for IPv6. When this
           property is set to the default value NM_DHCP_HOSTNAME_FLAG_NONE
           (0x0), a global default is looked up in NetworkManager
           configuration. If that value is unset or also
           NM_DHCP_HOSTNAME_FLAG_NONE (0x0), then the standard FQDN flags
           described above are sent in the DHCP requests.

           Format: uint32

       dhcp-iaid
           A string containing the "Identity Association Identifier" (IAID)
           used by the DHCP client. The property is a 32-bit decimal value or
           a special value among "mac", "perm-mac", "ifname" and "stable".
           When set to "mac" (or "perm-mac"), the last 4 bytes of the current
           (or permanent) MAC address are used as IAID. When set to "ifname",
           the IAID is computed by hashing the interface name. The special
           value "stable" can be used to generate an IAID based on the
           stable-id (see connection.stable-id), a per-host key and the
           interface name. When the property is unset, the value from global
           configuration is used; if no global default is set then the IAID is
           assumed to be "ifname". Note that at the moment this property is
           ignored for IPv6 by dhclient, which always derives the IAID from
           the MAC address.

           Format: string

       dhcp-reject-servers
           Array of servers from which DHCP offers must be rejected. This
           property is useful to avoid getting a lease from misconfigured or
           rogue servers. For DHCPv4, each element must be an IPv4 address,
           optionally followed by a slash and a prefix length (e.g.
           "192.168.122.0/24"). This property is currently not implemented for
           DHCPv6.

           Format: array of string

       dhcp-send-hostname
           If TRUE, a hostname is sent to the DHCP server when acquiring a
           lease. Some DHCP servers use this hostname to update DNS databases,
           essentially providing a static hostname for the computer. If the
           "dhcp-hostname" property is NULL and this property is TRUE, the
           current persistent hostname of the computer is sent.

           Format: boolean

       dhcp-timeout
           A timeout for a DHCP transaction in seconds. If zero (the default),
           a globally configured default is used. If still unspecified, a
           device specific timeout is used (usually 45 seconds). Set to
           2147483647 (MAXINT32) for infinity.

           Format: int32

       dhcp-vendor-class-identifier
           The Vendor Class Identifier DHCP option (60). Special characters in
           the data string may be escaped using C-style escapes, nevertheless
           this property cannot contain nul bytes. If the per-profile value is
           unspecified (the default), a global connection default gets
           consulted. If still unspecified, the DHCP option is not sent to the
           server. Since 1.28

           Format: string

       dns
           Array of IP addresses of DNS servers.

           Format: array of uint32

       dns-options
           Array of DNS options as described in man 5 resolv.conf. NULL means
           that the options are unset and left at the default. In this case
           NetworkManager will use default options. This is distinct from an
           empty list of properties. The currently supported options are
           "attempts", "debug", "edns0", "inet6", "ip6-bytestring",
           "ip6-dotint", "ndots", "no-check-names", "no-ip6-dotint",
           "no-reload", "no-tld-query", "rotate", "single-request",
           "single-request-reopen", "timeout", "trust-ad", "use-vc". The
           "trust-ad" setting is only honored if the profile contributes name
           servers to resolv.conf, and if all contributing profiles have
           "trust-ad" enabled. When using a caching DNS plugin (dnsmasq or
           systemd-resolved in NetworkManager.conf) then "edns0" and
           "trust-ad" are automatically added.

           Format: array of string

       dns-priority
           DNS servers priority. The relative priority for DNS servers
           specified by this setting. A lower numerical value is better
           (higher priority). Negative values have the special effect of
           excluding other configurations with a greater numerical priority
           value; so in presence of at least one negative priority, only DNS
           servers from connections with the lowest priority value will be
           used. To avoid all DNS leaks, set the priority of the profile that
           should be used to the most negative value of all active connections
           profiles. Zero selects a globally configured default value. If the
           latter is missing or zero too, it defaults to 50 for VPNs
           (including WireGuard) and 100 for other connections. Note that the
           priority is to order DNS settings for multiple active connections.
           It does not disambiguate multiple DNS servers within the same
           connection profile. When multiple devices have configurations with
           the same priority, VPNs will be considered first, then devices with
           the best (lowest metric) default route and then all other devices.
           When using dns=default, servers with higher priority will be on top
           of resolv.conf. To prioritize a given server over another one
           within the same connection, just specify them in the desired order.
           Note that commonly the resolver tries name servers in
           /etc/resolv.conf in the order listed, proceeding with the next
           server in the list on failure. See for example the "rotate" option
           of the dns-options setting. If there are any negative DNS
           priorities, then only name servers from the devices with that
           lowest priority will be considered. When using a DNS resolver that
           supports Conditional Forwarding or Split DNS (with dns=dnsmasq or
           dns=systemd-resolved settings), each connection is used to query
           domains in its search list. The search domains determine which name
           servers to ask, and the DNS priority is used to prioritize name
           servers based on the domain. Queries for domains not present in any
           search list are routed through connections having the '~.' special
           wildcard domain, which is added automatically to connections with
           the default route (or can be added manually). When multiple
           connections specify the same domain, the one with the best priority
           (lowest numerical value) wins. If a sub domain is configured on
           another interface it will be accepted regardless the priority,
           unless parent domain on the other interface has a negative
           priority, which causes the sub domain to be shadowed. With Split
           DNS one can avoid undesired DNS leaks by properly configuring DNS
           priorities and the search domains, so that only name servers of the
           desired interface are configured.

           Format: int32

       dns-search
           Array of DNS search domains. Domains starting with a tilde ('~')
           are considered 'routing' domains and are used only to decide the
           interface over which a query must be forwarded; they are not used
           to complete unqualified host names. When using a DNS plugin that
           supports Conditional Forwarding or Split DNS, then the search
           domains specify which name servers to query. This makes the
           behavior different from running with plain /etc/resolv.conf. For
           more information see also the dns-priority setting.

           Format: array of string

       gateway
           Alias: gw4

           The gateway associated with this configuration. This is only
           meaningful if "addresses" is also set. The gateway's main purpose
           is to control the next hop of the standard default route on the
           device. Hence, the gateway property conflicts with "never-default"
           and will be automatically dropped if the IP configuration is set to
           never-default. As an alternative to set the gateway, configure a
           static default route with /0 as prefix length.

           Format: string

       ignore-auto-dns
           When "method" is set to "auto" and this property to TRUE,
           automatically configured name servers and search domains are
           ignored and only name servers and search domains specified in the
           "dns" and "dns-search" properties, if any, are used.

           Format: boolean

       ignore-auto-routes
           When "method" is set to "auto" and this property to TRUE,
           automatically configured routes are ignored and only routes
           specified in the "routes" property, if any, are used.

           Format: boolean

       may-fail
           If TRUE, allow overall network configuration to proceed even if the
           configuration specified by this property times out. Note that at
           least one IP configuration must succeed or overall network
           configuration will still fail. For example, in IPv6-only networks,
           setting this property to TRUE on the NMSettingIP4Config allows the
           overall network configuration to succeed if IPv4 configuration
           fails but IPv6 configuration completes successfully.

           Format: boolean

       method
           IP configuration method. NMSettingIP4Config and NMSettingIP6Config
           both support "disabled", "auto", "manual", and "link-local". See
           the subclass-specific documentation for other values. In general,
           for the "auto" method, properties such as "dns" and "routes"
           specify information that is added on to the information returned
           from automatic configuration. The "ignore-auto-routes" and
           "ignore-auto-dns" properties modify this behavior. For methods that
           imply no upstream network, such as "shared" or "link-local", these
           properties must be empty. For IPv4 method "shared", the IP subnet
           can be configured by adding one manual IPv4 address or otherwise
           10.42.x.0/24 is chosen. Note that the shared method must be
           configured on the interface which shares the internet to a subnet,
           not on the uplink which is shared.

           Format: string

       never-default
           If TRUE, this connection will never be the default connection for
           this IP type, meaning it will never be assigned the default route
           by NetworkManager.

           Format: boolean

       required-timeout
           The minimum time interval in milliseconds for which dynamic IP
           configuration should be tried before the connection succeeds. This
           property is useful for example if both IPv4 and IPv6 are enabled
           and are allowed to fail. Normally the connection succeeds as soon
           as one of the two address families completes; by setting a required
           timeout for e.g. IPv4, one can ensure that even if IP6 succeeds
           earlier than IPv4, NetworkManager waits some time for IPv4 before
           the connection becomes active. Note that if "may-fail" is FALSE for
           the same address family, this property has no effect as
           NetworkManager needs to wait for the full DHCP timeout. A zero
           value means that no required timeout is present, -1 means the
           default value (either configuration ipvx.required-timeout override
           or zero).

           Format: int32

       route-metric
           The default metric for routes that don't explicitly specify a
           metric. The default value -1 means that the metric is chosen
           automatically based on the device type. The metric applies to
           dynamic routes, manual (static) routes that don't have an explicit
           metric setting, address prefix routes, and the default route. Note
           that for IPv6, the kernel accepts zero (0) but coerces it to 1024
           (user default). Hence, setting this property to zero effectively
           mean setting it to 1024. For IPv4, zero is a regular value for the
           metric.

           Format: int64

       route-table
           Enable policy routing (source routing) and set the routing table
           used when adding routes. This affects all routes, including
           device-routes, IPv4LL, DHCP, SLAAC, default-routes and static
           routes. But note that static routes can individually overwrite the
           setting by explicitly specifying a non-zero routing table. If the
           table setting is left at zero, it is eligible to be overwritten via
           global configuration. If the property is zero even after applying
           the global configuration value, policy routing is disabled for the
           address family of this connection. Policy routing disabled means
           that NetworkManager will add all routes to the main table (except
           static routes that explicitly configure a different table).
           Additionally, NetworkManager will not delete any extraneous routes
           from tables except the main table. This is to preserve backward
           compatibility for users who manage routing tables outside of
           NetworkManager.

           Format: uint32

       routes
           A list of IPv4 destination addresses, prefix length, optional IPv4
           next hop addresses, optional route metric, optional attribute. The
           valid syntax is: "ip[/prefix] [next-hop] [metric]
           [attribute=val]...[,ip[/prefix]...]". For example "192.0.2.0/24
           10.1.1.1 77, 198.51.100.0/24".

           Various attributes are supported:

           •   "cwnd" - an unsigned 32 bit integer.

           •   "initcwnd" - an unsigned 32 bit integer.

           •   "initrwnd" - an unsigned 32 bit integer.

           •   "lock-cwnd" - a boolean value.

           •   "lock-initcwnd" - a boolean value.

           •   "lock-initrwnd" - a boolean value.

           •   "lock-mtu" - a boolean value.

           •   "lock-window" - a boolean value.

           •   "mtu" - an unsigned 32 bit integer.

           •   "onlink" - a boolean value.

           •   "scope" - an unsigned 8 bit integer. IPv4 only.

           •   "src" - an IPv4 address.

           •   "table" - an unsigned 32 bit integer. The default depends on
               ipv4.route-table.

           •   "tos" - an unsigned 8 bit integer. IPv4 only.

           •   "type" - one of unicast, local, blackhole, unavailable,
               prohibit. The default is unicast.

           •   "window" - an unsigned 32 bit integer.

           For details see also `man ip-route`.

           Format: a comma separated list of routes

       routing-rules
           A comma separated list of routing rules for policy routing. The
           format is based on ip rule add syntax and mostly compatible. One
           difference is that routing rules in NetworkManager always need a
           fixed priority.

           Example: priority 5 from 192.167.4.0/24 table 45

           Format: a comma separated list of routing rules

   ipv6 setting
       IPv6 Settings.

       Properties:

       addr-gen-mode
           Configure method for creating the address for use with RFC4862 IPv6
           Stateless Address Autoconfiguration. The permitted values are:
           NM_SETTING_IP6_CONFIG_ADDR_GEN_MODE_EUI64 (0) or
           NM_SETTING_IP6_CONFIG_ADDR_GEN_MODE_STABLE_PRIVACY (1). If the
           property is set to EUI64, the addresses will be generated using the
           interface tokens derived from hardware address. This makes the host
           part of the address to stay constant, making it possible to track
           host's presence when it changes networks. The address changes when
           the interface hardware is replaced. The value of stable-privacy
           enables use of cryptographically secure hash of a secret
           host-specific key along with the connection's stable-id and the
           network address as specified by RFC7217. This makes it impossible
           to use the address track host's presence, and makes the address
           stable when the network interface hardware is replaced. On D-Bus,
           the absence of an addr-gen-mode setting equals enabling
           stable-privacy. For keyfile plugin, the absence of the setting on
           disk means EUI64 so that the property doesn't change on upgrade
           from older versions. Note that this setting is distinct from the
           Privacy Extensions as configured by "ip6-privacy" property and it
           does not affect the temporary addresses configured with this
           option.

           Format: int32

       addresses
           Alias: ip6

           A list of IPv6 addresses and their prefix length. Multiple
           addresses can be separated by comma. For example
           "2001:db8:85a3::8a2e:370:7334/64, 2001:db8:85a3::5/64". The
           addresses are listed in increasing priority, meaning the last
           address will be the primary address.

           Format: a comma separated list of addresses

       dhcp-duid
           A string containing the DHCPv6 Unique Identifier (DUID) used by the
           dhcp client to identify itself to DHCPv6 servers (RFC 3315). The
           DUID is carried in the Client Identifier option. If the property is
           a hex string ('aa:bb:cc') it is interpreted as a binary DUID and
           filled as an opaque value in the Client Identifier option. The
           special value "lease" will retrieve the DUID previously used from
           the lease file belonging to the connection. If no DUID is found and
           "dhclient" is the configured dhcp client, the DUID is searched in
           the system-wide dhclient lease file. If still no DUID is found, or
           another dhcp client is used, a global and permanent DUID-UUID (RFC
           6355) will be generated based on the machine-id. The special values
           "llt" and "ll" will generate a DUID of type LLT or LL (see RFC
           3315) based on the current MAC address of the device. In order to
           try providing a stable DUID-LLT, the time field will contain a
           constant timestamp that is used globally (for all profiles) and
           persisted to disk. The special values "stable-llt", "stable-ll" and
           "stable-uuid" will generate a DUID of the corresponding type,
           derived from the connection's stable-id and a per-host unique key.
           You may want to include the "${DEVICE}" or "${MAC}" specifier in
           the stable-id, in case this profile gets activated on multiple
           devices. So, the link-layer address of "stable-ll" and "stable-llt"
           will be a generated address derived from the stable id. The
           DUID-LLT time value in the "stable-llt" option will be picked among
           a static timespan of three years (the upper bound of the interval
           is the same constant timestamp used in "llt"). When the property is
           unset, the global value provided for "ipv6.dhcp-duid" is used. If
           no global value is provided, the default "lease" value is assumed.

           Format: string

       dhcp-hostname
           If the "dhcp-send-hostname" property is TRUE, then the specified
           name will be sent to the DHCP server when acquiring a lease. This
           property and "dhcp-fqdn" are mutually exclusive and cannot be set
           at the same time.

           Format: string

       dhcp-hostname-flags
           Flags for the DHCP hostname and FQDN. Currently, this property only
           includes flags to control the FQDN flags set in the DHCP FQDN
           option. Supported FQDN flags are
           NM_DHCP_HOSTNAME_FLAG_FQDN_SERV_UPDATE (0x1),
           NM_DHCP_HOSTNAME_FLAG_FQDN_ENCODED (0x2) and
           NM_DHCP_HOSTNAME_FLAG_FQDN_NO_UPDATE (0x4). When no FQDN flag is
           set and NM_DHCP_HOSTNAME_FLAG_FQDN_CLEAR_FLAGS (0x8) is set, the
           DHCP FQDN option will contain no flag. Otherwise, if no FQDN flag
           is set and NM_DHCP_HOSTNAME_FLAG_FQDN_CLEAR_FLAGS (0x8) is not set,
           the standard FQDN flags are set in the request:
           NM_DHCP_HOSTNAME_FLAG_FQDN_SERV_UPDATE (0x1),
           NM_DHCP_HOSTNAME_FLAG_FQDN_ENCODED (0x2) for IPv4 and
           NM_DHCP_HOSTNAME_FLAG_FQDN_SERV_UPDATE (0x1) for IPv6. When this
           property is set to the default value NM_DHCP_HOSTNAME_FLAG_NONE
           (0x0), a global default is looked up in NetworkManager
           configuration. If that value is unset or also
           NM_DHCP_HOSTNAME_FLAG_NONE (0x0), then the standard FQDN flags
           described above are sent in the DHCP requests.

           Format: uint32

       dhcp-iaid
           A string containing the "Identity Association Identifier" (IAID)
           used by the DHCP client. The property is a 32-bit decimal value or
           a special value among "mac", "perm-mac", "ifname" and "stable".
           When set to "mac" (or "perm-mac"), the last 4 bytes of the current
           (or permanent) MAC address are used as IAID. When set to "ifname",
           the IAID is computed by hashing the interface name. The special
           value "stable" can be used to generate an IAID based on the
           stable-id (see connection.stable-id), a per-host key and the
           interface name. When the property is unset, the value from global
           configuration is used; if no global default is set then the IAID is
           assumed to be "ifname". Note that at the moment this property is
           ignored for IPv6 by dhclient, which always derives the IAID from
           the MAC address.

           Format: string

       dhcp-send-hostname
           If TRUE, a hostname is sent to the DHCP server when acquiring a
           lease. Some DHCP servers use this hostname to update DNS databases,
           essentially providing a static hostname for the computer. If the
           "dhcp-hostname" property is NULL and this property is TRUE, the
           current persistent hostname of the computer is sent.

           Format: boolean

       dhcp-timeout
           A timeout for a DHCP transaction in seconds. If zero (the default),
           a globally configured default is used. If still unspecified, a
           device specific timeout is used (usually 45 seconds). Set to
           2147483647 (MAXINT32) for infinity.

           Format: int32

       dns
           Array of IP addresses of DNS servers.

           Format: array of byte array

       dns-options
           Array of DNS options as described in man 5 resolv.conf. NULL means
           that the options are unset and left at the default. In this case
           NetworkManager will use default options. This is distinct from an
           empty list of properties. The currently supported options are
           "attempts", "debug", "edns0", "inet6", "ip6-bytestring",
           "ip6-dotint", "ndots", "no-check-names", "no-ip6-dotint",
           "no-reload", "no-tld-query", "rotate", "single-request",
           "single-request-reopen", "timeout", "trust-ad", "use-vc". The
           "trust-ad" setting is only honored if the profile contributes name
           servers to resolv.conf, and if all contributing profiles have
           "trust-ad" enabled. When using a caching DNS plugin (dnsmasq or
           systemd-resolved in NetworkManager.conf) then "edns0" and
           "trust-ad" are automatically added.

           Format: array of string

       dns-priority
           DNS servers priority. The relative priority for DNS servers
           specified by this setting. A lower numerical value is better
           (higher priority). Negative values have the special effect of
           excluding other configurations with a greater numerical priority
           value; so in presence of at least one negative priority, only DNS
           servers from connections with the lowest priority value will be
           used. To avoid all DNS leaks, set the priority of the profile that
           should be used to the most negative value of all active connections
           profiles. Zero selects a globally configured default value. If the
           latter is missing or zero too, it defaults to 50 for VPNs
           (including WireGuard) and 100 for other connections. Note that the
           priority is to order DNS settings for multiple active connections.
           It does not disambiguate multiple DNS servers within the same
           connection profile. When multiple devices have configurations with
           the same priority, VPNs will be considered first, then devices with
           the best (lowest metric) default route and then all other devices.
           When using dns=default, servers with higher priority will be on top
           of resolv.conf. To prioritize a given server over another one
           within the same connection, just specify them in the desired order.
           Note that commonly the resolver tries name servers in
           /etc/resolv.conf in the order listed, proceeding with the next
           server in the list on failure. See for example the "rotate" option
           of the dns-options setting. If there are any negative DNS
           priorities, then only name servers from the devices with that
           lowest priority will be considered. When using a DNS resolver that
           supports Conditional Forwarding or Split DNS (with dns=dnsmasq or
           dns=systemd-resolved settings), each connection is used to query
           domains in its search list. The search domains determine which name
           servers to ask, and the DNS priority is used to prioritize name
           servers based on the domain. Queries for domains not present in any
           search list are routed through connections having the '~.' special
           wildcard domain, which is added automatically to connections with
           the default route (or can be added manually). When multiple
           connections specify the same domain, the one with the best priority
           (lowest numerical value) wins. If a sub domain is configured on
           another interface it will be accepted regardless the priority,
           unless parent domain on the other interface has a negative
           priority, which causes the sub domain to be shadowed. With Split
           DNS one can avoid undesired DNS leaks by properly configuring DNS
           priorities and the search domains, so that only name servers of the
           desired interface are configured.

           Format: int32

       dns-search
           Array of DNS search domains. Domains starting with a tilde ('~')
           are considered 'routing' domains and are used only to decide the
           interface over which a query must be forwarded; they are not used
           to complete unqualified host names. When using a DNS plugin that
           supports Conditional Forwarding or Split DNS, then the search
           domains specify which name servers to query. This makes the
           behavior different from running with plain /etc/resolv.conf. For
           more information see also the dns-priority setting.

           Format: array of string

       gateway
           Alias: gw6

           The gateway associated with this configuration. This is only
           meaningful if "addresses" is also set. The gateway's main purpose
           is to control the next hop of the standard default route on the
           device. Hence, the gateway property conflicts with "never-default"
           and will be automatically dropped if the IP configuration is set to
           never-default. As an alternative to set the gateway, configure a
           static default route with /0 as prefix length.

           Format: string

       ignore-auto-dns
           When "method" is set to "auto" and this property to TRUE,
           automatically configured name servers and search domains are
           ignored and only name servers and search domains specified in the
           "dns" and "dns-search" properties, if any, are used.

           Format: boolean

       ignore-auto-routes
           When "method" is set to "auto" and this property to TRUE,
           automatically configured routes are ignored and only routes
           specified in the "routes" property, if any, are used.

           Format: boolean

       ip6-privacy
           Configure IPv6 Privacy Extensions for SLAAC, described in RFC4941.
           If enabled, it makes the kernel generate a temporary IPv6 address
           in addition to the public one generated from MAC address via
           modified EUI-64. This enhances privacy, but could cause problems in
           some applications, on the other hand. The permitted values are: -1:
           unknown, 0: disabled, 1: enabled (prefer public address), 2:
           enabled (prefer temporary addresses). Having a per-connection
           setting set to "-1" (unknown) means fallback to global
           configuration "ipv6.ip6-privacy". If also global configuration is
           unspecified or set to "-1", fallback to read
           "/proc/sys/net/ipv6/conf/default/use_tempaddr". Note that this
           setting is distinct from the Stable Privacy addresses that can be
           enabled with the "addr-gen-mode" property's "stable-privacy"
           setting as another way of avoiding host tracking with IPv6
           addresses.

           Format: NMSettingIP6ConfigPrivacy (int32)

       may-fail
           If TRUE, allow overall network configuration to proceed even if the
           configuration specified by this property times out. Note that at
           least one IP configuration must succeed or overall network
           configuration will still fail. For example, in IPv6-only networks,
           setting this property to TRUE on the NMSettingIP4Config allows the
           overall network configuration to succeed if IPv4 configuration
           fails but IPv6 configuration completes successfully.

           Format: boolean

       method
           IP configuration method. NMSettingIP4Config and NMSettingIP6Config
           both support "disabled", "auto", "manual", and "link-local". See
           the subclass-specific documentation for other values. In general,
           for the "auto" method, properties such as "dns" and "routes"
           specify information that is added on to the information returned
           from automatic configuration. The "ignore-auto-routes" and
           "ignore-auto-dns" properties modify this behavior. For methods that
           imply no upstream network, such as "shared" or "link-local", these
           properties must be empty. For IPv4 method "shared", the IP subnet
           can be configured by adding one manual IPv4 address or otherwise
           10.42.x.0/24 is chosen. Note that the shared method must be
           configured on the interface which shares the internet to a subnet,
           not on the uplink which is shared.

           Format: string

       never-default
           If TRUE, this connection will never be the default connection for
           this IP type, meaning it will never be assigned the default route
           by NetworkManager.

           Format: boolean

       ra-timeout
           A timeout for waiting Router Advertisements in seconds. If zero
           (the default), a globally configured default is used. If still
           unspecified, the timeout depends on the sysctl settings of the
           device. Set to 2147483647 (MAXINT32) for infinity.

           Format: int32

       required-timeout
           The minimum time interval in milliseconds for which dynamic IP
           configuration should be tried before the connection succeeds. This
           property is useful for example if both IPv4 and IPv6 are enabled
           and are allowed to fail. Normally the connection succeeds as soon
           as one of the two address families completes; by setting a required
           timeout for e.g. IPv4, one can ensure that even if IP6 succeeds
           earlier than IPv4, NetworkManager waits some time for IPv4 before
           the connection becomes active. Note that if "may-fail" is FALSE for
           the same address family, this property has no effect as
           NetworkManager needs to wait for the full DHCP timeout. A zero
           value means that no required timeout is present, -1 means the
           default value (either configuration ipvx.required-timeout override
           or zero).

           Format: int32

       route-metric
           The default metric for routes that don't explicitly specify a
           metric. The default value -1 means that the metric is chosen
           automatically based on the device type. The metric applies to
           dynamic routes, manual (static) routes that don't have an explicit
           metric setting, address prefix routes, and the default route. Note
           that for IPv6, the kernel accepts zero (0) but coerces it to 1024
           (user default). Hence, setting this property to zero effectively
           mean setting it to 1024. For IPv4, zero is a regular value for the
           metric.

           Format: int64

       route-table
           Enable policy routing (source routing) and set the routing table
           used when adding routes. This affects all routes, including
           device-routes, IPv4LL, DHCP, SLAAC, default-routes and static
           routes. But note that static routes can individually overwrite the
           setting by explicitly specifying a non-zero routing table. If the
           table setting is left at zero, it is eligible to be overwritten via
           global configuration. If the property is zero even after applying
           the global configuration value, policy routing is disabled for the
           address family of this connection. Policy routing disabled means
           that NetworkManager will add all routes to the main table (except
           static routes that explicitly configure a different table).
           Additionally, NetworkManager will not delete any extraneous routes
           from tables except the main table. This is to preserve backward
           compatibility for users who manage routing tables outside of
           NetworkManager.

           Format: uint32

       routes
           A list of IPv6 destination addresses, prefix length, optional IPv6
           next hop addresses, optional route metric, optional attribute. The
           valid syntax is: "ip[/prefix] [next-hop] [metric]
           [attribute=val]...[,ip[/prefix]...]".

           Various attributes are supported:

           •   "cwnd" - an unsigned 32 bit integer.

           •   "from" - an IPv6 address with optional prefix. IPv6 only.

           •   "initcwnd" - an unsigned 32 bit integer.

           •   "initrwnd" - an unsigned 32 bit integer.

           •   "lock-cwnd" - a boolean value.

           •   "lock-initcwnd" - a boolean value.

           •   "lock-initrwnd" - a boolean value.

           •   "lock-mtu" - a boolean value.

           •   "lock-window" - a boolean value.

           •   "mtu" - an unsigned 32 bit integer.

           •   "onlink" - a boolean value.

           •   "src" - an IPv6 address.

           •   "table" - an unsigned 32 bit integer. The default depends on
               ipv6.route-table.

           •   "type" - one of unicast, local, blackhole, unavailable,
               prohibit. The default is unicast.

           •   "window" - an unsigned 32 bit integer.

           For details see also `man ip-route`.

           Format: a comma separated list of routes

       routing-rules
           A comma separated list of routing rules for policy routing. The
           format is based on ip rule add syntax and mostly compatible. One
           difference is that routing rules in NetworkManager always need a
           fixed priority.

           Example: priority 5 from 1:2:3::5/128 table 45

           Format: a comma separated list of routing rules

       token
           Configure the token for
           draft-chown-6man-tokenised-ipv6-identifiers-02 IPv6 tokenized
           interface identifiers. Useful with eui64 addr-gen-mode.

           Format: string

   ip-tunnel setting
       IP Tunneling Settings.

       Properties:

       encapsulation-limit
           How many additional levels of encapsulation are permitted to be
           prepended to packets. This property applies only to IPv6 tunnels.

           Format: uint32

       flags
           Tunnel flags. Currently, the following values are supported:
           NM_IP_TUNNEL_FLAG_IP6_IGN_ENCAP_LIMIT (0x1),
           NM_IP_TUNNEL_FLAG_IP6_USE_ORIG_TCLASS (0x2),
           NM_IP_TUNNEL_FLAG_IP6_USE_ORIG_FLOWLABEL (0x4),
           NM_IP_TUNNEL_FLAG_IP6_MIP6_DEV (0x8),
           NM_IP_TUNNEL_FLAG_IP6_RCV_DSCP_COPY (0x10),
           NM_IP_TUNNEL_FLAG_IP6_USE_ORIG_FWMARK (0x20). They are valid only
           for IPv6 tunnels.

           Format: uint32

       flow-label
           The flow label to assign to tunnel packets. This property applies
           only to IPv6 tunnels.

           Format: uint32

       input-key
           The key used for tunnel input packets; the property is valid only
           for certain tunnel modes (GRE, IP6GRE). If empty, no key is used.

           Format: string

       local
           Alias: local

           The local endpoint of the tunnel; the value can be empty, otherwise
           it must contain an IPv4 or IPv6 address.

           Format: string

       mode
           Alias: mode

           The tunneling mode, for example NM_IP_TUNNEL_MODE_IPIP (1) or
           NM_IP_TUNNEL_MODE_GRE (2).

           Format: uint32

       mtu
           If non-zero, only transmit packets of the specified size or
           smaller, breaking larger packets up into multiple fragments.

           Format: uint32

       output-key
           The key used for tunnel output packets; the property is valid only
           for certain tunnel modes (GRE, IP6GRE). If empty, no key is used.

           Format: string

       parent
           Alias: dev

           If given, specifies the parent interface name or parent connection
           UUID the new device will be bound to so that tunneled packets will
           only be routed via that interface.

           Format: string

       path-mtu-discovery
           Whether to enable Path MTU Discovery on this tunnel.

           Format: boolean

       remote
           Alias: remote

           The remote endpoint of the tunnel; the value must contain an IPv4
           or IPv6 address.

           Format: string

       tos
           The type of service (IPv4) or traffic class (IPv6) field to be set
           on tunneled packets.

           Format: uint32

       ttl
           The TTL to assign to tunneled packets. 0 is a special value meaning
           that packets inherit the TTL value.

           Format: uint32

   macsec setting
       MACSec Settings.

       Properties:

       encrypt
           Alias: encrypt

           Whether the transmitted traffic must be encrypted.

           Format: boolean

       mka-cak
           Alias: cak

           The pre-shared CAK (Connectivity Association Key) for MACsec Key
           Agreement.

           Format: string

       mka-cak-flags
           Flags indicating how to handle the "mka-cak" property. See the
           section called “Secret flag types:” for flag values.

           Format: NMSettingSecretFlags (uint32)

       mka-ckn
           Alias: ckn

           The pre-shared CKN (Connectivity-association Key Name) for MACsec
           Key Agreement.

           Format: string

       mode
           Alias: mode

           Specifies how the CAK (Connectivity Association Key) for MKA
           (MACsec Key Agreement) is obtained.

           Format: int32

       parent
           Alias: dev

           If given, specifies the parent interface name or parent connection
           UUID from which this MACSEC interface should be created. If this
           property is not specified, the connection must contain an
           "802-3-ethernet" setting with a "mac-address" property.

           Format: string

       port
           Alias: port

           The port component of the SCI (Secure Channel Identifier), between
           1 and 65534.

           Format: int32

       send-sci
           Specifies whether the SCI (Secure Channel Identifier) is included
           in every packet.

           Format: boolean

       validation
           Specifies the validation mode for incoming frames.

           Format: int32

   macvlan setting
       MAC VLAN Settings.

       Properties:

       mode
           Alias: mode

           The macvlan mode, which specifies the communication mechanism
           between multiple macvlans on the same lower device.

           Format: uint32

       parent
           Alias: dev

           If given, specifies the parent interface name or parent connection
           UUID from which this MAC-VLAN interface should be created. If this
           property is not specified, the connection must contain an
           "802-3-ethernet" setting with a "mac-address" property.

           Format: string

       promiscuous
           Whether the interface should be put in promiscuous mode.

           Format: boolean

       tap
           Alias: tap

           Whether the interface should be a MACVTAP.

           Format: boolean

   match setting
       Match settings.

       Properties:

       driver
           A list of driver names to match. Each element is a shell wildcard
           pattern. See NMSettingMatch:interface-name for how special
           characters '|', '&', '!' and '\' are used for optional and
           mandatory matches and inverting the pattern.

           Format: array of string

       interface-name
           A list of interface names to match. Each element is a shell
           wildcard pattern. An element can be prefixed with a pipe symbol (|)
           or an ampersand (&). The former means that the element is optional
           and the latter means that it is mandatory. If there are any
           optional elements, than the match evaluates to true if at least one
           of the optional element matches (logical OR). If there are any
           mandatory elements, then they all must match (logical AND). By
           default, an element is optional. This means that an element "foo"
           behaves the same as "|foo". An element can also be inverted with
           exclamation mark (!) between the pipe symbol (or the ampersand) and
           before the pattern. Note that "!foo" is a shortcut for the
           mandatory match "&!foo". Finally, a backslash can be used at the
           beginning of the element (after the optional special characters) to
           escape the start of the pattern. For example, "&\!a" is an
           mandatory match for literally "!a".

           Format: array of string

       kernel-command-line
           A list of kernel command line arguments to match. This may be used
           to check whether a specific kernel command line option is set (or
           unset, if prefixed with the exclamation mark). The argument must
           either be a single word, or an assignment (i.e. two words, joined
           by "="). In the former case the kernel command line is searched for
           the word appearing as is, or as left hand side of an assignment. In
           the latter case, the exact assignment is looked for with right and
           left hand side matching. Wildcard patterns are not supported. See
           NMSettingMatch:interface-name for how special characters '|', '&',
           '!' and '\' are used for optional and mandatory matches and
           inverting the match.

           Format: array of string

       path
           A list of paths to match against the ID_PATH udev property of
           devices. ID_PATH represents the topological persistent path of a
           device. It typically contains a subsystem string (pci, usb,
           platform, etc.) and a subsystem-specific identifier. For PCI
           devices the path has the form "pci-$domain:$bus:$device.$function",
           where each variable is an hexadecimal value; for example
           "pci-0000:0a:00.0". The path of a device can be obtained with
           "udevadm info /sys/class/net/$dev | grep ID_PATH=" or by looking at
           the "path" property exported by NetworkManager ("nmcli -f
           general.path device show $dev"). Each element of the list is a
           shell wildcard pattern. See NMSettingMatch:interface-name for how
           special characters '|', '&', '!' and '\' are used for optional and
           mandatory matches and inverting the pattern.

           Format: array of string

   802-11-olpc-mesh setting
       Alias: olpc-mesh

       OLPC Wireless Mesh Settings.

       Properties:

       channel
           Alias: channel

           Channel on which the mesh network to join is located.

           Format: uint32

       dhcp-anycast-address
           Alias: dhcp-anycast

           Anycast DHCP MAC address used when requesting an IP address via
           DHCP. The specific anycast address used determines which DHCP
           server class answers the request. This is currently only
           implemented by dhclient DHCP plugin.

           Format: byte array

       ssid
           Alias: ssid

           SSID of the mesh network to join.

           Format: byte array

   ovs-bridge setting
       OvsBridge Link Settings.

       Properties:

       datapath-type
           The data path type. One of "system", "netdev" or empty.

           Format: string

       fail-mode
           The bridge failure mode. One of "secure", "standalone" or empty.

           Format: string

       mcast-snooping-enable
           Enable or disable multicast snooping.

           Format: boolean

       rstp-enable
           Enable or disable RSTP.

           Format: boolean

       stp-enable
           Enable or disable STP.

           Format: boolean

   ovs-dpdk setting
       OvsDpdk Link Settings.

       Properties:

       devargs
           Open vSwitch DPDK device arguments.

           Format: string

       n-rxq
           Open vSwitch DPDK number of rx queues. Defaults to zero which means
           to leave the parameter in OVS unspecified and effectively
           configures one queue.

           Format: uint32

   ovs-interface setting
       Open vSwitch Interface Settings.

       Properties:

       type
           The interface type. Either "internal", "system", "patch", "dpdk",
           or empty.

           Format: string

   ovs-patch setting
       OvsPatch Link Settings.

       Properties:

       peer
           Specifies the name of the interface for the other side of the
           patch. The patch on the other side must also set this interface as
           peer.

           Format: string

   ovs-port setting
       OvsPort Link Settings.

       Properties:

       bond-downdelay
           The time port must be inactive in order to be considered down.

           Format: uint32

       bond-mode
           Bonding mode. One of "active-backup", "balance-slb", or
           "balance-tcp".

           Format: string

       bond-updelay
           The time port must be active before it starts forwarding traffic.

           Format: uint32

       lacp
           LACP mode. One of "active", "off", or "passive".

           Format: string

       tag
           The VLAN tag in the range 0-4095.

           Format: uint32

       vlan-mode
           The VLAN mode. One of "access", "native-tagged", "native-untagged",
           "trunk" or unset.

           Format: string

   ppp setting
       Point-to-Point Protocol Settings.

       Properties:

       baud
           If non-zero, instruct pppd to set the serial port to the specified
           baudrate. This value should normally be left as 0 to automatically
           choose the speed.

           Format: uint32

       crtscts
           If TRUE, specify that pppd should set the serial port to use
           hardware flow control with RTS and CTS signals. This value should
           normally be set to FALSE.

           Format: boolean

       lcp-echo-failure
           If non-zero, instruct pppd to presume the connection to the peer
           has failed if the specified number of LCP echo-requests go
           unanswered by the peer. The "lcp-echo-interval" property must also
           be set to a non-zero value if this property is used.

           Format: uint32

       lcp-echo-interval
           If non-zero, instruct pppd to send an LCP echo-request frame to the
           peer every n seconds (where n is the specified value). Note that
           some PPP peers will respond to echo requests and some will not, and
           it is not possible to autodetect this.

           Format: uint32

       mppe-stateful
           If TRUE, stateful MPPE is used. See pppd documentation for more
           information on stateful MPPE.

           Format: boolean

       mru
           If non-zero, instruct pppd to request that the peer send packets no
           larger than the specified size. If non-zero, the MRU should be
           between 128 and 16384.

           Format: uint32

       mtu
           If non-zero, instruct pppd to send packets no larger than the
           specified size.

           Format: uint32

       no-vj-comp
           If TRUE, Van Jacobsen TCP header compression will not be requested.

           Format: boolean

       noauth
           If TRUE, do not require the other side (usually the PPP server) to
           authenticate itself to the client. If FALSE, require authentication
           from the remote side. In almost all cases, this should be TRUE.

           Format: boolean

       nobsdcomp
           If TRUE, BSD compression will not be requested.

           Format: boolean

       nodeflate
           If TRUE, "deflate" compression will not be requested.

           Format: boolean

       refuse-chap
           If TRUE, the CHAP authentication method will not be used.

           Format: boolean

       refuse-eap
           If TRUE, the EAP authentication method will not be used.

           Format: boolean

       refuse-mschap
           If TRUE, the MSCHAP authentication method will not be used.

           Format: boolean

       refuse-mschapv2
           If TRUE, the MSCHAPv2 authentication method will not be used.

           Format: boolean

       refuse-pap
           If TRUE, the PAP authentication method will not be used.

           Format: boolean

       require-mppe
           If TRUE, MPPE (Microsoft Point-to-Point Encryption) will be
           required for the PPP session. If either 64-bit or 128-bit MPPE is
           not available the session will fail. Note that MPPE is not used on
           mobile broadband connections.

           Format: boolean

       require-mppe-128
           If TRUE, 128-bit MPPE (Microsoft Point-to-Point Encryption) will be
           required for the PPP session, and the "require-mppe" property must
           also be set to TRUE. If 128-bit MPPE is not available the session
           will fail.

           Format: boolean

   pppoe setting
       PPP-over-Ethernet Settings.

       Properties:

       parent
           Alias: parent

           If given, specifies the parent interface name on which this PPPoE
           connection should be created. If this property is not specified,
           the connection is activated on the interface specified in
           "interface-name" of NMSettingConnection.

           Format: string

       password
           Alias: password

           Password used to authenticate with the PPPoE service.

           Format: string

       password-flags
           Flags indicating how to handle the "password" property. See the
           section called “Secret flag types:” for flag values.

           Format: NMSettingSecretFlags (uint32)

       service
           Alias: service

           If specified, instruct PPPoE to only initiate sessions with access
           concentrators that provide the specified service. For most
           providers, this should be left blank. It is only required if there
           are multiple access concentrators or a specific service is known to
           be required.

           Format: string

       username
           Alias: username

           Username used to authenticate with the PPPoE service.

           Format: string

   proxy setting
       WWW Proxy Settings.

       Properties:

       browser-only
           Alias: browser-only

           Whether the proxy configuration is for browser only.

           Format: boolean

       method
           Alias: method

           Method for proxy configuration, Default is
           NM_SETTING_PROXY_METHOD_NONE (0)

           Format: int32

       pac-script
           Alias: pac-script

           PAC script for the connection.

           Format: string

       pac-url
           Alias: pac-url

           PAC URL for obtaining PAC file.

           Format: string

   serial setting
       Serial Link Settings.

       Properties:

       baud
           Speed to use for communication over the serial port. Note that this
           value usually has no effect for mobile broadband modems as they
           generally ignore speed settings and use the highest available
           speed.

           Format: uint32

       bits
           Byte-width of the serial communication. The 8 in "8n1" for example.

           Format: uint32

       parity
           Parity setting of the serial port.

           Format: NMSettingSerialParity (byte)

       send-delay
           Time to delay between each byte sent to the modem, in microseconds.

           Format: uint64

       stopbits
           Number of stop bits for communication on the serial port. Either 1
           or 2. The 1 in "8n1" for example.

           Format: uint32

   sriov setting
       SR-IOV settings.

       Properties:

       autoprobe-drivers
           Whether to autoprobe virtual functions by a compatible driver. If
           set to NM_TERNARY_TRUE (1), the kernel will try to bind VFs to a
           compatible driver and if this succeeds a new network interface will
           be instantiated for each VF. If set to NM_TERNARY_FALSE (0), VFs
           will not be claimed and no network interfaces will be created for
           them. When set to NM_TERNARY_DEFAULT (-1), the global default is
           used; in case the global default is unspecified it is assumed to be
           NM_TERNARY_TRUE (1).

           Format: NMTernary (int32)

       total-vfs
           The total number of virtual functions to create. Note that when the
           sriov setting is present NetworkManager enforces the number of
           virtual functions on the interface (also when it is zero) during
           activation and resets it upon deactivation. To prevent any changes
           to SR-IOV parameters don't add a sriov setting to the connection.

           Format: uint32

       vfs
           Array of virtual function descriptors. Each VF descriptor is a
           dictionary mapping attribute names to GVariant values. The 'index'
           entry is mandatory for each VF. When represented as string a VF is
           in the form: "INDEX [ATTR=VALUE[ ATTR=VALUE]...]". for example: "2
           mac=00:11:22:33:44:55 spoof-check=true". Multiple VFs can be
           specified using a comma as separator. Currently, the following
           attributes are supported: mac, spoof-check, trust, min-tx-rate,
           max-tx-rate, vlans. The "vlans" attribute is represented as a
           semicolon-separated list of VLAN descriptors, where each descriptor
           has the form "ID[.PRIORITY[.PROTO]]". PROTO can be either 'q' for
           802.1Q (the default) or 'ad' for 802.1ad.

           Format: array of vardict

   tc setting
       Linux Traffic Control Settings.

       Properties:

       qdiscs
           Array of TC queueing disciplines. qdisc is a basic block in the
           Linux traffic control subsystem

           Each qdisc can be specified by the following attributes:

           handle HANDLE
               specifies the qdisc handle. A qdisc, which potentially can have
               children, gets assigned a major number, called a 'handle',
               leaving the minor number namespace available for classes. The
               handle is expressed as '10:'. It is customary to explicitly
               assign a handle to qdiscs expected to have children.

           parent HANDLE
               specifies the handle of the parent qdisc the current qdisc must
               be attached to.

           root
               specifies that the qdisc is attached to the root of device.

           KIND
               this is the qdisc kind. NetworkManager currently supports the
               following kinds: fq_codel, sfq, tbf. Each qdisc kind has a
               different set of parameters, described below. There are also
               some kinds like pfifo, pfifo_fast, prio supported by
               NetworkManager but their parameters are not supported by
               NetworkManager.

           Parameters for 'fq_codel':

           limit U32
               the hard limit on the real queue size. When this limit is
               reached, incoming packets are dropped. Default is 10240
               packets.

           memory_limit U32
               sets a limit on the total number of bytes that can be queued in
               this FQ-CoDel instance. The lower of the packet limit of the
               limit parameter and the memory limit will be enforced. Default
               is 32 MB.

           flows U32
               the number of flows into which the incoming packets are
               classified. Due to the stochastic nature of hashing, multiple
               flows may end up being hashed into the same slot. Newer flows
               have priority over older ones. This parameter can be set only
               at load time since memory has to be allocated for the hash
               table. Default value is 1024.

           target U32
               the acceptable minimum standing/persistent queue delay. This
               minimum delay is identified by tracking the local minimum queue
               delay that packets experience. The unit of measurement is
               microsecond(us). Default value is 5ms.

           interval U32
               used to ensure that the measured minimum delay does not become
               too stale. The minimum delay must be experienced in the last
               epoch of length .B interval. It should be set on the order of
               the worst-case RTT through the bottleneck to give endpoints
               sufficient time to react. Default value is 100ms.

           quantum U32
               the number of bytes used as 'deficit' in the fair queuing
               algorithm. Default is set to 1514 bytes which corresponds to
               the Ethernet MTU plus the hardware header length of 14 bytes.

           ecn BOOL
               can be used to mark packets instead of dropping them. ecn is
               turned on by default.

           ce_threshold U32
               sets a threshold above which all packets are marked with ECN
               Congestion Experienced. This is useful for DCTCP-style
               congestion control algorithms that require marking at very
               shallow queueing thresholds.

           Parameters for 'sfq':

           divisor U32
               can be used to set a different hash table size, available from
               kernel 2.6.39 onwards. The specified divisor must be a power of
               two and cannot be larger than 65536. Default value: 1024.

           limit U32
               Upper limit of the SFQ. Can be used to reduce the default
               length of 127 packets.

           depth U32
               Limit of packets per flow. Default to 127 and can be lowered.

           perturb_period U32
               Interval in seconds for queue algorithm perturbation. Defaults
               to 0, which means that no perturbation occurs. Do not set too
               low for each perturbation may cause some packet reordering or
               losses. Advised value: 60 This value has no effect when
               external flow classification is used. Its better to increase
               divisor value to lower risk of hash collisions.

           quantum U32
               Amount of bytes a flow is allowed to dequeue during a round of
               the round robin process. Defaults to the MTU of the interface
               which is also the advised value and the minimum value.

           flows U32
               Default value is 127.

           Parameters for 'tbf':

           rate U64
               Bandwidth or rate. These parameters accept a floating point
               number, possibly followed by either a unit (both SI and IEC
               units supported), or a float followed by a percent character to
               specify the rate as a percentage of the device's speed.

           burst U32
               Also known as buffer or maxburst. Size of the bucket, in bytes.
               This is the maximum amount of bytes that tokens can be
               available for instantaneously. In general, larger shaping rates
               require a larger buffer. For 10mbit/s on Intel, you need at
               least 10kbyte buffer if you want to reach your configured rate!

               If your buffer is too small, packets may be dropped because
               more tokens arrive per timer tick than fit in your bucket. The
               minimum buffer size can be calculated by dividing the rate by
               HZ.

               Token usage calculations are performed using a table which by
               default has a resolution of 8 packets. This resolution can be
               changed by specifying the cell size with the burst. For
               example, to specify a 6000 byte buffer with a 16 byte cell
               size, set a burst of 6000/16. You will probably never have to
               set this. Must be an integral power of 2.

           limit U32
               Limit is the number of bytes that can be queued waiting for
               tokens to become available.

           latency U32
               specifies the maximum amount of time a packet can sit in the
               TBF. The latency calculation takes into account the size of the
               bucket, the rate and possibly the peakrate (if set). The
               latency and limit are mutually exclusive.

           Format: GPtrArray(NMTCQdisc)

       tfilters
           Array of TC traffic filters. Traffic control can manage the packet
           content during classification by using filters.

           Each tfilters can be specified by the following attributes:

           handle HANDLE
               specifies the tfilters handle. A filter is used by a classful
               qdisc to determine in which class a packet will be enqueued. It
               is important to notice that filters reside within qdiscs.
               Therefore, see qdiscs handle for detailed information.

           parent HANDLE
               specifies the handle of the parent qdisc the current qdisc must
               be attached to.

           root
               specifies that the qdisc is attached to the root of device.

           KIND
               this is the tfilters kind. NetworkManager currently supports
               following kinds: mirred, simple. Each filter kind has a
               different set of actions, described below. There are also some
               other kinds like matchall, basic, u32 supported by
               NetworkManager.

           Actions for 'mirred':

           egress bool
               Define whether the packet should exit from the interface.

           ingress bool
               Define whether the packet should come into the interface.

           mirror bool
               Define whether the packet should be copied to the destination
               space.

           redirect bool
               Define whether the packet should be moved to the destination
               space.

           Action for 'simple':

           sdata char[32]
               The actual string to print.

           Format: GPtrArray(NMTCTfilter)

   team setting
       Teaming Settings.

       Properties:

       config
           Alias: config

           The JSON configuration for the team network interface. The property
           should contain raw JSON configuration data suitable for teamd,
           because the value is passed directly to teamd. If not specified,
           the default configuration is used. See man teamd.conf for the
           format details.

           Format: string

       link-watchers
           Link watchers configuration for the connection: each link watcher
           is defined by a dictionary, whose keys depend upon the selected
           link watcher. Available link watchers are 'ethtool', 'nsna_ping'
           and 'arp_ping' and it is specified in the dictionary with the key
           'name'. Available keys are: ethtool: 'delay-up', 'delay-down',
           'init-wait'; nsna_ping: 'init-wait', 'interval', 'missed-max',
           'target-host'; arp_ping: all the ones in nsna_ping and
           'source-host', 'validate-active', 'validate-inactive',
           'send-always'. See teamd.conf man for more details.

           Format: array of vardict

       mcast-rejoin-count
           Corresponds to the teamd mcast_rejoin.count.

           Format: int32

       mcast-rejoin-interval
           Corresponds to the teamd mcast_rejoin.interval.

           Format: int32

       notify-peers-count
           Corresponds to the teamd notify_peers.count.

           Format: int32

       notify-peers-interval
           Corresponds to the teamd notify_peers.interval.

           Format: int32

       runner
           Corresponds to the teamd runner.name. Permitted values are:
           "roundrobin", "broadcast", "activebackup", "loadbalance", "lacp",
           "random".

           Format: string

       runner-active
           Corresponds to the teamd runner.active.

           Format: boolean

       runner-agg-select-policy
           Corresponds to the teamd runner.agg_select_policy.

           Format: string

       runner-fast-rate
           Corresponds to the teamd runner.fast_rate.

           Format: boolean

       runner-hwaddr-policy
           Corresponds to the teamd runner.hwaddr_policy.

           Format: string

       runner-min-ports
           Corresponds to the teamd runner.min_ports.

           Format: int32

       runner-sys-prio
           Corresponds to the teamd runner.sys_prio.

           Format: int32

       runner-tx-balancer
           Corresponds to the teamd runner.tx_balancer.name.

           Format: string

       runner-tx-balancer-interval
           Corresponds to the teamd runner.tx_balancer.interval.

           Format: int32

       runner-tx-hash
           Corresponds to the teamd runner.tx_hash.

           Format: array of string

   team-port setting
       Team Port Settings.

       Properties:

       config
           Alias: config

           The JSON configuration for the team port. The property should
           contain raw JSON configuration data suitable for teamd, because the
           value is passed directly to teamd. If not specified, the default
           configuration is used. See man teamd.conf for the format details.

           Format: string

       lacp-key
           Corresponds to the teamd ports.PORTIFNAME.lacp_key.

           Format: int32

       lacp-prio
           Corresponds to the teamd ports.PORTIFNAME.lacp_prio.

           Format: int32

       link-watchers
           Link watchers configuration for the connection: each link watcher
           is defined by a dictionary, whose keys depend upon the selected
           link watcher. Available link watchers are 'ethtool', 'nsna_ping'
           and 'arp_ping' and it is specified in the dictionary with the key
           'name'. Available keys are: ethtool: 'delay-up', 'delay-down',
           'init-wait'; nsna_ping: 'init-wait', 'interval', 'missed-max',
           'target-host'; arp_ping: all the ones in nsna_ping and
           'source-host', 'validate-active', 'validate-inactive',
           'send-always'. See teamd.conf man for more details.

           Format: array of vardict

       prio
           Corresponds to the teamd ports.PORTIFNAME.prio.

           Format: int32

       queue-id
           Corresponds to the teamd ports.PORTIFNAME.queue_id. When set to -1
           means the parameter is skipped from the json config.

           Format: int32

       sticky
           Corresponds to the teamd ports.PORTIFNAME.sticky.

           Format: boolean

   tun setting
       Tunnel Settings.

       Properties:

       group
           Alias: group

           The group ID which will own the device. If set to NULL everyone
           will be able to use the device.

           Format: string

       mode
           Alias: mode

           The operating mode of the virtual device. Allowed values are
           NM_SETTING_TUN_MODE_TUN (1) to create a layer 3 device and
           NM_SETTING_TUN_MODE_TAP (2) to create an Ethernet-like layer 2 one.

           Format: uint32

       multi-queue
           Alias: multi-queue

           If the property is set to TRUE, the interface will support multiple
           file descriptors (queues) to parallelize packet sending or
           receiving. Otherwise, the interface will only support a single
           queue.

           Format: boolean

       owner
           Alias: owner

           The user ID which will own the device. If set to NULL everyone will
           be able to use the device.

           Format: string

       pi
           Alias: pi

           If TRUE the interface will prepend a 4 byte header describing the
           physical interface to the packets.

           Format: boolean

       vnet-hdr
           Alias: vnet-hdr

           If TRUE the IFF_VNET_HDR the tunnel packets will include a virtio
           network header.

           Format: boolean

   vlan setting
       VLAN Settings.

       Properties:

       egress-priority-map
           Alias: egress

           For outgoing packets, a list of mappings from Linux SKB priorities
           to 802.1p priorities. The mapping is given in the format "from:to"
           where both "from" and "to" are unsigned integers, ie "7:3".

           Format: array of string

       flags
           Alias: flags

           One or more flags which control the behavior and features of the
           VLAN interface. Flags include NM_VLAN_FLAG_REORDER_HEADERS (0x1)
           (reordering of output packet headers), NM_VLAN_FLAG_GVRP (0x2) (use
           of the GVRP protocol), and NM_VLAN_FLAG_LOOSE_BINDING (0x4) (loose
           binding of the interface to its master device's operating state).
           NM_VLAN_FLAG_MVRP (0x8) (use of the MVRP protocol). The default
           value of this property is NM_VLAN_FLAG_REORDER_HEADERS, but it used
           to be 0. To preserve backward compatibility, the default-value in
           the D-Bus API continues to be 0 and a missing property on D-Bus is
           still considered as 0.

           Format: NMVlanFlags (uint32)

       id
           Alias: id

           The VLAN identifier that the interface created by this connection
           should be assigned. The valid range is from 0 to 4094, without the
           reserved id 4095.

           Format: uint32

       ingress-priority-map
           Alias: ingress

           For incoming packets, a list of mappings from 802.1p priorities to
           Linux SKB priorities. The mapping is given in the format "from:to"
           where both "from" and "to" are unsigned integers, ie "7:3".

           Format: array of string

       parent
           Alias: dev

           If given, specifies the parent interface name or parent connection
           UUID from which this VLAN interface should be created. If this
           property is not specified, the connection must contain an
           "802-3-ethernet" setting with a "mac-address" property.

           Format: string

   vpn setting
       VPN Settings.

       Properties:

       data
           Dictionary of key/value pairs of VPN plugin specific data. Both
           keys and values must be strings.

           Format: dict of string to string

       persistent
           If the VPN service supports persistence, and this property is TRUE,
           the VPN will attempt to stay connected across link changes and
           outages, until explicitly disconnected.

           Format: boolean

       secrets
           Dictionary of key/value pairs of VPN plugin specific secrets like
           passwords or private keys. Both keys and values must be strings.

           Format: dict of string to string

       service-type
           Alias: vpn-type

           D-Bus service name of the VPN plugin that this setting uses to
           connect to its network. i.e. org.freedesktop.NetworkManager.vpnc
           for the vpnc plugin.

           Format: string

       timeout
           Timeout for the VPN service to establish the connection. Some
           services may take quite a long time to connect. Value of 0 means a
           default timeout, which is 60 seconds (unless overridden by
           vpn.timeout in configuration file). Values greater than zero mean
           timeout in seconds.

           Format: uint32

       user-name
           Alias: user

           If the VPN connection requires a user name for authentication, that
           name should be provided here. If the connection is available to
           more than one user, and the VPN requires each user to supply a
           different name, then leave this property empty. If this property is
           empty, NetworkManager will automatically supply the username of the
           user which requested the VPN connection.

           Format: string

   vrf setting
       VRF settings.

       Properties:

       table
           Alias: table

           The routing table for this VRF.

           Format: uint32

   vxlan setting
       VXLAN Settings.

       Properties:

       ageing
           Specifies the lifetime in seconds of FDB entries learnt by the
           kernel.

           Format: uint32

       destination-port
           Alias: destination-port

           Specifies the UDP destination port to communicate to the remote
           VXLAN tunnel endpoint.

           Format: uint32

       id
           Alias: id

           Specifies the VXLAN Network Identifier (or VXLAN Segment
           Identifier) to use.

           Format: uint32

       l2-miss
           Specifies whether netlink LL ADDR miss notifications are generated.

           Format: boolean

       l3-miss
           Specifies whether netlink IP ADDR miss notifications are generated.

           Format: boolean

       learning
           Specifies whether unknown source link layer addresses and IP
           addresses are entered into the VXLAN device forwarding database.

           Format: boolean

       limit
           Specifies the maximum number of FDB entries. A value of zero means
           that the kernel will store unlimited entries.

           Format: uint32

       local
           Alias: local

           If given, specifies the source IP address to use in outgoing
           packets.

           Format: string

       parent
           Alias: dev

           If given, specifies the parent interface name or parent connection
           UUID.

           Format: string

       proxy
           Specifies whether ARP proxy is turned on.

           Format: boolean

       remote
           Alias: remote

           Specifies the unicast destination IP address to use in outgoing
           packets when the destination link layer address is not known in the
           VXLAN device forwarding database, or the multicast IP address to
           join.

           Format: string

       rsc
           Specifies whether route short circuit is turned on.

           Format: boolean

       source-port-max
           Alias: source-port-max

           Specifies the maximum UDP source port to communicate to the remote
           VXLAN tunnel endpoint.

           Format: uint32

       source-port-min
           Alias: source-port-min

           Specifies the minimum UDP source port to communicate to the remote
           VXLAN tunnel endpoint.

           Format: uint32

       tos
           Specifies the TOS value to use in outgoing packets.

           Format: uint32

       ttl
           Specifies the time-to-live value to use in outgoing packets.

           Format: uint32

   wifi-p2p setting
       Wi-Fi P2P Settings.

       Properties:

       peer
           Alias: peer

           The P2P device that should be connected to. Currently, this is the
           only way to create or join a group.

           Format: string

       wfd-ies
           The Wi-Fi Display (WFD) Information Elements (IEs) to set. Wi-Fi
           Display requires a protocol specific information element to be set
           in certain Wi-Fi frames. These can be specified here for the
           purpose of establishing a connection. This setting is only useful
           when implementing a Wi-Fi Display client.

           Format: byte array

       wps-method
           Flags indicating which mode of WPS is to be used. There's little
           point in changing the default setting as NetworkManager will
           automatically determine the best method to use.

           Format: uint32

   wimax setting
       WiMax Settings.

       Properties:

       mac-address
           Alias: mac

           If specified, this connection will only apply to the WiMAX device
           whose MAC address matches. This property does not change the MAC
           address of the device (known as MAC spoofing). Deprecated: 1

           Format: byte array

       network-name
           Alias: nsp

           Network Service Provider (NSP) name of the WiMAX network this
           connection should use. Deprecated: 1

           Format: string

   802-3-ethernet setting
       Alias: ethernet

       Wired Ethernet Settings.

       Properties:

       accept-all-mac-addresses
           When TRUE, setup the interface to accept packets for all MAC
           addresses. This is enabling the kernel interface flag IFF_PROMISC.
           When FALSE, the interface will only accept the packets with the
           interface destination mac address or broadcast.

           Format: NMTernary (int32)

       auto-negotiate
           When TRUE, enforce auto-negotiation of speed and duplex mode. If
           "speed" and "duplex" properties are both specified, only that
           single mode will be advertised and accepted during the link
           auto-negotiation process: this works only for BASE-T 802.3
           specifications and is useful for enforcing gigabits modes, as in
           these cases link negotiation is mandatory. When FALSE, "speed" and
           "duplex" properties should be both set or link configuration will
           be skipped.

           Format: boolean

       cloned-mac-address
           Alias: cloned-mac

           If specified, request that the device use this MAC address instead.
           This is known as MAC cloning or spoofing. Beside explicitly
           specifying a MAC address, the special values "preserve",
           "permanent", "random" and "stable" are supported. "preserve" means
           not to touch the MAC address on activation. "permanent" means to
           use the permanent hardware address if the device has one (otherwise
           this is treated as "preserve"). "random" creates a random MAC
           address on each connect. "stable" creates a hashed MAC address
           based on connection.stable-id and a machine dependent key. If
           unspecified, the value can be overwritten via global defaults, see
           manual of NetworkManager.conf. If still unspecified, it defaults to
           "preserve" (older versions of NetworkManager may use a different
           default value). On D-Bus, this field is expressed as
           "assigned-mac-address" or the deprecated "cloned-mac-address".

           Format: byte array

       duplex
           When a value is set, either "half" or "full", configures the device
           to use the specified duplex mode. If "auto-negotiate" is "yes" the
           specified duplex mode will be the only one advertised during link
           negotiation: this works only for BASE-T 802.3 specifications and is
           useful for enforcing gigabits modes, as in these cases link
           negotiation is mandatory. If the value is unset (the default), the
           link configuration will be either skipped (if "auto-negotiate" is
           "no", the default) or will be auto-negotiated (if "auto-negotiate"
           is "yes") and the local device will advertise all the supported
           duplex modes. Must be set together with the "speed" property if
           specified. Before specifying a duplex mode be sure your device
           supports it.

           Format: string

       generate-mac-address-mask
           With "cloned-mac-address" setting "random" or "stable", by default
           all bits of the MAC address are scrambled and a
           locally-administered, unicast MAC address is created. This property
           allows to specify that certain bits are fixed. Note that the least
           significant bit of the first MAC address will always be unset to
           create a unicast MAC address. If the property is NULL, it is
           eligible to be overwritten by a default connection setting. If the
           value is still NULL or an empty string, the default is to create a
           locally-administered, unicast MAC address. If the value contains
           one MAC address, this address is used as mask. The set bits of the
           mask are to be filled with the current MAC address of the device,
           while the unset bits are subject to randomization. Setting
           "FE:FF:FF:00:00:00" means to preserve the OUI of the current MAC
           address and only randomize the lower 3 bytes using the "random" or
           "stable" algorithm. If the value contains one additional MAC
           address after the mask, this address is used instead of the current
           MAC address to fill the bits that shall not be randomized. For
           example, a value of "FE:FF:FF:00:00:00 68:F7:28:00:00:00" will set
           the OUI of the MAC address to 68:F7:28, while the lower bits are
           randomized. A value of "02:00:00:00:00:00 00:00:00:00:00:00" will
           create a fully scrambled globally-administered, burned-in MAC
           address. If the value contains more than one additional MAC
           addresses, one of them is chosen randomly. For example,
           "02:00:00:00:00:00 00:00:00:00:00:00 02:00:00:00:00:00" will create
           a fully scrambled MAC address, randomly locally or globally
           administered.

           Format: string

       mac-address
           Alias: mac

           If specified, this connection will only apply to the Ethernet
           device whose permanent MAC address matches. This property does not
           change the MAC address of the device (i.e. MAC spoofing).

           Format: byte array

       mac-address-blacklist
           If specified, this connection will never apply to the Ethernet
           device whose permanent MAC address matches an address in the list.
           Each MAC address is in the standard hex-digits-and-colons notation
           (00:11:22:33:44:55).

           Format: array of string

       mtu
           Alias: mtu

           If non-zero, only transmit packets of the specified size or
           smaller, breaking larger packets up into multiple Ethernet frames.

           Format: uint32

       port
           Specific port type to use if the device supports multiple
           attachment methods. One of "tp" (Twisted Pair), "aui" (Attachment
           Unit Interface), "bnc" (Thin Ethernet) or "mii" (Media Independent
           Interface). If the device supports only one port type, this setting
           is ignored.

           Format: string

       s390-nettype
           s390 network device type; one of "qeth", "lcs", or "ctc",
           representing the different types of virtual network devices
           available on s390 systems.

           Format: string

       s390-options
           Dictionary of key/value pairs of s390-specific device options. Both
           keys and values must be strings. Allowed keys include "portno",
           "layer2", "portname", "protocol", among others. Key names must
           contain only alphanumeric characters (ie, [a-zA-Z0-9]). Currently,
           NetworkManager itself does nothing with this information. However,
           s390utils ships a udev rule which parses this information and
           applies it to the interface.

           Format: dict of string to string

       s390-subchannels
           Identifies specific subchannels that this network device uses for
           communication with z/VM or s390 host. Like the "mac-address"
           property for non-z/VM devices, this property can be used to ensure
           this connection only applies to the network device that uses these
           subchannels. The list should contain exactly 3 strings, and each
           string may only be composed of hexadecimal characters and the
           period (.) character.

           Format: array of string

       speed
           When a value greater than 0 is set, configures the device to use
           the specified speed. If "auto-negotiate" is "yes" the specified
           speed will be the only one advertised during link negotiation: this
           works only for BASE-T 802.3 specifications and is useful for
           enforcing gigabit speeds, as in this case link negotiation is
           mandatory. If the value is unset (0, the default), the link
           configuration will be either skipped (if "auto-negotiate" is "no",
           the default) or will be auto-negotiated (if "auto-negotiate" is
           "yes") and the local device will advertise all the supported
           speeds. In Mbit/s, ie 100 == 100Mbit/s. Must be set together with
           the "duplex" property when non-zero. Before specifying a speed
           value be sure your device supports it.

           Format: uint32

       wake-on-lan
           The NMSettingWiredWakeOnLan options to enable. Not all devices
           support all options. May be any combination of
           NM_SETTING_WIRED_WAKE_ON_LAN_PHY (0x2),
           NM_SETTING_WIRED_WAKE_ON_LAN_UNICAST (0x4),
           NM_SETTING_WIRED_WAKE_ON_LAN_MULTICAST (0x8),
           NM_SETTING_WIRED_WAKE_ON_LAN_BROADCAST (0x10),
           NM_SETTING_WIRED_WAKE_ON_LAN_ARP (0x20),
           NM_SETTING_WIRED_WAKE_ON_LAN_MAGIC (0x40) or the special values
           NM_SETTING_WIRED_WAKE_ON_LAN_DEFAULT (0x1) (to use global settings)
           and NM_SETTING_WIRED_WAKE_ON_LAN_IGNORE (0x8000) (to disable
           management of Wake-on-LAN in NetworkManager).

           Format: uint32

       wake-on-lan-password
           If specified, the password used with magic-packet-based
           Wake-on-LAN, represented as an Ethernet MAC address. If NULL, no
           password will be required.

           Format: string

   wireguard setting
       WireGuard Settings.

       Properties:

       fwmark
           The use of fwmark is optional and is by default off. Setting it to
           0 disables it. Otherwise, it is a 32-bit fwmark for outgoing
           packets. Note that "ip4-auto-default-route" or
           "ip6-auto-default-route" enabled, implies to automatically choose a
           fwmark.

           Format: uint32

       ip4-auto-default-route
           Whether to enable special handling of the IPv4 default route. If
           enabled, the IPv4 default route from wireguard.peer-routes will be
           placed to a dedicated routing-table and two policy routing rules
           will be added. The fwmark number is also used as routing-table for
           the default-route, and if fwmark is zero, an unused fwmark/table is
           chosen automatically. This corresponds to what wg-quick does with
           Table=auto and what WireGuard calls "Improved Rule-based Routing".
           Note that for this automatism to work, you usually don't want to
           set ipv4.gateway, because that will result in a conflicting default
           route. Leaving this at the default will enable this option
           automatically if ipv4.never-default is not set and there are any
           peers that use a default-route as allowed-ips.

           Format: NMTernary (int32)

       ip6-auto-default-route
           Like ip4-auto-default-route, but for the IPv6 default route.

           Format: NMTernary (int32)

       listen-port
           The listen-port. If listen-port is not specified, the port will be
           chosen randomly when the interface comes up.

           Format: uint32

       mtu
           If non-zero, only transmit packets of the specified size or
           smaller, breaking larger packets up into multiple fragments. If
           zero a default MTU is used. Note that contrary to wg-quick's MTU
           setting, this does not take into account the current routes at the
           time of activation.

           Format: uint32

       peer-routes
           Whether to automatically add routes for the AllowedIPs ranges of
           the peers. If TRUE (the default), NetworkManager will automatically
           add routes in the routing tables according to ipv4.route-table and
           ipv6.route-table. Usually you want this automatism enabled. If
           FALSE, no such routes are added automatically. In this case, the
           user may want to configure static routes in ipv4.routes and
           ipv6.routes, respectively. Note that if the peer's AllowedIPs is
           "0.0.0.0/0" or "::/0" and the profile's ipv4.never-default or
           ipv6.never-default setting is enabled, the peer route for this peer
           won't be added automatically.

           Format: boolean

       private-key
           The 256 bit private-key in base64 encoding.

           Format: string

       private-key-flags
           Flags indicating how to handle the "private-key" property. See the
           section called “Secret flag types:” for flag values.

           Format: NMSettingSecretFlags (uint32)

   802-11-wireless setting
       Alias: wifi

       Wi-Fi Settings.

       Properties:

       ap-isolation
           Configures AP isolation, which prevents communication between
           wireless devices connected to this AP. This property can be set to
           a value different from NM_TERNARY_DEFAULT (-1) only when the
           interface is configured in AP mode. If set to NM_TERNARY_TRUE (1),
           devices are not able to communicate with each other. This increases
           security because it protects devices against attacks from other
           clients in the network. At the same time, it prevents devices to
           access resources on the same wireless networks as file shares,
           printers, etc. If set to NM_TERNARY_FALSE (0), devices can talk to
           each other. When set to NM_TERNARY_DEFAULT (-1), the global default
           is used; in case the global default is unspecified it is assumed to
           be NM_TERNARY_FALSE (0).

           Format: NMTernary (int32)

       band
           802.11 frequency band of the network. One of "a" for 5GHz 802.11a
           or "bg" for 2.4GHz 802.11. This will lock associations to the Wi-Fi
           network to the specific band, i.e. if "a" is specified, the device
           will not associate with the same network in the 2.4GHz band even if
           the network's settings are compatible. This setting depends on
           specific driver capability and may not work with all drivers.

           Format: string

       bssid
           If specified, directs the device to only associate with the given
           access point. This capability is highly driver dependent and not
           supported by all devices. Note: this property does not control the
           BSSID used when creating an Ad-Hoc network and is unlikely to in
           the future.

           Format: byte array

       channel
           Wireless channel to use for the Wi-Fi connection. The device will
           only join (or create for Ad-Hoc networks) a Wi-Fi network on the
           specified channel. Because channel numbers overlap between bands,
           this property also requires the "band" property to be set.

           Format: uint32

       cloned-mac-address
           Alias: cloned-mac

           If specified, request that the device use this MAC address instead.
           This is known as MAC cloning or spoofing. Beside explicitly
           specifying a MAC address, the special values "preserve",
           "permanent", "random" and "stable" are supported. "preserve" means
           not to touch the MAC address on activation. "permanent" means to
           use the permanent hardware address of the device. "random" creates
           a random MAC address on each connect. "stable" creates a hashed MAC
           address based on connection.stable-id and a machine dependent key.
           If unspecified, the value can be overwritten via global defaults,
           see manual of NetworkManager.conf. If still unspecified, it
           defaults to "preserve" (older versions of NetworkManager may use a
           different default value). On D-Bus, this field is expressed as
           "assigned-mac-address" or the deprecated "cloned-mac-address".

           Format: byte array

       generate-mac-address-mask
           With "cloned-mac-address" setting "random" or "stable", by default
           all bits of the MAC address are scrambled and a
           locally-administered, unicast MAC address is created. This property
           allows to specify that certain bits are fixed. Note that the least
           significant bit of the first MAC address will always be unset to
           create a unicast MAC address. If the property is NULL, it is
           eligible to be overwritten by a default connection setting. If the
           value is still NULL or an empty string, the default is to create a
           locally-administered, unicast MAC address. If the value contains
           one MAC address, this address is used as mask. The set bits of the
           mask are to be filled with the current MAC address of the device,
           while the unset bits are subject to randomization. Setting
           "FE:FF:FF:00:00:00" means to preserve the OUI of the current MAC
           address and only randomize the lower 3 bytes using the "random" or
           "stable" algorithm. If the value contains one additional MAC
           address after the mask, this address is used instead of the current
           MAC address to fill the bits that shall not be randomized. For
           example, a value of "FE:FF:FF:00:00:00 68:F7:28:00:00:00" will set
           the OUI of the MAC address to 68:F7:28, while the lower bits are
           randomized. A value of "02:00:00:00:00:00 00:00:00:00:00:00" will
           create a fully scrambled globally-administered, burned-in MAC
           address. If the value contains more than one additional MAC
           addresses, one of them is chosen randomly. For example,
           "02:00:00:00:00:00 00:00:00:00:00:00 02:00:00:00:00:00" will create
           a fully scrambled MAC address, randomly locally or globally
           administered.

           Format: string

       hidden
           If TRUE, indicates that the network is a non-broadcasting network
           that hides its SSID. This works both in infrastructure and AP mode.
           In infrastructure mode, various workarounds are used for a more
           reliable discovery of hidden networks, such as probe-scanning the
           SSID. However, these workarounds expose inherent insecurities with
           hidden SSID networks, and thus hidden SSID networks should be used
           with caution. In AP mode, the created network does not broadcast
           its SSID. Note that marking the network as hidden may be a privacy
           issue for you (in infrastructure mode) or client stations (in AP
           mode), as the explicit probe-scans are distinctly recognizable on
           the air.

           Format: boolean

       mac-address
           Alias: mac

           If specified, this connection will only apply to the Wi-Fi device
           whose permanent MAC address matches. This property does not change
           the MAC address of the device (i.e. MAC spoofing).

           Format: byte array

       mac-address-blacklist
           A list of permanent MAC addresses of Wi-Fi devices to which this
           connection should never apply. Each MAC address should be given in
           the standard hex-digits-and-colons notation (eg
           "00:11:22:33:44:55").

           Format: array of string

       mac-address-randomization
           One of NM_SETTING_MAC_RANDOMIZATION_DEFAULT (0) (never randomize
           unless the user has set a global default to randomize and the
           supplicant supports randomization),
           NM_SETTING_MAC_RANDOMIZATION_NEVER (1) (never randomize the MAC
           address), or NM_SETTING_MAC_RANDOMIZATION_ALWAYS (2) (always
           randomize the MAC address). This property is deprecated for
           'cloned-mac-address'. Deprecated: 1

           Format: uint32

       mode
           Alias: mode

           Wi-Fi network mode; one of "infrastructure", "mesh", "adhoc" or
           "ap". If blank, infrastructure is assumed.

           Format: string

       mtu
           Alias: mtu

           If non-zero, only transmit packets of the specified size or
           smaller, breaking larger packets up into multiple Ethernet frames.

           Format: uint32

       powersave
           One of NM_SETTING_WIRELESS_POWERSAVE_DISABLE (2) (disable Wi-Fi
           power saving), NM_SETTING_WIRELESS_POWERSAVE_ENABLE (3) (enable
           Wi-Fi power saving), NM_SETTING_WIRELESS_POWERSAVE_IGNORE (1)
           (don't touch currently configure setting) or
           NM_SETTING_WIRELESS_POWERSAVE_DEFAULT (0) (use the globally
           configured value). All other values are reserved.

           Format: uint32

       rate
           If non-zero, directs the device to only use the specified bitrate
           for communication with the access point. Units are in Kb/s, ie 5500
           = 5.5 Mbit/s. This property is highly driver dependent and not all
           devices support setting a static bitrate.

           Format: uint32

       seen-bssids
           A list of BSSIDs (each BSSID formatted as a MAC address like
           "00:11:22:33:44:55") that have been detected as part of the Wi-Fi
           network. NetworkManager internally tracks previously seen BSSIDs.
           The property is only meant for reading and reflects the BSSID list
           of NetworkManager. The changes you make to this property will not
           be preserved.

           Format: array of string

       ssid
           Alias: ssid

           SSID of the Wi-Fi network. Must be specified.

           Format: byte array

       tx-power
           If non-zero, directs the device to use the specified transmit
           power. Units are dBm. This property is highly driver dependent and
           not all devices support setting a static transmit power.

           Format: uint32

       wake-on-wlan
           The NMSettingWirelessWakeOnWLan options to enable. Not all devices
           support all options. May be any combination of
           NM_SETTING_WIRELESS_WAKE_ON_WLAN_ANY (0x2),
           NM_SETTING_WIRELESS_WAKE_ON_WLAN_DISCONNECT (0x4),
           NM_SETTING_WIRELESS_WAKE_ON_WLAN_MAGIC (0x8),
           NM_SETTING_WIRELESS_WAKE_ON_WLAN_GTK_REKEY_FAILURE (0x10),
           NM_SETTING_WIRELESS_WAKE_ON_WLAN_EAP_IDENTITY_REQUEST (0x20),
           NM_SETTING_WIRELESS_WAKE_ON_WLAN_4WAY_HANDSHAKE (0x40),
           NM_SETTING_WIRELESS_WAKE_ON_WLAN_RFKILL_RELEASE (0x80),
           NM_SETTING_WIRELESS_WAKE_ON_WLAN_TCP (0x100) or the special values
           NM_SETTING_WIRELESS_WAKE_ON_WLAN_DEFAULT (0x1) (to use global
           settings) and NM_SETTING_WIRELESS_WAKE_ON_WLAN_IGNORE (0x8000) (to
           disable management of Wake-on-LAN in NetworkManager).

           Format: uint32

   802-11-wireless-security setting
       Alias: wifi-sec

       Wi-Fi Security Settings.

       Properties:

       auth-alg
           When WEP is used (ie, key-mgmt = "none" or "ieee8021x") indicate
           the 802.11 authentication algorithm required by the AP here. One of
           "open" for Open System, "shared" for Shared Key, or "leap" for
           Cisco LEAP. When using Cisco LEAP (ie, key-mgmt = "ieee8021x" and
           auth-alg = "leap") the "leap-username" and "leap-password"
           properties must be specified.

           Format: string

       fils
           Indicates whether Fast Initial Link Setup (802.11ai) must be
           enabled for the connection. One of
           NM_SETTING_WIRELESS_SECURITY_FILS_DEFAULT (0) (use global default
           value), NM_SETTING_WIRELESS_SECURITY_FILS_DISABLE (1) (disable
           FILS), NM_SETTING_WIRELESS_SECURITY_FILS_OPTIONAL (2) (enable FILS
           if the supplicant and the access point support it) or
           NM_SETTING_WIRELESS_SECURITY_FILS_REQUIRED (3) (enable FILS and
           fail if not supported). When set to
           NM_SETTING_WIRELESS_SECURITY_FILS_DEFAULT (0) and no global default
           is set, FILS will be optionally enabled.

           Format: int32

       group
           A list of group/broadcast encryption algorithms which prevents
           connections to Wi-Fi networks that do not utilize one of the
           algorithms in the list. For maximum compatibility leave this
           property empty. Each list element may be one of "wep40", "wep104",
           "tkip", or "ccmp".

           Format: array of string

       key-mgmt
           Key management used for the connection. One of "none" (WEP or no
           password protection), "ieee8021x" (Dynamic WEP), "owe"
           (Opportunistic Wireless Encryption), "wpa-psk" (WPA2 + WPA3
           personal), "sae" (WPA3 personal only), "wpa-eap" (WPA2 + WPA3
           enterprise) or "wpa-eap-suite-b-192" (WPA3 enterprise only). This
           property must be set for any Wi-Fi connection that uses security.

           Format: string

       leap-password
           The login password for legacy LEAP connections (ie, key-mgmt =
           "ieee8021x" and auth-alg = "leap").

           Format: string

       leap-password-flags
           Flags indicating how to handle the "leap-password" property. See
           the section called “Secret flag types:” for flag values.

           Format: NMSettingSecretFlags (uint32)

       leap-username
           The login username for legacy LEAP connections (ie, key-mgmt =
           "ieee8021x" and auth-alg = "leap").

           Format: string

       pairwise
           A list of pairwise encryption algorithms which prevents connections
           to Wi-Fi networks that do not utilize one of the algorithms in the
           list. For maximum compatibility leave this property empty. Each
           list element may be one of "tkip" or "ccmp".

           Format: array of string

       pmf
           Indicates whether Protected Management Frames (802.11w) must be
           enabled for the connection. One of
           NM_SETTING_WIRELESS_SECURITY_PMF_DEFAULT (0) (use global default
           value), NM_SETTING_WIRELESS_SECURITY_PMF_DISABLE (1) (disable PMF),
           NM_SETTING_WIRELESS_SECURITY_PMF_OPTIONAL (2) (enable PMF if the
           supplicant and the access point support it) or
           NM_SETTING_WIRELESS_SECURITY_PMF_REQUIRED (3) (enable PMF and fail
           if not supported). When set to
           NM_SETTING_WIRELESS_SECURITY_PMF_DEFAULT (0) and no global default
           is set, PMF will be optionally enabled.

           Format: int32

       proto
           List of strings specifying the allowed WPA protocol versions to
           use. Each element may be one "wpa" (allow WPA) or "rsn" (allow
           WPA2/RSN). If not specified, both WPA and RSN connections are
           allowed.

           Format: array of string

       psk
           Pre-Shared-Key for WPA networks. For WPA-PSK, it's either an ASCII
           passphrase of 8 to 63 characters that is (as specified in the
           802.11i standard) hashed to derive the actual key, or the key in
           form of 64 hexadecimal character. The WPA3-Personal networks use a
           passphrase of any length for SAE authentication.

           Format: string

       psk-flags
           Flags indicating how to handle the "psk" property. See the section
           called “Secret flag types:” for flag values.

           Format: NMSettingSecretFlags (uint32)

       wep-key-flags
           Flags indicating how to handle the "wep-key0", "wep-key1",
           "wep-key2", and "wep-key3" properties. See the section called
           “Secret flag types:” for flag values.

           Format: NMSettingSecretFlags (uint32)

       wep-key-type
           Controls the interpretation of WEP keys. Allowed values are
           NM_WEP_KEY_TYPE_KEY (1), in which case the key is either a 10- or
           26-character hexadecimal string, or a 5- or 13-character ASCII
           password; or NM_WEP_KEY_TYPE_PASSPHRASE (2), in which case the
           passphrase is provided as a string and will be hashed using the
           de-facto MD5 method to derive the actual WEP key.

           Format: NMWepKeyType (uint32)

       wep-key0
           Index 0 WEP key. This is the WEP key used in most networks. See the
           "wep-key-type" property for a description of how this key is
           interpreted.

           Format: string

       wep-key1
           Index 1 WEP key. This WEP index is not used by most networks. See
           the "wep-key-type" property for a description of how this key is
           interpreted.

           Format: string

       wep-key2
           Index 2 WEP key. This WEP index is not used by most networks. See
           the "wep-key-type" property for a description of how this key is
           interpreted.

           Format: string

       wep-key3
           Index 3 WEP key. This WEP index is not used by most networks. See
           the "wep-key-type" property for a description of how this key is
           interpreted.

           Format: string

       wep-tx-keyidx
           When static WEP is used (ie, key-mgmt = "none") and a non-default
           WEP key index is used by the AP, put that WEP key index here. Valid
           values are 0 (default key) through 3. Note that some consumer
           access points (like the Linksys WRT54G) number the keys 1 - 4.

           Format: uint32

       wps-method
           Flags indicating which mode of WPS is to be used if any. There's
           little point in changing the default setting as NetworkManager will
           automatically determine whether it's feasible to start WPS
           enrollment from the Access Point capabilities. WPS can be disabled
           by setting this property to a value of 1.

           Format: uint32

   wpan setting
       IEEE 802.15.4 (WPAN) MAC Settings.

       Properties:

       channel
           Alias: channel

           IEEE 802.15.4 channel. A positive integer or -1, meaning "do not
           set, use whatever the device is already set to".

           Format: int32

       mac-address
           Alias: mac

           If specified, this connection will only apply to the IEEE 802.15.4
           (WPAN) MAC layer device whose permanent MAC address matches.

           Format: string

       page
           Alias: page

           IEEE 802.15.4 channel page. A positive integer or -1, meaning "do
           not set, use whatever the device is already set to".

           Format: int32

       pan-id
           Alias: pan-id

           IEEE 802.15.4 Personal Area Network (PAN) identifier.

           Format: uint32

       short-address
           Alias: short-addr

           Short IEEE 802.15.4 address to be used within a restricted
           environment.

           Format: uint32

   bond-port setting
       Bond Port Settings.

       Properties:

       queue-id
           Alias: queue-id

           The queue ID of this bond port. The maximum value of queue ID is
           the number of TX queues currently active in device.

           Format: uint32

   hostname setting
       Hostname settings.

       Properties:

       from-dhcp
           Whether the system hostname can be determined from DHCP on this
           connection. When set to NM_TERNARY_DEFAULT (-1), the value from
           global configuration is used. If the property doesn't have a value
           in the global configuration, NetworkManager assumes the value to be
           NM_TERNARY_TRUE (1).

           Format: NMTernary (int32)

       from-dns-lookup
           Whether the system hostname can be determined from reverse DNS
           lookup of addresses on this device. When set to NM_TERNARY_DEFAULT
           (-1), the value from global configuration is used. If the property
           doesn't have a value in the global configuration, NetworkManager
           assumes the value to be NM_TERNARY_TRUE (1).

           Format: NMTernary (int32)

       only-from-default
           If set to NM_TERNARY_TRUE (1), NetworkManager attempts to get the
           hostname via DHCPv4/DHCPv6 or reverse DNS lookup on this device
           only when the device has the default route for the given address
           family (IPv4/IPv6). If set to NM_TERNARY_FALSE (0), the hostname
           can be set from this device even if it doesn't have the default
           route. When set to NM_TERNARY_DEFAULT (-1), the value from global
           configuration is used. If the property doesn't have a value in the
           global configuration, NetworkManager assumes the value to be
           NM_TERNARY_FALSE (0).

           Format: NMTernary (int32)

       priority
           The relative priority of this connection to determine the system
           hostname. A lower numerical value is better (higher priority). A
           connection with higher priority is considered before connections
           with lower priority. If the value is zero, it can be overridden by
           a global value from NetworkManager configuration. If the property
           doesn't have a value in the global configuration, the value is
           assumed to be 100. Negative values have the special effect of
           excluding other connections with a greater numerical priority
           value; so in presence of at least one negative priority, only
           connections with the lowest priority value will be used to
           determine the hostname.

           Format: int32

   veth setting
       Veth Settings.

       Properties:

       peer
           Alias: peer

           This property specifies the peer interface name of the veth. This
           property is mandatory.

           Format: string

   Secret flag types:
       Each password or secret property in a setting has an associated flags
       property that describes how to handle that secret. The flags property
       is a bitfield that contains zero or more of the following values
       logically OR-ed together.

       •   0x0 (none) - the system is responsible for providing and storing
           this secret. This may be required so that secrets are already
           available before the user logs in. It also commonly means that the
           secret will be stored in plain text on disk, accessible to root
           only. For example via the keyfile settings plugin as described in
           the "PLUGINS" section in NetworkManager.conf(5).

       •   0x1 (agent-owned) - a user-session secret agent is responsible for
           providing and storing this secret; when it is required, agents will
           be asked to provide it.

       •   0x2 (not-saved) - this secret should not be saved but should be
           requested from the user each time it is required. This flag should
           be used for One-Time-Pad secrets, PIN codes from hardware tokens,
           or if the user simply does not want to save the secret.

       •   0x4 (not-required) - in some situations it cannot be automatically
           determined that a secret is required or not. This flag hints that
           the secret is not required and should not be requested from the
           user.

FILES
       /etc/NetworkManager/system-connections or distro plugin-specific
       location

SEE ALSO
       nmcli(1), nmcli-examples(7), NetworkManager(8), nm-settings-dbus(5),
       nm-settings-keyfile(5), NetworkManager.conf(5)

NetworkManager 1.36.6                                     NM-SETTINGS-NMCLI(5)

Generated by dwww version 1.14 on Thu Jan 23 07:02:25 CET 2025.