本文整理匯總了Golang中github.com/wercker/wercker/util.RootLogger函數的典型用法代碼示例。如果您正苦於以下問題:Golang RootLogger函數的具體用法?Golang RootLogger怎麽用?Golang RootLogger使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了RootLogger函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: Exit
// Exit with either an error or a panic
func (s *SoftExit) Exit(v ...interface{}) error {
if s.options.Debug {
// Clearly this will cause it's own exit if it gets called.
util.RootLogger().Panicln(v...)
}
util.RootLogger().Errorln(v...)
return fmt.Errorf("Exiting.")
}
示例2: getServerVersion
func getServerVersion(channel string) (*util.Versions, error) {
logger := util.RootLogger().WithField("Logger", "getServerVersion")
url := fmt.Sprintf("https://s3.amazonaws.com/downloads.wercker.com/cli/%s/version.json", channel)
nv := &util.Versions{}
client := &http.Client{}
req, err := http.NewRequest("GET", url, nil)
if err != nil {
logger.WithField("Error", err).Debug("Unable to create request to version endpoint")
return nil, err
}
res, err := client.Do(req)
if err != nil {
logger.WithField("Error", err).Debug("Unable to execute HTTP request to version endpoint")
return nil, err
}
body, err := ioutil.ReadAll(res.Body)
if err != nil {
logger.WithField("Error", err).Debug("Unable to read response body")
return nil, err
}
err = json.Unmarshal(body, nv)
if err != nil {
logger.WithField("Error", err).Debug("Unable to unmarshal versions")
return nil, err
}
return nv, nil
}
示例3: getYml
// TODO(mies): maybe move to util.go at some point
func getYml(detected string, options *core.DetectOptions) {
logger := util.RootLogger().WithField("Logger", "Main")
yml := "wercker.yml"
if _, err := os.Stat(yml); err == nil {
logger.Println(yml, "already exists. Do you want to overwrite? (yes/no)")
if !askForConfirmation() {
logger.Println("Exiting...")
os.Exit(1)
}
}
url := fmt.Sprintf("%s/api/v2/yml/%s", options.BaseURL, detected)
res, err := http.Get(url)
if err != nil {
logger.WithField("Error", err).Error("Unable to reach wercker API")
os.Exit(1)
}
defer res.Body.Close()
body, err := ioutil.ReadAll(res.Body)
if err != nil {
logger.WithField("Error", err).Error("Unable to read response")
}
err = ioutil.WriteFile("wercker.yml", body, 0644)
if err != nil {
logger.WithField("Error", err).Error("Unable to write wercker.yml file")
}
}
示例4: NewStep
func NewStep(config *core.StepConfig, options *core.PipelineOptions, dockerOptions *DockerOptions) (core.Step, error) {
// NOTE(termie) Special case steps are special
if config.ID == "internal/docker-push" {
return NewDockerPushStep(config, options, dockerOptions)
}
if config.ID == "internal/docker-scratch-push" {
return NewDockerScratchPushStep(config, options, dockerOptions)
}
if config.ID == "internal/store-container" {
return NewStoreContainerStep(config, options, dockerOptions)
}
if strings.HasPrefix(config.ID, "internal/") {
if !options.EnableDevSteps {
util.RootLogger().Warnln("Ignoring dev step:", config.ID)
return nil, nil
}
}
if options.EnableDevSteps {
if config.ID == "internal/watch" {
return NewWatchStep(config, options, dockerOptions)
}
if config.ID == "internal/shell" {
return NewShellStep(config, options, dockerOptions)
}
}
return NewDockerStep(config, options, dockerOptions)
}
示例5: DumpOptions
// DumpOptions prints out a sorted list of options
func DumpOptions(options interface{}, indent ...string) {
indent = append(indent, " ")
s := reflect.ValueOf(options).Elem()
typeOfT := s.Type()
names := []string{}
for i := 0; i < s.NumField(); i++ {
// f := s.Field(i)
fieldName := typeOfT.Field(i).Name
if fieldName != "HostEnv" {
names = append(names, fieldName)
}
}
sort.Strings(names)
logger := util.RootLogger().WithField("Logger", "Options")
for _, name := range names {
r := reflect.ValueOf(options)
f := reflect.Indirect(r).FieldByName(name)
if strings.HasSuffix(name, "Options") {
if len(indent) > 1 && name == "GlobalOptions" {
continue
}
logger.Debugln(fmt.Sprintf("%s%s %s", strings.Join(indent, ""), name, f.Type()))
DumpOptions(f.Interface(), indent...)
} else {
logger.Debugln(fmt.Sprintf("%s%s %s = %v", strings.Join(indent, ""), name, f.Type(), f.Interface()))
}
}
}
示例6: NewDeployOptions
// NewDeployOptions constructor
func NewDeployOptions(c util.Settings, e *util.Environment) (*PipelineOptions, error) {
pipelineOpts, err := NewPipelineOptions(c, e)
if err != nil {
return nil, err
}
// default to last build output if none defined
target, _ := c.String("target")
if target == "" {
found, err := util.Exists("./.wercker/latest/output")
if err == nil && found {
util.RootLogger().Println("No target specified, using recent build output.")
pipelineOpts.ProjectPath, _ = filepath.Abs("./.wercker/latest/output")
}
}
// if the deploy target path does not have a wercker.yml, use the current one
werckerYml, _ := c.String("wercker-yml")
if werckerYml == "" {
found, _ := util.Exists(filepath.Join(pipelineOpts.ProjectPath, "wercker.yml"))
if !found {
pipelineOpts.WerckerYml = "./wercker.yml"
}
}
if pipelineOpts.RunID == "" {
pipelineOpts.RunID = uuid.NewRandom().String()
}
return pipelineOpts, nil
}
示例7: normalizeRegistry
func normalizeRegistry(address string) string {
logger := util.RootLogger().WithField("Logger", "Docker")
if address == "" {
logger.Debugln("No registry address provided, using https://registry.hub.docker.com")
return "https://registry.hub.docker.com/v1/"
}
parsed, err := url.Parse(address)
if err != nil {
logger.Errorln("Registry address is invalid, this will probably fail:", address)
return address
}
if parsed.Scheme != "https" {
logger.Warnln("Registry address is expected to begin with 'https://', forcing it to use https")
parsed.Scheme = "https"
address = parsed.String()
}
if strings.HasSuffix(address, "/") {
address = address[:len(address)-1]
}
parts := strings.Split(address, "/")
possiblyAPIVersionStr := parts[len(parts)-1]
// we only support v1, so...
if possiblyAPIVersionStr == "v2" {
logger.Warnln("Registry API v2 not supported, using v1")
newParts := append(parts[:len(parts)-1], "v1")
address = strings.Join(newParts, "/")
} else if possiblyAPIVersionStr != "v1" {
newParts := append(parts, "v1")
address = strings.Join(newParts, "/")
}
return address + "/"
}
示例8: NewDockerPushStep
// NewDockerPushStep is a special step for doing docker pushes
func NewDockerPushStep(stepConfig *core.StepConfig, options *core.PipelineOptions, dockerOptions *DockerOptions) (*DockerPushStep, error) {
name := "docker-push"
displayName := "docker push"
if stepConfig.Name != "" {
displayName = stepConfig.Name
}
// Add a random number to the name to prevent collisions on disk
stepSafeID := fmt.Sprintf("%s-%s", name, uuid.NewRandom().String())
baseStep := core.NewBaseStep(core.BaseStepOptions{
DisplayName: displayName,
Env: &util.Environment{},
ID: name,
Name: name,
Owner: "wercker",
SafeID: stepSafeID,
Version: util.Version(),
})
return &DockerPushStep{
BaseStep: baseStep,
data: stepConfig.Data,
logger: util.RootLogger().WithField("Logger", "DockerPushStep"),
options: options,
dockerOptions: dockerOptions,
}, nil
}
示例9: NewDockerClient
// NewDockerClient based on options and env
func NewDockerClient(options *DockerOptions) (*DockerClient, error) {
dockerHost := options.DockerHost
tlsVerify := options.DockerTLSVerify
logger := util.RootLogger().WithField("Logger", "Docker")
var (
client *docker.Client
err error
)
if tlsVerify == "1" {
// We're using TLS, let's locate our certs and such
// boot2docker puts its certs at...
dockerCertPath := options.DockerCertPath
// TODO(termie): maybe fast-fail if these don't exist?
cert := path.Join(dockerCertPath, fmt.Sprintf("cert.pem"))
ca := path.Join(dockerCertPath, fmt.Sprintf("ca.pem"))
key := path.Join(dockerCertPath, fmt.Sprintf("key.pem"))
client, err = docker.NewVersionnedTLSClient(dockerHost, cert, key, ca, "")
if err != nil {
return nil, err
}
} else {
client, err = docker.NewClient(dockerHost)
if err != nil {
return nil, err
}
}
return &DockerClient{Client: client, logger: logger}, nil
}
示例10: NewDockerFileCollector
// NewDockerFileCollector constructor
func NewDockerFileCollector(client *DockerClient, containerID string) *DockerFileCollector {
return &DockerFileCollector{
client: client,
containerID: containerID,
logger: util.RootLogger().WithField("Logger", "DockerFileCollector"),
}
}
示例11: NewDockerBox
// NewDockerBox from a name and other references
func NewDockerBox(boxConfig *core.BoxConfig, options *core.PipelineOptions, dockerOptions *DockerOptions) (*DockerBox, error) {
name := boxConfig.ID
if strings.Contains(name, "@") {
return nil, fmt.Errorf("Invalid box name, '@' is not allowed in docker repositories.")
}
parts := strings.Split(name, ":")
repository := parts[0]
tag := "latest"
if len(parts) > 1 {
tag = parts[1]
}
if boxConfig.Tag != "" {
tag = boxConfig.Tag
}
name = fmt.Sprintf("%s:%s", repository, tag)
repoParts := strings.Split(repository, "/")
shortName := repository
if len(repoParts) > 1 {
shortName = repoParts[len(repoParts)-1]
}
networkDisabled := false
cmd := boxConfig.Cmd
if cmd == "" {
cmd = "/bin/bash"
}
entrypoint := boxConfig.Entrypoint
logger := util.RootLogger().WithFields(util.LogFields{
"Logger": "Box",
"Name": name,
"ShortName": shortName,
})
client, err := NewDockerClient(dockerOptions)
if err != nil {
return nil, err
}
return &DockerBox{
Name: name,
ShortName: shortName,
client: client,
config: boxConfig,
options: options,
dockerOptions: dockerOptions,
repository: repository,
tag: tag,
networkDisabled: networkDisabled,
logger: logger,
cmd: cmd,
entrypoint: entrypoint,
volumes: []string{},
}, nil
}
示例12: NewDockerTransport
// NewDockerTransport constructor
func NewDockerTransport(options *core.PipelineOptions, dockerOptions *DockerOptions, containerID string) (core.Transport, error) {
client, err := NewDockerClient(dockerOptions)
if err != nil {
return nil, err
}
logger := util.RootLogger().WithField("Logger", "DockerTransport")
return &DockerTransport{options: options, client: client, containerID: containerID, logger: logger}, nil
}
示例13: NewExternalServiceBox
// NewExternalServiceBox gives us an ExternalServiceBox from config
func NewExternalServiceBox(boxConfig *core.BoxConfig, options *core.PipelineOptions, dockerOptions *DockerOptions, builder Builder) (*ExternalServiceBox, error) {
logger := util.RootLogger().WithField("Logger", "ExternalService")
box := &DockerBox{options: options, dockerOptions: dockerOptions}
return &ExternalServiceBox{
InternalServiceBox: &InternalServiceBox{DockerBox: box, logger: logger},
externalConfig: boxConfig,
builder: builder,
}, nil
}
示例14: NewSession
// NewSession returns a new interactive session to a container.
func NewSession(options *PipelineOptions, transport Transport) *Session {
logger := util.RootLogger().WithField("Logger", "Session")
return &Session{
options: options,
transport: transport,
logsHidden: false,
logger: logger,
}
}
示例15: AskForUpdate
// AskForUpdate asks users if they want to update and returns the answer
func AskForUpdate() bool {
fmt.Println("Would you like update? [yN]")
reader := bufio.NewReader(os.Stdin)
line, err := reader.ReadString('\n')
if err != nil {
util.RootLogger().Errorln("Problem reading answer", err)
return false
}
return strings.HasPrefix(strings.ToLower(line), "y")
}