io.vertx.redis.client.Response Maven / Gradle / Ivy
/*
* Copyright 2019 Red Hat, Inc.
*
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* and Apache License v2.0 which accompanies this distribution.
*
* The Eclipse Public License is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* The Apache License v2.0 is available at
* http://www.opensource.org/licenses/apache2.0.php
*
* You may elect to redistribute this code under either of these licenses.
*/
package io.vertx.redis.client;
import io.vertx.codegen.annotations.GenIgnore;
import io.vertx.codegen.annotations.Nullable;
import io.vertx.codegen.annotations.VertxGen;
import io.vertx.core.buffer.Buffer;
import java.math.BigInteger;
import java.nio.charset.Charset;
import java.util.Collections;
import java.util.Iterator;
import java.util.Map;
import java.util.Set;
import java.util.stream.Stream;
import java.util.stream.StreamSupport;
/**
* The response received from the REDIS server. Redis responses can have several representations:
*
*
* - simple string - C string
* - integer - 64bit integer value
* - bulk - byte array
* - multi - list
*
*
* Due to the dynamic nature the response object will try to cast the received response to the desired type. A special
* case should be noted that multi responses are also handled by the response object as it implements the iterable
* interface. So in this case constructs like for loops on the response will give you access to the underlying elements.
*
* @author Paulo Lopes
*/
@VertxGen
public interface Response extends Iterable {
/**
* The response return type.
* @return the type.
*/
ResponseType type();
/**
* RESP3 responses may include attributes
* @return the a key value map of attributes to this response.
*/
default Map attributes() {
return Collections.emptyMap();
}
/**
* Get this response as a String.
* @return string value
*/
@Override
String toString();
/**
* RESP3 Verbatim Bulk message include a 3 character format.
*/
default @Nullable String format() {
throw new UnsupportedOperationException("This type doesn't hold a Verbatim Bulk type");
}
/**
* Get this response as a Number. In contrast to other numeric getters, this will not
* perform any conversion if the underlying type is not numeric.
* @return number value
*/
@GenIgnore(GenIgnore.PERMITTED_TYPE)
default Number toNumber() {
throw new UnsupportedOperationException("This type doesn't hold a Numeric type");
}
/**
* Get this response as a Double.
* @return double value.
*/
default @Nullable Double toDouble() {
final String msg = toString();
if (msg != null) {
return Double.parseDouble(msg);
}
return null;
}
/**
* Get this response as a Float.
* @return double value.
*/
default @Nullable Float toFloat() {
final String msg = toString();
if (msg != null) {
return Float.parseFloat(msg);
}
return null;
}
/**
* Get this response as a BigInteger.
* @return long value.
*/
@GenIgnore(GenIgnore.PERMITTED_TYPE)
default @Nullable BigInteger toBigInteger() {
final String msg = toString();
if (msg != null) {
return new BigInteger(msg);
}
return null;
}
/**
* Get this response as a Long.
* @return long value.
*/
default @Nullable Long toLong() {
final String msg = toString();
if (msg != null) {
return Long.parseLong(msg);
}
return null;
}
/**
* Get this response as a Integer.
* @return int value.
*/
default @Nullable Integer toInteger() {
final String msg = toString();
if (msg != null) {
return Integer.parseInt(msg);
}
return null;
}
/**
* Get this response as a Short.
* @return short value.
*/
default @Nullable Short toShort() {
final String msg = toString();
if (msg != null) {
return Short.parseShort(msg);
}
return null;
}
/**
* Get this response as a Byte.
* @return byte value.
*/
default @Nullable Byte toByte() {
final String msg = toString();
if (msg != null) {
return Byte.parseByte(msg);
}
return null;
}
/**
* Get this response as a Boolean.
* @return boolean value.
*/
default @Nullable Boolean toBoolean() {
final String msg = toString();
if (msg != null) {
// the format used by redis RESP3 is 't' for true, 'f' for false.
return msg.length() == 1 && msg.charAt(0) == 't';
}
return null;
}
/**
* Get this response as a String encoded with the given charset.
* @return String value.
*/
@GenIgnore(GenIgnore.PERMITTED_TYPE)
default String toString(Charset encoding) {
throw new UnsupportedOperationException("This type doesn't hold a Bulk type");
}
/**
* Get this response as Buffer.
* @return buffer value.
*/
default Buffer toBuffer() {
throw new UnsupportedOperationException("This type doesn't hold a Bulk type");
}
/**
* Get this response as a byte[].
* @return byte[] value.
*/
@GenIgnore(GenIgnore.PERMITTED_TYPE)
default byte[] toBytes() {
throw new UnsupportedOperationException("This type doesn't hold a Bulk type");
}
/**
* Get this multi response value at a numerical index.
* @param index the required index.
* @return Response value.
*/
default Response get(int index) {
throw new UnsupportedOperationException("This type doesn't hold an Array type");
}
/**
* Get this multi response value at a string key. Note that REDIS does not support strings as keys but by convention
* it encodes hashes in lists where index i is the key, and index i+1 is the value.
* @param key the required key.
* @return Response value.
*/
default Response get(String key) {
throw new UnsupportedOperationException("This type doesn't hold a Map type");
}
/**
* Does this multi response contains a string key. Note that REDIS does not support strings as keys but by convention
* it encodes hashes in lists where index i is the key, and index i+1 is the value.
* @param key the required key.
* @return Response value.
*/
default boolean containsKey(String key) {
throw new UnsupportedOperationException("This type doesn't hold a Map type");
}
/**
* Get this multi response keys from a hash. Note that REDIS does not support strings as keys but by convention
* it encodes hashes in lists where index i is the key, and index i+1 is the value.
* @return the set of keys.
*/
default Set getKeys() {
throw new UnsupportedOperationException("This type doesn't hold a Map type");
}
/**
* Get this size of this multi response.
* @return the size of the multi.
*/
default int size() {
throw new UnsupportedOperationException("This type doesn't hold an Array/Map type");
}
/**
* Return an iterator so it can be iterated using the foreach construct.
* @return response iterator.
*/
@Override
@GenIgnore
default Iterator iterator() {
throw new UnsupportedOperationException("This type doesn't hold a Array type");
}
/**
* Return a stream of responses based on the iterable of this object.
* @return a stream of response
*/
@GenIgnore
default Stream stream() {
return StreamSupport.stream(spliterator(), false);
}
}