mirror of
https://github.com/taigrr/wtf
synced 2025-01-18 04:03:14 -08:00
'apiKey' is one that people are likely to spell wrong in their configs as 'apikey'. Given that there's no sanity-checking around required config values yet, and a missing API key can cause silent failures in some modules, be liberal in accepting spelling.
32 lines
882 B
Go
32 lines
882 B
Go
package newrelic
|
|
|
|
import (
|
|
"os"
|
|
|
|
"github.com/olebedev/config"
|
|
"github.com/wtfutil/wtf/cfg"
|
|
)
|
|
|
|
const defaultTitle = "NewRelic"
|
|
|
|
type Settings struct {
|
|
common *cfg.Common
|
|
|
|
apiKey string `help:"Your New Relic API token."`
|
|
applicationID int `help:"The integer ID of the New Relic application you wish to report on."`
|
|
deployCount int `help:"The number of past deploys to display on screen." optional:"true"`
|
|
}
|
|
|
|
func NewSettingsFromYAML(name string, ymlConfig *config.Config, globalConfig *config.Config) *Settings {
|
|
|
|
settings := Settings{
|
|
common: cfg.NewCommonSettingsFromModule(name, defaultTitle, ymlConfig, globalConfig),
|
|
|
|
apiKey: ymlConfig.UString("apiKey", ymlConfig.UString("apikey", os.Getenv("WTF_NEW_RELIC_API_KEY"))),
|
|
applicationID: ymlConfig.UInt("applicationID"),
|
|
deployCount: ymlConfig.UInt("deployCount", 5),
|
|
}
|
|
|
|
return &settings
|
|
}
|