2015-05-28 04:06:09 +00:00
|
|
|
package influxql
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"errors"
|
2016-04-29 13:00:21 +00:00
|
|
|
"fmt"
|
2015-09-16 21:32:50 +00:00
|
|
|
|
2016-02-10 17:26:18 +00:00
|
|
|
"github.com/influxdata/influxdb/models"
|
2015-05-28 04:06:09 +00:00
|
|
|
)
|
|
|
|
|
2016-04-13 14:44:59 +00:00
|
|
|
const (
|
|
|
|
// WarningLevel is the message level for a warning.
|
|
|
|
WarningLevel = "warning"
|
|
|
|
)
|
|
|
|
|
2015-07-06 12:31:52 +00:00
|
|
|
// TagSet is a fundamental concept within the query system. It represents a composite series,
|
|
|
|
// composed of multiple individual series that share a set of tag attributes.
|
|
|
|
type TagSet struct {
|
|
|
|
Tags map[string]string
|
|
|
|
Filters []Expr
|
|
|
|
SeriesKeys []string
|
|
|
|
Key []byte
|
|
|
|
}
|
|
|
|
|
|
|
|
// AddFilter adds a series-level filter to the Tagset.
|
|
|
|
func (t *TagSet) AddFilter(key string, filter Expr) {
|
|
|
|
t.SeriesKeys = append(t.SeriesKeys, key)
|
|
|
|
t.Filters = append(t.Filters, filter)
|
|
|
|
}
|
|
|
|
|
2016-04-18 21:40:49 +00:00
|
|
|
func (t *TagSet) Len() int { return len(t.SeriesKeys) }
|
|
|
|
func (t *TagSet) Less(i, j int) bool { return t.SeriesKeys[i] < t.SeriesKeys[j] }
|
|
|
|
func (t *TagSet) Swap(i, j int) {
|
|
|
|
t.SeriesKeys[i], t.SeriesKeys[j] = t.SeriesKeys[j], t.SeriesKeys[i]
|
|
|
|
t.Filters[i], t.Filters[j] = t.Filters[j], t.Filters[i]
|
|
|
|
}
|
|
|
|
|
2016-04-13 14:44:59 +00:00
|
|
|
// Message represents a user-facing message to be included with the result.
|
|
|
|
type Message struct {
|
|
|
|
Level string `json:"level"`
|
|
|
|
Text string `json:"text"`
|
|
|
|
}
|
|
|
|
|
2016-04-29 13:00:21 +00:00
|
|
|
// ReadOnlyWarning generates a warning message that tells the user the command
|
|
|
|
// they are using is being used for writing in a read only context.
|
|
|
|
//
|
|
|
|
// This is a temporary method while to be used while transitioning to read only
|
|
|
|
// operations for issue #6290.
|
|
|
|
func ReadOnlyWarning(stmt string) *Message {
|
|
|
|
return &Message{
|
|
|
|
Level: WarningLevel,
|
|
|
|
Text: fmt.Sprintf("deprecated use of '%s' in a read only context, please use a POST request instead", stmt),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-28 04:06:09 +00:00
|
|
|
// Result represents a resultset returned from a single statement.
|
2016-01-14 15:36:38 +00:00
|
|
|
// Rows represents a list of rows that can be sorted consistently by name/tag.
|
2015-05-28 04:06:09 +00:00
|
|
|
type Result struct {
|
|
|
|
// StatementID is just the statement's position in the query. It's used
|
|
|
|
// to combine statement results if they're being buffered in memory.
|
|
|
|
StatementID int `json:"-"`
|
2015-09-16 21:32:50 +00:00
|
|
|
Series models.Rows
|
2016-04-13 14:44:59 +00:00
|
|
|
Messages []*Message
|
2015-05-28 04:06:09 +00:00
|
|
|
Err error
|
|
|
|
}
|
|
|
|
|
|
|
|
// MarshalJSON encodes the result into JSON.
|
|
|
|
func (r *Result) MarshalJSON() ([]byte, error) {
|
|
|
|
// Define a struct that outputs "error" as a string.
|
|
|
|
var o struct {
|
2016-04-13 14:44:59 +00:00
|
|
|
Series []*models.Row `json:"series,omitempty"`
|
|
|
|
Messages []*Message `json:"messages,omitempty"`
|
|
|
|
Err string `json:"error,omitempty"`
|
2015-05-28 04:06:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Copy fields to output struct.
|
|
|
|
o.Series = r.Series
|
2016-04-13 14:44:59 +00:00
|
|
|
o.Messages = r.Messages
|
2015-05-28 04:06:09 +00:00
|
|
|
if r.Err != nil {
|
|
|
|
o.Err = r.Err.Error()
|
|
|
|
}
|
|
|
|
|
|
|
|
return json.Marshal(&o)
|
|
|
|
}
|
|
|
|
|
|
|
|
// UnmarshalJSON decodes the data into the Result struct
|
|
|
|
func (r *Result) UnmarshalJSON(b []byte) error {
|
|
|
|
var o struct {
|
2016-04-13 14:44:59 +00:00
|
|
|
Series []*models.Row `json:"series,omitempty"`
|
|
|
|
Messages []*Message `json:"messages,omitempty"`
|
|
|
|
Err string `json:"error,omitempty"`
|
2015-05-28 04:06:09 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
err := json.Unmarshal(b, &o)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
r.Series = o.Series
|
2016-04-13 14:44:59 +00:00
|
|
|
r.Messages = o.Messages
|
2015-05-28 04:06:09 +00:00
|
|
|
if o.Err != "" {
|
|
|
|
r.Err = errors.New(o.Err)
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|