mirror of
https://gitee.com/acl-dev/acl.git
synced 2024-12-14 17:00:52 +08:00
111 lines
1.8 KiB
C++
111 lines
1.8 KiB
C++
|
#pragma once
|
||
|
#include "acl_cpp/acl_cpp_define.hpp"
|
||
|
#include <vector>
|
||
|
#include "acl_cpp/stdlib/string.hpp"
|
||
|
|
||
|
namespace acl
|
||
|
{
|
||
|
|
||
|
class redis_result;
|
||
|
|
||
|
class ACL_CPP_API disque_job
|
||
|
{
|
||
|
public:
|
||
|
disque_job();
|
||
|
~disque_job();
|
||
|
|
||
|
const char* get_id() const
|
||
|
{
|
||
|
return id_.c_str();
|
||
|
}
|
||
|
|
||
|
const char* get_queue() const
|
||
|
{
|
||
|
return queue_.c_str();
|
||
|
}
|
||
|
|
||
|
const string& get_body() const
|
||
|
{
|
||
|
return body_;
|
||
|
}
|
||
|
|
||
|
void set_id(const char* id);
|
||
|
void set_queue(const char* name);
|
||
|
void set_body(const char* job, size_t len);
|
||
|
|
||
|
/////////////////////////////////////////////////////////////////////
|
||
|
|
||
|
bool init(const redis_result& rr);
|
||
|
|
||
|
const char* get_state() const
|
||
|
{
|
||
|
return state_.c_str();
|
||
|
}
|
||
|
|
||
|
int get_repl() const
|
||
|
{
|
||
|
return repl_;
|
||
|
}
|
||
|
|
||
|
int get_ttl() const
|
||
|
{
|
||
|
return ttl_;
|
||
|
}
|
||
|
|
||
|
long long int get_ctime() const
|
||
|
{
|
||
|
return ctime_;
|
||
|
}
|
||
|
|
||
|
int get_delay() const
|
||
|
{
|
||
|
return delay_;
|
||
|
}
|
||
|
|
||
|
int get_retry() const
|
||
|
{
|
||
|
return retry_;
|
||
|
}
|
||
|
|
||
|
const std::vector<string>& get_nodes_delivered() const
|
||
|
{
|
||
|
return nodes_delivered_;
|
||
|
}
|
||
|
|
||
|
const std::vector<string>& get_nodes_confirmed() const
|
||
|
{
|
||
|
return nodes_confirmed_;
|
||
|
}
|
||
|
|
||
|
int get_next_requeue_within() const
|
||
|
{
|
||
|
return next_requeue_within_;
|
||
|
}
|
||
|
|
||
|
int get_next_awake_within() const
|
||
|
{
|
||
|
return next_awake_within_;
|
||
|
}
|
||
|
|
||
|
private:
|
||
|
string id_;
|
||
|
string queue_;
|
||
|
string state_;
|
||
|
int repl_;
|
||
|
int ttl_;
|
||
|
long long int ctime_;
|
||
|
int delay_;
|
||
|
int retry_;
|
||
|
std::vector<string> nodes_delivered_;
|
||
|
std::vector<string> nodes_confirmed_;
|
||
|
int next_requeue_within_;
|
||
|
int next_awake_within_;
|
||
|
string body_;
|
||
|
|
||
|
void set_nodes_delivered(const redis_result& rr);
|
||
|
void set_nodes_confirmed(const redis_result& rr);
|
||
|
void set_nodes(const redis_result& rr, std::vector<string>& out);
|
||
|
};
|
||
|
|
||
|
} // namespace acl
|