com.urbanairship.api.staticlists.StaticListUploadRequest 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.fasterxml.jackson.databind.ObjectMapper;
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.client.ResponseParser;
import com.urbanairship.api.common.model.GenericResponse;
import org.apache.commons.lang.StringUtils;
import org.apache.http.entity.ContentType;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.net.URI;
import java.util.HashMap;
import java.util.Map;
/**
* The StaticListUploadRequest class builds a static list upload request to be executed in
* the {@link com.urbanairship.api.client.UrbanAirshipClient}.
*/
public class StaticListUploadRequest implements Request {
private final static String API_LISTS_PATH = "/api/lists/";
private final static String CSV_PATH = "/csv";
private final String path;
private File csv;
private Boolean gzip = false;
private StaticListUploadRequest(String path, File csv) {
this.path = path;
this.csv = csv;
}
/**
* Create a static list upload request.
*
* @param name The name of the list as a string.
* @param csvFile A string path to a csv file.
* @return StaticListUploadRequest
*/
public static StaticListUploadRequest newRequest(String name, String csvFile) {
Preconditions.checkArgument(StringUtils.isNotEmpty(name), "List name cannot be null.");
File csv = new File(csvFile);
Preconditions.checkArgument(csv.exists() && csv.isFile(), "File does not exist: " + csvFile);
return new StaticListUploadRequest(API_LISTS_PATH + name + CSV_PATH, csv);
}
/**
* Return whether the request uses gzip encoding.
*
* @return Boolean
*/
public Boolean getGzipEnabled() {
return this.gzip;
}
/**
* Set whether the request uses gzip encoding.
*
* @param gzip Boolean
* @return StaticListUploadRequest
*/
public StaticListUploadRequest setGzipEnabled(Boolean gzip) {
this.gzip = gzip;
return this;
}
@Override
public ContentType getContentType() {
return ContentType.TEXT_PLAIN;
}
@Override
public Map getRequestHeaders() {
Map headers = new HashMap();
headers.put(HttpHeaders.ACCEPT, UA_VERSION_JSON);
headers.put(HttpHeaders.CONTENT_TYPE, CONTENT_TYPE_TEXT_CSV);
if (this.gzip) {
headers.put(HttpHeaders.CONTENT_ENCODING, CONTENT_ENCODING_GZIP);
}
return headers;
}
@Override
public Request.HttpMethod getHttpMethod() {
return Request.HttpMethod.PUT;
}
@Override
public String getRequestBody() {
try ( BufferedReader reader = new BufferedReader(new FileReader(this.csv)) ) {
StringBuffer body = new StringBuffer();
String line;
while ((line = reader.readLine()) != null) {
body.append(line).append("\n");
}
return body.toString();
} catch (Exception ex) {
return "{ \"exception\" : \"" + ex.getClass().getName() + "\", \"message\" : \"" + ex.getMessage() + "\" }";
}
}
@Override
public URI getUri(URI baseUri) {
return RequestUtils.resolveURI(baseUri, path);
}
@Override
public ResponseParser getResponseParser() {
return RequestUtils.GENERIC_RESPONSE_PARSER;
}
@Override
public boolean bearerTokenAuthRequired() {
return false;
}
@Override
public boolean canUseBearerTokenAuth() {
return true;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy