]> arthur.barton.de Git - bup.git/blob - cmd/daemon-cmd.py
cmd/daemon: correctly report socket binding/listening errors.
[bup.git] / cmd / daemon-cmd.py
1 #!/usr/bin/env python
2 import sys, getopt, socket, subprocess
3 from bup import options, path
4 from bup.helpers import *
5
6 optspec = """
7 bup daemon [options...]
8 --
9 l,listen  ip address to listen on, defaults to *
10 p,port    port to listen on, defaults to 1982
11 """
12 o = options.Options(optspec, optfunc=getopt.getopt)
13 (opt, flags, extra) = o.parse(sys.argv[1:])
14 if extra:
15     o.fatal('no arguments expected')
16
17 host = opt.listen
18 port = opt.port and int(opt.port) or 1982
19
20 import socket
21 import sys
22
23 socks = []
24 e = None
25 for res in socket.getaddrinfo(host, port, socket.AF_UNSPEC,
26                               socket.SOCK_STREAM, 0, socket.AI_PASSIVE):
27     af, socktype, proto, canonname, sa = res
28     try:
29         s = socket.socket(af, socktype, proto)
30     except socket.error, e:
31         continue
32     try:
33         if af == socket.AF_INET6:
34             log("bup daemon: listening on [%s]:%s\n" % sa[:2])
35         else:
36             log("bup daemon: listening on %s:%s\n" % sa[:2])
37         s.bind(sa)
38         s.listen(1)
39     except socket.error, e:
40         s.close()
41         continue
42     socks.append(s)
43
44 if not socks:
45     log('bup daemon: listen socket: %s\n' % e.args[1])
46     sys.exit(1)
47
48 try:
49     while True:
50         [rl,wl,xl] = select.select(socks, [], [], 60)
51         for l in rl:
52             s, src = l.accept()
53             log("Socket accepted connection from %s\n" % (src,))
54             sp = subprocess.Popen([path.exe(), 'mux', 'server'],
55                                   stdin=os.dup(s.fileno()), stdout=os.dup(s.fileno()))
56             s.close()
57 finally:
58     for l in socks:
59         l.shutdown(socket.SHUT_RDWR)
60         l.close()
61
62 debug1("bup daemon: done")