2 * Copyright (c) 2010-2024 Contributors to the openHAB project
4 * See the NOTICE file(s) distributed with this work for additional
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
11 * SPDX-License-Identifier: EPL-2.0
13 package org.openhab.binding.monopriceaudio.internal.communication;
15 import java.io.DataInputStream;
16 import java.io.DataOutputStream;
17 import java.io.IOException;
18 import java.io.InputStream;
19 import java.net.Socket;
20 import java.net.SocketTimeoutException;
22 import org.eclipse.jdt.annotation.NonNullByDefault;
23 import org.eclipse.jdt.annotation.Nullable;
24 import org.openhab.binding.monopriceaudio.internal.MonopriceAudioException;
25 import org.slf4j.Logger;
26 import org.slf4j.LoggerFactory;
29 * Class for communicating with the MonopriceAudio device through a serial over IP connection
31 * @author Laurent Garnier - Initial contribution
32 * @author Michael Lobstein - Adapted for the MonopriceAudio binding
35 public class MonopriceAudioIpConnector extends MonopriceAudioConnector {
37 private final Logger logger = LoggerFactory.getLogger(MonopriceAudioIpConnector.class);
39 private final @Nullable String address;
40 private final int port;
41 private final String uid;
43 private @Nullable Socket clientSocket;
48 * @param address the IP address of the serial over IP device
49 * @param port the TCP port to be used
50 * @param uid the thing uid string
51 * @param amp the AmplifierModel being used
53 public MonopriceAudioIpConnector(@Nullable String address, int port, String uid, AmplifierModel amp) {
54 this.address = address;
57 setAmplifierModel(amp);
61 public synchronized void open() throws MonopriceAudioException {
62 logger.debug("Opening IP connection on IP {} port {}", this.address, this.port);
64 Socket clientSocket = new Socket(this.address, this.port);
65 clientSocket.setSoTimeout(100);
67 dataOut = new DataOutputStream(clientSocket.getOutputStream());
68 dataIn = new DataInputStream(clientSocket.getInputStream());
70 Thread thread = new MonopriceAudioReaderThread(this, this.uid, this.address + "." + this.port);
72 setReaderThread(thread);
75 this.clientSocket = clientSocket;
79 logger.debug("IP connection opened");
80 } catch (IOException | SecurityException | IllegalArgumentException e) {
82 throw new MonopriceAudioException("Opening IP connection failed: " + e.getMessage(), e);
87 public synchronized void close() {
88 logger.debug("Closing IP connection");
90 Socket clientSocket = this.clientSocket;
91 if (clientSocket != null) {
94 } catch (IOException e) {
96 this.clientSocket = null;
99 logger.debug("IP connection closed");
103 * Reads some number of bytes from the input stream and stores them into the buffer array b. The number of bytes
104 * actually read is returned as an integer.
105 * In case of socket timeout, the returned value is 0.
107 * @param dataBuffer the buffer into which the data is read.
109 * @return the total number of bytes read into the buffer, or -1 if there is no more data because the end of the
110 * stream has been reached.
112 * @throws MonopriceAudioException - If the input stream is null, if the first byte cannot be read for any reason
113 * other than the end of the file, if the input stream has been closed, or if some other I/O error
117 protected int readInput(byte[] dataBuffer) throws MonopriceAudioException {
118 InputStream dataIn = this.dataIn;
119 if (dataIn == null) {
120 throw new MonopriceAudioException("readInput failed: input stream is null");
123 return dataIn.read(dataBuffer);
124 } catch (SocketTimeoutException e) {
126 } catch (IOException e) {
127 throw new MonopriceAudioException("readInput failed: " + e.getMessage(), e);