me
/
guix
Archived
1
0
Fork 0

copy, offload: Explicitly close SSH channels and sessions.

Fixes <https://bugs.gnu.org/42740>.

* guix/scripts/copy.scm (send-to-remote-host): Keep the result of
'connect-to-remote-daemon' in scope, and explicitly close it after the
call to 'send-files'.
(retrieve-from-remote-host): Explicitly close REMOTE and disconnect
SESSION.
* guix/scripts/offload.scm (transfer-and-offload): Explicitly close
STORE and disconnect SESSION upon completion.
master
Ludovic Courtès 2020-08-29 16:05:05 +02:00
parent d7965b58d2
commit 61fe9ced7d
No known key found for this signature in database
GPG Key ID: 090B11993D9AEBB5
2 changed files with 8 additions and 2 deletions

View File

@ -20,6 +20,7 @@
#:use-module (guix ui)
#:use-module (guix scripts)
#:use-module (guix ssh)
#:use-module ((ssh session) #:select (disconnect!))
#:use-module (guix store)
#:use-module ((guix status) #:select (with-status-verbosity))
#:use-module (guix utils)
@ -71,9 +72,10 @@ package names, build the underlying packages before sending them."
(and (build-derivations local drv)
(let* ((session (open-ssh-session host #:user user
#:port (or port 22)))
(sent (send-files local items
(connect-to-remote-daemon session)
(remote (connect-to-remote-daemon session))
(sent (send-files local items remote
#:recursive? #t)))
(close-connection remote)
(format #t "~{~a~%~}" sent)
sent))))
@ -93,6 +95,8 @@ package names, build the underlying packages before sending them."
(options->derivations+files local opts))
((retrieved)
(retrieve-files local items remote #:recursive? #t)))
(close-connection remote)
(disconnect! session)
(format #t "~{~a~%~}" retrieved)
retrieved)))

View File

@ -365,6 +365,8 @@ of free disk space on '~a'~%")
#:log-port (current-error-port)
#:lock? #f)))
(close-connection store)
(disconnect! session)
(format (current-error-port) "done with offloaded '~a'~%"
(derivation-file-name drv)))