2015-02-22 19:50:43 +00:00
|
|
|
package influxdb
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/influxdb/influxdb/influxql"
|
|
|
|
"github.com/influxdb/influxdb/messaging"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
// Data node messages
|
|
|
|
createDataNodeMessageType = messaging.MessageType(0x00)
|
|
|
|
deleteDataNodeMessageType = messaging.MessageType(0x01)
|
|
|
|
|
|
|
|
// Database messages
|
|
|
|
createDatabaseMessageType = messaging.MessageType(0x10)
|
2015-02-23 18:46:08 +00:00
|
|
|
dropDatabaseMessageType = messaging.MessageType(0x11)
|
2015-02-22 19:50:43 +00:00
|
|
|
|
|
|
|
// Retention policy messages
|
|
|
|
createRetentionPolicyMessageType = messaging.MessageType(0x20)
|
|
|
|
updateRetentionPolicyMessageType = messaging.MessageType(0x21)
|
|
|
|
deleteRetentionPolicyMessageType = messaging.MessageType(0x22)
|
|
|
|
setDefaultRetentionPolicyMessageType = messaging.MessageType(0x23)
|
|
|
|
|
|
|
|
// User messages
|
|
|
|
createUserMessageType = messaging.MessageType(0x30)
|
|
|
|
updateUserMessageType = messaging.MessageType(0x31)
|
|
|
|
deleteUserMessageType = messaging.MessageType(0x32)
|
|
|
|
|
|
|
|
// Shard messages
|
2015-03-10 00:54:37 +00:00
|
|
|
createShardGroupIfNotExistsMessageType = messaging.MessageType(0x40)
|
|
|
|
deleteShardGroupMessageType = messaging.MessageType(0x41)
|
2015-02-22 19:50:43 +00:00
|
|
|
|
|
|
|
// Series messages
|
|
|
|
dropSeriesMessageType = messaging.MessageType(0x50)
|
|
|
|
|
|
|
|
// Measurement messages
|
|
|
|
createMeasurementsIfNotExistsMessageType = messaging.MessageType(0x60)
|
2015-02-24 00:06:54 +00:00
|
|
|
dropMeasurementMessageType = messaging.MessageType(0x61)
|
2015-02-22 19:50:43 +00:00
|
|
|
|
|
|
|
// Continuous Query messages
|
|
|
|
createContinuousQueryMessageType = messaging.MessageType(0x70)
|
2015-03-25 00:11:26 +00:00
|
|
|
dropContinuousQueryMessageType = messaging.MessageType(0x71)
|
2015-02-22 19:50:43 +00:00
|
|
|
|
|
|
|
// Write series data messages (per-topic)
|
|
|
|
writeRawSeriesMessageType = messaging.MessageType(0x80)
|
|
|
|
|
|
|
|
// Privilege messages
|
|
|
|
setPrivilegeMessageType = messaging.MessageType(0x90)
|
|
|
|
)
|
|
|
|
|
|
|
|
type createDataNodeCommand struct {
|
|
|
|
URL string `json:"url"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type deleteDataNodeCommand struct {
|
|
|
|
ID uint64 `json:"id"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type createDatabaseCommand struct {
|
|
|
|
Name string `json:"name"`
|
|
|
|
}
|
|
|
|
|
2015-02-23 18:46:08 +00:00
|
|
|
type dropDatabaseCommand struct {
|
2015-02-22 19:50:43 +00:00
|
|
|
Name string `json:"name"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type createShardGroupIfNotExistsCommand struct {
|
|
|
|
Database string `json:"database"`
|
|
|
|
Policy string `json:"policy"`
|
|
|
|
Timestamp time.Time `json:"timestamp"`
|
|
|
|
}
|
2015-03-09 23:27:15 +00:00
|
|
|
|
2015-02-22 19:50:43 +00:00
|
|
|
type deleteShardGroupCommand struct {
|
|
|
|
Database string `json:"database"`
|
|
|
|
Policy string `json:"policy"`
|
|
|
|
ID uint64 `json:"id"`
|
|
|
|
}
|
2015-03-09 23:27:15 +00:00
|
|
|
|
2015-02-22 19:50:43 +00:00
|
|
|
type createUserCommand struct {
|
|
|
|
Username string `json:"username"`
|
|
|
|
Password string `json:"password"`
|
|
|
|
Admin bool `json:"admin,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type updateUserCommand struct {
|
|
|
|
Username string `json:"username"`
|
|
|
|
Password string `json:"password,omitempty"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type deleteUserCommand struct {
|
|
|
|
Username string `json:"username"`
|
|
|
|
}
|
|
|
|
type setPrivilegeCommand struct {
|
|
|
|
Privilege influxql.Privilege `json:"privilege"`
|
|
|
|
Username string `json:"username"`
|
|
|
|
Database string `json:"database"`
|
|
|
|
}
|
|
|
|
type createRetentionPolicyCommand struct {
|
2015-03-09 23:27:15 +00:00
|
|
|
Database string `json:"database"`
|
|
|
|
Name string `json:"name"`
|
|
|
|
Duration time.Duration `json:"duration"`
|
|
|
|
ShardGroupDuration time.Duration `json:"shardGroupDuration"`
|
|
|
|
ReplicaN uint32 `json:"replicaN"`
|
|
|
|
SplitN uint32 `json:"splitN"`
|
2015-02-22 19:50:43 +00:00
|
|
|
}
|
|
|
|
type updateRetentionPolicyCommand struct {
|
|
|
|
Database string `json:"database"`
|
|
|
|
Name string `json:"name"`
|
|
|
|
Policy *RetentionPolicyUpdate `json:"policy"`
|
|
|
|
}
|
|
|
|
type deleteRetentionPolicyCommand struct {
|
|
|
|
Database string `json:"database"`
|
|
|
|
Name string `json:"name"`
|
|
|
|
}
|
|
|
|
|
|
|
|
type setDefaultRetentionPolicyCommand struct {
|
|
|
|
Database string `json:"database"`
|
|
|
|
Name string `json:"name"`
|
|
|
|
}
|
|
|
|
|
2015-02-24 00:06:54 +00:00
|
|
|
type dropMeasurementCommand struct {
|
2015-02-24 00:20:12 +00:00
|
|
|
Database string `json:"database"`
|
|
|
|
Name string `json:"name"`
|
2015-02-24 00:06:54 +00:00
|
|
|
}
|
|
|
|
|
2015-02-22 19:50:43 +00:00
|
|
|
type createMeasurementSubcommand struct {
|
2015-04-01 03:49:54 +00:00
|
|
|
Name string `json:"name"`
|
|
|
|
Tags []map[string]string `json:"tags"`
|
|
|
|
Fields []*Field `json:"fields"`
|
|
|
|
|
2015-04-01 03:08:09 +00:00
|
|
|
marshaledTags map[string]struct{} // local cache...don't marshal
|
2015-02-22 19:50:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
type createMeasurementsIfNotExistsCommand struct {
|
2015-02-28 00:25:50 +00:00
|
|
|
Database string `json:"database"`
|
|
|
|
Measurements []*createMeasurementSubcommand `json:"measurements"`
|
2015-02-22 19:50:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func newCreateMeasurementsIfNotExistsCommand(database string) *createMeasurementsIfNotExistsCommand {
|
|
|
|
return &createMeasurementsIfNotExistsCommand{
|
|
|
|
Database: database,
|
2015-02-28 00:25:50 +00:00
|
|
|
Measurements: make([]*createMeasurementSubcommand, 0),
|
2015-02-22 19:50:43 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// addMeasurementIfNotExists adds the Measurement to the command, but only if not already present
|
|
|
|
// in the command.
|
2015-02-28 00:25:50 +00:00
|
|
|
func (c *createMeasurementsIfNotExistsCommand) addMeasurementIfNotExists(name string) *createMeasurementSubcommand {
|
|
|
|
for _, m := range c.Measurements {
|
|
|
|
if m.Name == name {
|
|
|
|
return m
|
2015-02-22 19:50:43 +00:00
|
|
|
}
|
|
|
|
}
|
2015-02-28 00:25:50 +00:00
|
|
|
m := &createMeasurementSubcommand{
|
2015-04-01 03:08:09 +00:00
|
|
|
Name: name,
|
|
|
|
Tags: make([]map[string]string, 0),
|
|
|
|
marshaledTags: make(map[string]struct{}, 0),
|
|
|
|
Fields: make([]*Field, 0),
|
2015-02-28 00:25:50 +00:00
|
|
|
}
|
|
|
|
c.Measurements = append(c.Measurements, m)
|
|
|
|
return m
|
2015-02-22 19:50:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// addSeriesIfNotExists adds the Series, identified by Measurement name and tag set, to
|
|
|
|
// the command, but only if not already present in the command.
|
|
|
|
func (c *createMeasurementsIfNotExistsCommand) addSeriesIfNotExists(measurement string, tags map[string]string) {
|
2015-02-28 00:25:50 +00:00
|
|
|
m := c.addMeasurementIfNotExists(measurement)
|
2015-02-22 19:50:43 +00:00
|
|
|
|
|
|
|
tagset := string(marshalTags(tags))
|
2015-04-01 03:08:09 +00:00
|
|
|
if _, ok := m.marshaledTags[tagset]; ok {
|
|
|
|
return
|
2015-02-22 19:50:43 +00:00
|
|
|
}
|
|
|
|
// Tag-set needs to added to subcommand.
|
|
|
|
m.Tags = append(m.Tags, tags)
|
2015-03-31 23:18:51 +00:00
|
|
|
// Store marshaled tags in local cache for performance.
|
2015-04-01 03:08:09 +00:00
|
|
|
m.marshaledTags[tagset] = struct{}{}
|
2015-02-22 19:50:43 +00:00
|
|
|
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// addFieldIfNotExists adds the field to the command for the Measurement, but only if it is not already
|
|
|
|
// present. It will return an error if the field is present in the command, but is of a different type.
|
|
|
|
func (c *createMeasurementsIfNotExistsCommand) addFieldIfNotExists(measurement, name string, typ influxql.DataType) error {
|
2015-02-28 00:25:50 +00:00
|
|
|
m := c.addMeasurementIfNotExists(measurement)
|
2015-02-22 19:50:43 +00:00
|
|
|
|
|
|
|
for _, f := range m.Fields {
|
|
|
|
if f.Name == name {
|
|
|
|
if f.Type != typ {
|
|
|
|
return ErrFieldTypeConflict
|
|
|
|
}
|
|
|
|
// Field already present in subcommand with same type, nothing to do.
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// New field for this measurement so add it to the subcommand.
|
|
|
|
newField := &Field{Name: name, Type: typ}
|
|
|
|
m.Fields = append(m.Fields, newField)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
type dropSeriesCommand struct {
|
2015-03-24 22:53:04 +00:00
|
|
|
Database string `json:"database"`
|
2015-04-08 22:46:56 +00:00
|
|
|
SeriesByMeasurement map[string][]uint64 `json:"seriesIds"`
|
2015-02-22 19:50:43 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// createContinuousQueryCommand is the raft command for creating a continuous query on a database
|
|
|
|
type createContinuousQueryCommand struct {
|
|
|
|
Query string `json:"query"`
|
|
|
|
}
|
2015-03-25 00:11:26 +00:00
|
|
|
|
|
|
|
type dropContinuousQueryCommand struct {
|
|
|
|
Name string `json:"name"`
|
|
|
|
Database string `json:"database"`
|
|
|
|
}
|