mirror of
https://gitee.com/spark-store-project/spark-store
synced 2025-12-14 04:42:03 +08:00
* 调整:重写了spark-dstore-patch,速度提升,尤其对机械硬盘下
* 调整:优化了aptss源文件同步策略
This commit is contained in:
7
debian/changelog
vendored
7
debian/changelog
vendored
@@ -1,3 +1,10 @@
|
|||||||
|
spark-store (4.2.5.1) stable; urgency=medium
|
||||||
|
* 调整:重写了spark-dstore-patch,速度提升,尤其对机械硬盘下
|
||||||
|
* 调整:优化了aptss源文件同步策略
|
||||||
|
|
||||||
|
-- shenmo <shenmo@spark-app.store>
|
||||||
|
|
||||||
|
|
||||||
spark-store (4.2.5) stable; urgency=medium
|
spark-store (4.2.5) stable; urgency=medium
|
||||||
* 修复:ssinstall在文件不存在时仍然报安装成功
|
* 修复:ssinstall在文件不存在时仍然报安装成功
|
||||||
* 修复:删除不再需要的依赖:libc6-dev
|
* 修复:删除不再需要的依赖:libc6-dev
|
||||||
|
|||||||
@@ -11,7 +11,6 @@ TEMPLATE = subdirs
|
|||||||
CONFIG += wayland-compositor
|
CONFIG += wayland-compositor
|
||||||
|
|
||||||
SUBDIRS += \
|
SUBDIRS += \
|
||||||
src/spark-dstore-patch \
|
|
||||||
src/spark-store.pro
|
src/spark-store.pro
|
||||||
|
|
||||||
# https://wiki.debian.org/Hardening
|
# https://wiki.debian.org/Hardening
|
||||||
|
|||||||
@@ -1,9 +0,0 @@
|
|||||||
TARGET = spark-dstore-patch
|
|
||||||
TEMPLATE += app
|
|
||||||
QT += widgets
|
|
||||||
SOURCES += spark-dstore-tool.cpp
|
|
||||||
|
|
||||||
# Default rules for deployment.
|
|
||||||
qnx: target.path = /tmp/spark-store/bin
|
|
||||||
else: unix:!android: target.path = /opt/durapps/spark-store/bin
|
|
||||||
!isEmpty(target.path): INSTALLS += target
|
|
||||||
@@ -1,195 +0,0 @@
|
|||||||
#include <QCoreApplication>
|
|
||||||
#include <QDir>
|
|
||||||
#include <QJsonObject>
|
|
||||||
#include <QJsonDocument>
|
|
||||||
#include <QDebug>
|
|
||||||
#include <QDirIterator>
|
|
||||||
#include <QProcess>
|
|
||||||
|
|
||||||
#include <unistd.h>
|
|
||||||
|
|
||||||
QList<QJsonObject> enumAppInfoList()
|
|
||||||
{
|
|
||||||
QList<QJsonObject> appInfoList;
|
|
||||||
QDir apps("/opt/apps");
|
|
||||||
auto list = apps.entryList(QDir::Dirs | QDir::NoDotAndDotDot);
|
|
||||||
for (auto &appID : list) {
|
|
||||||
auto infoPath = apps.absoluteFilePath(appID + "/info");
|
|
||||||
QFile infoFile(infoPath);
|
|
||||||
if (!infoFile.open(QIODevice::ReadOnly)) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
auto doc = QJsonDocument::fromJson(infoFile.readAll());
|
|
||||||
appInfoList.push_back(doc.object());
|
|
||||||
}
|
|
||||||
return appInfoList;
|
|
||||||
}
|
|
||||||
//这段是去找appid和info,没看懂用来干啥的,在此之后info文件也没再用过
|
|
||||||
//可能以后版本的实现会用到,等官方加功能再说
|
|
||||||
void linkDir(const QString &source, const QString &target)
|
|
||||||
{
|
|
||||||
auto ensureTargetDir = [](const QString &targetFile) {
|
|
||||||
QFileInfo t(targetFile);
|
|
||||||
QDir tDir(t.dir());
|
|
||||||
tDir.mkpath(".");
|
|
||||||
};
|
|
||||||
|
|
||||||
QDir sourceDir(source);
|
|
||||||
QDir targetDir(target);
|
|
||||||
QDirIterator iter(source, QDir::Files | QDir::NoDotAndDotDot, QDirIterator::Subdirectories);
|
|
||||||
while (iter.hasNext()) {
|
|
||||||
auto sourceFile = iter.next();
|
|
||||||
auto targetFile = targetDir.absoluteFilePath(sourceDir.relativeFilePath(sourceFile));
|
|
||||||
|
|
||||||
QFileInfo tfi(targetFile);
|
|
||||||
// if (tfi.isSymLink() && (tfi.canonicalFilePath() == sourceFile)) {
|
|
||||||
//这里官方应该是写错了,否则会每触发一次就把所有软链接都删了重新创建一次
|
|
||||||
if (tfi.isSymLink() && (tfi.symLinkTarget() == sourceFile)) {
|
|
||||||
continue;
|
|
||||||
} else {
|
|
||||||
QFile::remove(targetFile);
|
|
||||||
}
|
|
||||||
|
|
||||||
ensureTargetDir(targetFile);
|
|
||||||
auto ret = symlink(sourceFile.toStdString().c_str(), targetFile.toStdString().c_str());
|
|
||||||
if (0 != ret) {
|
|
||||||
qDebug() << "link failed" << sourceFile << "=>" << targetFile << ret;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//reset Dynamic library rpath
|
|
||||||
void setRpath(const QString &file, const QString &path)
|
|
||||||
{
|
|
||||||
if (!QFileInfo::exists(path))
|
|
||||||
return;
|
|
||||||
QProcess p;
|
|
||||||
auto cmd = "patchelf " + file + " --set-rpath " + path;
|
|
||||||
p.start("bash", QStringList {"-c", cmd});
|
|
||||||
p.waitForFinished();
|
|
||||||
}
|
|
||||||
|
|
||||||
QString getGlic()
|
|
||||||
{
|
|
||||||
//get arch & glibc
|
|
||||||
QProcess p;
|
|
||||||
auto cmd = "gcc -dumpmachine";
|
|
||||||
p.start("bash", QStringList {"-c", cmd});
|
|
||||||
p.waitForFinished();
|
|
||||||
return p.readAll();
|
|
||||||
}
|
|
||||||
|
|
||||||
void linkApp(const QJsonObject &app)
|
|
||||||
{
|
|
||||||
auto appID = app.value("appid").toString();
|
|
||||||
auto appEntriesDir = QDir("/opt/apps/" + appID + "/entries");
|
|
||||||
auto appLibsDir = QDir("/opt/apps/" + appID + "/files/lib");
|
|
||||||
auto autoStartDir = QDir(appEntriesDir.absoluteFilePath("autostart"));
|
|
||||||
|
|
||||||
bool autoStart = app.value("permissions").toObject().value("autostart").toBool();
|
|
||||||
if (autoStart) {
|
|
||||||
linkDir(appEntriesDir.absoluteFilePath("autostart"), "/etc/xdg/autostart");
|
|
||||||
}
|
|
||||||
|
|
||||||
// link application
|
|
||||||
auto sysShareDir = QDir("/usr/share");
|
|
||||||
linkDir(appEntriesDir.absoluteFilePath("applications"), sysShareDir.absoluteFilePath("applications"));
|
|
||||||
linkDir(appEntriesDir.absoluteFilePath("icons"), sysShareDir.absoluteFilePath("icons"));
|
|
||||||
linkDir(appEntriesDir.absoluteFilePath("mime"), sysShareDir.absoluteFilePath("mime"));
|
|
||||||
linkDir(appEntriesDir.absoluteFilePath("glib-2.0"), sysShareDir.absoluteFilePath("glib-2.0"));
|
|
||||||
linkDir(appEntriesDir.absoluteFilePath("services"), sysShareDir.absoluteFilePath("dbus-1/services"));
|
|
||||||
linkDir(appEntriesDir.absoluteFilePath("GConf"), sysShareDir.absoluteFilePath("GConf"));
|
|
||||||
linkDir(appEntriesDir.absoluteFilePath("help"), sysShareDir.absoluteFilePath("help"));
|
|
||||||
linkDir(appEntriesDir.absoluteFilePath("locale"), sysShareDir.absoluteFilePath("locale"));
|
|
||||||
linkDir(appEntriesDir.absoluteFilePath("fcitx"), sysShareDir.absoluteFilePath("fcitx"));
|
|
||||||
linkDir(appEntriesDir.absoluteFilePath("polkit"), sysShareDir.absoluteFilePath("polkit-1"));
|
|
||||||
linkDir(appEntriesDir.absoluteFilePath("fonts/conf"), "/etc/fonts/conf.d");
|
|
||||||
linkDir(appEntriesDir.absoluteFilePath("fonts/files"), sysShareDir.absoluteFilePath("fonts"));
|
|
||||||
|
|
||||||
|
|
||||||
//原来会导致Gtk相关应用翻译缺失,补足了
|
|
||||||
|
|
||||||
|
|
||||||
auto pluginDir = QDir(appEntriesDir.absoluteFilePath("plugins"));
|
|
||||||
if (pluginDir.exists()) {
|
|
||||||
QString arch = getGlic();
|
|
||||||
// if (pluginDir.exists()) {
|
|
||||||
// QDirIterator iter(pluginDir.absolutePath(), QDir::Files | QDir::NoDotAndDotDot, QDirIterator::Subdirectories);
|
|
||||||
// while (iter.hasNext()) {
|
|
||||||
// auto sourceFile = iter.next();
|
|
||||||
// setRpath(sourceFile, appLibsDir.absolutePath()); //set rpath
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
|
|
||||||
linkDir(appEntriesDir.absoluteFilePath("plugins/fcitx"), "/usr/lib/" + arch + "/fcitx");
|
|
||||||
linkDir(appEntriesDir.absoluteFilePath("plugins/browser"), "/usr/lib/mozilla/plugins");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void cleanLink()
|
|
||||||
{
|
|
||||||
auto cleanDirBrokenLink = [](const QString &dir) {
|
|
||||||
QProcess p;
|
|
||||||
auto cmd = "find " + dir + " -xtype l -delete";
|
|
||||||
p.start("bash", QStringList {"-c", cmd});
|
|
||||||
p.waitForFinished();
|
|
||||||
};
|
|
||||||
|
|
||||||
QString arch = getGlic();
|
|
||||||
auto sysShareDir = QDir("/usr/share");
|
|
||||||
cleanDirBrokenLink(sysShareDir.absoluteFilePath("applications"));
|
|
||||||
cleanDirBrokenLink(sysShareDir.absoluteFilePath("icons"));
|
|
||||||
cleanDirBrokenLink(sysShareDir.absoluteFilePath("mime/packages"));
|
|
||||||
cleanDirBrokenLink(sysShareDir.absoluteFilePath("glib-2.0"));
|
|
||||||
cleanDirBrokenLink(sysShareDir.absoluteFilePath("dbus-1/services"));
|
|
||||||
cleanDirBrokenLink("/etc/xdg/autostart");
|
|
||||||
cleanDirBrokenLink(sysShareDir.absoluteFilePath("fcitx"));
|
|
||||||
cleanDirBrokenLink(sysShareDir.absoluteFilePath("help"));
|
|
||||||
cleanDirBrokenLink(sysShareDir.absoluteFilePath("locale"));
|
|
||||||
cleanDirBrokenLink("/usr/lib/" + arch + "/fcitx");
|
|
||||||
cleanDirBrokenLink("/usr/lib/mozilla/plugins");
|
|
||||||
cleanDirBrokenLink(sysShareDir.absoluteFilePath("polkit-1/actions"));
|
|
||||||
cleanDirBrokenLink(sysShareDir.absoluteFilePath("fonts"));
|
|
||||||
cleanDirBrokenLink("/etc/fonts/conf.d");
|
|
||||||
}
|
|
||||||
|
|
||||||
void update()
|
|
||||||
{
|
|
||||||
QProcess p;
|
|
||||||
auto cmd = "glib-compile-schemas /usr/share/glib-2.0/schemas/";
|
|
||||||
p.start("bash", QStringList {"-c", cmd});
|
|
||||||
p.waitForFinished();
|
|
||||||
|
|
||||||
cmd = "update-icon-caches /usr/share/icons/*";
|
|
||||||
p.start("bash", QStringList {"-c", cmd});
|
|
||||||
p.waitForFinished();
|
|
||||||
|
|
||||||
cmd = "update-desktop-database -q";
|
|
||||||
p.start("bash", QStringList {"-c", cmd});
|
|
||||||
p.waitForFinished();
|
|
||||||
|
|
||||||
cmd = "update-mime-database -V /usr/share/mime";
|
|
||||||
p.start("bash", QStringList {"-c", cmd});
|
|
||||||
p.waitForFinished();
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
|
||||||
{
|
|
||||||
QCoreApplication app(argc, argv);
|
|
||||||
|
|
||||||
cleanLink();
|
|
||||||
|
|
||||||
for (auto &a : enumAppInfoList()) {
|
|
||||||
linkApp(a);
|
|
||||||
}
|
|
||||||
qInfo()<<"Spark dstore patch (c) The Spark Project 2022-Now. Modified from deepin-app-store-tool";
|
|
||||||
|
|
||||||
// trigger
|
|
||||||
update();
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
80
tool/spark-dstore-patch
Executable file
80
tool/spark-dstore-patch
Executable file
@@ -0,0 +1,80 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
echo "----------------Running Spark DStore Patch----------------"
|
||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
|
||||||
|
enumAppInfoList() {
|
||||||
|
appInfoList=()
|
||||||
|
apps="/opt/apps"
|
||||||
|
list=$(ls $apps)
|
||||||
|
for appID in $list; do
|
||||||
|
appInfoList+=("$appID")
|
||||||
|
done
|
||||||
|
echo "${appInfoList[@]}"
|
||||||
|
}
|
||||||
|
linkDir() {
|
||||||
|
ensureTargetDir() {
|
||||||
|
targetFile=$1
|
||||||
|
t=$(dirname "$targetFile")
|
||||||
|
mkdir -p "$t"
|
||||||
|
}
|
||||||
|
|
||||||
|
source=$1
|
||||||
|
target=$2
|
||||||
|
sourceDir=$(dirname "$source")
|
||||||
|
targetDir=$(dirname "$target")
|
||||||
|
find "$source" -type f | while read sourceFile; do
|
||||||
|
targetFile="$targetDir/${sourceFile#$sourceDir/}"
|
||||||
|
if [ -L "$targetFile" ] && [ "$(readlink "$targetFile")" = "$sourceFile" ]; then
|
||||||
|
continue
|
||||||
|
else
|
||||||
|
rm -f "$targetFile"
|
||||||
|
fi
|
||||||
|
|
||||||
|
ensureTargetDir "$targetFile"
|
||||||
|
ln -s "$sourceFile" "$targetFile"
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
linkApp() {
|
||||||
|
appID=$1
|
||||||
|
appEntriesDir="/opt/apps/$appID/entries"
|
||||||
|
appLibsDir="/opt/apps/$appID/files/lib"
|
||||||
|
autoStartDir="$appEntriesDir/autostart"
|
||||||
|
|
||||||
|
if [ -d "$autoStartDir" ]; then
|
||||||
|
linkDir "$autoStartDir" "/etc/xdg/autostart"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# link application
|
||||||
|
sysShareDir="/usr/share"
|
||||||
|
for folder in "$appEntriesDir/applications" "$appEntriesDir/icons" "$appEntriesDir/mime" "$appEntriesDir/glib-2.0" "$appEntriesDir/services" "$appEntriesDir/GConf" "$appEntriesDir/help" "$appEntriesDir/locale" "$appEntriesDir/fcitx"; do
|
||||||
|
if [ ! -d "$folder" ]; then
|
||||||
|
continue
|
||||||
|
fi
|
||||||
|
if [ "$folder" = "$appEntriesDir/polkit" ]; then
|
||||||
|
linkDir "$folder" "/usr/share/polkit-1"
|
||||||
|
elif [ "$folder" = "$appEntriesDir/fonts/conf" ]; then
|
||||||
|
linkDir "$folder" "/etc/fonts/conf.d"
|
||||||
|
else
|
||||||
|
linkDir "$folder" "$sysShareDir/${folder##*/}"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
# execute linkApp function for each app and print output
|
||||||
|
for app in $(enumAppInfoList); do
|
||||||
|
linkApp "$app"
|
||||||
|
|
||||||
|
if [ "$1" = "--debug" ]; then
|
||||||
|
echo "Linking complete for $app"
|
||||||
|
fi
|
||||||
|
# remove broken links in /usr/share
|
||||||
|
|
||||||
|
done
|
||||||
|
find /usr/share -xtype l -delete
|
||||||
|
find /etc/fonts/conf.d -xtype l -delete
|
||||||
|
|
||||||
|
echo "----------------Finished----------------"
|
||||||
Reference in New Issue
Block a user