This repository has been archived by the owner on Nov 29, 2021. It is now read-only.
forked from kubernetes-retired/heapster
/
influxdb.go
109 lines (97 loc) · 2.56 KB
/
influxdb.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
// Copyright 2015 Google Inc. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package influxdb
import (
"fmt"
"net/url"
"strconv"
"time"
"k8s.io/heapster/version"
influxdb "github.com/influxdata/influxdb/client"
)
type InfluxdbClient interface {
Write(influxdb.BatchPoints) (*influxdb.Response, error)
Query(influxdb.Query) (*influxdb.Response, error)
Ping() (time.Duration, string, error)
}
type InfluxdbConfig struct {
User string
Password string
Secure bool
Host string
DbName string
WithFields bool
}
func NewClient(c InfluxdbConfig) (InfluxdbClient, error) {
url := &url.URL{
Scheme: "http",
Host: c.Host,
}
if c.Secure {
url.Scheme = "https"
}
iConfig := &influxdb.Config{
URL: *url,
Username: c.User,
Password: c.Password,
UserAgent: fmt.Sprintf("%v/%v", "heapster", version.HeapsterVersion),
}
client, err := influxdb.NewClient(*iConfig)
if err != nil {
return nil, err
}
if _, _, err := client.Ping(); err != nil {
return nil, fmt.Errorf("failed to ping InfluxDB server at %q - %v", c.Host, err)
}
return client, nil
}
func BuildConfig(uri *url.URL) (*InfluxdbConfig, error) {
config := InfluxdbConfig{
User: "root",
Password: "root",
Host: "localhost:8086",
DbName: "k8s",
Secure: false,
WithFields: false,
}
if len(uri.Host) > 0 {
config.Host = uri.Host
}
opts := uri.Query()
if len(opts["user"]) >= 1 {
config.User = opts["user"][0]
}
// TODO: use more secure way to pass the password.
if len(opts["pw"]) >= 1 {
config.Password = opts["pw"][0]
}
if len(opts["db"]) >= 1 {
config.DbName = opts["db"][0]
}
if len(opts["withfields"]) >= 1 {
val, err := strconv.ParseBool(opts["withfields"][0])
if err != nil {
return nil, fmt.Errorf("failed to parse `withfields` flag - %v", err)
}
config.WithFields = val
}
if len(opts["secure"]) >= 1 {
val, err := strconv.ParseBool(opts["secure"][0])
if err != nil {
return nil, fmt.Errorf("failed to parse `secure` flag - %v", err)
}
config.Secure = val
}
return &config, nil
}