add env init
This commit is contained in:
parent
8736847912
commit
9ec789f4bb
4 changed files with 259 additions and 3 deletions
|
|
@ -36,8 +36,8 @@ func RunCaddy(cfg *config.Config) error {
|
|||
return nil
|
||||
}
|
||||
ctx, cancel := context.WithCancel(context.Background())
|
||||
caddyPath := cfg.Server.CaddyDir + "caddy"
|
||||
cmd := exec.CommandContext(ctx, caddyPath, "run", "--config", "Caddyfile")
|
||||
cmd := exec.CommandContext(ctx, "./caddy", "run", "--config", "Caddyfile")
|
||||
cmd.Dir = cfg.Server.CaddyDir
|
||||
cmd.Stdout = os.Stdout
|
||||
cmd.Stderr = os.Stderr
|
||||
caddyRunning.SetRunning(true)
|
||||
|
|
|
|||
|
|
@ -0,0 +1,216 @@
|
|||
#! /bin/bash
|
||||
# By WJQSERVER-STUDIO_WJQSERVER
|
||||
#https://github.com/WJQSERVER/tools-stable
|
||||
|
||||
# 导入配置文件
|
||||
source "repo_url.conf"
|
||||
|
||||
mikublue="\033[38;2;57;197;187m"
|
||||
yellow='\033[33m'
|
||||
white='\033[0m'
|
||||
green='\033[0;32m'
|
||||
blue='\033[0;34m'
|
||||
red='\033[31m'
|
||||
gray='\e[37m'
|
||||
|
||||
#彩色
|
||||
mikublue(){
|
||||
echo -e "\033[38;2;57;197;187m\033[01m$1\033[0m"
|
||||
}
|
||||
white(){
|
||||
echo -e "\033[0m\033[01m$1\033[0m"
|
||||
}
|
||||
red(){
|
||||
echo -e "\033[31m\033[01m$1\033[0m"
|
||||
}
|
||||
green(){
|
||||
echo -e "\033[32m\033[01m$1\033[0m"
|
||||
}
|
||||
yellow(){
|
||||
echo -e "\033[33m\033[01m$1\033[0m"
|
||||
}
|
||||
blue(){
|
||||
echo -e "\033[34m\033[01m$1\033[0m"
|
||||
}
|
||||
gray(){
|
||||
echo -e "\e[37m\033[01m$1\033[0m"
|
||||
}
|
||||
option(){
|
||||
echo -e "\033[32m\033[01m ${1}. \033[38;2;57;197;187m${2}\033[0m"
|
||||
}
|
||||
|
||||
version=$(curl -s --max-time 3 ${repo_url}Version)
|
||||
if [ $? -ne 0 ]; then
|
||||
version="unknown"
|
||||
fi
|
||||
|
||||
clear
|
||||
|
||||
function writeSystemdServiceNoEnv() {
|
||||
|
||||
cat <<EOF > /etc/systemd/system/caddydash.service
|
||||
[Unit]
|
||||
Description=CaddyDash
|
||||
After=network.target network-online.target
|
||||
Requires=network-online.target
|
||||
|
||||
[Service]
|
||||
Type=notify
|
||||
User=root
|
||||
Group=root
|
||||
ExecStart=/root/data/caddy/caddydash -c ./config/config.toml
|
||||
ExecReload=/root/data/caddy/caddydash
|
||||
WorkingDirectory=/root/data/caddy
|
||||
TimeoutStopSec=5s
|
||||
LimitNOFILE=1048576
|
||||
PrivateTmp=true
|
||||
ProtectSystem=full
|
||||
AmbientCapabilities=CAP_NET_ADMIN CAP_NET_BIND_SERVICE
|
||||
|
||||
[Install]
|
||||
WantedBy=multi-user.target
|
||||
|
||||
EOF
|
||||
|
||||
}
|
||||
|
||||
function writeSystemdServiceWithPasswdEnv() {
|
||||
local username="$1"
|
||||
local password="$2"
|
||||
|
||||
cat <<EOF > /etc/systemd/system/caddydash.service
|
||||
[Unit]
|
||||
Description=CaddyDash
|
||||
After=network.target network-online.target
|
||||
Requires=network-online.target
|
||||
|
||||
[Service]
|
||||
Type=notify
|
||||
User=root
|
||||
Group=root
|
||||
ExecStart=/root/data/caddy/caddydash -c ./config/config.toml
|
||||
ExecReload=/root/data/caddy/caddydash
|
||||
WorkingDirectory=/root/data/caddy
|
||||
TimeoutStopSec=5s
|
||||
LimitNOFILE=1048576
|
||||
PrivateTmp=true
|
||||
ProtectSystem=full
|
||||
AmbientCapabilities=CAP_NET_ADMIN CAP_NET_BIND_SERVICE
|
||||
Environment="CADDYDASH_USERNAME=${username}"
|
||||
Environment="CADDYDASH_PASSWORD=${password}"
|
||||
|
||||
[Install]
|
||||
WantedBy=multi-user.target
|
||||
|
||||
EOF
|
||||
|
||||
echo -e "${green}>${white} $mikublue CaddyDash 用户名: ${username}" $white
|
||||
echo -e "${green}>${white} $mikublue CaddyDash 密码: ${password}" $white
|
||||
|
||||
}
|
||||
|
||||
# 选择安装模式
|
||||
echo -e "${green}>${white} $mikublue 选择安装模式" $white
|
||||
echo -e "${green}1.${white} $mikublue 不使用环境变量配置用户名密码" $white
|
||||
echo -e "${green}2.${white} $mikublue 使用环境变量配置用户名密码" $white
|
||||
read -p "请输入选项 [1/2]: " install_mode
|
||||
|
||||
if [[ "$install_mode" == "2" ]]; then
|
||||
read -p "请输入CaddyDash用户名: " caddydash_username
|
||||
writeSystemdServiceWithPasswdEnv "$caddydash_username"
|
||||
else
|
||||
writeSystemdServiceNoEnv
|
||||
fi
|
||||
|
||||
|
||||
}
|
||||
|
||||
# 显示免责声明
|
||||
echo -e "${red}免责声明:${mikublue}请阅读并同意以下条款才能继续使用本脚本。"
|
||||
echo -e "${yellow}===================================================================="
|
||||
echo -e "${mikublue}本脚本仅供学习和参考使用,作者不对其完整性、准确性或实用性做出任何保证。"
|
||||
echo -e "${mikublue}使用本脚本所造成的任何损失或损害,作者不承担任何责任。"
|
||||
echo -e "${mikublue}不提供/保证任何功能的可用性,安全性,有效性,合法性"
|
||||
echo -e "${mikublue}当前版本为${white} [${yellow} V${version} ${white}] ${white}"
|
||||
echo -e "${yellow}===================================================================="
|
||||
sleep 1
|
||||
|
||||
# 判断caddy是否已安装
|
||||
if [ -f /root/data/caddy/caddy ]; then
|
||||
echo -e "[${yellow}Warning${white}] $mikublue caddy已安装, 将会覆盖安装" $white
|
||||
read -p "是否继续安装? [Y/n]" choice
|
||||
if [[ "$choice" == "" || "$choice" == "Y" || "$choice" == "y" ]]; then
|
||||
echo -e "[${yellow}Warning${white}] $mikublue 停止caddy" $white
|
||||
systemctl stop caddy
|
||||
systemctl stop caddydash
|
||||
systemctl disable caddy
|
||||
systemctl disable caddydash
|
||||
else
|
||||
echo -e "[${red}Cancel${white}] $mikublue 取消安装" $white
|
||||
exit 1
|
||||
fi
|
||||
fi
|
||||
|
||||
echo -e "[${yellow}RUN${white}] $mikublue 開始安裝Caddy" $white
|
||||
|
||||
echo -e "${green}>${white} $mikublue 創建安裝目錄" $white
|
||||
mkdir -p /root/data/caddy
|
||||
mkdir -p /root/data/caddy/config.d
|
||||
mkdir -p /root/data/caddy/config
|
||||
echo -e "${green}>${white} $mikublue 下載主程序" $white
|
||||
input_version="$@" #获取输入的版本号
|
||||
if [ -z "$input_version" ]; then
|
||||
VERSION=$(curl -s https://raw.githubusercontent.com/WJQSERVER/caddy/main/Caddy-VERSION)
|
||||
else
|
||||
VERSION=$input_version
|
||||
fi
|
||||
wget -q -O /root/data/caddy/caddy.tar.gz https://github.com/WJQSERVER/caddy/releases/download/$VERSION/caddy-linux-amd64-pages.tar.gz
|
||||
echo -e "${green}>${white} $mikublue 解壓程序及其資源" $white
|
||||
tar -xzvf /root/data/caddy/caddy.tar.gz -C /root/data/caddy
|
||||
echo -e "${green}>${white} $mikublue 清理安裝資源" $white
|
||||
rm /root/data/caddy/caddy.tar.gz
|
||||
echo -e "${green}>${white} $mikublue 設置程序運行權限" $white
|
||||
chmod +x /root/data/caddy/caddy
|
||||
chown root:root /root/data/caddy/caddy
|
||||
|
||||
# 询问是否创建caddydash账户密码
|
||||
echo -e "${green}>${white} $mikublue 是否创建caddydash账户密码" $white
|
||||
|
||||
read -p "是否创建caddydash账户密码? [Y/n]" choice
|
||||
if [[ "$choice" == "" || "$choice" == "Y" || "$choice" == "y" ]]; then
|
||||
read -p "请输入CaddyDash用户名: " caddydash_username
|
||||
read -p "请输入CaddyDash密码: " caddydash_password
|
||||
writeSystemdServiceWithPasswdEnv "$caddydash_username" "$caddydash_password"
|
||||
else
|
||||
writeSystemdServiceNoEnv
|
||||
fi
|
||||
|
||||
echo -e "${green}>${white} $mikublue 創建SERVICE文件" $white
|
||||
|
||||
|
||||
echo -e "${green}>${white} $mikublue 拉取Caddyfile配置" $white
|
||||
# 预留配置
|
||||
|
||||
echo -e "${green}>${white} $mikublue 啟動程序" $white
|
||||
systemctl daemon-reload
|
||||
systemctl enable caddydash.service
|
||||
systemctl start caddydash.service
|
||||
echo -e "[${green}OK${white}] $mikublue caddy安装完成" $white
|
||||
|
||||
#回到root目录
|
||||
cd /root
|
||||
|
||||
# 导入配置文件
|
||||
source "repo_url.conf"
|
||||
|
||||
#等待1s
|
||||
sleep 1
|
||||
|
||||
#返回菜单/退出脚本
|
||||
read -p "是否返回菜单?: [Y/n]" choice
|
||||
|
||||
if [[ "$choice" == "" || "$choice" == "Y" || "$choice" == "y" ]]; then
|
||||
wget -O program-menu.sh ${repo_url}program/program-menu.sh && chmod +x program-menu.sh && ./program-menu.sh
|
||||
else
|
||||
echo "脚本结束"
|
||||
fi
|
||||
8
main.go
8
main.go
|
|
@ -70,7 +70,13 @@ func loadDatabase(filepath string) {
|
|||
}
|
||||
|
||||
func loadAdminStatus(cdb *db.ConfigDB) {
|
||||
err := user.InitAdminUserStatus(cdb)
|
||||
err := user.InitFormEnv(cdb)
|
||||
if err != nil {
|
||||
fmt.Printf("Failed to initialize admin user status: %v\n", err)
|
||||
os.Exit(1)
|
||||
}
|
||||
|
||||
err = user.InitAdminUserStatus(cdb)
|
||||
if err != nil {
|
||||
fmt.Printf("Failed to initialize admin user status: %v\n", err)
|
||||
os.Exit(1)
|
||||
|
|
|
|||
34
user/init.go
34
user/init.go
|
|
@ -3,6 +3,7 @@ package user
|
|||
import (
|
||||
"caddydash/db"
|
||||
"fmt"
|
||||
"os"
|
||||
|
||||
"golang.org/x/crypto/bcrypt"
|
||||
)
|
||||
|
|
@ -50,3 +51,36 @@ func InitAdminUserStatus(cdb *db.ConfigDB) error {
|
|||
return nil
|
||||
}
|
||||
}
|
||||
|
||||
func InitFormEnv(cdb *db.ConfigDB) error {
|
||||
username := os.Getenv("CADDYDASH_USERNAME")
|
||||
password := os.Getenv("CADDYDASH_PASSWORD")
|
||||
|
||||
if username != "" && password != "" {
|
||||
// 检查是否已经有用户
|
||||
hasUser, err := cdb.HasAnyUser()
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to check if any user exists: %w", err)
|
||||
}
|
||||
if hasUser {
|
||||
// 如果已经有用户,则不执行初始化,但设置状态为已初始化
|
||||
userStatus.SetInitialized(true)
|
||||
return nil
|
||||
}
|
||||
|
||||
// 执行初始化
|
||||
hashedPassword, err := hashPassword(password)
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to hash password from env: %w", err)
|
||||
}
|
||||
err = cdb.AddUser(username, hashedPassword)
|
||||
if err != nil {
|
||||
return fmt.Errorf("failed to add admin user from env: %w", err)
|
||||
}
|
||||
userStatus.SetInitialized(true)
|
||||
return nil
|
||||
}
|
||||
|
||||
// 如果环境变量不存在,则根据数据库状态设置初始化状态
|
||||
return InitAdminUserStatus(cdb)
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue