detect that xpra server is ready for connections, inform oz-daemon

networking
brl 10 years ago
parent 796d39c197
commit f3825e2d06

@ -117,7 +117,9 @@ func (sbox *Sandbox) logMessages() {
scanner := bufio.NewScanner(sbox.stderr)
for scanner.Scan() {
line := scanner.Text()
if len(line) > 1 {
if line == "XPRA READY" {
sbox.daemon.log.Info("Xpra server is ready for connection")
} else if len(line) > 1 {
sbox.logLine(line)
}
}

@ -13,7 +13,9 @@ import (
"github.com/subgraph/oz/xpra"
"os/user"
"strconv"
"path"
"io"
"bufio"
"strings"
)
const profileDirectory = "/var/lib/oz/cells.d"
@ -42,6 +44,7 @@ func createLogger() *logging.Logger {
}
var allowRootShell = false
var logXpra = true
func Main() {
st := parseArgs()
@ -138,16 +141,13 @@ func (st *initState) startXpraServer() {
st.log.Warning("Xpra work directory not set")
return
}
logpath := path.Join(workdir, "xpra-server.out")
f,err := os.Create(logpath)
xpra := xpra.NewServer(&st.profile.XServer, uint64(st.display), workdir)
p,err := xpra.Process.StderrPipe()
if err != nil {
st.log.Warning("Failed to open xpra logfile (%s): %v", logpath, err)
return
st.log.Warning("Error creating stderr pipe for xpra output: %v", err)
os.Exit(1)
}
defer f.Close()
xpra := xpra.NewServer(&st.profile.XServer, uint64(st.display), workdir)
xpra.Process.Stdout = f
xpra.Process.Stderr = f
go st.readXpraOutput(p)
xpra.Process.Env = []string{
"HOME="+ st.user.HomeDir,
}
@ -162,6 +162,25 @@ func (st *initState) startXpraServer() {
}
}
func (st *initState) readXpraOutput(r io.ReadCloser) {
sc := bufio.NewScanner(r)
for sc.Scan() {
line := sc.Text()
if len(line) > 0 {
if strings.Contains(line, "xpra is ready.") {
os.Stderr.WriteString("XPRA READY\n")
if !logXpra {
r.Close()
return
}
}
if logXpra {
st.log.Debug("(xpra) %s", line)
}
}
}
}
func loadProfile(name string) (*oz.Profile, error) {
ps,err := oz.LoadProfiles(profileDirectory)
if err != nil {

Loading…
Cancel
Save