# frozen_string_literal: false class ActiveRedisDB::String < ActiveRedisDB::Base class << self def find(key) value = client.get(normalize_key(key)) value = metamorph(value) if evaluate? value end def find_each(*args) args = stringify_keys(args) value = client.mget(args) value = metamorph(value) if evaluate? value end def length(key) client.strlen(normalize_key(key)) end def split(key, start, finish) client.getrange(normalize_key(key), start, finish) end def create(key, value, opts = {}) client.set(normalize_key(key), value, opts) end def create!(key, value) client.setnx(normalize_key(key), value) end def create_each(*args) args = stringify_keys(args) client.mset(args) end def create_each!(*args) args = stringify_keys(args) client.msetnx(args) end def create_until(key, value, seconds, format = :seconds) normalized_key = normalize_key(key) if seconds?(format) client.setex(normalized_key, seconds, value) else client.psetex(normalized_key, seconds, value) end end def append(key, value) client.append(normalize_key(key), value) end def replace(key, value, offset) client.setrange(normalize_key(key), offset, value) end def decrement(key, value = 1) normalized_key = normalize_key(key) value == 1 ? client.decr(normalized_key) : client.decrby(normalized_key, value) end def increment(key, value = 1) normalized_key = normalize_key(key) if value.is_a?(Float) client.incrbyfloat(normalized_key, value) else value == 1 ? client.incr(normalized_key) : client.incrby(normalized_key, value) end end def reset(key, value = 0) client.getset(normalize_key(key), value) end def bit_count(key, start = 0, finish = -1) client.bitcount(normalize_key(key), start, finish) end def bit_where(operation, key, *keys) client.bitop(operation, key, *keys) end def get_bit(key, offset) client.getbit(normalize_key(key), offset) end def set_bit(key, offset, bit) client.setbit(normalize_key(key), offset, bit) end end end