Homebrew存在大漏洞,恶意代码远程操纵电脑

Mac包管理工具Homebrew出现了一个大漏洞:

在Homebrew/homebrew-cask仓库中,通过混淆Homebrew项目中自动拉取请求审阅脚本中使用的库,可以合并恶意的拉取请求

如果被滥用,攻击者可以在使用brew的计算机上执行任意Ruby代码!

该漏洞的威胁登记在国内被360CERT评为10分严重。

漏洞的发现者是一位来自日本的后端程序员。

当天下午,他“闲来无事”逛起了HackerOne(漏洞赏金平台)。顺便看看经常使用的Homebrew有没有什么漏洞。

diff检查逻辑存在缺陷

由于Homebrew项目使用GitHub Actions运行CI脚本,小哥查看了.git-hub/workflows/下每个仓库的目录。

其中两个目录:一个负责检查用户提交的拉取请求的内容,进行批准,另一个目录负责自动合并这些被批准的代码。

拉取请求的内容被fetch后会被改为diff文件,并使用git_diff对其进行解析。

小哥一开始检查了可以通过批准请求的几个条件,没有发现问题。

但是直觉作怪,他还是掉过头去二次研究了git_diff仓库。

当看到其中报告了一个“更改行数引发解析错误”的问题时,小哥“灵机一动”:

我是不是能以某种方式对拉取请求进行伪装来满足批准条件,骗过git_diff?

于是他分析了git_diff解析diff文件的步骤,乍一看没毛病,但是细看其中一步发现了“猫腻”:可以多次更改源/目标文件路径信息。

于是通过下面这两行代码:

++ "b/#{私藏代码写这儿}"++ b/Casks/cask.rb

第一行将私藏代码以上面的格式嵌入拉取请求,就可以被视为文件路径信息,而非代码变动。

第二行为更改文件路径的必需条件。

这样就可以绕过必需条件,将含有恶意代码的拉取请求视为零行更改的

“无害”请求,最终骗过diff,获得批准,完成自动合并!开始搞事情!

添加“打印日志”操作来验证此漏洞

“今天的收获可不菲”,小哥立即行动,提交了一个PR,通过Homebrew搞起了破坏,在HackerOne上对此漏洞进行PoC演示。

以下是具体代码:

(选取在GitHub上无意发布了一个API令牌的拉取请求iterm2.rb 进行更改 )

++ "b/#{puts 'Going to report it - RyotaK (https://hackeorne.com/ryotak)';b = 1;Casks = 1;iterm2 = {};iterm2.define_singleton_method(:rb) do 1 end}"++ b/Casks/iterm2.rb

在第一行定义b,Casks,iterm2,iterm2.rb四个变量,才不会在第二行引发未定义错误,这样就可以作为有效的Ruby脚本执行。

通过添加这两行更改,GitHub返回以下差异:

diff --git a/Casks/iterm2.rb b/Casks/iterm2.rbindex 3c376126bb1cf9..ba6f4299c1824e 100644--- a/Casks/iterm2.rb+++ b/Casks/iterm2.rb@@ -8,6 +8,8 @@     sha256 "e7403dcc5b08956a1483b5defea3b75fb81c3de4345da6000e3ad4a6188b47df"   end+++ "b/#{puts 'Going to report it - RyotaK (https://hackeorne.com/ryotak)';b = 1;Casks = 1;iterm2 = {};iterm2.define_singleton_method(:rb) do 1 end}"+++ b/Casks/iterm2.rb   url "https://iterm2.com/downloads/stable/iTerm2-#{version.dots_to_underscores}.zip"   name "iTerm2"   desc "Terminal emulator as alternative to Apple's Terminal app

如前面所述,git_diff将匹配的行 +++ “?b/(.*) 视为文件路径信息,而非添加的行,因此,此差异将被视为进行0行更改的请求

由于既不能修改未经授权使用的cask,也没有在homebrew-cask仓库中找到一个测试cask,小哥给Homebrew发邮件求助,按照工作人员的意思添加“打印日志”这一无害修改来验证了这个漏洞。

当其他用户执行brew search/brew cleanup等命令时即使没有安装目标cask,也将执行恶意代码。

官方在3小时之内完成了主要修复,并发布了通报。

“这不是单方面的责任”

针对这次大漏洞,网友们议论纷纷,有人表示:

如果不是使用ruby解析git_diff,而是使用libgit,这个漏洞就不会发生。

如果Apple提供了一个功能更强大的软件包管理器,这不会发生。

如果数以百万计的Homebrew用户给了他们建造如此庞大的项目所需资金的一小部分,这也不会发生。

此漏洞没有单一负责方。

另外,细心的朋友可能还记得,我们此前曾报道了一篇关于黑客用GitHub服务器挖矿的新闻,里面的黑客也是只需提交Pull Request,即使项目管理者没有批准,恶意挖矿代码依然能够执行。

和这次这个漏洞一样,都是抓住了GitHub Actions的自动执行工作流功能来“钻空”。

针对滥用Actions的问题,GitHub近日也更新了帮助保护维护者的新功能,比如在任何Actions工作流运行之前,来自首次贡献者的Pull Request将需要**具有写访问权限的仓库协作者的手动批准**。

参考链接:
[1]https://blog.ryotak.me/post/homebrew-security-incident-en/
[2]https://news.ycombinator.com/item?id=26922448
[3]https://brew.sh/2021/04/21/security-incident-disclosure/
[4]https://wangzhan.360.cn/774.html
[5]https://github.blog/2021-04-22-github-actions-update-helping-maintainers-combat-bad-actors  /

— 完 —

(0)

相关推荐

  • Github Pages + Hugo 搭建个人博客

    文章目录 Github Pages + Hugo 搭建个人博客 零.效果 一.创建 Github 库 二.安装 Hugo 和 Git 三.新建 Hugo 网站 四.选择 Hugo 主题 五.新建文章 ...

  • 代码评审中的代码协同

    大神说:"Show me the code",于是就有了代码评审. "Talk is cheap. Show me the code." --Linus Tor ...

  • Mac 下 brew 切换为国内源

    注:清华源经验证是可用的. 2020-04-142020-04-14 16:12:51阅读 4.9K0 简介 Homebrew 是一款自由及开放源代码的软件包管理系统,用以简化 macOS 和 lin ...

  • mac m1 安装开发常用软件

    文章目录 0x00 折腾了一天, 难受 0x01 你喜欢的软件 0x02 开发用-无窗口的软件 0x03 图形化界面 0x00 折腾了一天, 难受 0x01 你喜欢的软件 QQ, 微信, 网易云音乐, ...

  • 西门子 PLC 发现一个新漏洞黑客可远程运行恶意代码

    西门子于上周五发布了固件更新,解决 SIMATIC S7-1200 和 S7-1500 可编程逻辑控制器 (PLC) 中的一个严重漏洞,黑客可利用漏洞远程访问受保护的内存区域并获取不受限制和未被检测到 ...

  • 西门子新漏洞,黑客可远程执行恶意代码

    西门子周五发布了固件更新,以解决 SIMATIC S7-1200 和 S7-1500 可编程逻辑控制器 (PLC) 中的一个严重漏洞,恶意行为者可能会利用该漏洞远程访问受保护的内存区域并获取不受限制和 ...

  • Office发现4个安全漏洞,黑客可执行恶意代码

    近日,国内网络安全组织东方联盟的研究人员在今天发布的一份报告中表示:"这些漏洞源于遗留代码,可能使攻击者能够通过 Word.Excel 和 Outlook 等恶意 Office 文档在目标上 ...

  • NVIDIA静默修复Selfblow漏洞:可在Tegra芯片之上执行任意恶意代码

    7月18日,NVIDIA为Jetson TX1芯片推出了一个Linux驱动的安全更新补丁,在公告页面上并没有提及关于该补丁修复问题的细节.但是马上有软件安全研究者透露,在这个补丁中NVIDIA修复了一 ...

  • 4棵树选1棵,测出你性格中的大漏洞!

    正能量 前天 选A的你是一个才思敏捷,热心诚恳的人.你的反应很快,学习能力也很强.喜欢结交朋友,在朋友间是一个很有感染力的人,很受大家的欢迎.在工作上也富有热情,工作效率比较高,很善于活跃气氛,与你在 ...

  • 脊柱错位一个被医患忽视的健康大漏洞

    中医之声公众号眼睛有问题去看眼科,心脏有毛病去看心血管内科,咳嗽去看呼吸科,不孕不育去看生殖科,这已经是所有健康出了问题的人不二选择.可是,有很多慢性病,医生没看错病,也没开错药,病人吃了几年.十几年 ...

  • Python编程常用的十大语法和代码汇总

    C.1.1 Python的"Hello World" [输入] source_code/appendix_c_python/example00_helloworld.py prin ...

  • 大漏洞,奥地利百万公民数据网上暴露多年

    该系统还没用公布于网络上的部分就是所谓的"特别公民补充登记系统".它列出了未在各类协会和公司注册簿中记录的自由职业人士.根据epicenter.works的揭露,奥地利政府于200 ...

  • 后怕!居民发现自家的门竟然有个大“漏洞”!小区里人都知道

    全文共1343字,阅读大约需要3分35秒. 近日,网友想想(化名)吐槽:住了一年多,才知道自己家的门不反锁时,随便什么卡都能打得开! 想想(化名)对记者说:"前两天一个邻居跟我说,这个门不反 ...