From: Xi Lu <lx@shellcodes.org>
Date: Fri, 23 Dec 2022 04:52:48 +0000 (+0800)
Subject: Fix ruby-mode.el local command injection vulnerability (bug#60268)
X-Git-Tag: emacs-28.3-rc1~8
X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=22fb5ff5126dc8bb01edaa0252829d853afb284f;p=emacs.git

Fix ruby-mode.el local command injection vulnerability (bug#60268)

* lisp/progmodes/ruby-mode.el
(ruby-find-library-file): Fix local command injection vulnerability.

(cherry picked from commit 9a3b08061feea14d6f37685ca1ab8801758bfd1c)
---

diff --git a/lisp/progmodes/ruby-mode.el b/lisp/progmodes/ruby-mode.el
index 72631a6557f..9b05b04a52c 100644
--- a/lisp/progmodes/ruby-mode.el
+++ b/lisp/progmodes/ruby-mode.el
@@ -1819,7 +1819,7 @@ or `gem' statement around point."
       (setq feature-name (read-string "Feature name: " init))))
   (let ((out
          (substring
-          (shell-command-to-string (concat "gem which " feature-name))
+          (shell-command-to-string (concat "gem which " (shell-quote-argument feature-name)))
           0 -1)))
     (if (string-match-p "\\`ERROR" out)
         (user-error "%s" out)