Go to file
Jiangjie.Bai 2e1763cce7
Merge pull request #5739 from jumpserver/dev
v2.8 发版 (2)
2021-03-12 20:56:23 +08:00
.github perf(github): 更新github issue模版 2020-11-10 10:30:15 +08:00
apps Merge pull request #5739 from jumpserver/dev 2021-03-12 20:56:23 +08:00
data fix: 修复 celery 等日志文件的访问漏洞 (#5469) 2021-01-19 14:36:41 +08:00
docs Merge branch 'stable' into dev 2019-03-04 10:47:31 +08:00
logs Add new directory logs 2016-09-04 12:37:42 +08:00
requirements perf: 添加依赖包(pyvmomi==7.0.1)(termcolor==1.1.0) 2021-03-04 17:12:51 +08:00
tmp Dev (#1053) 2018-03-07 23:18:34 +08:00
utils perf(project): 优化命名的风格 (#5693) 2021-03-08 10:08:51 +08:00
.dockerignore added Vagrantfile to support windows dev (#3036) 2019-07-29 17:00:31 +08:00
.gitignore ci(release&build): 添加 github workflows, 自动构建 release 2020-07-07 13:03:48 +08:00
Dockerfile fix: 干掉 dockerfile 行内注释 2021-03-11 20:31:38 +08:00
LICENSE [Demo] update demo mode code 2017-06-19 17:59:13 +08:00
README.md chore: 添加贡献者图片 (#5532) 2021-01-27 13:03:20 +08:00
README_EN.md Update README_EN.md 2021-01-18 04:13:11 -06:00
Vagrantfile added Vagrantfile to support windows dev (#3036) 2019-07-29 17:00:31 +08:00
config_example.yml Update config_example.yml 2020-10-12 05:23:49 -05:00
entrypoint.sh perf: 优化entrypoint.sh 2020-12-03 14:23:16 +08:00
jms refactor(celery): 重构celery,使用 threads 模型,避免 占用太多内存 (#5525) 2021-01-25 05:34:41 -06:00
run_server.py [Update] 管理脚本 2018-03-19 11:26:51 +08:00

README_EN.md

Jumpserver

Python3 Django Docker Pulls


CRITICAL BUG WARNING

Recently we have found a critical bug for remote execution vulnerability which leads to pre-auth and info leak, please fix it as soon as possible.

Thanks for reactivity from Alibaba Hackerone bug bounty program report us this bug

Vulnerable version:

< v2.6.2
< v2.5.4
< v2.4.5 
= v1.5.9
>= v1.5.3

Safe and Stable version:

>= v2.6.2
>= v2.5.4
>= v2.4.5 
= v1.5.9 version tag didn't change
< v1.5.3

Bug Fix Solution: Upgrade to the latest version or the version mentioned above

Temporary Solution (upgrade asap):

Modify the Nginx config file and disable the vulnerable api listed below

/api/v1/authentication/connection-token/
/api/v1/users/connection-token/

Path to Nginx config file

# Previous Community version
/etc/nginx/conf.d/jumpserver.conf

# Previous Enterprise version
jumpserver-release/nginx/http_server.conf
 
# Latest version
jumpserver-release/compose/config_static/http_server.conf

Changes in Nginx config file

### Put the following code on top of location server, or before /api and /
location /api/v1/authentication/connection-token/ {
   return 403;
}
 
location /api/v1/users/connection-token/ {
   return 403;
}
### End right here
 
location /api/ {
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header Host $host;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_pass http://core:8080;
  }
 
...

Save the file and restart Nginx

docker deployment: 
$ docker restart jms_nginx

rpm or other deployment:
$ systemctl restart nginx

Bug Fix Verification

# Download the following script to check if it is fixed
$ wget https://github.com/jumpserver/jumpserver/releases/download/v2.6.2/jms_bug_check.sh 

# Run the code to verify it
$ bash jms_bug_check.sh demo.jumpserver.org
漏洞已修复 (It means the bug is fixed)
漏洞未修复 (It means the bug is not fixed and the system is still vulnerable)

Attack Simulation

Go to the logs directory which should contain gunicorn.log file. Then download the "attack" script and execute it

$ pwd
/opt/jumpserver/core/logs

$ ls gunicorn.log
gunicorn.log

$ wget 'https://github.com/jumpserver/jumpserver/releases/download/v2.6.2/jms_check_attack.sh'
$ bash jms_check_attack.sh
系统未被入侵 (It means the system is safe)
系统已被入侵 (It means the system is being attacked)


Jumpserver is the world's first open-source PAM (Privileged Access Management System) and is licensed under the GNU GPL v2.0. It is a 4A-compliant professional operation and maintenance security audit system.

Jumpserver uses Python / Django for development, follows Web 2.0 specifications, and is equipped with an industry-leading Web Terminal solution that provides a beautiful user interface and great user experience

Jumpserver adopts a distributed architecture to support multi-branch deployment across multiple cross-regional areas. The central node provides APIs, and login nodes are deployed in each branch. It can be scaled horizontally without concurrency restrictions.

Change the world, starting from little things.


Features

Jumpserver 功能

Start

Quick start Docker Install

Step by Step deployment. Docs

Full documentation Docs

Demo、Video 和 Snapshot

We provide online demo, demo video and screenshots to get you started quickly.

Demo Video Snapshot

SDK

We provide the SDK for your other systems to quickly interact with the Jumpserver API.

  • Python Jumpserver other components use this SDK to complete the interaction.
  • Java Thanks to 恺珺 for providing his Java SDK vesrion.

Copyright (c) 2014-2019 Beijing Duizhan Tech, Inc., All rights reserved.

Licensed under The GNU General Public License version 2 (GPLv2) (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

https://www.gnu.org/licenses/gpl-2.0.html

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.