/*
* Copyright Ericsson AB 2011-2014. All Rights Reserved.
*
* The contents of this file are subject to the Lesser GNU Public License,
* (the "License"), either version 2.1 of the License, or
* (at your option) any later version.; you may not use this file except in
* compliance with the License. You should have received a copy of the
* License along with this software. If not, it can be
* retrieved online at https://www.gnu.org/licenses/lgpl.html. Moreover
* it could also be requested from Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*
* BECAUSE THE LIBRARY IS LICENSED FREE OF CHARGE, THERE IS NO
* WARRANTY FOR THE LIBRARY, TO THE EXTENT PERMITTED BY APPLICABLE LAW.
* EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR
* OTHER PARTIES PROVIDE THE LIBRARY "AS IS" WITHOUT WARRANTY OF ANY KIND,
* EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO,
* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE
* LIBRARY IS WITH YOU. SHOULD THE LIBRARY PROVE DEFECTIVE,
* YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION.
*
* IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING
* WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MAY MODIFY AND/OR
* REDISTRIBUTE THE LIBRARY AS PERMITTED ABOVE, BE LIABLE TO YOU FOR
* DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL
* DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE LIBRARY
* (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED
* INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE
* OF THE LIBRARY TO OPERATE WITH ANY OTHER SOFTWARE), EVEN IF SUCH
* HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
*
*/
package com.ericsson.deviceaccess.upnp;
import com.ericsson.common.util.LegacyUtil;
import com.ericsson.deviceaccess.api.genericdevice.GDException;
import com.ericsson.deviceaccess.spi.service.homeautomation.power.SwitchPowerBase;
import java.util.HashMap;
import java.util.Map;
import org.osgi.service.upnp.UPnPAction;
import org.osgi.service.upnp.UPnPDevice;
import org.osgi.service.upnp.UPnPException;
import org.osgi.service.upnp.UPnPService;
import org.slf4j.Logger;
public class SwitchPowerUPnPImpl extends SwitchPowerBase implements UPnPDeviceAgent.UpdatePropertyInterface {
private static UPnPAction getUPnPAction(UPnPDevice device, String actionName) throws UPnPException {
for (UPnPService service : device.getServices()) {
UPnPAction action = service.getAction(actionName);
if (action != null) {
return action;
}
}
throw new UPnPException(UPnPException.INVALID_ACTION, "No such action supported " + actionName);
}
private final UPnPDevice upnpDev;
private final Logger logger;
public SwitchPowerUPnPImpl(UPnPDevice upnpDev, UPnPService upnpService, Logger logger) {
this.upnpDev = upnpDev;
this.logger = logger;
}
@Override
public void executeSetTarget(int target) throws GDException {
try {
UPnPAction action = SwitchPowerUPnPImpl.getUPnPAction(this.upnpDev, "SetTarget");
Map<String, Object> args = new HashMap<>();
args.put("newTargetValue", target == 1 ? "True" : "False");
action.invoke(LegacyUtil.toDictionary(args));
} catch (UPnPException ex) {
logger.error("Exception: " + ex);
} catch (Exception ex) {
logger.error("Exception: " + ex);
}
}
// @Override
@Override
protected void refreshProperties() {
// TODO Auto-generated method stub
}
// @Override
@Override
public void updateProperty(String name, Object value) {
logger.debug("updateProperty(" + name + ")");
if ("Status".equalsIgnoreCase(name)) {
if (value instanceof Boolean) {
logger.debug("updateCurrentTarget(" + value + ")");
this.updateCurrentTarget(((Boolean) value) ? 1 : 0);
}
} else {
// NOP
}
}
}