git clone https://github.com/mojocn/sshfortress.git && cd sshfortress; go build echo "run the app with SQLite database" ./sshfortress sqlite -v --listen=':3333' echo "run the app with Mysql database, you need a config.toml file in your sshfortress binary folder" ./sshfortress run -v --listen=':3333'
Docker pull docker pull mojotvcn/sshfortress
mysql
The config.toml file should in sshfortress binary folder. config.toml works with command sshfortress run
. Command sshfortress sqlite
can run with the config file.nginx
[app]
name="frotress.mojotv.cn" addr=":8360" verbose= true jwt_expire=240 #hour secret="asdf4e8hcjvbkjclkjkklfgki843895iojfdnvufh98" #jwt secret [db] # mysql database connection host = "127.0.0.1" user = "root" dbname = "sshfortress" password = "your_mysql_password" port = 3306 [github] #github.com OAuth2 client_id="d0b29360a088d0c4dc18" client_secret="89b272eeb22f373d8aa688986a8dbbc4edbfc64a" callback_url="http://sshfortress.mojotv.cn/#/"
https://sshfortress.mojotv.cn/#/logingit
just click the login button, the default password has input for you, user admin@sshfortress.cn
password: admin
,github
URL
: https://sshfortress.mojotv.cn/#/any-term
eg: https://sshfortress.mojotv.cn/#/any-term?a=home.mojotv.cn&p=test007&u=test007&z=1
a
: SSH Address with Port eg: home.mojotv.cn
home.mojotv.cn:22
u
: SSH Username eg: test007
p
: SSH Password eg: test007
z
: Not Use Zend Mode eg: 1
sshfortress.mojotv.cn.confweb
server {
server_name sshfortress.mojotv.cn;
charset utf-8; location /api/ws-any-term { proxy_pass http://127.0.0.1:8360; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "Upgrade"; proxy_set_header X-Real-IP $remote_addr; } location /api/ws/ { proxy_pass http://127.0.0.1:8360; proxy_http_version 1.1; proxy_set_header Upgrade $http_upgrade; proxy_set_header Connection "Upgrade"; proxy_set_header X-Real-IP $remote_addr; } location / { proxy_set_header X-Forwarded-For $remote_addr; proxy_set_header Host $http_host; proxy_pass http://127.0.0.1:8360; } access_log /data/wwwlogs/sshfortress.mojotv.cn.log; listen 443 ssl; # managed by Certbot ssl_certificate /etc/letsencrypt/live/sshfortress.mojotv.cn/fullchain.pem; # managed by Certbot ssl_certificate_key /etc/letsencrypt/live/sshfortress.mojotv.cn/privkey.pem; # managed by Certbot include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot }
Supervisor config file: sshfortress.ini
sql
[program:sshfortress.mojotv.cn]
command=/data/sshfortress/bin/sshfortress sqlite autostart=true autorestart=true startsecs=10 user=root chmod=0777 numprocs=1 redirect_stderr=true stdout_logfile=/data/sshfortress/supervisor.log