2015-05-08 17:51:50 +00:00
|
|
|
package internal;
|
|
|
|
|
|
|
|
//========================================================================
|
|
|
|
//
|
|
|
|
// Metadata
|
|
|
|
//
|
|
|
|
//========================================================================
|
|
|
|
|
|
|
|
message Data {
|
2015-06-11 04:48:44 +00:00
|
|
|
required uint64 Term = 1;
|
|
|
|
required uint64 Index = 2;
|
|
|
|
required uint64 ClusterID = 3;
|
|
|
|
|
|
|
|
repeated NodeInfo Nodes = 4;
|
|
|
|
repeated DatabaseInfo Databases = 5;
|
|
|
|
repeated UserInfo Users = 6;
|
|
|
|
|
|
|
|
required uint64 MaxNodeID = 7;
|
|
|
|
required uint64 MaxShardGroupID = 8;
|
|
|
|
required uint64 MaxShardID = 9;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message NodeInfo {
|
|
|
|
required uint64 ID = 1;
|
|
|
|
required string Host = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
message DatabaseInfo {
|
|
|
|
required string Name = 1;
|
|
|
|
required string DefaultRetentionPolicy = 2;
|
2015-06-08 19:07:05 +00:00
|
|
|
repeated RetentionPolicyInfo RetentionPolicies = 3;
|
2015-05-08 17:51:50 +00:00
|
|
|
repeated ContinuousQueryInfo ContinuousQueries = 4;
|
|
|
|
}
|
|
|
|
|
|
|
|
message RetentionPolicyInfo {
|
|
|
|
required string Name = 1;
|
|
|
|
required int64 Duration = 2;
|
|
|
|
required int64 ShardGroupDuration = 3;
|
|
|
|
required uint32 ReplicaN = 4;
|
|
|
|
repeated ShardGroupInfo ShardGroups = 5;
|
2015-10-08 16:45:23 +00:00
|
|
|
repeated SubscriptionInfo Subscriptions = 6;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message ShardGroupInfo {
|
|
|
|
required uint64 ID = 1;
|
|
|
|
required int64 StartTime = 2;
|
|
|
|
required int64 EndTime = 3;
|
2015-06-08 19:07:05 +00:00
|
|
|
required int64 DeletedAt = 4;
|
|
|
|
repeated ShardInfo Shards = 5;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message ShardInfo {
|
2015-08-31 22:03:44 +00:00
|
|
|
required uint64 ID = 1;
|
|
|
|
repeated uint64 OwnerIDs = 2 [deprecated=true];
|
|
|
|
repeated ShardOwner Owners = 3;
|
|
|
|
}
|
|
|
|
|
2015-10-08 16:45:23 +00:00
|
|
|
message SubscriptionInfo{
|
|
|
|
required string Name = 1;
|
|
|
|
required string Mode = 2;
|
|
|
|
repeated string Destinations = 3;
|
|
|
|
}
|
|
|
|
|
2015-08-31 22:03:44 +00:00
|
|
|
message ShardOwner {
|
|
|
|
required uint64 NodeID = 1;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message ContinuousQueryInfo {
|
2015-06-08 19:07:05 +00:00
|
|
|
required string Name = 1;
|
|
|
|
required string Query = 2;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
|
2015-06-08 19:07:05 +00:00
|
|
|
message UserInfo {
|
2015-05-08 17:51:50 +00:00
|
|
|
required string Name = 1;
|
|
|
|
required string Hash = 2;
|
|
|
|
required bool Admin = 3;
|
|
|
|
repeated UserPrivilege Privileges = 4;
|
|
|
|
}
|
|
|
|
|
|
|
|
message UserPrivilege {
|
|
|
|
required string Database = 1;
|
|
|
|
required int32 Privilege = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//========================================================================
|
|
|
|
//
|
|
|
|
// COMMANDS
|
|
|
|
//
|
|
|
|
//========================================================================
|
|
|
|
|
|
|
|
message Command {
|
|
|
|
extensions 100 to max;
|
|
|
|
|
|
|
|
enum Type {
|
2015-05-21 20:06:01 +00:00
|
|
|
CreateNodeCommand = 1;
|
|
|
|
DeleteNodeCommand = 2;
|
|
|
|
CreateDatabaseCommand = 3;
|
|
|
|
DropDatabaseCommand = 4;
|
|
|
|
CreateRetentionPolicyCommand = 5;
|
|
|
|
DropRetentionPolicyCommand = 6;
|
|
|
|
SetDefaultRetentionPolicyCommand = 7;
|
|
|
|
UpdateRetentionPolicyCommand = 8;
|
|
|
|
CreateShardGroupCommand = 9;
|
2015-06-05 20:40:18 +00:00
|
|
|
DeleteShardGroupCommand = 10;
|
|
|
|
CreateContinuousQueryCommand = 11;
|
|
|
|
DropContinuousQueryCommand = 12;
|
2015-05-21 20:06:01 +00:00
|
|
|
CreateUserCommand = 13;
|
|
|
|
DropUserCommand = 14;
|
|
|
|
UpdateUserCommand = 15;
|
|
|
|
SetPrivilegeCommand = 16;
|
2015-06-08 19:07:05 +00:00
|
|
|
SetDataCommand = 17;
|
2015-07-20 20:59:00 +00:00
|
|
|
SetAdminPrivilegeCommand = 18;
|
2015-08-05 16:25:55 +00:00
|
|
|
UpdateNodeCommand = 19;
|
2015-10-19 14:02:10 +00:00
|
|
|
CreateSubscriptionCommand = 21;
|
|
|
|
DropSubscriptionCommand = 22;
|
2015-10-06 16:10:37 +00:00
|
|
|
RemovePeerCommand = 23;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
required Type type = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message CreateNodeCommand {
|
|
|
|
extend Command {
|
2015-05-21 20:06:01 +00:00
|
|
|
optional CreateNodeCommand command = 101;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
required string Host = 1;
|
2015-06-11 04:28:18 +00:00
|
|
|
required uint64 Rand = 2;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message DeleteNodeCommand {
|
|
|
|
extend Command {
|
2015-05-21 20:06:01 +00:00
|
|
|
optional DeleteNodeCommand command = 102;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
2015-05-21 20:06:01 +00:00
|
|
|
required uint64 ID = 1;
|
2015-10-03 02:49:11 +00:00
|
|
|
required bool Force = 2;
|
2015-09-25 18:54:11 +00:00
|
|
|
}
|
|
|
|
|
2015-05-08 17:51:50 +00:00
|
|
|
message CreateDatabaseCommand {
|
|
|
|
extend Command {
|
2015-05-21 20:06:01 +00:00
|
|
|
optional CreateDatabaseCommand command = 103;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
required string Name = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message DropDatabaseCommand {
|
|
|
|
extend Command {
|
2015-05-21 20:06:01 +00:00
|
|
|
optional DropDatabaseCommand command = 104;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
required string Name = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message CreateRetentionPolicyCommand {
|
|
|
|
extend Command {
|
2015-05-21 20:06:01 +00:00
|
|
|
optional CreateRetentionPolicyCommand command = 105;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
required string Database = 1;
|
|
|
|
required RetentionPolicyInfo RetentionPolicy = 2;
|
|
|
|
}
|
|
|
|
|
2015-05-21 20:06:01 +00:00
|
|
|
message DropRetentionPolicyCommand {
|
2015-05-08 17:51:50 +00:00
|
|
|
extend Command {
|
2015-05-21 20:06:01 +00:00
|
|
|
optional DropRetentionPolicyCommand command = 106;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
required string Database = 1;
|
|
|
|
required string Name = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
message SetDefaultRetentionPolicyCommand {
|
|
|
|
extend Command {
|
2015-05-21 20:06:01 +00:00
|
|
|
optional SetDefaultRetentionPolicyCommand command = 107;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
required string Database = 1;
|
|
|
|
required string Name = 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
message UpdateRetentionPolicyCommand {
|
|
|
|
extend Command {
|
2015-05-21 20:06:01 +00:00
|
|
|
optional UpdateRetentionPolicyCommand command = 108;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
required string Database = 1;
|
|
|
|
required string Name = 2;
|
|
|
|
optional string NewName = 3;
|
|
|
|
optional int64 Duration = 4;
|
|
|
|
optional uint32 ReplicaN = 5;
|
|
|
|
}
|
|
|
|
|
2015-05-21 20:06:01 +00:00
|
|
|
message CreateShardGroupCommand {
|
2015-05-08 17:51:50 +00:00
|
|
|
extend Command {
|
2015-05-21 20:06:01 +00:00
|
|
|
optional CreateShardGroupCommand command = 109;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
required string Database = 1;
|
|
|
|
required string Policy = 2;
|
|
|
|
required int64 Timestamp = 3;
|
|
|
|
}
|
|
|
|
|
2015-05-21 20:06:01 +00:00
|
|
|
message DeleteShardGroupCommand {
|
|
|
|
extend Command {
|
|
|
|
optional DeleteShardGroupCommand command = 110;
|
|
|
|
}
|
|
|
|
required string Database = 1;
|
|
|
|
required string Policy = 2;
|
|
|
|
required uint64 ShardGroupID = 3;
|
|
|
|
}
|
|
|
|
|
|
|
|
message CreateContinuousQueryCommand {
|
|
|
|
extend Command {
|
|
|
|
optional CreateContinuousQueryCommand command = 111;
|
|
|
|
}
|
2015-05-28 04:06:09 +00:00
|
|
|
required string Database = 1;
|
|
|
|
required string Name = 2;
|
|
|
|
required string Query = 3;
|
2015-05-21 20:06:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message DropContinuousQueryCommand {
|
|
|
|
extend Command {
|
|
|
|
optional DropContinuousQueryCommand command = 112;
|
|
|
|
}
|
2015-05-28 04:06:09 +00:00
|
|
|
required string Database = 1;
|
|
|
|
required string Name = 2;
|
2015-05-21 20:06:01 +00:00
|
|
|
}
|
|
|
|
|
2015-05-08 17:51:50 +00:00
|
|
|
message CreateUserCommand {
|
|
|
|
extend Command {
|
2015-05-21 20:06:01 +00:00
|
|
|
optional CreateUserCommand command = 113;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
2015-05-21 20:06:01 +00:00
|
|
|
required string Name = 1;
|
|
|
|
required string Hash = 2;
|
2015-05-08 17:51:50 +00:00
|
|
|
required bool Admin = 3;
|
|
|
|
}
|
|
|
|
|
2015-05-21 20:06:01 +00:00
|
|
|
message DropUserCommand {
|
2015-05-08 17:51:50 +00:00
|
|
|
extend Command {
|
2015-05-21 20:06:01 +00:00
|
|
|
optional DropUserCommand command = 114;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
2015-05-21 20:06:01 +00:00
|
|
|
required string Name = 1;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message UpdateUserCommand {
|
|
|
|
extend Command {
|
2015-05-21 20:06:01 +00:00
|
|
|
optional UpdateUserCommand command = 115;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
2015-05-21 20:06:01 +00:00
|
|
|
required string Name = 1;
|
|
|
|
required string Hash = 2;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
message SetPrivilegeCommand {
|
|
|
|
extend Command {
|
2015-05-21 20:06:01 +00:00
|
|
|
optional SetPrivilegeCommand command = 116;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
required string Username = 1;
|
2015-05-27 19:41:58 +00:00
|
|
|
required string Database = 2;
|
|
|
|
required int32 Privilege = 3;
|
2015-05-08 17:51:50 +00:00
|
|
|
}
|
|
|
|
|
2015-06-08 19:07:05 +00:00
|
|
|
message SetDataCommand {
|
|
|
|
extend Command {
|
|
|
|
optional SetDataCommand command = 117;
|
|
|
|
}
|
|
|
|
required Data Data = 1;
|
|
|
|
}
|
|
|
|
|
2015-07-10 20:39:33 +00:00
|
|
|
message SetAdminPrivilegeCommand {
|
|
|
|
extend Command {
|
|
|
|
optional SetAdminPrivilegeCommand command = 118;
|
|
|
|
}
|
|
|
|
required string Username = 1;
|
|
|
|
required bool Admin = 2;
|
|
|
|
}
|
|
|
|
|
2015-07-28 20:22:32 +00:00
|
|
|
message UpdateNodeCommand {
|
|
|
|
extend Command {
|
|
|
|
optional UpdateNodeCommand command = 119;
|
|
|
|
}
|
|
|
|
required uint64 ID = 1;
|
|
|
|
required string Host = 2;
|
|
|
|
}
|
|
|
|
|
2015-10-08 16:45:23 +00:00
|
|
|
message CreateSubscriptionCommand {
|
|
|
|
extend Command {
|
|
|
|
optional CreateSubscriptionCommand command = 121;
|
|
|
|
}
|
|
|
|
required string Name = 1;
|
|
|
|
required string Database = 2;
|
|
|
|
required string RetentionPolicy = 3;
|
|
|
|
required string Mode = 4;
|
|
|
|
repeated string Destinations = 5;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
message DropSubscriptionCommand {
|
|
|
|
extend Command {
|
|
|
|
optional DropSubscriptionCommand command = 122;
|
|
|
|
}
|
|
|
|
required string Name = 1;
|
|
|
|
required string Database = 2;
|
|
|
|
required string RetentionPolicy = 3;
|
2015-09-21 18:59:12 +00:00
|
|
|
}
|
|
|
|
|
2015-10-06 16:10:37 +00:00
|
|
|
message RemovePeerCommand {
|
|
|
|
extend Command {
|
|
|
|
optional RemovePeerCommand command = 123;
|
|
|
|
}
|
|
|
|
required uint64 ID = 1;
|
|
|
|
required string Addr = 2;
|
|
|
|
}
|
|
|
|
|
2015-06-05 20:40:18 +00:00
|
|
|
message Response {
|
|
|
|
required bool OK = 1;
|
|
|
|
optional string Error = 2;
|
|
|
|
optional uint64 Index = 3;
|
|
|
|
}
|
2015-07-14 17:07:08 +00:00
|
|
|
|
|
|
|
|
|
|
|
//========================================================================
|
|
|
|
//
|
|
|
|
// RPC - higher-level cluster communication operations
|
|
|
|
//
|
|
|
|
//========================================================================
|
|
|
|
|
2015-07-15 05:06:39 +00:00
|
|
|
enum RPCType {
|
2015-07-16 16:31:07 +00:00
|
|
|
Error = 1;
|
|
|
|
FetchData = 2;
|
|
|
|
Join = 3;
|
2015-07-15 05:06:39 +00:00
|
|
|
}
|
2015-07-14 17:07:08 +00:00
|
|
|
|
2015-07-15 05:06:39 +00:00
|
|
|
message ResponseHeader {
|
|
|
|
required bool OK = 1;
|
|
|
|
optional string Error = 2;
|
|
|
|
}
|
2015-07-14 17:07:08 +00:00
|
|
|
|
2015-07-16 16:31:07 +00:00
|
|
|
message ErrorResponse {
|
|
|
|
required ResponseHeader Header = 1;
|
|
|
|
}
|
|
|
|
|
2015-07-15 05:06:39 +00:00
|
|
|
message FetchDataRequest {
|
2015-07-16 19:58:44 +00:00
|
|
|
required uint64 Index = 1;
|
|
|
|
required uint64 Term = 2;
|
|
|
|
optional bool Blocking = 3 [default = false];
|
2015-07-14 17:07:08 +00:00
|
|
|
}
|
|
|
|
|
2015-07-15 05:06:39 +00:00
|
|
|
message FetchDataResponse {
|
|
|
|
required ResponseHeader Header = 1;
|
2015-07-16 19:58:44 +00:00
|
|
|
required uint64 Index = 2;
|
|
|
|
required uint64 Term = 3;
|
|
|
|
optional bytes Data = 4;
|
2015-07-14 17:07:08 +00:00
|
|
|
}
|
|
|
|
|
2015-07-15 05:06:39 +00:00
|
|
|
message JoinRequest {
|
|
|
|
required string Addr = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
message JoinResponse {
|
|
|
|
required ResponseHeader Header = 1;
|
|
|
|
|
2015-07-15 21:02:59 +00:00
|
|
|
// Indicates that this node should take part in the raft cluster.
|
2015-07-15 05:06:39 +00:00
|
|
|
optional bool EnableRaft = 2;
|
2015-07-20 20:59:00 +00:00
|
|
|
|
2015-07-15 05:06:39 +00:00
|
|
|
// The addresses of raft peers to use if joining as a raft member. If not joining
|
|
|
|
// as a raft member, these are the nodes running raft.
|
2015-07-20 20:59:00 +00:00
|
|
|
repeated string RaftNodes = 3;
|
2015-07-15 21:02:59 +00:00
|
|
|
|
|
|
|
// The node ID assigned to the requesting node.
|
|
|
|
optional uint64 NodeID = 4;
|
2015-07-14 17:07:08 +00:00
|
|
|
}
|