From 3b3bf8f0defd5934eda8d12c33175a9000b29fd5 Mon Sep 17 00:00:00 2001 From: shenmo Date: Sun, 8 May 2022 23:11:42 +0800 Subject: [PATCH] =?UTF-8?q?=09=E4=BF=AE=E6=94=B9=EF=BC=9A=20=20=20=20=20sr?= =?UTF-8?q?c/downloadlist.cpp=20=09=E4=BF=AE=E6=94=B9=EF=BC=9A=20=20=20=20?= =?UTF-8?q?=20src/widget.cpp=20=09=E9=87=8D=E5=91=BD=E5=90=8D=EF=BC=9A=20?= =?UTF-8?q?=20=20pkg/usr/share/polkit-1/actions/store.spark-app.ssinstall.?= =?UTF-8?q?policy=20->=20tool/auto-install-policy/store.spark-app.ssinstal?= =?UTF-8?q?l.policy=20=09=E4=BF=AE=E6=94=B9=EF=BC=9A=20=20=20=20=20tool/up?= =?UTF-8?q?date-upgrade/ss-update-controler.sh=20=09=E4=BF=AE=E6=94=B9?= =?UTF-8?q?=EF=BC=9A=20=20=20=20=20translations/spark-store=5Fen.ts=20=09?= =?UTF-8?q?=E4=BF=AE=E6=94=B9=EF=BC=9A=20=20=20=20=20translations/spark-st?= =?UTF-8?q?ore=5Ffr.ts=20=09=E4=BF=AE=E6=94=B9=EF=BC=9A=20=20=20=20=20tran?= =?UTF-8?q?slations/spark-store=5Fzh=5FCN.ts?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/downloadlist.cpp | 2 +- src/widget.cpp | 2 +- .../store.spark-app.ssinstall.policy | 0 tool/update-upgrade/ss-update-controler.sh | 96 ++++++++++++++----- translations/spark-store_en.ts | 12 +-- translations/spark-store_fr.ts | 12 +-- translations/spark-store_zh_CN.ts | 12 ++- 7 files changed, 92 insertions(+), 44 deletions(-) rename {pkg/usr/share/polkit-1/actions => tool/auto-install-policy}/store.spark-app.ssinstall.policy (100%) diff --git a/src/downloadlist.cpp b/src/downloadlist.cpp index 1c37332..a24c704 100644 --- a/src/downloadlist.cpp +++ b/src/downloadlist.cpp @@ -71,7 +71,7 @@ void downloadlist::setValue(qint64 value) ui->label_2->setText(QString::number(double(value) / 100) + "% (" + speed + ")"); if(ui->label_2->text().left(4) == "100%") { - ui->label_2->setText(tr("Downloaded, waiting to install")); + ui->label_2->setText(tr("Downloaded. Open APP Upgrade and Install Settings to enable password-free installation")); } } diff --git a/src/widget.cpp b/src/widget.cpp index e61332b..88300f4 100644 --- a/src/widget.cpp +++ b/src/widget.cpp @@ -192,7 +192,7 @@ void Widget::initUI() // 添加菜单项 QAction *actionSubmission = new QAction(tr("Submit App"), this); QAction *setting = new QAction(tr("Settings")); - QAction *upgrade = new QAction(tr("App Upgrade")); + QAction *upgrade = new QAction(tr("APP Upgrade and Install Settings")); QMenu *menu = new QMenu; menu->addAction(setting); diff --git a/pkg/usr/share/polkit-1/actions/store.spark-app.ssinstall.policy b/tool/auto-install-policy/store.spark-app.ssinstall.policy similarity index 100% rename from pkg/usr/share/polkit-1/actions/store.spark-app.ssinstall.policy rename to tool/auto-install-policy/store.spark-app.ssinstall.policy diff --git a/tool/update-upgrade/ss-update-controler.sh b/tool/update-upgrade/ss-update-controler.sh index bd61b14..6196b29 100755 --- a/tool/update-upgrade/ss-update-controler.sh +++ b/tool/update-upgrade/ss-update-controler.sh @@ -1,57 +1,71 @@ #!/bin/bash -set -e -echo "因为目前没有有时间的Qt程序员志愿者所以现在加功能只有让shenmo写脚本了..." -echo -echo "此功能被添加的原因是:为了防止影响系统更新,星火源默认的优先级是400,低于默认的500。这导致了与系统仓库相同包名的软件包无法正常更新到比系统仓库更高的版本。例如:hugo,系统仓库中的低版本会被优先安装,而且默认不会更新到星火的更新的版本" -echo "此脚本可以检测星火源中是否有比当前系统更高版本的软件包,由您决定是否安装" -echo "此脚本使用apt update/apt list --upgrade/apt upgrade来更新软件源、列出更新列表和操作更新" -echo -echo "该脚本不对其使用效果有任何明示或暗示的担保,在使用前请您确保您清楚地知道您在干什么。您应当清楚,星火商店的软件包并不是适配所有发行版的;尽管绝大多数的软件更新是无害的,您仍然应该仔细检查显示出来的更新内容,以确保不会对您的依赖环境造成破坏,尤其是那些看起来和系统依赖相关的软件包。在查看过更新列表之后,确认更新之前,您仍有一次取消更新的机会。" -echo "本脚本的开发者不对使用该脚本可能造成的后果负责" -echo -echo -echo -echo "请按回车继续..." -#"只有回车可以用啊!""啊?"“你说的任意都行啊”“唔。。。戳到我的盲区了” -read reset endloop=0 - +#####################检测是否启动过了更新检测工具 while [ $endloop -eq 0 ] ;do if [ -f /etc/xdg/autostart/spark-update-notifier.desktop ];then -textupdateopen="关闭" +text_update_open="关闭" #已经开启了就显示关闭 else -textupdateopen="开启" +text_update_open="开启" fi -echo "欢迎使用星火更新工具 脚本版 " +if [ -f /usr/share/polkit-1/actions/store.spark-app.ssinstall.policy ];then +text_auto_install_open="关闭" +#已经开启了就显示关闭 +else +text_auto_install_open="开启" +fi + + +echo "欢迎使用星火更新和安装设置工具" echo "请在以下操作中选择一个进行~" -echo "输入1 $textupdateopen星火更新检测工具(如果开启则会在系统启动后自动检测更新。如有更新则会弹出通知)" +echo "输入0 查看自动更新相关功能使用前须知(重要)" +echo "输入1 $text_update_open星火更新检测工具(如果开启则会在系统启动后自动检测更新。如有更新则会弹出通知)" echo "输入2 查看可更新软件包列表并决定是否更新" -echo "输入3 退出脚本" +echo "输入3 $text_auto_install_open点击安装免输入密码功能" +echo "输入4 退出脚本" read option case $option in + 0) + reset + echo "此须知适用于自动更新功能" + echo "此脚本可以检测星火源中是否有比当前系统更高版本的软件包,由您决定是否安装" + echo "此脚本使用apt update/apt list --upgrade/apt upgrade来更新软件源、列出更新列表和操作更新" + echo + echo "该脚本不对其使用效果有任何明示或暗示的担保,在使用前请您确保您清楚地知道您在干什么。您应当清楚,星火商店的软件包并不是适配所有发行版的;尽管绝大多数的软件更新是无害的,您仍然应该仔细检查显示出来的更新内容,以确保不会对您 的依赖环境造成破坏,尤其是那些看起来和系统依赖相关的软件包。在查看过更新列表之后,确认更新之前,您仍有一次取消更新的机会。" + echo "本脚本的开发者不对使用该脚本可能造成的后果负责" + echo + echo + echo + echo "请按回车继续..." +#"只有回车可以用啊!""啊?"“你说的任意都行啊”“唔。。。戳到我的盲区了” + read + reset + ;; 1) echo "执行以下操作需要授权..." if [ -f /etc/xdg/autostart/spark-update-notifier.desktop ];then - echo "检测到已经启动了自动更新检测,关闭中" + echo "检测到已经启动了自动更新检测,执行关闭" sudo systemctl disable spark-update-notifier sudo rm /etc/xdg/autostart/spark-update-notifier.desktop - + sleep 3 + reset else - echo "未检测到自动更新检测,启动中" + echo "未检测到自动更新检测,启动" sudo systemctl enable spark-update-notifier sudo service spark-update-notifier start # ln -s /opt/durapps/spark-store/bin/update-upgrade/autostart/spark-update-notifier.desktop $XDG_CONFIG_HOME/autostart # sudo ln -s /opt/durapps/spark-store/bin/update-upgrade/autostart/spark-update-notifier.desktop /etc/xdg/autostart /opt/durapps/spark-store/bin/update-upgrade/ss-update-notify.sh now + sleep 3 + reset fi ;; @@ -59,10 +73,40 @@ case $option in echo "执行以下操作需要授权..." /opt/durapps/spark-store/bin/update-upgrade/ss-upgrade-list.sh /opt/durapps/spark-store/bin/update-upgrade/ss-do-upgrade.sh - + echo "请按回车返回" + read + reset ;; 3) - echo "按回车退出" + if [ -f /usr/share/polkit-1/actions/store.spark-app.ssinstall.policy ];then + echo "检测到已经启动了免输入密码,执行关闭" + sudo rm /usr/share/polkit-1/actions/store.spark-app.ssinstall.policy + sleep 3 + reset + else + +cat << EOF +请注意:这个功能尚未开发完成,一旦开启,则运行pkexec ssinstall时不再需要授权 +仅对星火内置安装器生效 +理论上会存在一定的安全风险~ +如果接受,请输入1,否则输入2 +EOF +read is_accept_polkiy + +if [ "$is_accept_polkiy" = "1" ];then + echo "执行以下操作需要授权..." + sudo ln /opt/durapps/spark-store/bin/auto-install-policy/store.spark-app.ssinstall.policy /usr/share/polkit-1/actions/store.spark-app.ssinstall.policy + echo 已启动 + sleep 3 + reset + else + echo 未同意,返回 + sleep 3 + reset +fi +fi + ;; + 4) exit 0 ;; *) diff --git a/translations/spark-store_en.ts b/translations/spark-store_en.ts index a953856..00f5347 100644 --- a/translations/spark-store_en.ts +++ b/translations/spark-store_en.ts @@ -447,6 +447,11 @@ Settings + + + APP Upgrade and Install Settings + + Not Exist @@ -472,11 +477,6 @@ Failed to get the name to the file to be downloaded. - - - App Upgrade - - Upgrade @@ -582,7 +582,7 @@ - Downloaded, waiting to install + Downloaded. Open APP Upgrade and Install Settings to enable password-free installation diff --git a/translations/spark-store_fr.ts b/translations/spark-store_fr.ts index f4371d0..a57f8e4 100644 --- a/translations/spark-store_fr.ts +++ b/translations/spark-store_fr.ts @@ -629,6 +629,11 @@ Nous sommes nés pour le changement. Settings + + + APP Upgrade and Install Settings + + Not Exist @@ -645,11 +650,6 @@ Nous sommes nés pour le changement. Failed to get the name to the file to be downloaded. - - - App Upgrade - - Relative apps Not Found! @@ -776,7 +776,7 @@ Nous sommes nés pour le changement. - Downloaded, waiting to install + Downloaded. Open APP Upgrade and Install Settings to enable password-free installation diff --git a/translations/spark-store_zh_CN.ts b/translations/spark-store_zh_CN.ts index e6c829b..2094575 100644 --- a/translations/spark-store_zh_CN.ts +++ b/translations/spark-store_zh_CN.ts @@ -505,8 +505,8 @@ - App Upgrade - + APP Upgrade and Install Settings + 应用更新和安装设置 @@ -728,9 +728,8 @@ Click yes to continue. 深度软件包安装器 - Downloaded, waiting to install - 已完成,等待安装 + 已完成,等待安装 @@ -756,6 +755,11 @@ Click yes to continue. Installing... 正在安装 + + + Downloaded. Open APP Upgrade and Install Settings to enable password-free installation + 下载完成 可进入应用更新和安装设置来启动免密码安装 + Finish