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

io.quarkus.redis.datasource.keys.TransactionalKeyCommands Maven / Gradle / Ivy

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

import java.time.Duration;
import java.time.Instant;

import io.quarkus.redis.datasource.TransactionalRedisCommands;

public interface TransactionalKeyCommands extends TransactionalRedisCommands {

    /**
     * Execute the command COPY.
     * Summary: Copy a key
     * Group: generic
     * Requires Redis 6.2.0
     *
     * @param source the key
     * @param destination the key
     */
    void copy(K source, K destination);

    /**
     * Execute the command COPY.
     * Summary: Copy a key
     * Group: generic
     * Requires Redis 6.2.0
     *
     * @param source the key
     * @param destination the key
     * @param copyArgs the additional arguments
     */
    void copy(K source, K destination, CopyArgs copyArgs);

    /**
     * Execute the command DEL.
     * Summary: Delete one or multiple keys
     * Group: generic
     * Requires Redis 1.0.0
     *
     * @param keys the keys.
     */
    void del(K... keys);

    /**
     * Execute the command DUMP.
     * Summary: Return a serialized version of the value stored at the specified key.
     * Group: generic
     * Requires Redis 2.6.0
     *
     * @param key the key
     */
    void dump(K key);

    /**
     * Execute the command EXISTS.
     * Summary: Determine if a key exists
     * Group: generic
     * Requires Redis 1.0.0
     *
     * @param key the key to check
     */
    void exists(K key);

    /**
     * Execute the command EXISTS.
     * Summary: Determine if a key exists
     * Group: generic
     * Requires Redis 1.0.0
     *
     * @param keys the keys to check
     */
    void exists(K... keys);

    /**
     * Execute the command EXPIRE.
     * Summary: Set a key's time to live in seconds
     * Group: generic
     * Requires Redis 1.0.0
     *
     * @param key the key
     * @param seconds the new TTL
     * @param expireArgs the {@code EXPIRE} command extra-arguments
     */
    void expire(K key, long seconds, ExpireArgs expireArgs);

    /**
     * Execute the command EXPIRE.
     * Summary: Set a key's time to live in seconds
     * Group: generic
     * Requires Redis 1.0.0
     *
     * @param key the key
     * @param duration the new TTL
     * @param expireArgs the {@code EXPIRE} command extra-arguments
     */
    void expire(K key, Duration duration, ExpireArgs expireArgs);

    /**
     * Execute the command EXPIRE.
     * Summary: Set a key's time to live in seconds
     * Group: generic
     * Requires Redis 1.0.0
     *
     * @param key the key
     * @param seconds the new TTL
     */
    void expire(K key, long seconds);

    /**
     * Execute the command EXPIRE.
     * Summary: Set a key's time to live in seconds
     * Group: generic
     * Requires Redis 1.0.0
     *
     * @param key the key
     * @param duration the new TTL
     */
    void expire(K key, Duration duration);

    /**
     * Execute the command EXPIREAT.
     * Summary: Set the expiration for a key as a UNIX timestamp
     * Group: generic
     * Requires Redis 1.2.0
     *
     * @param key the key
     * @param timestamp the timestamp
     */
    void expireat(K key, long timestamp);

    /**
     * Execute the command EXPIREAT.
     * Summary: Set the expiration for a key as a UNIX timestamp
     * Group: generic
     * Requires Redis 1.2.0
     *
     * @param key the key
     * @param timestamp the timestamp
     */
    void expireat(K key, Instant timestamp);

    /**
     * Execute the command EXPIREAT.
     * Summary: Set the expiration for a key as a UNIX timestamp
     * Group: generic
     * Requires Redis 1.2.0
     *
     * @param key the key
     * @param timestamp the timestamp
     * @param expireArgs the {@code EXPIREAT} command extra-arguments
     */
    void expireat(K key, long timestamp, ExpireArgs expireArgs);

    /**
     * Execute the command EXPIREAT.
     * Summary: Set the expiration for a key as a UNIX timestamp
     * Group: generic
     * Requires Redis 1.2.0
     *
     * @param key the key
     * @param timestamp the timestamp
     * @param expireArgs the {@code EXPIREAT} command extra-arguments
     */
    void expireat(K key, Instant timestamp, ExpireArgs expireArgs);

    /**
     * Execute the command EXPIRETIME.
     * Summary: Get the expiration Unix timestamp for a key
     * Group: generic
     * Requires Redis 7.0.0
     *
     * @param key the key
     * @throws RedisKeyNotFoundException if the key does not exist
     */
    void expiretime(K key);

    /**
     * Execute the command KEYS.
     * Summary: Find all keys matching the given pattern
     * Group: generic
     * Requires Redis 1.0.0
     *
     * @param pattern the glob-style pattern
     */
    void keys(String pattern);

    /**
     * Execute the command MOVE.
     * Summary: Move a key to another database
     * Group: generic
     * Requires Redis 1.0.0
     *
     * @param key the key
     */
    void move(K key, long db);

    /**
     * Execute the command PERSIST.
     * Summary: Remove the expiration from a key
     * Group: generic
     * Requires Redis 2.2.0
     *
     * @param key the key
     */
    void persist(K key);

    /**
     * Execute the command PEXPIRE.
     * Summary: Set a key's time to live in milliseconds
     * Group: generic
     * Requires Redis 2.6.0
     *
     * @param key the key
     * @param duration the new TTL
     * @param expireArgs the {@code PEXPIRE} command extra-arguments
     */
    void pexpire(K key, Duration duration, ExpireArgs expireArgs);

    /**
     * Execute the command PEXPIRE.
     * Summary: Set a key's time to live in milliseconds
     * Group: generic
     * Requires Redis 2.6.0
     *
     * @param key the key
     * @param ms the new TTL
     */
    void pexpire(K key, long ms);

    /**
     * Execute the command PEXPIRE.
     * Summary: Set a key's time to live in milliseconds
     * Group: generic
     * Requires Redis 2.6.0
     *
     * @param key the key
     * @param duration the new TTL
     */
    void pexpire(K key, Duration duration);

    /**
     * Execute the command PEXPIRE.
     * Summary: Set a key's time to live in milliseconds
     * Group: generic
     * Requires Redis 2.6.0
     *
     * @param key the key
     * @param milliseconds the new TTL
     * @param expireArgs the {@code PEXPIRE} command extra-arguments
     */
    void pexpire(K key, long milliseconds, ExpireArgs expireArgs);

    /**
     * Execute the command PEXPIREAT.
     * Summary: Set the expiration for a key as a UNIX timestamp
     * Group: generic
     * Requires Redis 2.6.0
     *
     * @param key the key
     * @param timestamp the timestamp
     */
    void pexpireat(K key, long timestamp);

    /**
     * Execute the command PEXPIREAT.
     * Summary: Set the expiration for a key as a UNIX timestamp
     * Group: generic
     * Requires Redis 2.6.0
     *
     * @param key the key
     * @param timestamp the timestamp
     */
    void pexpireat(K key, Instant timestamp);

    /**
     * Execute the command PEXPIREAT.
     * Summary: Set the expiration for a key as a UNIX timestamp
     * Group: generic
     * Requires Redis 2.6.0
     *
     * @param key the key
     * @param timestamp the timestamp
     * @param expireArgs the {@code EXPIREAT} command extra-arguments
     */
    void pexpireat(K key, long timestamp, ExpireArgs expireArgs);

    /**
     * Execute the command PEXPIREAT.
     * Summary: Set the expiration for a key as a UNIX timestamp
     * Group: generic
     * Requires Redis 2.6.0
     *
     * @param key the key
     * @param timestamp the timestamp
     * @param expireArgs the {@code EXPIREAT} command extra-arguments
     */
    void pexpireat(K key, Instant timestamp, ExpireArgs expireArgs);

    /**
     * Execute the command PEXPIRETIME.
     * Summary: Get the expiration Unix timestamp for a key
     * Group: generic
     * Requires Redis 2.6.0
     *
     * @param key the key
     * @throws RedisKeyNotFoundException if the key does not exist
     */
    void pexpiretime(K key);

    /**
     * Execute the command PTTL.
     * Summary: Get the time to live for a key in milliseconds
     * Group: generic
     * Requires Redis 2.6.0
     *
     * @param key the key
     * @throws RedisKeyNotFoundException if the key does not exist
     */
    void pttl(K key) throws RedisKeyNotFoundException;

    /**
     * Execute the command RANDOMKEY.
     * Summary: Return a random key from the keyspace
     * Group: generic
     * Requires Redis 1.0.0
     */
    void randomkey();

    /**
     * Execute the command RENAME.
     * Summary: Rename a key
     * Group: generic
     * Requires Redis 1.0.0
     *
     * @param key the key
     * @param newkey the new key
     */
    void rename(K key, K newkey);

    /**
     * Execute the command RENAMENX.
     * Summary: Rename a key, only if the new key does not exist
     * Group: generic
     * Requires Redis 1.0.0
     *
     * @param key the key
     * @param newkey the new key
     */
    void renamenx(K key, K newkey);

    /**
     * Execute the command TOUCH.
     * Summary: Alters the last access time of a key(s). Returns the number of existing keys specified.
     * Group: generic
     * Requires Redis 3.2.1
     *
     * @param keys the keys
     */
    void touch(K... keys);

    /**
     * Execute the command TTL.
     * Summary: Get the time to live for a key in seconds
     * Group: generic
     * Requires Redis 1.0.0
     *
     * @param key the key
     * @throws RedisKeyNotFoundException if the key does not exist
     */
    void ttl(K key) throws RedisKeyNotFoundException;

    /**
     * Execute the command TYPE.
     * Summary: Determine the type stored at key
     * Group: generic
     * Requires Redis 1.0.0
     *
     * @param key the key
     */
    void type(K key);

    /**
     * Execute the command UNLINK.
     * Summary: Delete a key asynchronously in another thread. Otherwise, it is just as {@code DEL}, but non-blocking.
     * Group: generic
     * Requires Redis 4.0.0
     *
     * @param keys the keys
     */
    void unlink(K... keys);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy