package org.apache.logging.log4j.core.net;
import java.io.IOException;
import java.io.OutputStream;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.SocketException;
import java.net.UnknownHostException;
import org.apache.logging.log4j.Logger;
import org.apache.logging.log4j.core.appender.AppenderLoggingException;
import org.apache.logging.log4j.status.StatusLogger;
public class DatagramOutputStream extends OutputStream {
protected static final Logger LOGGER = StatusLogger.getLogger();
private static final int SHIFT_1 = 8;
private static final int SHIFT_2 = 16;
private static final int SHIFT_3 = 24;
private DatagramSocket datagramSocket;
private final InetAddress inetAddress;
private final int port;
private byte[] data;
private final byte[] ;
private final byte[] ;
public DatagramOutputStream(final String host, final int port, final byte[] header, final byte[] footer) {
this.port = port;
this.header = header;
this.footer = footer;
try {
inetAddress = InetAddress.getByName(host);
} catch (final UnknownHostException ex) {
final String msg = "Could not find host " + host;
LOGGER.error(msg, ex);
throw new AppenderLoggingException(msg, ex);
}
try {
datagramSocket = new DatagramSocket();
} catch (final SocketException ex) {
final String msg = "Could not instantiate DatagramSocket to " + host;
LOGGER.error(msg, ex);
throw new AppenderLoggingException(msg, ex);
}
}
@Override
public synchronized void write(final byte[] bytes, final int offset, final int length) throws IOException {
copy(bytes, offset, length);
}
@Override
public synchronized void write(final int i) throws IOException {
copy(new byte[] {(byte) (i >>> SHIFT_3), (byte) (i >>> SHIFT_2), (byte) (i >>> SHIFT_1), (byte) i}, 0, 4);
}
@Override
public synchronized void write(final byte[] bytes) throws IOException {
copy(bytes, 0, bytes.length);
}
@Override
public synchronized void flush() throws IOException {
try {
if (this.data != null && this.datagramSocket != null && this.inetAddress != null) {
if (footer != null) {
copy(footer, 0, footer.length);
}
final DatagramPacket packet = new DatagramPacket(data, data.length, inetAddress, port);
datagramSocket.send(packet);
}
} finally {
data = null;
if (header != null) {
copy(header, 0, header.length);
}
}
}
@Override
public synchronized void close() throws IOException {
if (datagramSocket != null) {
if (data != null) {
flush();
}
datagramSocket.close();
datagramSocket = null;
}
}
private void copy(final byte[] bytes, final int offset, final int length) {
final int index = data == null ? 0 : data.length;
final byte[] copy = new byte[length + index];
if (data != null) {
System.arraycopy(data, 0, copy, 0, data.length);
}
System.arraycopy(bytes, offset, copy, index, length);
data = copy;
}
}