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
112 lines
3.9 KiB
Go
112 lines
3.9 KiB
Go
package newrelic
|
|
|
|
import (
|
|
"strconv"
|
|
"time"
|
|
)
|
|
|
|
// ApplicationSummary describes the brief summary component of an Application.
|
|
type ApplicationSummary struct {
|
|
ResponseTime float64 `json:"response_time,omitempty"`
|
|
Throughput float64 `json:"throughput,omitempty"`
|
|
ErrorRate float64 `json:"error_rate,omitempty"`
|
|
ApdexTarget float64 `json:"apdex_target,omitempty"`
|
|
ApdexScore float64 `json:"apdex_score,omitempty"`
|
|
HostCount int `json:"host_count,omitempty"`
|
|
InstanceCount int `json:"instance_count,omitempty"`
|
|
ConcurrentInstanceCount int `json:"concurrent_instance_count,omitempty"`
|
|
}
|
|
|
|
// EndUserSummary describes the end user summary component of an Application.
|
|
type EndUserSummary struct {
|
|
ResponseTime float64 `json:"response_time,omitempty"`
|
|
Throughput float64 `json:"throughput,omitempty"`
|
|
ApdexTarget float64 `json:"apdex_target,omitempty"`
|
|
ApdexScore float64 `json:"apdex_score,omitempty"`
|
|
}
|
|
|
|
// Settings describe settings for an Application.
|
|
type Settings struct {
|
|
AppApdexThreshold float64 `json:"app_apdex_threshold,omitempty"`
|
|
EndUserApdexThreshold float64 `json:"end_user_apdex_threshold,omitempty"`
|
|
EnableRealUserMonitoring bool `json:"enable_real_user_monitoring,omitempty"`
|
|
UseServerSideConfig bool `json:"use_server_side_config,omitempty"`
|
|
}
|
|
|
|
// Links list IDs associated with an Application.
|
|
type Links struct {
|
|
Servers []int `json:"servers,omitempty"`
|
|
ApplicationHosts []int `json:"application_hosts,omitempty"`
|
|
ApplicationInstances []int `json:"application_instances,omitempty"`
|
|
AlertPolicy int `json:"alert_policy,omitempty"`
|
|
}
|
|
|
|
// Application describes a New Relic Application.
|
|
type Application struct {
|
|
ID int `json:"id,omitempty"`
|
|
Name string `json:"name,omitempty"`
|
|
Language string `json:"language,omitempty"`
|
|
HealthStatus string `json:"health_status,omitempty"`
|
|
Reporting bool `json:"reporting,omitempty"`
|
|
LastReportedAt time.Time `json:"last_reported_at,omitempty"`
|
|
ApplicationSummary ApplicationSummary `json:"application_summary,omitempty"`
|
|
EndUserSummary EndUserSummary `json:"end_user_summary,omitempty"`
|
|
Settings Settings `json:"settings,omitempty"`
|
|
Links Links `json:"links,omitempty"`
|
|
}
|
|
|
|
// ApplicationFilter provides a means to filter requests through
|
|
// ApplicaitonOptions when calling GetApplications.
|
|
type ApplicationFilter struct {
|
|
Name string
|
|
Host string
|
|
IDs []int
|
|
Language string
|
|
}
|
|
|
|
// ApplicationOptions provides a means to filter results when calling
|
|
// GetApplicaitons.
|
|
type ApplicationOptions struct {
|
|
Filter ApplicationFilter
|
|
Page int
|
|
}
|
|
|
|
func (o *ApplicationOptions) String() string {
|
|
if o == nil {
|
|
return ""
|
|
}
|
|
return encodeGetParams(map[string]interface{}{
|
|
"filter[name]": o.Filter.Name,
|
|
"filter[host]": o.Filter.Host,
|
|
"filter[ids]": o.Filter.IDs,
|
|
"filter[language]": o.Filter.Language,
|
|
"page": o.Page,
|
|
})
|
|
}
|
|
|
|
// GetApplications returns a slice of New Relic Applications, optionally
|
|
// filtering by ApplicationOptions.
|
|
func (c *Client) GetApplications(options *ApplicationOptions) ([]Application, error) {
|
|
resp := &struct {
|
|
Applications []Application `json:"applications,omitempty"`
|
|
}{}
|
|
err := c.doGet("applications.json", options, resp)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return resp.Applications, nil
|
|
}
|
|
|
|
// GetApplication returns a single Application associated with a given ID.
|
|
func (c *Client) GetApplication(id int) (*Application, error) {
|
|
resp := &struct {
|
|
Application Application `json:"application,omitempty"`
|
|
}{}
|
|
path := "applications/" + strconv.Itoa(id) + ".json"
|
|
err := c.doGet(path, nil, resp)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return &resp.Application, nil
|
|
}
|