-
Notifications
You must be signed in to change notification settings - Fork 106
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Switch back to using entrypoints to serve desktop-websocket
This is simpler than inheriting from the proxying handler from jupyter_server_proxy directly, and more importantly keeps our launcher entry simple and existing!
- Loading branch information
Showing
5 changed files
with
82 additions
and
67 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,65 @@ | ||
import os | ||
import shlex | ||
import tempfile | ||
from shutil import which | ||
|
||
HERE = os.path.dirname(os.path.abspath(__file__)) | ||
|
||
|
||
def setup_websockify(): | ||
# make a secure temporary directory for sockets | ||
# This is only readable, writeable & searchable by our uid | ||
sockets_dir = tempfile.mkdtemp() | ||
sockets_path = os.path.join(sockets_dir, 'vnc-socket') | ||
vncserver = which('vncserver') | ||
|
||
if vncserver is None: | ||
# Use bundled tigervnc | ||
vncserver = os.path.join(HERE, 'share/tigervnc/bin/vncserver') | ||
|
||
# TigerVNC provides the option to connect a Unix socket. TurboVNC does not. | ||
# TurboVNC and TigerVNC share the same origin and both use a Perl script | ||
# as the executable vncserver. We can determine if vncserver is TigerVNC | ||
# by searching TigerVNC string in the Perl script. | ||
with open(vncserver) as vncserver_file: | ||
is_tigervnc = "TigerVNC" in vncserver_file.read() | ||
|
||
if is_tigervnc: | ||
vnc_args = [vncserver, '-rfbunixpath', sockets_path] | ||
socket_args = ['--unix-target', sockets_path] | ||
else: | ||
vnc_args = [vncserver] | ||
socket_args = [] | ||
|
||
if not os.path.exists(os.path.expanduser('~/.vnc/xstartup')): | ||
vnc_args.extend(['-xstartup', os.path.join(HERE, 'share/xstartup')]) | ||
|
||
vnc_command = shlex.join( | ||
vnc_args | ||
+ [ | ||
'-verbose', | ||
'-geometry', | ||
'1680x1050', | ||
'-SecurityTypes', | ||
'None', | ||
'-fg', | ||
] | ||
) | ||
|
||
return { | ||
'command': [ | ||
'websockify', | ||
'-v', | ||
'--heartbeat', | ||
'30', | ||
'{port}', | ||
] | ||
+ socket_args | ||
+ ['--', '/bin/sh', '-c', f'cd {os.getcwd()} && {vnc_command}'], | ||
'timeout': 30, | ||
'new_browser_window': True, | ||
# We want the launcher entry to point to /desktop/, not to /desktop-websockify/ | ||
# /desktop/ is the user facing URL, while /desktop-websockify/ now *only* serves | ||
# websockets. | ||
"launcher_entry": {"title": "Desktop", "path_info": "desktop"}, | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters