mirror of
https://github.com/grafana/grafana.git
synced 2025-02-20 11:48:34 -06:00
* rendering: headless chrome progress * renderer: minor change * grpc: version hell * updated grpc libs * wip: minor progess * rendering: new image rendering plugin is starting to work * feat: now phantomjs works as well and updated alerting to use new rendering service * refactor: renamed renderer package and service to rendering to make renderer name less confusing (rendering is internal service that handles the renderer plugin now) * rendering: now render key is passed and render auth is working in plugin mode * removed unneeded lines from gitignore * rendering: now plugin mode supports waiting for all panels to complete rendering * fix: LastSeenAt fix for render calls, was not set which causes a lot of updates to Last Seen at during rendering, this should fix sqlite db locked issues in seen in previous releases * change: changed render tz url parameter to use proper timezone name as chrome does not handle UTC offset TZ values * fix: another update to tz param generation * renderer: added http mode to renderer service, new ini setting [rendering] server_url
78 lines
1.5 KiB
Go
78 lines
1.5 KiB
Go
// Copyright 2016 The Xorm Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package builder
|
|
|
|
import "fmt"
|
|
|
|
// Not defines NOT condition
|
|
type Not [1]Cond
|
|
|
|
var _ Cond = Not{}
|
|
|
|
// WriteTo writes SQL to Writer
|
|
func (not Not) WriteTo(w Writer) error {
|
|
if _, err := fmt.Fprint(w, "NOT "); err != nil {
|
|
return err
|
|
}
|
|
switch not[0].(type) {
|
|
case condAnd, condOr:
|
|
if _, err := fmt.Fprint(w, "("); err != nil {
|
|
return err
|
|
}
|
|
case Eq:
|
|
if len(not[0].(Eq)) > 1 {
|
|
if _, err := fmt.Fprint(w, "("); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
case Neq:
|
|
if len(not[0].(Neq)) > 1 {
|
|
if _, err := fmt.Fprint(w, "("); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
}
|
|
|
|
if err := not[0].WriteTo(w); err != nil {
|
|
return err
|
|
}
|
|
|
|
switch not[0].(type) {
|
|
case condAnd, condOr:
|
|
if _, err := fmt.Fprint(w, ")"); err != nil {
|
|
return err
|
|
}
|
|
case Eq:
|
|
if len(not[0].(Eq)) > 1 {
|
|
if _, err := fmt.Fprint(w, ")"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
case Neq:
|
|
if len(not[0].(Neq)) > 1 {
|
|
if _, err := fmt.Fprint(w, ")"); err != nil {
|
|
return err
|
|
}
|
|
}
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
// And implements And with other conditions
|
|
func (not Not) And(conds ...Cond) Cond {
|
|
return And(not, And(conds...))
|
|
}
|
|
|
|
// Or implements Or with other conditions
|
|
func (not Not) Or(conds ...Cond) Cond {
|
|
return Or(not, Or(conds...))
|
|
}
|
|
|
|
// IsValid tests if this condition is valid
|
|
func (not Not) IsValid() bool {
|
|
return not[0] != nil && not[0].IsValid()
|
|
}
|