io.vertx.ext.web.api.service.ServiceResponse Maven / Gradle / Ivy
The newest version!
package io.vertx.ext.web.api.service;
import io.netty.handler.codec.http.HttpResponseStatus;
import io.vertx.codegen.annotations.DataObject;
import io.vertx.codegen.annotations.Fluent;
import io.vertx.codegen.json.annotations.JsonGen;
import io.vertx.core.MultiMap;
import io.vertx.core.buffer.Buffer;
import io.vertx.core.http.HttpHeaders;
import io.vertx.core.json.JsonArray;
import io.vertx.core.json.JsonObject;
import java.util.Map;
/**
* Data object that encapsulates all informations about an HTTP Response
*/
@DataObject
@JsonGen(publicConverter = false)
public class ServiceResponse {
private final static Integer DEFAULT_STATUS_CODE = 200;
private Integer statusCode;
private String statusMessage;
private Buffer payload;
private MultiMap headers;
public ServiceResponse() {
init();
}
public ServiceResponse(JsonObject json) {
init();
ServiceResponseConverter.fromJson(json, this);
JsonObject hdrs = json.getJsonObject("headers", null);
if (hdrs != null) {
headers = HttpHeaders.headers();
for (Map.Entry entry: hdrs) {
if (!(entry.getValue() instanceof String)) {
throw new IllegalStateException("Invalid type for message header value " + entry.getValue().getClass());
}
headers.set(entry.getKey(), (String)entry.getValue());
}
}
}
public ServiceResponse(Integer statusCode, String statusMessage, Buffer payload, MultiMap headers) {
this.statusCode = statusCode;
this.statusMessage = statusMessage;
this.payload = payload;
this.headers = headers;
}
public ServiceResponse(ServiceResponse other) {
this.statusCode = other.getStatusCode();
this.statusMessage = other.getStatusMessage();
this.payload = other.getPayload();
this.headers = other.getHeaders();
}
public JsonObject toJson() {
JsonObject json = new JsonObject();
ServiceResponseConverter.toJson(this, json);
if (headers != null) {
JsonObject hJson = new JsonObject();
headers.entries().forEach(entry -> hJson.put(entry.getKey(), entry.getValue()));
json.put("headers", hJson);
}
return json;
}
private void init() {
this.statusCode = DEFAULT_STATUS_CODE;
this.payload = null;
this.headers = MultiMap.caseInsensitiveMultiMap();
}
public Integer getStatusCode() {
return statusCode;
}
public String getStatusMessage() {
return statusMessage;
}
public Buffer getPayload() {
return payload;
}
public MultiMap getHeaders() {
return headers;
}
@Fluent public ServiceResponse setHeaders(MultiMap headers) {
this.headers = headers;
return this;
}
@Fluent public ServiceResponse setStatusCode(Integer statusCode) {
this.statusCode = statusCode;
return this;
}
@Fluent public ServiceResponse setStatusMessage(String statusMessage) {
this.statusMessage = statusMessage;
return this;
}
@Fluent public ServiceResponse setPayload(Buffer payload) {
this.payload = payload;
return this;
}
@Fluent public ServiceResponse putHeader(String key, String value) {
this.headers.add(key, value);
return this;
}
/**
* Creates a {@link ServiceResponse} with status code 200, status message OK, content type {@code application/json} and {@code jsonObject} as body
*
* @param jsonObject
* @return
*/
public static ServiceResponse completedWithJson(JsonObject jsonObject) {
return completedWithJson(jsonObject.toBuffer());
}
/**
* Creates a {@link ServiceResponse} with status code 200, status message OK, content type {@code application/json} and {@code jsonArray} as body
*
* @param jsonArray
* @return
*/
public static ServiceResponse completedWithJson(JsonArray jsonArray) {
return completedWithJson(jsonArray.toBuffer());
}
/**
* Creates a {@link ServiceResponse} with status code 200, status message OK, content type {@code application/json} and {@code json} as body
*
* @param json
* @return
*/
public static ServiceResponse completedWithJson(Buffer json) {
ServiceResponse op = new ServiceResponse();
op.setStatusCode(200);
op.setStatusMessage(HttpResponseStatus.OK.reasonPhrase());
op.putHeader(HttpHeaders.CONTENT_TYPE.toString(), "application/json");
op.setPayload(json);
return op;
}
/**
* Creates a {@link ServiceResponse} with status code 200, status message OK, content type {@code text/plain} and {@code text} as body
*
* @param text
* @return
*/
public static ServiceResponse completedWithPlainText(Buffer text) {
return new ServiceResponse()
.setStatusCode(200)
.setStatusMessage(HttpResponseStatus.OK.reasonPhrase())
.putHeader(HttpHeaders.CONTENT_TYPE.toString(), "text/plain")
.setPayload(text);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy