#include "scriptaction.h" #include "devices/devicemanager.h" #include "types/action.h" #include #include "loggingcategories.h" namespace nymeaserver { ScriptAction::ScriptAction(QObject *parent) : QObject(parent) { } void ScriptAction::classBegin() { m_deviceManager = reinterpret_cast(qmlEngine(this)->property("deviceManager").toULongLong()); } void ScriptAction::componentComplete() { } QString ScriptAction::deviceId() const { return m_deviceId; } void ScriptAction::setDeviceId(const QString &deviceId) { if (m_deviceId != deviceId) { m_deviceId = deviceId; emit deviceIdChanged(); } } QString ScriptAction::actionTypeId() const { return m_actionTypeId; } void ScriptAction::setActionTypeId(const QString &actionTypeId) { if (m_actionTypeId != actionTypeId) { m_actionTypeId = actionTypeId; emit actionTypeIdChanged(); } } QString ScriptAction::actionName() const { return m_actionName; } void ScriptAction::setActionName(const QString &actionName) { if (m_actionName != actionName) { m_actionName = actionName; emit actionNameChanged(); } } void ScriptAction::execute(const QVariantList ¶ms) { Device *device = m_deviceManager->configuredDevices().findById(DeviceId(m_deviceId)); if (!device) { qCWarning(dcScriptEngine) << "No device with id" << m_deviceId; return; } ActionTypeId actionTypeId = ActionTypeId(m_actionTypeId); if (actionTypeId.isNull()) { actionTypeId = device->deviceClass().actionTypes().findByName(m_actionName).id(); } if (actionTypeId.isNull()) { qCWarning(dcScriptEngine()) << "Either a valid actionTypeId or actionName is required"; return; } Action action; action.setActionTypeId(actionTypeId); action.setDeviceId(DeviceId(m_deviceId)); ParamList paramList; foreach (const QVariant &p, params) { paramList << Param(ParamTypeId(p.toMap().value("paramTypeId").toUuid()), p.toMap().value("value")); } action.setParams(paramList); m_deviceManager->executeAction(action); } }