2018-06-10 08:44:53 +02:00
|
|
|
package base
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"strings"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Session represents a PostgreSQL backend
|
|
|
|
type Session struct {
|
2018-06-11 21:02:24 +02:00
|
|
|
Pid int64
|
|
|
|
User string
|
|
|
|
Db string
|
|
|
|
Client string
|
|
|
|
State string
|
|
|
|
Query string
|
|
|
|
StateDuration float64
|
2018-06-10 08:44:53 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// NewSession instanciates a Session
|
2018-06-11 21:02:24 +02:00
|
|
|
func NewSession(pid int64, user string, db string, client string, state string, query string, stateDuration float64) Session {
|
2018-06-10 08:44:53 +02:00
|
|
|
return Session{
|
2018-06-11 21:02:24 +02:00
|
|
|
Pid: pid,
|
|
|
|
User: user,
|
|
|
|
Db: db,
|
|
|
|
Client: client,
|
|
|
|
State: state,
|
|
|
|
Query: query,
|
|
|
|
StateDuration: stateDuration,
|
2018-06-10 08:44:53 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// String represents a Session as a string
|
|
|
|
func (s Session) String() string {
|
|
|
|
var output []string
|
|
|
|
if s.Pid != 0 {
|
|
|
|
output = append(output, fmt.Sprintf("pid=%d", s.Pid))
|
|
|
|
}
|
|
|
|
if s.User != "" {
|
|
|
|
output = append(output, fmt.Sprintf("user=%s", s.User))
|
|
|
|
}
|
|
|
|
if s.Db != "" {
|
|
|
|
output = append(output, fmt.Sprintf("db=%s", s.Db))
|
|
|
|
}
|
|
|
|
if s.Client != "" {
|
|
|
|
output = append(output, fmt.Sprintf("client=%s", s.Client))
|
|
|
|
}
|
|
|
|
if s.State != "" {
|
|
|
|
output = append(output, fmt.Sprintf("state=%s", s.State))
|
|
|
|
}
|
2018-06-11 21:02:24 +02:00
|
|
|
if s.StateDuration != 0 {
|
|
|
|
output = append(output, fmt.Sprintf("state_duration=%f", s.StateDuration))
|
2018-06-10 08:44:53 +02:00
|
|
|
}
|
2018-06-11 21:02:24 +02:00
|
|
|
if s.Query != "" && !s.IsIdle() {
|
2018-06-10 08:44:53 +02:00
|
|
|
output = append(output, fmt.Sprintf("query=%s", s.Query))
|
|
|
|
}
|
|
|
|
return strings.Join(output, " ")
|
|
|
|
}
|
2018-06-11 21:02:24 +02:00
|
|
|
|
|
|
|
// IsIdle returns true when a session is doing nothing
|
|
|
|
func (s Session) IsIdle() bool {
|
|
|
|
if s.State == "idle" || s.State == "idle in transaction" || s.State == "idle in transaction (aborted)" {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|