com.urbanairship.api.staticlists.StaticListDownloadRequest Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of java-client Show documentation
Show all versions of java-client Show documentation
The Urban Airship Java client library
/*
* Copyright (c) 2013-2016. Urban Airship and Contributors
*/
package com.urbanairship.api.staticlists;
import com.google.common.base.Preconditions;
import com.google.common.net.HttpHeaders;
import com.urbanairship.api.client.Request;
import com.urbanairship.api.client.RequestUtils;
import com.urbanairship.api.common.CSVUtils;
import org.apache.commons.lang.StringUtils;
import org.apache.http.entity.ContentType;
import com.urbanairship.api.client.ResponseParser;
import java.io.FileOutputStream;
import java.io.OutputStreamWriter;
import java.net.URI;
import java.util.HashMap;
import java.util.Map;
import java.util.Optional;
/*
* The StaticListDownloadRequest class static list download request to be executed in
* the {@link com.urbanairship.api.client.UrbanAirshipClient}.
*/
public class StaticListDownloadRequest implements Request {
private final static String API_LISTS_PATH = "/api/lists/";
private final String path;
private Optional fileOutputStream = Optional.empty();
private StaticListDownloadRequest(String name) {
this.path = API_LISTS_PATH + name + "/csv";
}
/**
* Build a static list download request.
*
* @param name The name of the list as a string.
* @return StaticListDownloadRequest
*/
public static StaticListDownloadRequest newRequest(String name) {
Preconditions.checkArgument(StringUtils.isNotEmpty(name), "List name cannot be empty.");
return new StaticListDownloadRequest(name);
}
/**
* Build a static list download request.
*
* @param type A lifecycle list type.
* @return StaticListDownloadRequest
*/
public static StaticListDownloadRequest newRequest(LifecycleListType type) {
return new StaticListDownloadRequest(type.getType());
}
/**
* Specify a file output stream to route the response data to.
*
* @param fileOutputStream The output stream to write to.
* @return StaticListDownloadRequest
*/
public StaticListDownloadRequest setOutputStream(FileOutputStream fileOutputStream) {
this.fileOutputStream = Optional.of(fileOutputStream);
return this;
}
@Override
public ContentType getContentType() {
return null;
}
@Override
public Map getRequestHeaders() {
Map headers = new HashMap();
headers.put(HttpHeaders.ACCEPT, UA_VERSION_CSV);
return headers;
}
@Override
public Request.HttpMethod getHttpMethod() {
return HttpMethod.GET;
}
@Override
public String getRequestBody() {
return null;
}
@Override
public URI getUri(URI baseUri) {
return RequestUtils.resolveURI(baseUri, path);
}
@Override
public ResponseParser getResponseParser() {
return response -> {
if (fileOutputStream.isPresent()) {
try (OutputStreamWriter stream = new OutputStreamWriter(fileOutputStream.get())) {
String[] rows = response.split("\n");
for (String row : rows) {
String[] columns = row.split(",");
// Manually format each row for CSV
String csvRow = CSVUtils.formatRowForCSV(columns);
stream.write(csvRow + "\n");
}
} finally {
fileOutputStream.get().close();
}
}
return response;
};
}
@Override
public boolean bearerTokenAuthRequired() {
return false;
}
@Override
public boolean canUseBearerTokenAuth() {
return true;
}
}