本文整理匯總了Golang中github.com/pritunl/pritunl-client-electron/service/event.Event.Init方法的典型用法代碼示例。如果您正苦於以下問題:Golang Event.Init方法的具體用法?Golang Event.Init怎麽用?Golang Event.Init使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/pritunl/pritunl-client-electron/service/event.Event
的用法示例。
在下文中一共展示了Event.Init方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: parseLine
func (p *Profile) parseLine(line string) {
p.pushOutput(string(line))
if strings.Contains(line, "Initialization Sequence Completed") {
p.Status = "connected"
p.update()
} else if strings.Contains(line, "Inactivity timeout") {
p.Status = "reconnecting"
p.update()
} else if strings.Contains(line, "AUTH_FAILED") || strings.Contains(
line, "auth-failure") {
evt := event.Event{
Type: "auto_error",
Data: p,
}
evt.Init()
} else if strings.Contains(line, "link remote:") {
sIndex := strings.LastIndex(line, "]") + 1
eIndex := strings.LastIndex(line, ":")
p.ServerAddr = line[sIndex:eIndex]
p.update()
} else if strings.Contains(line, "network/local/netmask") {
eIndex := strings.LastIndex(line, "/")
line = line[:eIndex]
sIndex := strings.LastIndex(line, "/") + 1
p.ClientAddr = line[sIndex:]
p.update()
} else if strings.Contains(line, "ifconfig") && strings.Contains(
line, "netmask") {
sIndex := strings.Index(line, "ifconfig") + 9
eIndex := strings.Index(line, "netmask")
line = line[sIndex:eIndex]
split := strings.Split(line, " ")
if len(split) > 2 {
p.ClientAddr = split[1]
p.update()
}
} else if strings.Contains(line, "ip addr add dev") {
sIndex := strings.Index(line, "ip addr add dev") + 16
eIndex := strings.Index(line, "broadcast")
line = line[sIndex:eIndex]
split := strings.Split(line, " ")
if len(split) > 1 {
split := strings.Split(split[1], "/")
if len(split) > 1 {
p.ClientAddr = split[0]
p.update()
}
}
}
}
示例2: update
func (p *Profile) update() {
evt := event.Event{
Type: "update",
Data: p,
}
evt.Init()
status := GetStatus()
if status {
evt := event.Event{
Type: "connected",
}
evt.Init()
} else {
evt := event.Event{
Type: "disconnected",
}
evt.Init()
}
}
示例3: Start
//.........這裏部分代碼省略.........
if authPath != "" {
args = append(args, "--auth-user-pass", authPath)
}
cmd := exec.Command(getOpenvpnPath(), args...)
p.cmd = cmd
stdout, err := cmd.StdoutPipe()
if err != nil {
err = &ExecError{
errors.Wrap(err, "profile: Failed to get stdout"),
}
p.clearStatus(start)
return
}
stderr, err := cmd.StderrPipe()
if err != nil {
err = &ExecError{
errors.Wrap(err, "profile: Failed to get stderr"),
}
p.clearStatus(start)
return
}
go func() {
out := bufio.NewReader(stdout)
for {
line, _, err := out.ReadLine()
if err != nil {
if err != io.EOF {
err = &ExecError{
errors.Wrap(err, "profile: Failed to read stdout"),
}
logrus.WithFields(logrus.Fields{
"error": err,
}).Error("profile: Stdout error")
}
return
}
p.parseLine(string(line))
}
}()
go func() {
out := bufio.NewReader(stderr)
for {
line, _, err := out.ReadLine()
if err != nil {
if err != io.EOF {
err = &ExecError{
errors.Wrap(err, "profile: Failed to read stderr"),
}
logrus.WithFields(logrus.Fields{
"error": err,
}).Error("profile: Stderr error")
}
return
}
p.parseLine(string(line))
}
}()
err = cmd.Start()
if err != nil {
err = &ExecError{
errors.Wrap(err, "profile: Failed to start openvpn"),
}
p.clearStatus(start)
return
}
running := true
go func() {
cmd.Wait()
running = false
p.clearStatus(start)
delete(Profiles, p.Id)
}()
if timeout {
go func() {
time.Sleep(connTimeout)
if p.Status != "connected" && running {
cmd.Process.Kill()
evt := event.Event{
Type: "timeout_error",
Data: p,
}
evt.Init()
}
}()
}
return
}
示例4: Start
//.........這裏部分代碼省略.........
if authPath != "" {
args = append(args, "--auth-user-pass", authPath)
}
cmd := exec.Command(getOpenvpnPath(), args...)
p.cmd = cmd
stdout, err := cmd.StdoutPipe()
if err != nil {
err = &ExecError{
errors.Wrap(err, "profile: Failed to get stdout"),
}
p.clearStatus(start)
return
}
stderr, err := cmd.StderrPipe()
if err != nil {
err = &ExecError{
errors.Wrap(err, "profile: Failed to get stderr"),
}
p.clearStatus(start)
return
}
go func() {
out := bufio.NewReader(stdout)
for {
line, _, err := out.ReadLine()
if err != nil {
if err != io.EOF {
err = &ExecError{
errors.Wrap(err, "profile: Failed to read stdout"),
}
logrus.WithFields(logrus.Fields{
"error": err,
}).Error("profile: Stdout error")
}
return
}
p.parseLine(string(line))
}
}()
go func() {
out := bufio.NewReader(stderr)
for {
line, _, err := out.ReadLine()
if err != nil {
if err != io.EOF {
err = &ExecError{
errors.Wrap(err, "profile: Failed to read stderr"),
}
logrus.WithFields(logrus.Fields{
"error": err,
}).Error("profile: Stderr error")
}
return
}
p.parseLine(string(line))
}
}()
err = cmd.Start()
if err != nil {
err = &ExecError{
errors.Wrap(err, "profile: Failed to start openvpn"),
}
p.clearStatus(start)
return
}
running := true
go func() {
cmd.Wait()
running = false
p.clearStatus(start)
delete(Profiles, p.Id)
}()
if timeout {
go func() {
time.Sleep(connTimeout)
if p.Status != "connected" && running {
cmd.Process.Kill()
evt := event.Event{
Type: "timeout_error",
Data: p,
}
evt.Init()
}
}()
}
return
}