mirror of
https://github.com/taigrr/wtf
synced 2025-01-18 04:03:14 -08:00
Output from 'dep status': PROJECT CONSTRAINT VERSION REVISION LATEST PKGS USED cloud.google.com/go v0.23.0 v0.23.0 0fd7230 v0.23.0 1 github.com/briandowns/openweathermap ^0.11.0 0.11 1b87579 0.11 1 github.com/gdamore/encoding branch master branch master b23993c b23993c 1 github.com/gdamore/tcell ^1.0.0 v1.0.0 061d51a v1.0.0 2 github.com/go-test/deep ^1.0.1 v1.0.1 6592d9c v1.0.1 1 github.com/golang/protobuf v1.1.0 v1.1.0 b4deda0 v1.1.0 1 github.com/google/go-github branch master branch master 2ae5df7 2ae5df7 1 github.com/google/go-querystring branch master branch master 53e6ce1 53e6ce1 1 github.com/jessevdk/go-flags ^1.4.0 v1.4.0 c6ca198 v1.4.0 1 github.com/lucasb-eyer/go-colorful v1.0 v1.0 345fbb3 v1.0 1 github.com/mattn/go-runewidth v0.0.2 v0.0.2 9e777a8 v0.0.2 1 github.com/olebedev/config branch master branch master 9a10d05 9a10d05 1 github.com/radovskyb/watcher ^1.0.2 v1.0.2 6145e14 v1.0.2 1 github.com/rivo/tview branch master branch master 71ecf1f 71ecf1f 1 github.com/yfronto/newrelic branch master branch master f7fa0c6 f7fa0c6 1 golang.org/x/net branch master branch master 1e49130 1e49130 2 golang.org/x/oauth2 branch master branch master 1e0a3fa 1e0a3fa 5 golang.org/x/text v0.3.0 v0.3.0 f21a4df v0.3.0 5 google.golang.org/api branch master branch master 00e3bb8 00e3bb8 4 google.golang.org/appengine v1.0.0 v1.0.0 150dc57 v1.0.0 10 gopkg.in/yaml.v2 ^2.2.1 v2.2.1 5420a8b v2.2.1 1 See https://golang.github.io/dep/docs/daily-dep.html
129 lines
3.3 KiB
Go
129 lines
3.3 KiB
Go
package newrelic
|
|
|
|
import (
|
|
"time"
|
|
)
|
|
|
|
// Metric describes a New Relic metric.
|
|
type Metric struct {
|
|
Name string `json:"name,omitempty"`
|
|
Values []string `json:"values,omitempty"`
|
|
}
|
|
|
|
// MetricsOptions options allow filtering when getting lists of metric names
|
|
// associated with an entity.
|
|
type MetricsOptions struct {
|
|
Name string
|
|
Page int
|
|
}
|
|
|
|
// MetricTimeslice describes the period to which a Metric pertains.
|
|
type MetricTimeslice struct {
|
|
From time.Time `json:"from,omitempty"`
|
|
To time.Time `json:"to,omitempty"`
|
|
Values map[string]float64 `json:"values,omitempty"`
|
|
}
|
|
|
|
// MetricData describes the data for a particular metric.
|
|
type MetricData struct {
|
|
Name string `json:"name,omitempty"`
|
|
Timeslices []MetricTimeslice `json:"timeslices,omitempty"`
|
|
}
|
|
|
|
// MetricDataOptions allow filtering when getting data about a particular set
|
|
// of New Relic metrics.
|
|
type MetricDataOptions struct {
|
|
Names Array
|
|
Values Array
|
|
From time.Time
|
|
To time.Time
|
|
Period int
|
|
Summarize bool
|
|
Raw bool
|
|
}
|
|
|
|
// MetricDataResponse is the response received from New Relic for any request
|
|
// for metric data.
|
|
type MetricDataResponse struct {
|
|
From time.Time `json:"from,omitempty"`
|
|
To time.Time `json:"to,omitempty"`
|
|
MetricsNotFound []string `json:"metrics_not_found,omitempty"`
|
|
MetricsFound []string `json:"metrics_found,omitempty"`
|
|
Metrics []MetricData `json:"metrics,omitempty"`
|
|
}
|
|
|
|
func (o *MetricsOptions) String() string {
|
|
if o == nil {
|
|
return ""
|
|
}
|
|
return encodeGetParams(map[string]interface{}{
|
|
"name": o.Name,
|
|
"page": o.Page,
|
|
})
|
|
}
|
|
|
|
func (o *MetricDataOptions) String() string {
|
|
if o == nil {
|
|
return ""
|
|
}
|
|
return encodeGetParams(map[string]interface{}{
|
|
"names[]": o.Names,
|
|
"values[]": o.Values,
|
|
"from": o.From,
|
|
"to": o.To,
|
|
"period": o.Period,
|
|
"summarize": o.Summarize,
|
|
"raw": o.Raw,
|
|
})
|
|
}
|
|
|
|
// MetricClient implements a generic New Relic metrics client.
|
|
// This is used as a general client for fetching metric names and data.
|
|
type MetricClient struct {
|
|
newRelicClient *Client
|
|
}
|
|
|
|
// NewMetricClient creates and returns a new MetricClient.
|
|
func NewMetricClient(newRelicClient *Client) *MetricClient {
|
|
return &MetricClient{
|
|
newRelicClient: newRelicClient,
|
|
}
|
|
}
|
|
|
|
// GetMetrics is a generic function for fetching a list of available metrics
|
|
// from different parts of New Relic.
|
|
// Example: Application metrics, Component metrics, etc.
|
|
func (mc *MetricClient) GetMetrics(path string, options *MetricsOptions) ([]Metric, error) {
|
|
resp := &struct {
|
|
Metrics []Metric `json:"metrics,omitempty"`
|
|
}{}
|
|
|
|
err := mc.newRelicClient.doGet(path, options, resp)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return resp.Metrics, nil
|
|
}
|
|
|
|
// GetMetricData is a generic function for fetching data for a specific metric.
|
|
// from different parts of New Relic.
|
|
// Example: Application metric data, Component metric data, etc.
|
|
func (mc *MetricClient) GetMetricData(path string, names []string, options *MetricDataOptions) (*MetricDataResponse, error) {
|
|
resp := &struct {
|
|
MetricData MetricDataResponse `json:"metric_data,omitempty"`
|
|
}{}
|
|
|
|
if options == nil {
|
|
options = &MetricDataOptions{}
|
|
}
|
|
|
|
options.Names = Array{names}
|
|
err := mc.newRelicClient.doGet(path, options, resp)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &resp.MetricData, nil
|
|
}
|