本文经AI新媒体量子位(公众号ID:QbitAI)授权转载,转载请联系出处。
Mac包管理工具Homebrew出现了一个大漏洞:
在Homebrew/homebrew-cask仓库中,通过混淆Homebrew项目中自动拉取请求审阅脚本中使用的库,可以合并恶意的拉取请求。
如果被滥用,攻击者可以在使用brew的计算机上执行任意Ruby代码!
[[405521]]
该漏洞的威胁登记在国内被360CERT评为10分严重。
漏洞的发现者是一位来自日本的后端程序员。
当天下午,他“闲来无事”逛起了HackerOne(漏洞赏金平台)。顺便看看经常使用的Homebrew有没有什么漏洞。
由于Homebrew项目使用GitHub Actions运行CI脚本,小哥查看了.git-hub/workflows/下每个仓库的目录。
其中两个目录:一个负责检查用户提交的拉取请求的内容,进行批准,另一个目录负责自动合并这些被批准的代码。
拉取请求的内容被fetch后会被改为diff文件,并使用git_diff对其进行解析。
小哥一开始检查了可以通过批准请求的几个条件,没有发现问题。
但是直觉作怪,他还是掉过头去二次研究了git_diff仓库。
当看到其中报告了一个“更改行数引发解析错误”的问题时,小哥“灵机一动”:
我是不是能以某种方式对拉取请求进行伪装来满足批准条件,骗过git_diff?
于是他分析了git_diff解析diff文件的步骤,乍一看没毛病,但是细看其中一步发现了“猫腻”:可以多次更改源/目标文件路径信息。
于是通过下面这两行代码:
- ++ "b/#{私藏代码写这儿}"
- ++ b/Casks/cask.rb
第一行将私藏代码以上面的格式嵌入拉取请求,就可以被视为文件路径信息,而非代码变动。
第二行为更改文件路径的必需条件。
这样就可以绕过必需条件,将含有恶意代码的拉取请求视为零行更改的
“无害”请求,最终骗过diff,获得批准,完成自动合并!开始搞事情!
[[405522]]
“今天的收获可不菲”,小哥立即行动,提交了一个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返回以下差异:
如前面所述,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将需要**具有写访问权限的仓库协作者的手动批准**。
网页标题:Homebrew存在大漏洞,恶意代码远程操纵电脑
文章网址:http://www.mswzjz.cn/qtweb/news17/316467.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能