2021-12-20 17:42:55 +08:00
|
|
|
// Copyright 2021, Roman Gershman. All rights reserved.
|
|
|
|
// See LICENSE for licensing terms.
|
|
|
|
//
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "server/common_types.h"
|
2021-12-23 21:11:46 +08:00
|
|
|
#include "server/engine_shard_set.h"
|
2021-12-20 17:42:55 +08:00
|
|
|
#include "util/proactor_pool.h"
|
|
|
|
|
|
|
|
namespace dfly {
|
|
|
|
|
|
|
|
class ConnectionContext;
|
|
|
|
class CommandRegistry;
|
|
|
|
|
|
|
|
class SetCmd {
|
|
|
|
DbSlice* db_slice_;
|
|
|
|
|
|
|
|
public:
|
|
|
|
explicit SetCmd(DbSlice* db_slice);
|
|
|
|
~SetCmd();
|
|
|
|
|
|
|
|
enum SetHow { SET_ALWAYS, SET_IF_NOTEXIST, SET_IF_EXISTS };
|
|
|
|
|
|
|
|
struct SetParams {
|
|
|
|
SetHow how = SET_ALWAYS;
|
|
|
|
DbIndex db_index;
|
|
|
|
|
2022-02-21 04:07:33 +08:00
|
|
|
uint32_t memcache_flags = 0;
|
2021-12-20 17:42:55 +08:00
|
|
|
// Relative value based on now. 0 means no expiration.
|
|
|
|
uint64_t expire_after_ms = 0;
|
|
|
|
mutable std::optional<std::string>* prev_val = nullptr; // GETSET option
|
2021-12-23 21:11:46 +08:00
|
|
|
bool keep_expire = false; // KEEPTTL - TODO: to implement it.
|
2021-12-20 17:42:55 +08:00
|
|
|
|
|
|
|
explicit SetParams(DbIndex dib) : db_index(dib) {
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
OpResult<void> Set(const SetParams& params, std::string_view key, std::string_view value);
|
|
|
|
};
|
|
|
|
|
|
|
|
class StringFamily {
|
|
|
|
public:
|
|
|
|
static void Init(util::ProactorPool* pp);
|
|
|
|
static void Shutdown();
|
|
|
|
|
|
|
|
static void Register(CommandRegistry* registry);
|
|
|
|
|
|
|
|
private:
|
|
|
|
static void Set(CmdArgList args, ConnectionContext* cntx);
|
|
|
|
static void Get(CmdArgList args, ConnectionContext* cntx);
|
|
|
|
static void GetSet(CmdArgList args, ConnectionContext* cntx);
|
2021-12-23 21:11:46 +08:00
|
|
|
static void MGet(CmdArgList args, ConnectionContext* cntx);
|
|
|
|
static void MSet(CmdArgList args, ConnectionContext* cntx);
|
2022-01-14 13:13:08 +08:00
|
|
|
static void Incr(CmdArgList args, ConnectionContext* cntx);
|
|
|
|
static void IncrBy(CmdArgList args, ConnectionContext* cntx);
|
|
|
|
static void Decr(CmdArgList args, ConnectionContext* cntx);
|
|
|
|
static void DecrBy(CmdArgList args, ConnectionContext* cntx);
|
2022-02-22 19:23:35 +08:00
|
|
|
static void Append(CmdArgList args, ConnectionContext* cntx);
|
|
|
|
static void Prepend(CmdArgList args, ConnectionContext* cntx);
|
2022-01-14 13:13:08 +08:00
|
|
|
|
|
|
|
static void IncrByGeneric(std::string_view key, int64_t val, ConnectionContext* cntx);
|
2022-02-22 19:23:35 +08:00
|
|
|
static void ExtendGeneric(CmdArgList args, bool prepend, ConnectionContext* cntx);
|
2021-12-23 21:11:46 +08:00
|
|
|
|
2022-02-22 02:27:18 +08:00
|
|
|
struct GetResp {
|
|
|
|
std::string value;
|
2022-02-22 19:23:35 +08:00
|
|
|
uint64_t mc_ver = 0; // 0 means we do not output it (i.e has not been requested).
|
2022-02-22 02:27:18 +08:00
|
|
|
uint32_t mc_flag = 0;
|
|
|
|
};
|
2021-12-23 21:11:46 +08:00
|
|
|
|
2022-02-22 02:27:18 +08:00
|
|
|
using MGetResponse = std::vector<std::optional<GetResp>>;
|
2022-02-22 19:23:35 +08:00
|
|
|
static MGetResponse OpMGet(bool fetch_mcflag, bool fetch_mcver, const Transaction* t,
|
|
|
|
EngineShard* shard);
|
2021-12-23 21:11:46 +08:00
|
|
|
|
|
|
|
static OpStatus OpMSet(const Transaction* t, EngineShard* es);
|
2022-02-24 23:14:03 +08:00
|
|
|
|
|
|
|
// if skip_on_missing - returns KEY_NOTFOUND.
|
|
|
|
static OpResult<int64_t> OpIncrBy(const OpArgs& op_args, std::string_view key, int64_t val,
|
|
|
|
bool skip_on_missing);
|
2022-02-22 19:23:35 +08:00
|
|
|
|
|
|
|
// Returns the length of the extended string. if prepend is false - appends the val.
|
|
|
|
static OpResult<uint32_t> ExtendOrSet(const OpArgs& op_args, std::string_view key,
|
|
|
|
std::string_view val, bool prepend);
|
|
|
|
|
|
|
|
// Returns true if was extended, false if the key was not found.
|
|
|
|
static OpResult<bool> ExtendOrSkip(const OpArgs& op_args, std::string_view key,
|
|
|
|
std::string_view val, bool prepend);
|
2021-12-20 17:42:55 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace dfly
|