本文整理匯總了Golang中github.com/hashicorp/otto/ui.Ui類的典型用法代碼示例。如果您正苦於以下問題:Golang Ui類的具體用法?Golang Ui怎麽用?Golang Ui使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了Ui類的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: compileCallback
func (c *CompileCommand) compileCallback(ui ui.Ui) func(appfile.CompileEvent) {
return func(raw appfile.CompileEvent) {
switch e := raw.(type) {
case *appfile.CompileEventDep:
ui.Message(fmt.Sprintf(
"Fetching dependency: %s", e.Source))
case *appfile.CompileEventImport:
ui.Message(fmt.Sprintf(
"Fetching import: %s", e.Source))
}
}
}
示例2: Run
// Run runs the given command and streams all the output to the
// given UI. It also connects stdin properly so that input works as
// expected.
func Run(uiVal ui.Ui, cmd *exec.Cmd) error {
out_r, out_w := io.Pipe()
cmd.Stdin = os.Stdin
cmd.Stdout = out_w
cmd.Stderr = out_w
// Copy output to the UI until we can't.
output := false
uiDone := make(chan struct{})
go func() {
defer close(uiDone)
var buf [1024]byte
for {
n, err := out_r.Read(buf[:])
if n > 0 {
output = true
uiVal.Raw(string(buf[:n]))
}
// We just break on any error. io.EOF is not an error and
// is our true exit case, but any other error we don't really
// handle here. It probably means something went wrong
// somewhere else anyways.
if err != nil {
break
}
}
}()
// Run the command
log.Printf("[DEBUG] execDir: %s", cmd.Dir)
log.Printf("[DEBUG] exec: %s %s", cmd.Path, strings.Join(cmd.Args[1:], " "))
// Build a runnable command that we can log out to make things easier
// for debugging. This lets debuging devs just copy and paste the command.
logRunnableCommand(cmd)
// Run
err := Runner(cmd)
// Wait for all the output to finish
out_w.Close()
<-uiDone
if output {
// Output one extra newline to separate output from Otto. We only
// do this if there was any output to begin with.
uiVal.Message("")
}
// Return the output from the command
return err
}
示例3: VerifyCreds
func VerifyCreds(ui ui.Ui, publicKeyPath string) error {
found, err := HasKey(publicKeyPath)
if err != nil {
return SshAgentError(err)
}
if !found {
ok, _ := GuessAndLoadPrivateKey(
ui, publicKeyPath)
if ok {
ui.Message(
"A private key was found and loaded. Otto will now check\n" +
"the SSH Agent again and continue if the correct key is loaded")
found, err = HasKey(publicKeyPath)
if err != nil {
return SshAgentError(err)
}
}
}
if !found {
return SshAgentError(fmt.Errorf(
"You specified an SSH public key of: %q, but the private key from this\n"+
"keypair is not loaded the SSH Agent. To load it, run:\n\n"+
" ssh-add [PATH_TO_PRIVATE_KEY]",
publicKeyPath))
}
return nil
}
示例4: Run
// Run runs the given command and streams all the output to the
// given UI. It also connects stdin properly so that input works as
// expected.
func Run(uiVal ui.Ui, cmd *exec.Cmd) error {
out_r, out_w := io.Pipe()
cmd.Stdin = os.Stdin
cmd.Stdout = out_w
cmd.Stderr = out_w
// Copy output to the UI until we can't.
uiDone := make(chan struct{})
go func() {
defer close(uiDone)
var buf [1024]byte
for {
n, err := out_r.Read(buf[:])
if n > 0 {
uiVal.Raw(string(buf[:n]))
}
// We just break on any error. io.EOF is not an error and
// is our true exit case, but any other error we don't really
// handle here. It probably means something went wrong
// somewhere else anyways.
if err != nil {
break
}
}
}()
// Run the command
log.Printf("[DEBUG] execDir: %s", cmd.Dir)
log.Printf("[DEBUG] exec: %s %s", cmd.Path, strings.Join(cmd.Args[1:], " "))
err := cmd.Run()
// Wait for all the output to finish
out_w.Close()
<-uiDone
// Output one extra newline to separate output from Otto
uiVal.Message("")
// Return the output from the command
return err
}
示例5: guessAndLoadPrivateKey
// guessAndLoadPrivateKey takes a path to a public key and determines if a
// private key exists by just stripping ".pub" from the end of it. if so,
// it attempts to load that key into the agent.
func guessAndLoadPrivateKey(ui ui.Ui, pubKeyPath string) (bool, error) {
fullPath, err := homedir.Expand(pubKeyPath)
if err != nil {
return false, err
}
if !strings.HasSuffix(fullPath, ".pub") {
return false, fmt.Errorf("No .pub suffix, cannot guess path.")
}
privKeyGuess := strings.TrimSuffix(fullPath, ".pub")
if _, err := os.Stat(privKeyGuess); os.IsNotExist(err) {
return false, fmt.Errorf("No file at guessed path.")
}
ui.Header("Loading key into SSH Agent")
ui.Message(fmt.Sprintf(
"The key you provided (%s) was not found in your SSH Agent.", pubKeyPath))
ui.Message(fmt.Sprintf(
"However, Otto found a private key here: %s", privKeyGuess))
ui.Message(fmt.Sprintf(
"Automatically running 'ssh-add %s'.", privKeyGuess))
ui.Message("If your SSH key has a passphrase, you will be prompted for it.")
ui.Message("")
if err := sshagent.Add(ui, privKeyGuess); err != nil {
return false, err
}
return true, nil
}
示例6: guestAndLoadPrivateKey
// guestAndLoadPrivateKey 獲得private key路徑,隻是依賴判斷去除.pub部分的內容
// 如果存在則直接裝在agent
func guestAndLoadPrivateKey(ui ui.Ui, pubKeyPath string) (bool, error) {
fullPath, err := homedir.Expand(pubKeyPath)
if err != nil {
return false, err
}
if !strings.HasSuffix(fullPath, ".pub") {
return false, fmt.Errorf("沒有找到.pub後綴的文件")
}
privKeyGuess := strings.TrimSuffix(fullPath, ".pub")
if _, err := os.Stat(privKeyGuess); os.IsNotExist(err) {
return false, fmt.Errorf("文件不存在!")
}
ui.Header("裝載key到SSH Agent")
ui.Message(fmt.Sprintf(
"在SSH Agent中沒有你提供的key (%s)", pubKeyPath))
ui.Message(fmt.Sprintf(
"然而,Otto在這裏:%s 找的了一個private key", privKeyGuess))
ui.Message(fmt.Sprintf(
"自動運行'ssh-add %s'.", privKeyGuess))
ui.Message("如果你的SSH key有密碼,你會看到如下提示")
ui.Message("")
if err := sshagent.Add(ui, privKeyGuess); err != nil {
return false, err
}
return true, nil
}