]> git.basschouten.com Git - openhab-addons.git/blob
6537fedbaae0548024a460482a4d2527f1915135
[openhab-addons.git] /
1 /**
2  * Copyright (c) 2010-2023 Contributors to the openHAB project
3  *
4  * See the NOTICE file(s) distributed with this work for additional
5  * information.
6  *
7  * This program and the accompanying materials are made available under the
8  * terms of the Eclipse Public License 2.0 which is available at
9  * http://www.eclipse.org/legal/epl-2.0
10  *
11  * SPDX-License-Identifier: EPL-2.0
12  */
13 package org.openhab.binding.revogi.internal.api;
14
15 import java.util.List;
16 import java.util.Objects;
17 import java.util.concurrent.CompletableFuture;
18
19 import org.eclipse.jdt.annotation.NonNullByDefault;
20 import org.openhab.binding.revogi.internal.udp.UdpResponseDTO;
21 import org.openhab.binding.revogi.internal.udp.UdpSenderService;
22 import org.slf4j.Logger;
23 import org.slf4j.LoggerFactory;
24
25 import com.google.gson.Gson;
26 import com.google.gson.GsonBuilder;
27 import com.google.gson.JsonSyntaxException;
28
29 /**
30  * The {@link SwitchService} enables the binding to actually switch plugs on and of
31  *
32  * @author Andi Bräu - Initial contribution
33  */
34 @NonNullByDefault
35 public class SwitchService {
36
37     private static final String UDP_DISCOVERY_QUERY = "V3{\"sn\":\"%s\", \"cmd\": 20, \"port\": %d, \"state\": %d}";
38     private static final String VERSION_STRING = "V3";
39     private final Logger logger = LoggerFactory.getLogger(SwitchService.class);
40
41     private final Gson gson = new GsonBuilder().create();
42     private final UdpSenderService udpSenderService;
43
44     public SwitchService(UdpSenderService udpSenderService) {
45         this.udpSenderService = udpSenderService;
46     }
47
48     public CompletableFuture<SwitchResponseDTO> switchPort(String serialNumber, String ipAddress, int port, int state) {
49         if (state < 0 || state > 1) {
50             throw new IllegalArgumentException("state has to be 0 or 1");
51         }
52         if (port < 0) {
53             throw new IllegalArgumentException("Given port doesn't exist");
54         }
55
56         CompletableFuture<List<UdpResponseDTO>> responses;
57         if (ipAddress.trim().isEmpty()) {
58             responses = udpSenderService
59                     .broadcastUdpDatagram(String.format(UDP_DISCOVERY_QUERY, serialNumber, port, state));
60         } else {
61             responses = udpSenderService.sendMessage(String.format(UDP_DISCOVERY_QUERY, serialNumber, port, state),
62                     ipAddress);
63         }
64
65         return responses.thenApply(this::getSwitchResponse);
66     }
67
68     private SwitchResponseDTO getSwitchResponse(final List<UdpResponseDTO> singleResponse) {
69         return singleResponse.stream().filter(response -> !response.getAnswer().isEmpty())
70                 .map(response -> deserializeString(response.getAnswer()))
71                 .filter(switchResponse -> switchResponse.getCode() == 200 && switchResponse.getResponse() == 20)
72                 .findFirst().orElse(new SwitchResponseDTO(0, 503));
73     }
74
75     private SwitchResponseDTO deserializeString(String response) {
76         String extractedJsonResponse = response.substring(response.lastIndexOf(VERSION_STRING) + 2);
77         try {
78             return Objects.requireNonNull(gson.fromJson(extractedJsonResponse, SwitchResponseDTO.class));
79         } catch (JsonSyntaxException e) {
80             logger.warn("Could not parse string \"{}\" to SwitchResponse", response);
81             return new SwitchResponseDTO(0, 503);
82         }
83     }
84 }