首先你需要安装1Panel与添加第三方应用库
1Panel部署
安装1Panel
推荐直接在购买服务器(https://www.rainyun.com/wp-admin_
)的时候选择预装1Panel(以下简称1p)
如果你希望自行安装1p,那么请使用官方的安装脚本:
对于Centos/RedHat 系列
curl -sSL https://resource.fit2cloud.com/1panel/package/quick_start.sh -o quick_start.sh && sh quick_start.sh
对于Ubuntu
curl -sSL https://resource.fit2cloud.com/1panel/package/quick_start.sh -o quick_start.sh && sudo bash quick_start.sh
对于Debian
curl -sSL https://resource.fit2cloud.com/1panel/package/quick_start.sh -o quick_start.sh && bash quick_start.sh
添加第三方应用库
在1Panel后台点击“计划任务-创建计划任务”
执行周期建议每天一次
脚本内容中填入文末源码
之后如果你的1Panel是通过雨云预装的面板,则无需修改任何地方,若自行安装且更改了安装位置,那么需要将下方app_local_dir="/opt/1panel/resource/apps/local"
中的内容进行修改,使其能够指向1Panel安装目录下的资源目录-app目录-本地应用目录
完成后点击“执行”即可进行首次拉取,当然你也可以通过手动执行来提前触发cron
之后前往应用商店,点击右上角“更新应用列表”即可
源码如下
#!/bin/bash
# 这下面是修改配置的地方
#
# 1panel本地app的目录(如果不是默认安装,需修改该目录)
app_local_dir="/opt/1panel/resource/apps/local"
# AppStore的git仓库地址(必选)
# git_repo_url="https://github.com/xxxily/local-appstore-for-1Panel"
# git_repo_url="https://github.com/1Panel-dev/appstore"
git_repo_url="https://github.com/okxlin/appstore"
# 访问git仓库的access token,访问私有仓库时用,优先级高于账密(可选)
# 建议使用access token,降低账密泄露的风险
git_access_token=""
# 访问git仓库的用户名,访问私有仓库时用(可选)
git_username=""
# 访问git仓库的密码,访问私有仓库时用(可选)
git_password=""
# 指定克隆的分支(可选)
git_branch=""
# 指定克隆的深度(可选)
git_depth=1
# 拉取远程仓库前是否清空本地app目录(可选)
clean_local_app=false
# 拉取远程仓库前是否清空远程app缓存(可选)
clean_remote_app_cache=false
# 设置克隆或拉取远程仓库时使用的代理(可选)
proxyUrl=""
# 设置示例:
# proxyUrl="http://127.0.0.1:7890"
# proxyUrl="socks5://127.0.0.1:7890"
# proxyUrl="socks5://user:password@host:port"
# 将远程app store工程克隆到本地的工作目录
work_dir="/opt/1panel/appstore"
# 获取系统信息
os_info=$(uname -a)
# 检查是否为Debian系统
if [[ "$os_info" == *"Debian"* ]]; then
echo "检测到Debian环境,执行特殊设置"
chmod +x /usr/bin/bash
sudo su $@
else
echo "非Debian,跳过特殊设置"
fi
# 检测Git是否已安装
echo "检测Git是否安装"
if ! command -v git &> /dev/null; then
echo "Git未找到,开始安装..."
#
# apt版
if [[ -f /etc/apt/sources.list ]]; then
sudo apt-get update
sudo apt-get install git -y
fi
# yum版
if [[ -f /etc/yum.repos.d/CentOS-Base.repo ]]; then
sudo yum install git -y
fi
echo "Git安装完成."
else
echo "Git已安装."
fi
set -e
mkdir -p "$work_dir/logs"
log_file="$work_dir/logs/local_appstore_sync_helper_$(date +"%Y-%m-%d").log"
logs() {
local message="$1"
if [ -n "$log_file" ]; then
mkdir -p "$(dirname "$log_file")"
if [ $? -eq 0 ]; then
echo -e "[$(date +"%Y-%m-%d %H:%M:%S")] $message"
echo "[$(date +"%Y-%m-%d %H:%M:%S")] $message" >>"$log_file"
return
fi
fi
echo -e "$message"
}
# 函数: url_encode
# 参数:
# - url: 需要进行编码的字符串
# 返回值:
# 经过URL编码后的字符串
function url_encode() {
local string=$1
local length="${#string}"
local url_encoded_string=""
local c
for ((i = 0; i < length; i++)); do
c=${string:i:1}
case "$c" in
[a-zA-Z0-9.~_-]) url_encoded_string+=$c ;;
*) url_encoded_string+=$(printf '%%%02X' "'$c") ;;
esac
done
echo "$url_encoded_string"
}
# 定义函数,接收一个URL参数和可选的替换字符串参数
replace_protocol() {
local url=$1
local replacement=$2
# 如果没有提供替换字符串,则删除"http://"或"https://"
if [[ -z $replacement ]]; then
local new_url=$(echo $url | sed "s/http:\/\///" | sed "s/https:\/\///")
else
local new_url=$(echo $url | sed "s/http:\/\//${replacement}/" | sed "s/https:\/\//${replacement}/")
fi
# 输出替换后的URL
echo $new_url
}
# 函数: clone_git_repo
# 参数:
# - url: Git仓库URL
# - username: 账号(可选)
# - password: 密码(可选)
# - access_token: 访问令牌(可选)
# - branch: 克隆分支(可选)
# - depth: 克隆深度(可选,默认为0,即克隆整个仓库)
function clone_git_repo() {
local url=$1
local username=$2
local password=$3
local access_token=$4
local branch=$5
local depth=$6
branch=${branch:+--branch $branch}
depth=${depth:+--depth $depth}
echo "branch: $branch, depth: $depth"
if [[ -n $access_token ]]; then
echo "use access_token to clone"
local fix_url=$(replace_protocol "$url")
git clone "https://oauth2:$access_token@$fix_url" $branch $depth
elif [[ -n $username && -n $password ]]; then
local encoded_username=$(url_encode "$username")
local encoded_password=$(url_encode "$password")
local fix_url=$(replace_protocol "$url")
# echo "use username and password to clone, encoded_username: $encoded_username, encoded_password: $encoded_password, fix_url: $fix_url"
echo "use username and password to clone"
git clone "https://$encoded_username:$encoded_password@$fix_url" $branch $depth
else
echo "use default clone"
git clone "$url" $branch $depth
fi
}
# 取消代理
function proxy_off() {
unset http_proxy
unset https_proxy
unset ALL_PROXY
unset no_proxy
logs "Proxy Off"
}
# 开启代理
function proxy_on() {
proxy_url="http://127.0.0.1:7890"
match_str="://"
if [ -n "$1" ]; then
if [[ $1 =~ $match_str ]]; then
proxy_url=$1
else
logs "Incorrect proxy_url, use defualt proxy_url"
return
fi
fi
export http_proxy=$proxy_url
export https_proxy=$proxy_url
export ALL_PROXY=$proxy_url
export no_proxy="localhost,127.0.0.1,localaddress,.localdomain.com"
logs "Proxy On $proxy_url"
}
function scriptInfo() {
echo ""
logs "##################################################################"
logs "# Name: local appstore sync helper for 1Panel #"
logs "# Version: v1.0.1 #"
logs "# Author: xxxily #"
logs "# Author: BiliWind #"
logs "# Github: https://github.com/xxxily/local-appstore-for-1Panel #"
logs "##################################################################"
echo ""
}
function main() {
scriptInfo
if [ ! -d "$app_local_dir" ]; then
logs "未检测到1panel的app目录,请检查1panel是否安装正确,或修改脚本中的app_local_dir变量"
exit 1
fi
# 检查地址结尾是否包含.git,如果不包含则自动补全
if [[ "$git_repo_url" != *".git" ]]; then
git_repo_url="${git_repo_url}.git"
fi
local repo_username=""
local repo_projectname=""
# 使用正则表达式匹配仓库地址中的用户名和项目名
if [[ $git_repo_url =~ .*\/(.*)\/(.*)\.git ]]; then
repo_username=${BASH_REMATCH[1]}
repo_projectname=${BASH_REMATCH[2]}
# logs "用户名: $repo_username"
# logs "项目名: $repo_projectname"
fi
if [ -z "$repo_username" ] || [ -z "$repo_projectname" ]; then
logs "无法提取用户名和项目名,请检查git_repo_url变量提供的地址是否正确"
exit 1
fi
mkdir -p "$work_dir/temp"
local repo_user_dir="$work_dir/temp/$repo_username"
local repo_dir="$repo_user_dir/$repo_projectname"
# 根据clean_remote_app_cache变量的值决定是否清空远程app的缓存数据
if [ "$clean_remote_app_cache" = true ] && [ -d "$repo_dir" ]; then
rm -rf "$repo_dir"
logs "已清空远程app的缓存数据"
fi
# 根据proxyUrl变量的值决定是否开启代理
if [ -n "$proxyUrl" ]; then
proxy_on "$proxyUrl"
fi
# clone或拉取远程仓库最新代码
logs "准备获取远程仓库最新代码:$git_repo_url"
if [ -d "$repo_dir" ]; then
logs "执行git pull操作"
cd "$repo_dir"
# 强行拉取最新代码
git pull --force 2>>"$log_file"
else
logs "执行git clone操作"
mkdir -p "$repo_user_dir"
cd "$repo_user_dir"
clone_git_repo "$git_repo_url" "$git_username" "$git_password" "$git_access_token" "$git_branch" "$git_depth" 2>>"$log_file"
fi
logs "远程仓库最新代码获取完成"
if [ ! -d "$repo_dir/apps" ]; then
logs "未检测到apps目录,请检查远程仓库是否正确"
exit 1
fi
# 根据clean_local_app变量的值决定是否清空本地app目录
if [ "$clean_local_app" = true ]; then
rm -rf "$app_local_dir"/*
logs "已清空本地原有的app"
fi
# 将远程仓库的apps目录下的所有app复制到本地app_local_dir目录下
cd "$repo_dir"
cp -rf apps/* "$app_local_dir"
pwd
ls -lah
du -sh
# 根据clean_remote_app_cache变量的值决定是否清空远程app的缓存数据
if [ "$clean_remote_app_cache" = true ]; then
rm -rf "$repo_dir"
fi
if [ -n "$proxyUrl" ]; then
proxy_off
fi
logs "1panel本地app同步成功,enjoy it!"
}
main "$@"
logs "脚本由BiliWind-风屿岛站长二改,尊重开源,请不要删除或修改原作者、二改者信息"
找到WeekToDo点击安装
如果你希望使用ip:port
的形式访问,则需要勾选“端口外部访问”;如果你希望通过反向代理的方式访问,且反代应用与WeekToDo在同一服务器,那么无需勾选,但如果不在同一服务器,则需要勾选
点击确认后等待约30秒即可安装完成
点击“服务端口”可快速跳转到网页
命令行安装
对于Ubuntu/Debian
sudo apt update
sudo apt install snapd
执行完成后
sudo snap install weektodo
暂时没找到官方文档有关于centos的,我在尝试centos时也遇到了亿点问题
从源码构建
首先确保你的设备上有git和nodejs(v16.x及以上), Yarn 和 Electron.
官方给的命令:
git clone https://github.com/manuelernestog/weektodo
cd weektodo
yarn install
yarn run serve // to run web version
yarn run electron:serve // to run native version
git clone https://github.com/manuelernestog/weektodo
该命令是将GitHub上的源码clone到本地(可以理解为下载源码)
cd weektodo
是进入该目录
由于本人不会nodejs,所以不对剩下的命令做解释,这是ai的回答:
这些命令是在使用 Yarn,一个流行的 JavaScript 包管理器,来安装和运行一个项目。
yarn install:这个命令是用来安装项目所需的依赖项。当你获取一个项目,尤其是开源项目,往往需要运行这个命令来获取项目所需的库和工具,以便能够正确地编译和运行项目。
yarn run serve:这个命令是用来运行项目的 web 版本。在开发过程中,通常需要启动一个本地服务器来查看项目的效果。这个命令会启动一个开发服务器,并在浏览器中打开一个窗口来显示项目的运行结果。
yarn run electron:serve:这个命令是用来运行项目的原生应用程序版本。Electron 是一个用于构建跨平台桌面应用程序的开源框架。使用 Electron,可以将 web 技术(HTML、CSS 和 JavaScript)打包成桌面应用程序。这个命令会启动一个 Electron 服务器,并在一个 Electron 窗口中显示项目的运行结果。
这些命令都是在项目的根目录下运行的,并且需要在 package.json 文件中定义好这些脚本命令。
使用
点击左下角齿轮图标即可打开设置弹窗
在“显示”中可以改为深色模式
在“行为习惯”中可以更改一周从周几开始,若关闭此选项,则一周的排序为
周日-周一-周二-周三-周四-周五-周六