ai.api.http.HttpClient Maven / Gradle / Ivy
package ai.api.http;
/***********************************************************************************************************************
*
* API.AI Java SDK - client-side libraries for API.AI
* =================================================
*
* Copyright (C) 2015 by Speaktoit, Inc. (https://www.speaktoit.com)
* https://www.api.ai
*
***********************************************************************************************************************
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on
* an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the
* specific language governing permissions and limitations under the License.
*
***********************************************************************************************************************/
import ai.api.util.IOUtils;
import java.io.BufferedInputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.net.HttpURLConnection;
import java.nio.charset.Charset;
import java.nio.charset.StandardCharsets;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
public class HttpClient {
private static final Logger Log = LogManager.getLogger(HttpClient.class);
private static final int CHUNK_LENGTH = 2048;
private static final int BUFFER_LENGTH = 4096;
private static final Charset DEFAULT_CHARSET = StandardCharsets.UTF_8;
/**
* Cannot be null
*/
private final HttpURLConnection connection;
private OutputStream os;
private final String delimiter = "--";
private final String boundary = "SwA" + Long.toString(System.currentTimeMillis()) + "SwA";
private boolean writeSoundLog;
/**
* @param connection Cannot be null
*/
public HttpClient(final HttpURLConnection connection) {
if (connection == null) {
throw new IllegalArgumentException("Connection cannot be null");
}
this.connection = connection;
}
public void connectForMultipart() throws IOException {
connection.setRequestProperty("Connection", "Keep-Alive");
connection.setRequestProperty("Content-Type", "multipart/form-data; boundary=" + boundary);
connection.setChunkedStreamingMode(CHUNK_LENGTH);
connection.connect();
os = connection.getOutputStream();
}
/**
* @param paramName Cannot be null
* @param value Cannot be null
* @throws IOException
*/
public void addFormPart(final String paramName, final String value) throws IOException {
os.write((delimiter + boundary + "\r\n").getBytes());
os.write("Content-Type: application/json\r\n".getBytes());
os.write(("Content-Disposition: form-data; name=\"" + paramName + "\"\r\n").getBytes());
os.write(("\r\n" + value + "\r\n").getBytes());
}
/**
* @param paramName Cannot be null
* @param fileName Cannot be null
* @param data Cannot be null
* @throws IOException
*/
public void addFilePart(final String paramName, final String fileName, final InputStream data) throws IOException {
os.write((delimiter + boundary + "\r\n").getBytes());
os.write(("Content-Disposition: form-data; name=\"" + paramName + "\"; filename=\"" + fileName + "\"\r\n").getBytes());
os.write(("Content-Type: audio/wav\r\n").getBytes());
//os.write( ("Content-Transfer-Encoding: binary\r\n" ).getBytes());
os.write("\r\n".getBytes());
Log.debug("Sound write start");
FileOutputStream outputStream = null;
if (writeSoundLog) {
final File cacheDir = new File(System.getProperty("java.io.tmpdir"));
if (!cacheDir.exists()) {
cacheDir.mkdirs();
}
Log.debug(cacheDir.getAbsolutePath());
final File soundFile = new File(cacheDir, "log.wav");
outputStream = new FileOutputStream(soundFile, false);
}
final byte[] buffer = new byte[BUFFER_LENGTH];
int bytesActuallyRead;
bytesActuallyRead = data.read(buffer, 0, buffer.length);
while (bytesActuallyRead >= 0) {
if (bytesActuallyRead > 0) {
os.write(buffer, 0, bytesActuallyRead);
if (writeSoundLog) {
outputStream.write(buffer, 0, bytesActuallyRead);
}
}
bytesActuallyRead = data.read(buffer, 0, buffer.length);
}
if (writeSoundLog) {
outputStream.close();
}
Log.debug("Sound write finished");
os.write("\r\n".getBytes());
}
public void finishMultipart() throws IOException {
os.write((delimiter + boundary + delimiter + "\r\n").getBytes());
os.close();
}
/**
* @return Response string. Never null
* @throws IOException
*/
public String getResponse() throws IOException {
final InputStream inputStream = new BufferedInputStream(connection.getInputStream());
final String response = IOUtils.readAll(inputStream, DEFAULT_CHARSET);
inputStream.close();
return response;
}
public String getErrorString() {
try {
final InputStream inputStream = new BufferedInputStream(connection.getErrorStream());
final String response;
response = IOUtils.readAll(inputStream, DEFAULT_CHARSET);
inputStream.close();
return response;
} catch (final IOException e) {
e.printStackTrace();
}
return null;
}
public void setWriteSoundLog(final boolean writeSoundLog) {
this.writeSoundLog = writeSoundLog;
}
}