ModemManager::Modem Class
class ModemManager::ModemThe Modem class. More...
Header: | #include <ModemManagerQt/Modem> |
CMake: | find_package(KF6 REQUIRED COMPONENTS ModemManagerQt) target_link_libraries(mytarget PRIVATE KF6::ModemManagerQt) |
Inherits: | ModemManager::Interface |
Public Functions
Modem(const QString &path, QObject *parent = nullptr) | |
ModemManager::Modem::AccessTechnologies | accessTechnologies() const |
QDBusPendingReply<QString> | command(const QString &cmd, uint timeout) |
QDBusPendingReply<QDBusObjectPath> | createBearer(const ModemManager::BearerProperties &bearerProperties) |
QList<MMModemBand> | currentBands() const |
ModemManager::Modem::Capabilities | currentCapabilities() const |
ModemManager::CurrentModesType | currentModes() const |
QDBusPendingReply<void> | deleteBearer(const QString &bearer) |
QString | device() const |
QString | deviceIdentifier() const |
QStringList | drivers() const |
QString | equipmentIdentifier() const |
QDBusPendingReply<void> | factoryReset(const QString &code) |
ModemManager::Bearer::Ptr | findBearer(const QString &bearer) const |
bool | isEnabled() const |
bool | isValid() const |
ModemManager::Bearer::List | listBearers() const |
QString | manufacturer() const |
uint | maxActiveBearers() const |
uint | maxBearers() const |
QString | model() const |
QStringList | ownNumbers() const |
QString | plugin() const |
(since 1.1.94) ModemManager::PortList | ports() const |
MMModemPowerState | powerState() const |
QString | primaryPort() const |
QDBusPendingReply<void> | reset() |
QString | revision() const |
QDBusPendingReply<void> | setCurrentBands(const QList<MMModemBand> &bands) |
QDBusPendingReply<void> | setCurrentCapabilities(ModemManager::Modem::Capabilities caps) |
QDBusPendingReply<void> | setCurrentModes(const ModemManager::CurrentModesType &mode) |
QDBusPendingReply<void> | setEnabled(bool enable) |
QDBusPendingReply<void> | setPowerState(MMModemPowerState state) |
void | setTimeout(int timeout) |
ModemManager::SignalQualityPair | signalQuality() const |
QString | simPath() const |
MMModemState | state() const |
MMModemStateFailedReason | stateFailedReason() const |
QList<MMModemBand> | supportedBands() const |
QList<MMModemCapability> | supportedCapabilities() const |
ModemManager::Modem::IpBearerFamilies | supportedIpFamilies() const |
ModemManager::SupportedModesType | supportedModes() const |
int | timeout() const |
QString | uni() const |
MMModemLock | unlockRequired() const |
ModemManager::UnlockRetriesMap | unlockRetries() const |
Signals
void | accessTechnologiesChanged(QFlags<MMModemAccessTechnology> accessTechnologies) |
void | bearerAdded(const QString &bearer) |
void | bearerRemoved(const QString &bearer) |
void | bearersChanged() |
void | currentBandsChanged(const QList<MMModemBand> &supportedBands) |
void | currentCapabilitiesChanged(const QFlags<MMModemCapability> ¤tCapabilities) |
void | currentModesChanged(ModemManager::CurrentModesType currentModes) |
void | deviceChanged(const QString &device) |
void | deviceIdentifierChanged(const QString &deviceIdentifier) |
void | driversChanged(const QStringList &drivers) |
void | equipmentIdentifierChanged(const QString &equipmentIdentifier) |
void | manufacturerChanged(const QString &manufacturer) |
void | maxActiveBearersChanged(uint maxActiveBearers) |
void | maxBearersChanged(uint maxBearers) |
void | modelChanged(const QString &model) |
void | ownNumbersChanged(const QStringList &ownNumbers) |
void | pluginChanged(const QString &plugin) |
void | portsChanged(const ModemManager::PortList &ports) |
void | powerStateChanged(MMModemPowerState powerState) |
void | primaryPortChanged(const QString &primaryPort) |
void | revisionChanged(const QString &revision) |
void | signalQualityChanged(ModemManager::SignalQualityPair signalQuality) |
void | simPathChanged(const QString &oldPath, const QString &newPath) |
void | stateChanged(MMModemState oldState, MMModemState newState, MMModemStateChangeReason reason) |
void | stateFailedReasonChanged(MMModemStateFailedReason stateFailedReason) |
void | supportedBandsChanged(const QList<MMModemBand> &supportedBands) |
void | supportedCapabilitiesChanged(const QList<MMModemCapability> &supportedCapabilities) |
void | supportedIpFamiliesChanged(QFlags<MMBearerIpFamily> supportedIpFamilies) |
void | supportedModesChanged(ModemManager::SupportedModesType supportedModes) |
void | unlockRequiredChanged(MMModemLock unlockRequired) |
void | unlockRetriesChanged(const ModemManager::UnlockRetriesMap &unlockRetries) |
Detailed Description
The Modem interface controls the status and actions in a given modem object.
Member Function Documentation
[explicit]
Modem::Modem(const QString &path, QObject *parent = nullptr)
ModemManager::Modem::AccessTechnologies Modem::accessTechnologies() const
Returns QFlags of MMModemAccessTechnology values, specifying the current network access technologies used by the device to communicate with the network.
If the device's access technology cannot be determined, MM_MODEM_ACCESS_TECHNOLOGY_UNKNOWN will be reported.
[signal]
void Modem::accessTechnologiesChanged(QFlags<MMModemAccessTechnology> accessTechnologies)
[signal]
void Modem::bearerAdded(const QString &bearer)
[signal]
void Modem::bearerRemoved(const QString &bearer)
[signal]
void Modem::bearersChanged()
QDBusPendingReply<QString> Modem::command(const QString &cmd, uint timeout)
QDBusPendingReply<QDBusObjectPath> Modem::createBearer(const ModemManager::BearerProperties &bearerProperties)
Create a new packet data bearer using the given characteristics.
This request may fail if the modem does not support additional bearers, if too many bearers are already defined, or if properties are invalid.
QList<MMModemBand> Modem::currentBands() const
Returns List of MMModemBand values, specifying the radio frequency and technology bands the device is currently using when connecting to a network.
It must be a subset of supportedBands()
See also setCurrentBands().
[signal]
void Modem::currentBandsChanged(const QList<MMModemBand> &supportedBands)
ModemManager::Modem::Capabilities Modem::currentCapabilities() const
Returns QFlags of MMModemCapability values, specifying the generic family of access technologies the modem currently supports without a firmware reload or reinitialization.
See also setCurrentCapabilities().
[signal]
void Modem::currentCapabilitiesChanged(const QFlags<MMModemCapability> ¤tCapabilities)
ModemManager::CurrentModesType Modem::currentModes() const
Returns A pair of MMModemMode values, where the first one is a bitmask specifying the access technologies (eg 2G/3G/4G) the device is currently allowed to use when connecting to a network, and the second one is the preferred mode of those specified as allowed.
The pair must be one of those specified in supportedModes()
See also setCurrentModes().
[signal]
void Modem::currentModesChanged(ModemManager::CurrentModesType currentModes)
QDBusPendingReply<void> Modem::deleteBearer(const QString &bearer)
Delete an existing packet data bearer.
If the bearer is currently active and providing packet data server, it will be disconnected and that packet data service will terminate.
bearer path to the bearer to delete
QString Modem::device() const
Returns The physical modem device reference (ie, USB, PCI, PCMCIA device), which may be dependent upon the operating system.
In Linux for example, this points to a sysfs path of the usb_device object.
[signal]
void Modem::deviceChanged(const QString &device)
QString Modem::deviceIdentifier() const
Returns A best-effort device identifier based on various device information like model name, firmware revision, USB/PCI/PCMCIA IDs, and other properties.
This ID is not guaranteed to be unique and may be shared between identical devices with the same firmware, but is intended to be "unique enough" for use as a casual device identifier for various user experience operations.
This is not the device's IMEI or ESN since those may not be available before unlocking the device via a PIN.
[signal]
void Modem::deviceIdentifierChanged(const QString &deviceIdentifier)
QStringList Modem::drivers() const
Returns The Operating System device drivers handling communication with the modem hardware.
[signal]
void Modem::driversChanged(const QStringList &drivers)
QString Modem::equipmentIdentifier() const
Returns The identity of the device.
This will be the IMEI number for GSM devices and the hex-format ESN/MEID for CDMA devices.
[signal]
void Modem::equipmentIdentifierChanged(const QString &equipmentIdentifier)
QDBusPendingReply<void> Modem::factoryReset(const QString &code)
Clear the modem's configuration (including persistent configuration and state), and return the device to a factory-default state.
If not required by the modem, code may be ignored.
This command may or may not power-cycle the device.
code Carrier-supplied code required to reset the modem.
ModemManager::Bearer::Ptr Modem::findBearer(const QString &bearer) const
Returns the configured packet data bearer on given path
bool Modem::isEnabled() const
Returns true if the modem is fully functional, false when in low power mode or disabled
See also setEnabled().
bool Modem::isValid() const
ModemManager::Bearer::List Modem::listBearers() const
Returns the configured packet data bearers (EPS Bearers, PDP Contexts, or CDMA2000 Packet Data Sessions).
QString Modem::manufacturer() const
Returns The equipment manufacturer, as reported by the modem.
[signal]
void Modem::manufacturerChanged(const QString &manufacturer)
uint Modem::maxActiveBearers() const
Returns The maximum number of active packet data bearers the modem supports.
POTS and CDMA2000-only devices support one active bearer, while GSM/UMTS and LTE-capable devices (including LTE/CDMA devices) typically support at least two active bearers.
[signal]
void Modem::maxActiveBearersChanged(uint maxActiveBearers)
uint Modem::maxBearers() const
Returns The maximum number of defined packet data bearers the modem supports.
This is not the number of active/connected bearers the modem supports, but simply the number of bearers that may be defined at any given time. For example, POTS and CDMA2000-only devices support only one bearer, while GSM/UMTS devices typically support three or more, and any LTE-capable device (whether LTE-only, GSM/UMTS-capable, and/or CDMA2000-capable) also typically support three or more.
[signal]
void Modem::maxBearersChanged(uint maxBearers)
QString Modem::model() const
Returns The equipment model, as reported by the modem.
[signal]
void Modem::modelChanged(const QString &model)
QStringList Modem::ownNumbers() const
Returns List of numbers (e.g. MSISDN in 3GPP) being currently handled by this modem.
[signal]
void Modem::ownNumbersChanged(const QStringList &ownNumbers)
QString Modem::plugin() const
Returns The name of the plugin handling this modem.
[signal]
void Modem::pluginChanged(const QString &plugin)
[since 1.1.94]
ModemManager::PortList Modem::ports() const
Returns The list of ports in the modem, given as an array of string and unsigned integer pairs. The string is the port name or path, and the integer is the port type given as a MMModemPortType value.
This function was introduced in 1.1.94.
[signal]
void Modem::portsChanged(const ModemManager::PortList &ports)
MMModemPowerState Modem::powerState() const
Returns A MMModemPowerState value specifying the current power state of the modem.
See also setPowerState().
[signal]
void Modem::powerStateChanged(MMModemPowerState powerState)
QString Modem::primaryPort() const
Returns The name of the primary port using to control the modem.
[signal]
void Modem::primaryPortChanged(const QString &primaryPort)
QDBusPendingReply<void> Modem::reset()
Clear non-persistent configuration and state, and return the device to a newly-powered-on state.
This command may power-cycle the device.
QString Modem::revision() const
Returns The revision identification of the software, as reported by the modem.
[signal]
void Modem::revisionChanged(const QString &revision)
QDBusPendingReply<void> Modem::setCurrentBands(const QList<MMModemBand> &bands)
Set the radio frequency and technology bands the device is currently allowed to use when connecting to a network.
bands List of MMModemBand values, to specify the bands to be used.
See also currentBands().
QDBusPendingReply<void> Modem::setCurrentCapabilities(ModemManager::Modem::Capabilities caps)
Set the capabilities of the device. A restart of the modem may be required.
caps QFlags of MMModemCapability values, to specify the capabilities to use.
See also currentCapabilities().
QDBusPendingReply<void> Modem::setCurrentModes(const ModemManager::CurrentModesType &mode)
Set the access technologies (e.g. 2G/3G/4G preference) the device is currently allowed to use when connecting to a network.
The given combination should be supported by the modem, as specified in supportedModes()
See also currentModes().
QDBusPendingReply<void> Modem::setEnabled(bool enable)
Enable or disable the modem.
When enabled, the modem's radio is powered on and data sessions, voice calls, location services, and Short Message Service may be available.
When disabled, the modem enters low-power state and no network-related operations are available.
See also isEnabled().
QDBusPendingReply<void> Modem::setPowerState(MMModemPowerState state)
Set the power state of the modem. This action can only be run when the modem is in MM_MODEM_STATE_DISABLED state.
See also powerState().
void Modem::setTimeout(int timeout)
Sets the timeout in milliseconds for all async method DBus calls. -1 means the default DBus timeout (usually 25 seconds).
See also timeout().
ModemManager::SignalQualityPair Modem::signalQuality() const
Returns Signal quality in percent (0 - 100) of the dominant access technology the device is using to communicate with the network. Always 0 for POTS devices.
The additional boolean value indicates if the quality value given was recently taken.
[signal]
void Modem::signalQualityChanged(ModemManager::SignalQualityPair signalQuality)
QString Modem::simPath() const
Returns The path of the SIM object available in this device, if any.
[signal]
void Modem::simPathChanged(const QString &oldPath, const QString &newPath)
MMModemState Modem::state() const
Returns Overall state of the modem, given as a MMModemState value.
If the device's state cannot be determined, MM_MODEM_STATE_UNKNOWN will be reported.
[signal]
void Modem::stateChanged(MMModemState oldState, MMModemState newState, MMModemStateChangeReason reason)
MMModemStateFailedReason Modem::stateFailedReason() const
Returns Error specifying why the modem is in MM_MODEM_STATE_FAILED state, given as a MMModemStateFailedReason value.
[signal]
void Modem::stateFailedReasonChanged(MMModemStateFailedReason stateFailedReason)
QList<MMModemBand> Modem::supportedBands() const
Returns List of MMModemBand values, specifying the radio frequency and technology bands supported by the device.
For POTS devices, only the MM_MODEM_BAND_ANY mode will be returned.
[signal]
void Modem::supportedBandsChanged(const QList<MMModemBand> &supportedBands)
QList<MMModemCapability> Modem::supportedCapabilities() const
Returns List of MMModemCapability values, specifying the combinations of generic family of access technologies the modem supports.
If the modem doesn't allow changing the current capabilities, a single entry with MM_MODEM_CAPABILITY_ANY will be given.
[signal]
void Modem::supportedCapabilitiesChanged(const QList<MMModemCapability> &supportedCapabilities)
ModemManager::Modem::IpBearerFamilies Modem::supportedIpFamilies() const
Returns QFlags of MMBearerIpFamily values, specifying the IP families supported by the device.
[signal]
void Modem::supportedIpFamiliesChanged(QFlags<MMBearerIpFamily> supportedIpFamilies)
ModemManager::SupportedModesType Modem::supportedModes() const
Returns This property exposes the supported mode combinations, given as an list of unsigned integer pairs, where: The first integer is a bitmask of MMModemMode values, specifying the allowed modes. The second integer is a single MMModemMode, which specifies the preferred access technology, among the ones defined in the allowed modes.
[signal]
void Modem::supportedModesChanged(ModemManager::SupportedModesType supportedModes)
int Modem::timeout() const
Returns the current value of the DBus timeout in milliseconds. -1 means the default DBus timeout (usually 25 seconds).
See also setTimeout().
QString Modem::uni() const
MMModemLock Modem::unlockRequired() const
Returns Current lock state of the device, given as a MMModemLock value.
[signal]
void Modem::unlockRequiredChanged(MMModemLock unlockRequired)
ModemManager::UnlockRetriesMap Modem::unlockRetries() const
Returns A dictionary in which the keys are MMModemLock flags, and the values are integers giving the number of PIN tries remaining before the code becomes blocked (requiring a PUK) or permanently blocked. Dictionary entries exist only for the codes for which the modem is able to report retry counts.