-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy pathdata_source_query.go
More file actions
124 lines (115 loc) · 2.84 KB
/
Copy pathdata_source_query.go
File metadata and controls
124 lines (115 loc) · 2.84 KB
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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
package main
import (
"fmt"
"log"
"strings"
"time"
"github.com/hashicorp/terraform/helper/schema"
scalyr "github.com/scalyr/terraform-provider-dataset/scalyr-go"
)
func fixTypes(in *[]map[string]interface{}) *[]map[string]interface{} {
out := make([]map[string]interface{}, len(*in))
for i, valueMap := range *in {
out[i] = make(map[string]interface{})
for k, v := range valueMap {
if k == "timestamp" {
secs, nsecs := int64(v.(float64))/1000000000, int64(v.(float64))%1000000000
out[i][k] = time.Unix(secs, nsecs).Format(time.RFC3339)
continue
}
switch v.(type) {
case float64:
out[i][k] = fmt.Sprintf("%v", v)
default:
out[i][k] = v
}
}
}
return &out
}
func datasourceQuery() *schema.Resource {
return &schema.Resource{
Read: datasourceQueryRead,
Schema: map[string]*schema.Schema{
"query": {
Type: schema.TypeString,
Required: true,
},
"expected_count": {
Type: schema.TypeInt,
Optional: true,
Default: -1,
},
"retry_count": {
Type: schema.TypeInt,
Optional: true,
Default: 1,
},
"retry_wait": {
Type: schema.TypeInt,
Optional: true,
Default: 5,
},
"query_type": {
Type: schema.TypeString,
Optional: true,
Default: "pq",
},
"start_time": {
Type: schema.TypeString,
Optional: true,
Default: "10 mins",
},
"end_time": {
Type: schema.TypeString,
Optional: true,
Default: "",
},
"max_count": {
Type: schema.TypeInt,
Optional: true,
Default: 1,
},
"results": {
Type: schema.TypeList,
Computed: true,
Elem: &schema.Schema{Type: schema.TypeMap},
},
},
}
}
func datasourceQueryRead(d *schema.ResourceData, meta interface{}) error {
client := meta.(*scalyr.ScalyrConfig)
queryType := d.Get("query_type").(string)
query := strings.TrimSuffix(d.Get("query").(string), "\n")
startTime := d.Get("start_time").(string)
endTime := d.Get("end_time").(string)
expectedCount := d.Get("expected_count").(int)
retryWait := d.Get("retry_wait").(int)
retryCount := d.Get("retry_count").(int)
var request scalyr.Query
if queryType == "pq" {
request = client.NewPowerQuery(query)
} /* else {
request = client.NewLogQuery(query)
request.MaxCount(max_count)
} */
request.Range(startTime, endTime)
for i := 0; i < retryCount; i++ {
res, err := request.Fetch()
if err != nil {
log.Fatalf("Error Executing Query: %v - %v", query, err)
}
log.Printf("Res: %v", &res)
if err = d.Set("results", *fixTypes(&res)); err != nil {
return fmt.Errorf("Error setting results - %v", err)
}
if expectedCount < 0 || expectedCount == int(request.Size()) {
d.SetId(time.Now().UTC().String())
return nil
} else {
time.Sleep(time.Duration(retryWait) * time.Second)
}
}
return fmt.Errorf("Error Executing Query: %v", query)
}