Hash :
442de453
Author :
Thomas de Grivel
Date :
2023-11-01T22:06:14
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
;; cl-unix-cybernetics
;; Copyright 2013-2022 Thomas de Grivel <thodg@kmx.io>
;;
;; Permission is hereby granted to use this software granted
;; the above copyright notice and this permission paragraph
;; are included in all copies and substantial portions of this
;; software.
;;
;; THIS SOFTWARE IS PROVIDED "AS-IS" WITHOUT ANY GUARANTEE OF
;; PURPOSE AND PERFORMANCE. IN NO EVENT WHATSOEVER SHALL THE
;; AUTHOR BE CONSIDERED LIABLE FOR THE USE AND PERFORMANCE OF
;; THIS SOFTWARE.
(in-package :cl-unix-cybernetics)
(defun run (&rest command)
"Run a command at the current host. COMMAND is assembled using STR."
(apply #'host-run (current-host) command))
(defun run! (&rest command)
"Run a command at the current host. COMMAND is assembled using STR.
An error is raised if the command did not complete successfully."
(multiple-value-bind (out ret err) (apply #'run command)
(if (zerop ret)
(values out ret err)
(error "The command ~S failed with error code ~D.
Output : ~S
Error output : ~S"
(str command) ret out err))))
;; Run as root
(defgeneric run-as-root-command (host os))
(defmethod run-as-root-command ((host t) (os os-unix))
"sudo ")
(defun run-as-root (&rest command)
"Run a command at the current host as the root user (dangerous).
COMMAND is assembled using STR."
(let* ((host (current-host))
(prefix (unless (equal "root" (get-probed host :user))
(run-as-root-command host (get-probed host :os)))))
(apply #'run prefix command)))
(defun run-as-root! (&rest command)
"Run a command at the current host as the root user (dangerous).
COMMAND is assembled using STR.
An error is raised if the command did not complete successfully."
(multiple-value-bind (out ret err) (apply #'run-as-root command)
(if (zerop ret)
(values out ret err)
(error "The root command (dangerous) ~S failed with error code ~D.
Output : ~S
Error output : ~S"
(str command) ret out err))))