Statistics
| Branch: | Tag: | Revision:

root / vncauthproxy / client.py @ 0b74ef50

History | View | Annotate | Download (5 kB)

1 66d17b40 Apollon Oikonomopoulos
#!/usr/bin/env python
2 0c251ab5 Apollon Oikonomopoulos
#
3 7183f55d Faidon Liambotis
# Copyright (c) 2010-2011 Greek Research and Technology Network S.A.
4 0c251ab5 Apollon Oikonomopoulos
#
5 0c251ab5 Apollon Oikonomopoulos
# This program is free software; you can redistribute it and/or modify
6 0c251ab5 Apollon Oikonomopoulos
# it under the terms of the GNU General Public License as published by
7 0c251ab5 Apollon Oikonomopoulos
# the Free Software Foundation; either version 2 of the License, or
8 0c251ab5 Apollon Oikonomopoulos
# (at your option) any later version.
9 0c251ab5 Apollon Oikonomopoulos
#
10 0c251ab5 Apollon Oikonomopoulos
# This program is distributed in the hope that it will be useful, but
11 0c251ab5 Apollon Oikonomopoulos
# WITHOUT ANY WARRANTY; without even the implied warranty of
12 0c251ab5 Apollon Oikonomopoulos
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13 0c251ab5 Apollon Oikonomopoulos
# General Public License for more details.
14 0c251ab5 Apollon Oikonomopoulos
#
15 0c251ab5 Apollon Oikonomopoulos
# You should have received a copy of the GNU General Public License
16 0c251ab5 Apollon Oikonomopoulos
# along with this program; if not, write to the Free Software
17 0c251ab5 Apollon Oikonomopoulos
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
18 0c251ab5 Apollon Oikonomopoulos
# 02110-1301, USA.
19 66d17b40 Apollon Oikonomopoulos
20 66d17b40 Apollon Oikonomopoulos
import sys
21 66d17b40 Apollon Oikonomopoulos
import socket
22 0b74ef50 Stratos Psomadakis
import ssl
23 66d17b40 Apollon Oikonomopoulos
24 48b1400e Vangelis Koukis
try:
25 48b1400e Vangelis Koukis
    import simplejson as json
26 48b1400e Vangelis Koukis
except ImportError:
27 48b1400e Vangelis Koukis
    import json
28 48b1400e Vangelis Koukis
29 b129b0c0 Stratos Psomadakis
try:
30 b129b0c0 Stratos Psomadakis
    from gevent import sleep
31 b129b0c0 Stratos Psomadakis
except ImportError:
32 b129b0c0 Stratos Psomadakis
    import sleep
33 b129b0c0 Stratos Psomadakis
34 b129b0c0 Stratos Psomadakis
DEFAULT_SERVER_ADDRESS = '127.0.0.1'
35 b129b0c0 Stratos Psomadakis
DEFAULT_SERVER_PORT = 24999
36 66d17b40 Apollon Oikonomopoulos
37 31965126 Vangelis Koukis
38 03a592b9 Vangelis Koukis
def parse_arguments(args):
39 03a592b9 Vangelis Koukis
    from optparse import OptionParser
40 03a592b9 Vangelis Koukis
41 03a592b9 Vangelis Koukis
    parser = OptionParser()
42 b129b0c0 Stratos Psomadakis
    parser.add_option("--server", dest="server_address",
43 b129b0c0 Stratos Psomadakis
                      default=DEFAULT_SERVER_ADDRESS,
44 b129b0c0 Stratos Psomadakis
                      metavar="SERVER",
45 cf328b06 Stratos Psomadakis
                      help=("vncauthproxy server address"))
46 b129b0c0 Stratos Psomadakis
    parser.add_option("--server-port", dest="server_port",
47 b129b0c0 Stratos Psomadakis
                      default=DEFAULT_SERVER_PORT, type="int",
48 b129b0c0 Stratos Psomadakis
                      metavar="SERVER_PORT",
49 b129b0c0 Stratos Psomadakis
                      help=("vncauthproxy port"))
50 03a592b9 Vangelis Koukis
    parser.add_option('-s', dest="sport",
51 03a592b9 Vangelis Koukis
                      default=0, type="int",
52 03a592b9 Vangelis Koukis
                      metavar='PORT',
53 03a592b9 Vangelis Koukis
                      help=("Use source port PORT for incoming connections "
54 03a592b9 Vangelis Koukis
                            "(default: allocate a port automatically)"))
55 03a592b9 Vangelis Koukis
    parser.add_option("-d", "--dest",
56 03a592b9 Vangelis Koukis
                      default=None, dest="daddr",
57 03a592b9 Vangelis Koukis
                      metavar="HOST",
58 03a592b9 Vangelis Koukis
                      help="Proxy connection to destination host HOST")
59 03a592b9 Vangelis Koukis
    parser.add_option("-p", "--dport", dest="dport",
60 03a592b9 Vangelis Koukis
                      default=None, type="int",
61 03a592b9 Vangelis Koukis
                      metavar="PORT",
62 03a592b9 Vangelis Koukis
                      help="Proxy connection to destination port PORT")
63 03a592b9 Vangelis Koukis
    parser.add_option("-P", "--password", dest="password",
64 03a592b9 Vangelis Koukis
                      default=None,
65 03a592b9 Vangelis Koukis
                      metavar="PASSWORD",
66 03a592b9 Vangelis Koukis
                      help=("Use password PASSWD to authenticate incoming "
67 03a592b9 Vangelis Koukis
                            "VNC connections"))
68 03a592b9 Vangelis Koukis
69 03a592b9 Vangelis Koukis
    (opts, args) = parser.parse_args(args)
70 03a592b9 Vangelis Koukis
71 03a592b9 Vangelis Koukis
    # Mandatory arguments
72 03a592b9 Vangelis Koukis
    if not opts.password:
73 03a592b9 Vangelis Koukis
        parser.error("The -P/--password argument is mandatory.")
74 03a592b9 Vangelis Koukis
    if not opts.daddr:
75 03a592b9 Vangelis Koukis
        parser.error("The -d/--dest argument is mandatory.")
76 03a592b9 Vangelis Koukis
    if not opts.dport:
77 03a592b9 Vangelis Koukis
        parser.error("The -p/--dport argument is mandatory.")
78 03a592b9 Vangelis Koukis
79 03a592b9 Vangelis Koukis
    return (opts, args)
80 03a592b9 Vangelis Koukis
81 03a592b9 Vangelis Koukis
82 03a592b9 Vangelis Koukis
def request_forwarding(sport, daddr, dport, password,
83 b129b0c0 Stratos Psomadakis
                       server_address=DEFAULT_SERVER_ADDRESS,
84 0b74ef50 Stratos Psomadakis
                       server_port=DEFAULT_SERVER_PORT, ssl_sock=True):
85 03a592b9 Vangelis Koukis
    """Connect to vncauthproxy and request a VNC forwarding."""
86 03a592b9 Vangelis Koukis
    if not password:
87 03a592b9 Vangelis Koukis
        raise ValueError("You must specify a non-empty password")
88 03a592b9 Vangelis Koukis
89 48b1400e Vangelis Koukis
    req = {
90 48b1400e Vangelis Koukis
        "source_port": int(sport),
91 48b1400e Vangelis Koukis
        "destination_address": daddr,
92 48b1400e Vangelis Koukis
        "destination_port": int(dport),
93 b129b0c0 Stratos Psomadakis
        "password": password,
94 48b1400e Vangelis Koukis
    }
95 66d17b40 Apollon Oikonomopoulos
96 b129b0c0 Stratos Psomadakis
    retries = 5
97 b129b0c0 Stratos Psomadakis
    while retries:
98 b129b0c0 Stratos Psomadakis
        # Initiate server connection
99 b129b0c0 Stratos Psomadakis
        for res in socket.getaddrinfo(server_address, server_port,
100 b129b0c0 Stratos Psomadakis
                                      socket.AF_UNSPEC,
101 b129b0c0 Stratos Psomadakis
                                      socket.SOCK_STREAM, 0,
102 b129b0c0 Stratos Psomadakis
                                      socket.AI_PASSIVE):
103 b129b0c0 Stratos Psomadakis
            af, socktype, proto, canonname, sa = res
104 b129b0c0 Stratos Psomadakis
            try:
105 b129b0c0 Stratos Psomadakis
                server = socket.socket(af, socktype, proto)
106 b129b0c0 Stratos Psomadakis
            except socket.error:
107 b129b0c0 Stratos Psomadakis
                server = None
108 b129b0c0 Stratos Psomadakis
                continue
109 b129b0c0 Stratos Psomadakis
110 0b74ef50 Stratos Psomadakis
            if ssl_sock:
111 0b74ef50 Stratos Psomadakis
                server = ssl.wrap_socket(
112 0b74ef50 Stratos Psomadakis
                      server, cert_reqs=ssl.CERT_NONE,
113 0b74ef50 Stratos Psomadakis
                      ssl_version=ssl.PROTOCOL_TLSv1)
114 0b74ef50 Stratos Psomadakis
115 b129b0c0 Stratos Psomadakis
            server.settimeout(60.0)
116 b129b0c0 Stratos Psomadakis
117 b129b0c0 Stratos Psomadakis
            try:
118 b129b0c0 Stratos Psomadakis
                server.connect(sa)
119 b129b0c0 Stratos Psomadakis
            except socket.error:
120 b129b0c0 Stratos Psomadakis
                server.close()
121 b129b0c0 Stratos Psomadakis
                server = None
122 b129b0c0 Stratos Psomadakis
                continue
123 b129b0c0 Stratos Psomadakis
124 b129b0c0 Stratos Psomadakis
            retries = 0
125 b129b0c0 Stratos Psomadakis
            break
126 b129b0c0 Stratos Psomadakis
127 b129b0c0 Stratos Psomadakis
        sleep(0.2)
128 b129b0c0 Stratos Psomadakis
129 b129b0c0 Stratos Psomadakis
    if server is None:
130 b129b0c0 Stratos Psomadakis
        raise Exception("Failed to connect to server")
131 b129b0c0 Stratos Psomadakis
132 b129b0c0 Stratos Psomadakis
    server.send(json.dumps(req))
133 b129b0c0 Stratos Psomadakis
134 b129b0c0 Stratos Psomadakis
    response = server.recv(1024)
135 b129b0c0 Stratos Psomadakis
    server.close()
136 48b1400e Vangelis Koukis
    res = json.loads(response)
137 48b1400e Vangelis Koukis
    return res
138 66d17b40 Apollon Oikonomopoulos
139 03a592b9 Vangelis Koukis
140 66d17b40 Apollon Oikonomopoulos
if __name__ == '__main__':
141 03a592b9 Vangelis Koukis
    (opts, args) = parse_arguments(sys.argv[1:])
142 03a592b9 Vangelis Koukis
143 03a592b9 Vangelis Koukis
    res = request_forwarding(sport=opts.sport, daddr=opts.daddr,
144 b129b0c0 Stratos Psomadakis
                             dport=opts.dport, password=opts.password)
145 03a592b9 Vangelis Koukis
146 03a592b9 Vangelis Koukis
    sys.stderr.write("Forwaring %s -> %s:%s: %s\n" % (res['source_port'],
147 03a592b9 Vangelis Koukis
                                                      opts.daddr, opts.dport,
148 03a592b9 Vangelis Koukis
                                                      res['status']))
149 03a592b9 Vangelis Koukis
150 48b1400e Vangelis Koukis
    if res['status'] == "OK":
151 48b1400e Vangelis Koukis
        sys.exit(0)
152 48b1400e Vangelis Koukis
    else:
153 48b1400e Vangelis Koukis
        sys.exit(1)