本文整理匯總了Golang中github.com/coreos/fleet/third_party/github.com/codegangsta/cli.Context類的典型用法代碼示例。如果您正苦於以下問題:Golang Context類的具體用法?Golang Context怎麽用?Golang Context使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
在下文中一共展示了Context類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: verifyUnitAction
func verifyUnitAction(c *cli.Context) {
r := getRegistry()
if len(c.Args()) != 1 {
fmt.Println("One unit file must be provided.")
syscall.Exit(1)
}
name := path.Base(c.Args()[0])
payload := r.GetPayload(name)
if payload == nil {
fmt.Println("Job not found.")
syscall.Exit(1)
}
sv, err := sign.NewSignatureVerifierFromSSHAgent()
if err != nil {
fmt.Println("Fail to create SignatureVerifier:", err)
return
}
s := r.GetSignatureSetOfPayload(name)
ok, err := sv.VerifyPayload(payload, s)
if !ok || err != nil {
fmt.Printf("Check of payload %s failed: %v\n", payload.Name, err)
return
}
fmt.Printf("Succeed to verify job(%s).\n", payload.Name)
}
示例2: listMachinesAction
func listMachinesAction(c *cli.Context) {
if !c.Bool("no-legend") {
fmt.Fprintln(out, "MACHINE\tIP\tMETADATA")
}
full := c.Bool("full")
for _, m := range registryCtl.GetActiveMachines() {
mach := machineBootIDLegend(m, full)
ip := m.PublicIP
if len(ip) == 0 {
ip = "-"
}
metadata := "-"
if len(m.Metadata) != 0 {
metadata = formatMetadata(m.Metadata)
}
fmt.Fprintf(out, "%s\t%s\t%s\n", mach, ip, metadata)
}
out.Flush()
}
示例3: listMachinesAction
func listMachinesAction(c *cli.Context) {
r := getRegistry(c)
if !c.Bool("no-legend") {
fmt.Fprintln(out, "MACHINE\tIP\tMETADATA")
}
full := c.Bool("full")
for _, m := range r.GetActiveMachines() {
mach := m.BootId
if !full {
mach = ellipsize(mach, 8)
}
ip := m.PublicIP
if len(ip) == 0 {
ip = "-"
}
metadata := "-"
if len(m.Metadata) != 0 {
metadata = formatMetadata(m.Metadata)
}
fmt.Fprintf(out, "%s\t%s\t%s\n", mach, ip, metadata)
}
out.Flush()
}
示例4: getTunnelFlag
func getTunnelFlag(context *cli.Context) string {
tun := context.GlobalString("tunnel")
if tun != "" && !strings.Contains(tun, ":") {
tun += ":22"
}
return tun
}
示例5: listUnitsAction
func listUnitsAction(c *cli.Context) {
r := getRegistry(c)
if !c.Bool("no-legend") {
fmt.Fprintln(out, "UNIT\tLOAD\tACTIVE\tSUB\tDESC\tMACHINE")
}
names := make(map[string]bool, 0)
sortable := make(sort.StringSlice, 0)
for _, p := range r.GetAllPayloads() {
if _, ok := names[p.Name]; !ok {
names[p.Name] = true
sortable = append(sortable, p.Name)
}
}
for _, j := range r.GetAllJobs() {
if _, ok := names[j.Name]; !ok {
names[j.Name] = true
sortable = append(sortable, j.Name)
}
}
sortable.Sort()
full := c.Bool("full")
for _, name := range sortable {
state := r.GetJobState(name)
printJobState(name, state, full)
}
out.Flush()
}
示例6: getRegistry
func getRegistry(context *cli.Context) *registry.Registry {
tun := getTunnelFlag(context)
endpoint := context.GlobalString("endpoint")
machines := []string{endpoint}
client := etcd.NewClient(machines)
if tun != "" {
sshClient, err := ssh.NewSSHClient("core", tun)
if err != nil {
panic(err)
}
dial := func(network, addr string) (net.Conn, error) {
tcpaddr, err := net.ResolveTCPAddr(network, addr)
if err != nil {
return nil, err
}
return sshClient.DialTCP(network, nil, tcpaddr)
}
tr := http.Transport{
Dial: dial,
TLSClientConfig: &tls.Config{
InsecureSkipVerify: true,
},
}
client.SetTransport(&tr)
}
return registry.New(client)
}
示例7: stopUnitAction
func stopUnitAction(c *cli.Context) {
r := getRegistry()
for _, v := range c.Args() {
name := path.Base(v)
r.StopJob(name)
}
}
示例8: destroyUnitsAction
func destroyUnitsAction(c *cli.Context) {
for _, v := range c.Args() {
name := path.Base(v)
registryCtl.StopJob(name)
registryCtl.DestroyPayload(name)
registryCtl.DestroySignatureSetOfPayload(name)
}
}
示例9: destroyUnitsAction
func destroyUnitsAction(c *cli.Context) {
r := getRegistry()
for _, v := range c.Args() {
name := path.Base(v)
r.StopJob(name)
r.DestroyPayload(name)
}
}
示例10: statusUnitsAction
func statusUnitsAction(c *cli.Context) {
for i, v := range c.Args() {
// This extra newline here to match systemctl status output
if i != 0 {
fmt.Printf("\n")
}
name := path.Base(v)
printUnitStatus(c, name)
}
}
示例11: journalAction
func journalAction(c *cli.Context) {
if len(c.Args()) != 1 {
fmt.Println("One unit file must be provided.")
syscall.Exit(1)
}
jobName := c.Args()[0]
js := registryCtl.GetJobState(jobName)
if js == nil {
fmt.Printf("%s does not appear to be running\n", jobName)
syscall.Exit(1)
}
cmd := fmt.Sprintf("journalctl -u %s --no-pager -l -n %d", jobName, c.Int("lines"))
if c.Bool("follow") {
cmd += " -f"
}
// check if the job is running on this machine
var channel *ssh.Channel
var err error
if machine.IsLocalMachineState(js.MachineState) {
channel = runLocalCommand(cmd)
} else {
channel, err = runRemoteCommand(cmd, js.MachineState.PublicIP)
if err != nil {
log.Fatalf("Unable to run command over SSH: %v", err)
}
}
readSSHChannel(channel)
}
示例12: sshAction
func sshAction(c *cli.Context) {
unit := c.String("unit")
machine := c.String("machine")
if unit != "" && machine != "" {
log.Fatal("Both flags, machine and unit provided, please specify only one")
}
args := c.Args()
var err error
var addr string
switch {
case machine != "":
addr, _ = findAddressInMachineList(machine)
case unit != "":
addr, _ = findAddressInRunningUnits(unit)
default:
addr, err = globalMachineLookup(args)
args = args[1:]
}
if err != nil {
log.Fatal(err)
}
if addr == "" {
log.Fatalf("Requested machine could not be found")
}
agentForwarding := c.Bool("agent")
var sshClient *ssh.SSHForwardingClient
if tun := getTunnelFlag(); tun != "" {
sshClient, err = ssh.NewTunnelledSSHClient("core", tun, addr, getChecker(), agentForwarding)
} else {
sshClient, err = ssh.NewSSHClient("core", addr, getChecker(), agentForwarding)
}
if err != nil {
log.Fatal(err.Error())
return
}
defer sshClient.Close()
if len(args) > 0 {
cmd := strings.Join(args, " ")
channel, err := ssh.Execute(sshClient, cmd)
if err != nil {
log.Fatalf("Unable to run command over SSH: %s", err.Error())
}
readSSHChannel(channel)
} else {
if err := ssh.Shell(sshClient); err != nil {
log.Fatalf(err.Error())
}
}
}
示例13: printUnitAction
func printUnitAction(c *cli.Context) {
if len(c.Args()) != 1 {
fmt.Println("One unit file must be provided.")
syscall.Exit(1)
}
name := path.Base(c.Args()[0])
payload := registryCtl.GetPayload(name)
if payload == nil {
fmt.Println("Job not found.")
syscall.Exit(1)
}
fmt.Print(payload.Unit.String())
}
示例14: listUnitsAction
func listUnitsAction(c *cli.Context) {
if !c.Bool("no-legend") {
fmt.Fprintln(out, "UNIT\tLOAD\tACTIVE\tSUB\tDESC\tMACHINE")
}
names, sortable := findAllUnits()
full := c.Bool("full")
for _, name := range sortable {
state := registryCtl.GetJobState(name)
description := names[name]
printJobState(name, description, state, full)
}
out.Flush()
}
示例15: journalAction
func journalAction(c *cli.Context) {
if len(c.Args()) != 1 {
fmt.Println("One unit file must be provided.")
syscall.Exit(1)
}
jobName := c.Args()[0]
js := registryCtl.GetJobState(jobName)
if js == nil {
fmt.Printf("%s does not appear to be running\n", jobName)
syscall.Exit(1)
}
addr := fmt.Sprintf("%s:22", js.MachineState.PublicIP)
var err error
var sshClient *gossh.ClientConn
if tun := getTunnelFlag(); tun != "" {
sshClient, err = ssh.NewTunnelledSSHClient("core", tun, addr)
} else {
sshClient, err = ssh.NewSSHClient("core", addr)
}
if err != nil {
log.Fatal(err.Error())
}
defer sshClient.Close()
cmd := fmt.Sprintf("journalctl -u %s --no-pager -l -n %d", jobName, c.Int("lines"))
if c.Bool("follow") {
cmd += " -f"
}
stdout, err := ssh.Execute(sshClient, cmd)
if err != nil {
log.Fatalf("Unable to run command over SSH: %s", err.Error())
}
for true {
bytes, prefix, err := stdout.ReadLine()
if err != nil {
break
}
fmt.Print(string(bytes))
if !prefix {
fmt.Print("\n")
}
}
}