All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.quarkus.redis.runtime.datasource.AbstractHashCommands Maven / Gradle / Ivy

There is a newer version: 3.18.0.CR1
Show newest version
package io.quarkus.redis.runtime.datasource;

import static io.quarkus.redis.runtime.datasource.Validation.notNullOrEmpty;
import static io.quarkus.redis.runtime.datasource.Validation.positive;
import static io.smallrye.mutiny.helpers.ParameterValidation.doesNotContainNull;
import static io.smallrye.mutiny.helpers.ParameterValidation.nonNull;

import java.lang.reflect.Type;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import io.smallrye.mutiny.Uni;
import io.vertx.mutiny.redis.client.Command;
import io.vertx.mutiny.redis.client.Response;

class AbstractHashCommands extends AbstractRedisCommands {

    protected final Type typeOfValue;
    protected final Type typeOfField;

    AbstractHashCommands(RedisCommandExecutor redis, Type k, Type f, Type v) {
        super(redis, new Marshaller(k, f, v));
        this.typeOfField = f;
        this.typeOfValue = v;
    }

    Uni _hdel(K key, F[] fields) {
        nonNull(key, "key");
        notNullOrEmpty(fields, "fields");
        doesNotContainNull(fields, "fields");

        RedisCommand cmd = RedisCommand.of(Command.HDEL)
                .put(marshaller.encode(key));
        for (F field : fields) {
            cmd.put(marshaller.encode(field));
        }
        return execute(cmd);
    }

    Uni _hexists(K key, F field) {
        nonNull(key, "key");
        nonNull(field, "field");
        return execute(RedisCommand.of(Command.HEXISTS).put(marshaller.encode(key)).put(marshaller.encode(field)));
    }

    Uni _hget(K key, F field) {
        nonNull(key, "key");
        nonNull(field, "field");
        return execute(RedisCommand.of(Command.HGET).put(marshaller.encode(key)).put(marshaller.encode(field)));
    }

    Uni _hincrby(K key, F field, long amount) {
        nonNull(key, "key");
        nonNull(field, "field");
        return execute(RedisCommand.of(Command.HINCRBY).put(marshaller.encode(key))
                .put(marshaller.encode(field)).put(amount));
    }

    Uni _hincrbyfloat(K key, F field, double amount) {
        nonNull(key, "key");
        nonNull(field, "field");
        return execute(RedisCommand.of(Command.HINCRBYFLOAT).put(marshaller.encode(key))
                .put(marshaller.encode(field)).put(amount));
    }

    Uni _hgetall(K key) {
        nonNull(key, "key");
        return execute((RedisCommand.of(Command.HGETALL).put(marshaller.encode(key))));
    }

    Uni _hkeys(K key) {
        nonNull(key, "key");
        return execute((RedisCommand.of(Command.HKEYS).put(marshaller.encode(key))));
    }

    Uni _hlen(K key) {
        nonNull(key, "key");
        return execute((RedisCommand.of(Command.HLEN).put(marshaller.encode(key))));
    }

    @SafeVarargs
    final Uni _hmget(K key, F... fields) {
        nonNull(key, "key");
        doesNotContainNull(fields, "fields");
        if (fields.length == 0) {
            throw new IllegalArgumentException("`fields` must not be empty");
        }
        RedisCommand cmd = RedisCommand.of(Command.HMGET);
        cmd.put(marshaller.encode(key));

        for (F field : fields) {
            cmd.put(marshaller.encode(field));
        }

        return execute(cmd);
    }

    Uni _hmset(K key, Map map) {
        nonNull(key, "key");
        nonNull(map, "map");
        if (map.isEmpty()) {
            throw new IllegalArgumentException("`map` must not be empty");
        }
        RedisCommand cmd = RedisCommand.of(Command.HMSET);
        cmd.put(marshaller.encode(key));
        for (Map.Entry entry : map.entrySet()) {
            cmd.put(marshaller.encode(entry.getKey()));
            cmd.putNullable(marshaller.encode(entry.getValue()));
        }
        return execute(cmd);
    }

    Uni _hrandfield(K key) {
        nonNull(key, "key");
        return execute(RedisCommand.of(Command.HRANDFIELD).put(marshaller.encode(key)));
    }

    Uni _hrandfield(K key, long count) {
        nonNull(key, "key");
        positive(count, "count");
        return execute(RedisCommand.of(Command.HRANDFIELD).put(marshaller.encode(key)).put(count));
    }

    Uni _hrandfieldWithValues(K key, long count) {
        nonNull(key, "key");
        return execute(RedisCommand.of(Command.HRANDFIELD).put(marshaller.encode(key)).put(count).put("WITHVALUES"));
    }

    Uni _hset(K key, F field, V value) {
        nonNull(key, "key");
        nonNull(field, "field");
        nonNull(value, "value");
        return execute(RedisCommand.of(Command.HSET)
                .put(marshaller.encode(key))
                .put(marshaller.encode(field))
                .put(marshaller.encode(value)));
    }

    Uni _hset(K key, Map map) {
        nonNull(key, "key");
        nonNull(map, "map");
        if (map.isEmpty()) {
            throw new IllegalArgumentException("`map` must not be empty");
        }
        RedisCommand cmd = RedisCommand.of(Command.HSET);
        cmd.put(marshaller.encode(key));
        for (Map.Entry entry : map.entrySet()) {
            cmd
                    .put(marshaller.encode(entry.getKey()))
                    .put(marshaller.encode(entry.getValue()));
        }
        return execute(cmd);
    }

    Uni _hsetnx(K key, F field, V value) {
        nonNull(key, "key");
        nonNull(field, "field");
        return execute(RedisCommand.of(Command.HSETNX)
                .put(marshaller.encode(key))
                .put(marshaller.encode(field))
                .put(marshaller.encode(value)));
    }

    Uni _hstrlen(K key, F field) {
        nonNull(key, "key");
        nonNull(field, "field");
        return execute(RedisCommand.of(Command.HSTRLEN).put(marshaller.encode(key))
                .put(marshaller.encode(field)));
    }

    Uni _hvals(K key) {
        nonNull(key, "key");
        return execute(RedisCommand.of(Command.HVALS).put(marshaller.encode(key)));
    }

    V decodeV(Response resp) {
        return marshaller.decode(typeOfValue, resp);
    }

    Map decodeMap(Response r) {
        return marshaller.decodeAsMap(r, typeOfField, typeOfValue);
    }

    List decodeListOfField(Response r) {
        return marshaller.decodeAsList(r, typeOfField);
    }

    List decodeListOfValue(Response r) {
        return marshaller.decodeAsList(r, typeOfValue);
    }

    F decodeF(Response resp) {
        return marshaller.decode(typeOfField, resp);
    }

    Map decodeOrderedMap(Response r, F[] fields) {
        return marshaller.decodeAsOrderedMap(r, typeOfValue, fields);
    }

    Map decodeFieldWithValueMap(Response r) {
        if (r == null) {
            return Collections.emptyMap();
        }
        Map map = new HashMap<>();
        for (Response nested : r) {
            map.put(marshaller.decode(typeOfField, nested.get(0)),
                    marshaller.decode(typeOfValue, nested.get(1)));
        }
        return map;
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy