Fix flatpak remove
This commit is contained in:
parent
56f4ef955e
commit
ed72fab6d1
510
Cargo.lock
generated
510
Cargo.lock
generated
@ -110,6 +110,12 @@ dependencies = [
|
|||||||
"rustc-demangle",
|
"rustc-demangle",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "base64"
|
||||||
|
version = "0.21.7"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "9d297deb1925b89f2ccc13d7635fa0714f12c87adce1c75356b39ca9b7178567"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "bitflags"
|
name = "bitflags"
|
||||||
version = "1.3.2"
|
version = "1.3.2"
|
||||||
@ -254,6 +260,16 @@ dependencies = [
|
|||||||
"crossbeam-utils 0.8.20",
|
"crossbeam-utils 0.8.20",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "core-foundation"
|
||||||
|
version = "0.9.4"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "91e195e091a93c46f7102ec7818a2aa394e1e1771c3ab4825963fa03e45afb8f"
|
||||||
|
dependencies = [
|
||||||
|
"core-foundation-sys",
|
||||||
|
"libc",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "core-foundation-sys"
|
name = "core-foundation-sys"
|
||||||
version = "0.8.6"
|
version = "0.8.6"
|
||||||
@ -377,6 +393,15 @@ dependencies = [
|
|||||||
"shared_child",
|
"shared_child",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "encoding_rs"
|
||||||
|
version = "0.8.34"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "b45de904aa0b010bce2ab45264d0631681847fa7b6f2eaa7dab7619943bc4f59"
|
||||||
|
dependencies = [
|
||||||
|
"cfg-if 1.0.0",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "equivalent"
|
name = "equivalent"
|
||||||
version = "1.0.1"
|
version = "1.0.1"
|
||||||
@ -428,6 +453,12 @@ dependencies = [
|
|||||||
"pin-project-lite",
|
"pin-project-lite",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "fastrand"
|
||||||
|
version = "2.1.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "e8c02a5121d4ea3eb16a80748c74f5549a5665e4c21333c6098f283870fbdea6"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "field-offset"
|
name = "field-offset"
|
||||||
version = "0.3.6"
|
version = "0.3.6"
|
||||||
@ -444,6 +475,30 @@ version = "1.0.7"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "3f9eec918d3f24069decb9af1554cad7c880e2da24a9afd88aca000531ab82c1"
|
checksum = "3f9eec918d3f24069decb9af1554cad7c880e2da24a9afd88aca000531ab82c1"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "foreign-types"
|
||||||
|
version = "0.3.2"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "f6f339eb8adc052cd2ca78910fda869aefa38d22d5cb648e6485e4d3fc06f3b1"
|
||||||
|
dependencies = [
|
||||||
|
"foreign-types-shared",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "foreign-types-shared"
|
||||||
|
version = "0.1.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "00b0228411908ca8685dba7fc2cdd70ec9990a6e753e89b6ac91a84c40fbaf4b"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "form_urlencoded"
|
||||||
|
version = "1.2.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "e13624c2627564efccf4934284bdd98cbaa14e79b0b5a141218e507b3a823456"
|
||||||
|
dependencies = [
|
||||||
|
"percent-encoding",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "fuchsia-zircon"
|
name = "fuchsia-zircon"
|
||||||
version = "0.3.3"
|
version = "0.3.3"
|
||||||
@ -937,6 +992,25 @@ dependencies = [
|
|||||||
"system-deps 7.0.1",
|
"system-deps 7.0.1",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "h2"
|
||||||
|
version = "0.3.26"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "81fe527a889e1532da5c525686d96d4c2e74cdd345badf8dfef9f6b39dd5f5e8"
|
||||||
|
dependencies = [
|
||||||
|
"bytes 1.6.0",
|
||||||
|
"fnv",
|
||||||
|
"futures-core",
|
||||||
|
"futures-sink",
|
||||||
|
"futures-util",
|
||||||
|
"http",
|
||||||
|
"indexmap 2.2.6",
|
||||||
|
"slab",
|
||||||
|
"tokio",
|
||||||
|
"tokio-util",
|
||||||
|
"tracing",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "hashbrown"
|
name = "hashbrown"
|
||||||
version = "0.12.3"
|
version = "0.12.3"
|
||||||
@ -970,6 +1044,77 @@ version = "0.3.9"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "d231dfb89cfffdbc30e7fc41579ed6066ad03abda9e567ccafae602b97ec5024"
|
checksum = "d231dfb89cfffdbc30e7fc41579ed6066ad03abda9e567ccafae602b97ec5024"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "http"
|
||||||
|
version = "0.2.12"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "601cbb57e577e2f5ef5be8e7b83f0f63994f25aa94d673e54a92d5c516d101f1"
|
||||||
|
dependencies = [
|
||||||
|
"bytes 1.6.0",
|
||||||
|
"fnv",
|
||||||
|
"itoa",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "http-body"
|
||||||
|
version = "0.4.6"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "7ceab25649e9960c0311ea418d17bee82c0dcec1bd053b5f9a66e265a693bed2"
|
||||||
|
dependencies = [
|
||||||
|
"bytes 1.6.0",
|
||||||
|
"http",
|
||||||
|
"pin-project-lite",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "httparse"
|
||||||
|
version = "1.9.4"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "0fcc0b4a115bf80b728eb8ea024ad5bd707b615bfed49e0665b6e0f86fd082d9"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "httpdate"
|
||||||
|
version = "1.0.3"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "df3b46402a9d5adb4c86a0cf463f42e19994e3ee891101b1841f30a545cb49a9"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "hyper"
|
||||||
|
version = "0.14.30"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "a152ddd61dfaec7273fe8419ab357f33aee0d914c5f4efbf0d96fa749eea5ec9"
|
||||||
|
dependencies = [
|
||||||
|
"bytes 1.6.0",
|
||||||
|
"futures-channel",
|
||||||
|
"futures-core",
|
||||||
|
"futures-util",
|
||||||
|
"h2",
|
||||||
|
"http",
|
||||||
|
"http-body",
|
||||||
|
"httparse",
|
||||||
|
"httpdate",
|
||||||
|
"itoa",
|
||||||
|
"pin-project-lite",
|
||||||
|
"socket2",
|
||||||
|
"tokio",
|
||||||
|
"tower-service",
|
||||||
|
"tracing",
|
||||||
|
"want",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "hyper-tls"
|
||||||
|
version = "0.5.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "d6183ddfa99b85da61a140bea0efc93fdf56ceaa041b37d553518030827f9905"
|
||||||
|
dependencies = [
|
||||||
|
"bytes 1.6.0",
|
||||||
|
"hyper",
|
||||||
|
"native-tls",
|
||||||
|
"tokio",
|
||||||
|
"tokio-native-tls",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "iana-time-zone"
|
name = "iana-time-zone"
|
||||||
version = "0.1.60"
|
version = "0.1.60"
|
||||||
@ -993,6 +1138,16 @@ dependencies = [
|
|||||||
"cc",
|
"cc",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "idna"
|
||||||
|
version = "0.5.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "634d9b1461af396cad843f47fdba5597a4f9e6ddd4bfb6ff5d85028c25cb12f6"
|
||||||
|
dependencies = [
|
||||||
|
"unicode-bidi",
|
||||||
|
"unicode-normalization",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ignore"
|
name = "ignore"
|
||||||
version = "0.4.22"
|
version = "0.4.22"
|
||||||
@ -1038,6 +1193,12 @@ dependencies = [
|
|||||||
"libc",
|
"libc",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "ipnet"
|
||||||
|
version = "2.10.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "187674a687eed5fe42285b40c6291f9a01517d415fad1c3cbc6a9f778af7fcd4"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "itoa"
|
name = "itoa"
|
||||||
version = "1.0.11"
|
version = "1.0.11"
|
||||||
@ -1207,6 +1368,12 @@ dependencies = [
|
|||||||
"autocfg",
|
"autocfg",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "mime"
|
||||||
|
version = "0.3.17"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "6877bb514081ee2a7ff5ef9de3281f14a4dd4bceac4c09388074a6b5df8a139a"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "miniz_oxide"
|
name = "miniz_oxide"
|
||||||
version = "0.7.4"
|
version = "0.7.4"
|
||||||
@ -1269,6 +1436,23 @@ dependencies = [
|
|||||||
"ws2_32-sys",
|
"ws2_32-sys",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "native-tls"
|
||||||
|
version = "0.2.12"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "a8614eb2c83d59d1c8cc974dd3f920198647674a0a035e1af1fa58707e317466"
|
||||||
|
dependencies = [
|
||||||
|
"libc",
|
||||||
|
"log",
|
||||||
|
"openssl",
|
||||||
|
"openssl-probe",
|
||||||
|
"openssl-sys",
|
||||||
|
"schannel",
|
||||||
|
"security-framework",
|
||||||
|
"security-framework-sys",
|
||||||
|
"tempfile",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "net2"
|
name = "net2"
|
||||||
version = "0.2.39"
|
version = "0.2.39"
|
||||||
@ -1323,6 +1507,50 @@ version = "1.19.0"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "3fdb12b2476b595f9358c5161aa467c2438859caa136dec86c26fdd2efe17b92"
|
checksum = "3fdb12b2476b595f9358c5161aa467c2438859caa136dec86c26fdd2efe17b92"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "openssl"
|
||||||
|
version = "0.10.66"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "9529f4786b70a3e8c61e11179af17ab6188ad8d0ded78c5529441ed39d4bd9c1"
|
||||||
|
dependencies = [
|
||||||
|
"bitflags 2.6.0",
|
||||||
|
"cfg-if 1.0.0",
|
||||||
|
"foreign-types",
|
||||||
|
"libc",
|
||||||
|
"once_cell",
|
||||||
|
"openssl-macros",
|
||||||
|
"openssl-sys",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "openssl-macros"
|
||||||
|
version = "0.1.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "a948666b637a0f465e8564c73e89d4dde00d72d4d473cc972f390fc3dcee7d9c"
|
||||||
|
dependencies = [
|
||||||
|
"proc-macro2",
|
||||||
|
"quote",
|
||||||
|
"syn 2.0.70",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "openssl-probe"
|
||||||
|
version = "0.1.5"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "ff011a302c396a5197692431fc1948019154afc178baf7d8e37367442a4601cf"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "openssl-sys"
|
||||||
|
version = "0.9.103"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "7f9e8deee91df40a943c71b917e5874b951d32a802526c85721ce3b776c929d6"
|
||||||
|
dependencies = [
|
||||||
|
"cc",
|
||||||
|
"libc",
|
||||||
|
"pkg-config",
|
||||||
|
"vcpkg",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "os_pipe"
|
name = "os_pipe"
|
||||||
version = "1.2.1"
|
version = "1.2.1"
|
||||||
@ -1418,6 +1646,12 @@ version = "1.0.15"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "57c0d7b74b563b49d38dae00a0c37d4d6de9b432382b2892f0574ddcae73fd0a"
|
checksum = "57c0d7b74b563b49d38dae00a0c37d4d6de9b432382b2892f0574ddcae73fd0a"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "percent-encoding"
|
||||||
|
version = "2.3.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "e3148f5046208a5d56bcfc03053e3ca6334e51da8dfb19b6cdc8b306fae3283e"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "pikman-update-manager"
|
name = "pikman-update-manager"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
@ -1436,6 +1670,7 @@ dependencies = [
|
|||||||
"lock_api 0.4.12",
|
"lock_api 0.4.12",
|
||||||
"pretty-bytes",
|
"pretty-bytes",
|
||||||
"regex",
|
"regex",
|
||||||
|
"reqwest",
|
||||||
"rust-apt",
|
"rust-apt",
|
||||||
"rust-i18n",
|
"rust-i18n",
|
||||||
"serde",
|
"serde",
|
||||||
@ -1567,6 +1802,46 @@ version = "0.8.4"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "7a66a03ae7c801facd77a29370b4faec201768915ac14a721ba36f20bc9c209b"
|
checksum = "7a66a03ae7c801facd77a29370b4faec201768915ac14a721ba36f20bc9c209b"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "reqwest"
|
||||||
|
version = "0.11.27"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "dd67538700a17451e7cba03ac727fb961abb7607553461627b97de0b89cf4a62"
|
||||||
|
dependencies = [
|
||||||
|
"base64",
|
||||||
|
"bytes 1.6.0",
|
||||||
|
"encoding_rs",
|
||||||
|
"futures-core",
|
||||||
|
"futures-util",
|
||||||
|
"h2",
|
||||||
|
"http",
|
||||||
|
"http-body",
|
||||||
|
"hyper",
|
||||||
|
"hyper-tls",
|
||||||
|
"ipnet",
|
||||||
|
"js-sys",
|
||||||
|
"log",
|
||||||
|
"mime",
|
||||||
|
"native-tls",
|
||||||
|
"once_cell",
|
||||||
|
"percent-encoding",
|
||||||
|
"pin-project-lite",
|
||||||
|
"rustls-pemfile",
|
||||||
|
"serde",
|
||||||
|
"serde_json",
|
||||||
|
"serde_urlencoded",
|
||||||
|
"sync_wrapper",
|
||||||
|
"system-configuration",
|
||||||
|
"tokio",
|
||||||
|
"tokio-native-tls",
|
||||||
|
"tower-service",
|
||||||
|
"url",
|
||||||
|
"wasm-bindgen",
|
||||||
|
"wasm-bindgen-futures",
|
||||||
|
"web-sys",
|
||||||
|
"winreg",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "rowan"
|
name = "rowan"
|
||||||
version = "0.15.16"
|
version = "0.15.16"
|
||||||
@ -1684,6 +1959,15 @@ dependencies = [
|
|||||||
"windows-sys 0.52.0",
|
"windows-sys 0.52.0",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "rustls-pemfile"
|
||||||
|
version = "1.0.4"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "1c74cae0a4cf6ccbbf5f359f08efdf8ee7e1dc532573bf0db71968cb56b1448c"
|
||||||
|
dependencies = [
|
||||||
|
"base64",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "rustversion"
|
name = "rustversion"
|
||||||
version = "1.0.17"
|
version = "1.0.17"
|
||||||
@ -1705,6 +1989,15 @@ dependencies = [
|
|||||||
"winapi-util",
|
"winapi-util",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "schannel"
|
||||||
|
version = "0.1.24"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "e9aaafd5a2b6e3d657ff009d82fbd630b6bd54dd4eb06f21693925cdf80f9b8b"
|
||||||
|
dependencies = [
|
||||||
|
"windows-sys 0.59.0",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "scopeguard"
|
name = "scopeguard"
|
||||||
version = "1.2.0"
|
version = "1.2.0"
|
||||||
@ -1717,6 +2010,29 @@ version = "1.0.7"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "a3cf7c11c38cb994f3d40e8a8cde3bbd1f72a435e4c49e85d6553d8312306152"
|
checksum = "a3cf7c11c38cb994f3d40e8a8cde3bbd1f72a435e4c49e85d6553d8312306152"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "security-framework"
|
||||||
|
version = "2.11.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "897b2245f0b511c87893af39b033e5ca9cce68824c4d7e7630b5a1d339658d02"
|
||||||
|
dependencies = [
|
||||||
|
"bitflags 2.6.0",
|
||||||
|
"core-foundation",
|
||||||
|
"core-foundation-sys",
|
||||||
|
"libc",
|
||||||
|
"security-framework-sys",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "security-framework-sys"
|
||||||
|
version = "2.12.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "ea4a292869320c0272d7bc55a5a6aafaff59b4f63404a003887b679a2e05b4b6"
|
||||||
|
dependencies = [
|
||||||
|
"core-foundation-sys",
|
||||||
|
"libc",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "semver"
|
name = "semver"
|
||||||
version = "0.9.0"
|
version = "0.9.0"
|
||||||
@ -1778,6 +2094,18 @@ dependencies = [
|
|||||||
"serde",
|
"serde",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "serde_urlencoded"
|
||||||
|
version = "0.7.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "d3491c14715ca2294c4d6a88f15e84739788c1d030eed8c110436aafdaa2f3fd"
|
||||||
|
dependencies = [
|
||||||
|
"form_urlencoded",
|
||||||
|
"itoa",
|
||||||
|
"ryu",
|
||||||
|
"serde",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "serde_yaml"
|
name = "serde_yaml"
|
||||||
version = "0.8.26"
|
version = "0.8.26"
|
||||||
@ -1871,6 +2199,12 @@ dependencies = [
|
|||||||
"unicode-ident",
|
"unicode-ident",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "sync_wrapper"
|
||||||
|
version = "0.1.2"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "2047c6ded9c721764247e62cd3b03c09ffc529b2ba5b10ec482ae507a4a70160"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "synstructure"
|
name = "synstructure"
|
||||||
version = "0.12.6"
|
version = "0.12.6"
|
||||||
@ -1883,6 +2217,27 @@ dependencies = [
|
|||||||
"unicode-xid",
|
"unicode-xid",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "system-configuration"
|
||||||
|
version = "0.5.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "ba3a3adc5c275d719af8cb4272ea1c4a6d668a777f37e115f6d11ddbc1c8e0e7"
|
||||||
|
dependencies = [
|
||||||
|
"bitflags 1.3.2",
|
||||||
|
"core-foundation",
|
||||||
|
"system-configuration-sys",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "system-configuration-sys"
|
||||||
|
version = "0.5.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "a75fb188eb626b924683e3b95e3a48e63551fcfb51949de2f06a9d91dbee93c9"
|
||||||
|
dependencies = [
|
||||||
|
"core-foundation-sys",
|
||||||
|
"libc",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "system-deps"
|
name = "system-deps"
|
||||||
version = "6.2.2"
|
version = "6.2.2"
|
||||||
@ -1915,6 +2270,19 @@ version = "0.12.15"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "4873307b7c257eddcb50c9bedf158eb669578359fb28428bef438fec8e6ba7c2"
|
checksum = "4873307b7c257eddcb50c9bedf158eb669578359fb28428bef438fec8e6ba7c2"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "tempfile"
|
||||||
|
version = "3.12.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "04cbcdd0c794ebb0d4cf35e88edd2f7d2c4c3e9a5a6dab322839b321c6a87a64"
|
||||||
|
dependencies = [
|
||||||
|
"cfg-if 1.0.0",
|
||||||
|
"fastrand",
|
||||||
|
"once_cell",
|
||||||
|
"rustix",
|
||||||
|
"windows-sys 0.59.0",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "termcolor"
|
name = "termcolor"
|
||||||
version = "1.4.1"
|
version = "1.4.1"
|
||||||
@ -1960,6 +2328,21 @@ dependencies = [
|
|||||||
"syn 2.0.70",
|
"syn 2.0.70",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "tinyvec"
|
||||||
|
version = "1.8.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "445e881f4f6d382d5f27c034e25eb92edd7c784ceab92a0937db7f2e9471b938"
|
||||||
|
dependencies = [
|
||||||
|
"tinyvec_macros",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "tinyvec_macros"
|
||||||
|
version = "0.1.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "tokio"
|
name = "tokio"
|
||||||
version = "1.38.0"
|
version = "1.38.0"
|
||||||
@ -2022,6 +2405,16 @@ dependencies = [
|
|||||||
"syn 2.0.70",
|
"syn 2.0.70",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "tokio-native-tls"
|
||||||
|
version = "0.3.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "bbae76ab933c85776efabc971569dd6119c580d8f5d448769dec1764bf796ef2"
|
||||||
|
dependencies = [
|
||||||
|
"native-tls",
|
||||||
|
"tokio",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "tokio-reactor"
|
name = "tokio-reactor"
|
||||||
version = "0.1.12"
|
version = "0.1.12"
|
||||||
@ -2069,6 +2462,19 @@ dependencies = [
|
|||||||
"tokio-reactor",
|
"tokio-reactor",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "tokio-util"
|
||||||
|
version = "0.7.12"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "61e7c3654c13bcd040d4a03abee2c75b1d14a37b423cf5a813ceae1cc903ec6a"
|
||||||
|
dependencies = [
|
||||||
|
"bytes 1.6.0",
|
||||||
|
"futures-core",
|
||||||
|
"futures-sink",
|
||||||
|
"pin-project-lite",
|
||||||
|
"tokio",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "toml"
|
name = "toml"
|
||||||
version = "0.7.8"
|
version = "0.7.8"
|
||||||
@ -2139,6 +2545,31 @@ dependencies = [
|
|||||||
"winnow 0.6.13",
|
"winnow 0.6.13",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "tower-service"
|
||||||
|
version = "0.3.3"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "8df9b6e13f2d32c91b9bd719c00d1958837bc7dec474d94952798cc8e69eeec3"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "tracing"
|
||||||
|
version = "0.1.40"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "c3523ab5a71916ccf420eebdf5521fcef02141234bbc0b8a49f2fdc4544364ef"
|
||||||
|
dependencies = [
|
||||||
|
"pin-project-lite",
|
||||||
|
"tracing-core",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "tracing-core"
|
||||||
|
version = "0.1.32"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "c06d3da6113f116aaee68e4d601191614c9053067f9ab7f6edbcb161237daa54"
|
||||||
|
dependencies = [
|
||||||
|
"once_cell",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "triomphe"
|
name = "triomphe"
|
||||||
version = "0.1.13"
|
version = "0.1.13"
|
||||||
@ -2150,12 +2581,33 @@ dependencies = [
|
|||||||
"stable_deref_trait",
|
"stable_deref_trait",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "try-lock"
|
||||||
|
version = "0.2.5"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "e421abadd41a4225275504ea4d6566923418b7f05506fbc9c0fe86ba7396114b"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "unicode-bidi"
|
||||||
|
version = "0.3.15"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "08f95100a766bf4f8f28f90d77e0a5461bbdb219042e7679bebe79004fed8d75"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "unicode-ident"
|
name = "unicode-ident"
|
||||||
version = "1.0.12"
|
version = "1.0.12"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b"
|
checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "unicode-normalization"
|
||||||
|
version = "0.1.24"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "5033c97c4262335cded6d6fc3e5c18ab755e1a3dc96376350f3d8e9f009ad956"
|
||||||
|
dependencies = [
|
||||||
|
"tinyvec",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "unicode-width"
|
name = "unicode-width"
|
||||||
version = "0.1.13"
|
version = "0.1.13"
|
||||||
@ -2168,6 +2620,23 @@ version = "0.2.5"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "229730647fbc343e3a80e463c1db7f78f3855d3f3739bee0dda773c9a037c90a"
|
checksum = "229730647fbc343e3a80e463c1db7f78f3855d3f3739bee0dda773c9a037c90a"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "url"
|
||||||
|
version = "2.5.2"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "22784dbdf76fdde8af1aeda5622b546b422b6fc585325248a2bf9f5e41e94d6c"
|
||||||
|
dependencies = [
|
||||||
|
"form_urlencoded",
|
||||||
|
"idna",
|
||||||
|
"percent-encoding",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "vcpkg"
|
||||||
|
version = "0.2.15"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "accd4ea62f7bb7a82fe23066fb0957d48ef677f6eeb8215f372f52e48bb32426"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "version-compare"
|
name = "version-compare"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
@ -2190,6 +2659,15 @@ dependencies = [
|
|||||||
"winapi-util",
|
"winapi-util",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "want"
|
||||||
|
version = "0.3.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "bfa7760aed19e106de2c7c0b581b509f2f25d3dacaf737cb82ac61bc6d760b0e"
|
||||||
|
dependencies = [
|
||||||
|
"try-lock",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "wasi"
|
name = "wasi"
|
||||||
version = "0.11.0+wasi-snapshot-preview1"
|
version = "0.11.0+wasi-snapshot-preview1"
|
||||||
@ -2221,6 +2699,18 @@ dependencies = [
|
|||||||
"wasm-bindgen-shared",
|
"wasm-bindgen-shared",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "wasm-bindgen-futures"
|
||||||
|
version = "0.4.42"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "76bc14366121efc8dbb487ab05bcc9d346b3b5ec0eaa76e46594cabbe51762c0"
|
||||||
|
dependencies = [
|
||||||
|
"cfg-if 1.0.0",
|
||||||
|
"js-sys",
|
||||||
|
"wasm-bindgen",
|
||||||
|
"web-sys",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "wasm-bindgen-macro"
|
name = "wasm-bindgen-macro"
|
||||||
version = "0.2.92"
|
version = "0.2.92"
|
||||||
@ -2250,6 +2740,16 @@ version = "0.2.92"
|
|||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "af190c94f2773fdb3729c55b007a722abb5384da03bc0986df4c289bf5567e96"
|
checksum = "af190c94f2773fdb3729c55b007a722abb5384da03bc0986df4c289bf5567e96"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "web-sys"
|
||||||
|
version = "0.3.69"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "77afa9a11836342370f4817622a2f0f418b134426d91a82dfb48f532d2ec13ef"
|
||||||
|
dependencies = [
|
||||||
|
"js-sys",
|
||||||
|
"wasm-bindgen",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "winapi"
|
name = "winapi"
|
||||||
version = "0.2.8"
|
version = "0.2.8"
|
||||||
@ -2468,6 +2968,16 @@ dependencies = [
|
|||||||
"memchr",
|
"memchr",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "winreg"
|
||||||
|
version = "0.50.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "524e57b2c537c0f9b1e69f1965311ec12182b4122e45035b1508cd24d2adadb1"
|
||||||
|
dependencies = [
|
||||||
|
"cfg-if 1.0.0",
|
||||||
|
"windows-sys 0.48.0",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ws2_32-sys"
|
name = "ws2_32-sys"
|
||||||
version = "0.2.1"
|
version = "0.2.1"
|
||||||
|
@ -41,4 +41,5 @@ lock_api = "0.4.2"
|
|||||||
libflatpak = { version = "0.5.0", package = "libflatpak", features = ["v1_11_1"] }
|
libflatpak = { version = "0.5.0", package = "libflatpak", features = ["v1_11_1"] }
|
||||||
regex = "1.10.6"
|
regex = "1.10.6"
|
||||||
duct = "0.13.7"
|
duct = "0.13.7"
|
||||||
|
reqwest = { version = "0.11", features = ["blocking"] }
|
||||||
|
|
||||||
|
@ -125,5 +125,20 @@
|
|||||||
"unofficial_source_add_is_legacy_source_label_label": "Is A Source Repository",
|
"unofficial_source_add_is_legacy_source_label_label": "Is A Source Repository",
|
||||||
"apt_src_create_error_dialog_heading": "Could Not Save Changes: Error",
|
"apt_src_create_error_dialog_heading": "Could Not Save Changes: Error",
|
||||||
"apt_src_create_error_dialog_ok_label": "OK",
|
"apt_src_create_error_dialog_ok_label": "OK",
|
||||||
"system_mirror_save_button_tooltip_text": "Save Changes"
|
"flatpak_manage_page_title": "Flatpak Settings",
|
||||||
|
"system_mirror_save_button_tooltip_text": "Save Changes",
|
||||||
|
"flatpak_remotes_columnview_col0_title": "Remote Title",
|
||||||
|
"flatpak_remotes_columnview_col1_title": "Remote URL",
|
||||||
|
"flatpak_remotes_columnview_col2_title": "Remote Installation Type",
|
||||||
|
"flatpak_remotes_label": "Flatpak Remotes",
|
||||||
|
"flatpak_remotes_label1_label": "These Remotes Are for Software Provided via Flatpak. They May Present a Security Risk. Only Add Remotes That You Trust.",
|
||||||
|
"flatpak_remotes_columnview_system": "System",
|
||||||
|
"flatpak_remotes_columnview_user": "User",
|
||||||
|
"flatpak_remote_add_dialog_heading": "Add Flatpak Remote from URL",
|
||||||
|
"flatpak_remote_add_dialog_add_label": "Add Remote",
|
||||||
|
"flatpak_remote_add_dialog_cancel_label": "Cancel",
|
||||||
|
"flatpak_remote_add_error_dialog_heading": "Flatpak Remote Changes Failed Error:",
|
||||||
|
"flatpak_remote_add_error_dialog_ok_label": "OK",
|
||||||
|
"flatpak_remote_add_name_prefrencesgroup_title": "Remote Name",
|
||||||
|
"flatpak_remote_add_url_prefrencesgroup_title": "Remote Ref URL (flatpakrepo)"
|
||||||
}
|
}
|
@ -1,4 +1,5 @@
|
|||||||
use crate::apt_manage_page::apt_manage_page;
|
use crate::apt_manage_page::apt_manage_page;
|
||||||
|
use crate::flatpak_manage_page::flatpak_manage_page;
|
||||||
use crate::apt_update_page;
|
use crate::apt_update_page;
|
||||||
use crate::config::{APP_GITHUB, APP_ICON, APP_ID, VERSION};
|
use crate::config::{APP_GITHUB, APP_ICON, APP_ID, VERSION};
|
||||||
use crate::flatpak_update_page;
|
use crate::flatpak_update_page;
|
||||||
@ -310,7 +311,7 @@ pub fn build_ui(app: &Application) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
window_adw_stack.add_titled(
|
window_adw_stack.add_titled(
|
||||||
&apt_manage_page(window, &apt_retry_signal_action),
|
&apt_manage_page(window.clone(), &apt_retry_signal_action),
|
||||||
Some("apt_manage_page"),
|
Some("apt_manage_page"),
|
||||||
&t!("apt_manage_page_title"),
|
&t!("apt_manage_page_title"),
|
||||||
);
|
);
|
||||||
@ -319,6 +320,17 @@ pub fn build_ui(app: &Application) {
|
|||||||
add_content_button.clone()(false, "apt_manage_page".to_string(), t!("apt_manage_page_title").to_string());
|
add_content_button.clone()(false, "apt_manage_page".to_string(), t!("apt_manage_page_title").to_string());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
window_adw_stack.add_titled(
|
||||||
|
&flatpak_manage_page(window, &flatpak_retry_signal_action),
|
||||||
|
Some("flatpak_manage_page"),
|
||||||
|
&t!("flatpak_manage_page_title"),
|
||||||
|
);
|
||||||
|
|
||||||
|
{
|
||||||
|
add_content_button.clone()(false, "flatpak_manage_page".to_string(), t!("flatpak_manage_page_title").to_string());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// Refresh button
|
// Refresh button
|
||||||
|
|
||||||
refresh_button.connect_clicked(clone!(
|
refresh_button.connect_clicked(clone!(
|
||||||
@ -331,7 +343,9 @@ pub fn build_ui(app: &Application) {
|
|||||||
move |_| {
|
move |_| {
|
||||||
match window_adw_stack.visible_child_name().unwrap().as_str() {
|
match window_adw_stack.visible_child_name().unwrap().as_str() {
|
||||||
"apt_update_page" => apt_retry_signal_action.activate(None),
|
"apt_update_page" => apt_retry_signal_action.activate(None),
|
||||||
|
"apt_manage_page" => apt_retry_signal_action.activate(None),
|
||||||
"flatpak_update_page" => flatpak_retry_signal_action.activate(None),
|
"flatpak_update_page" => flatpak_retry_signal_action.activate(None),
|
||||||
|
"flatpak_manage_page" => flatpak_retry_signal_action.activate(None),
|
||||||
_ => {}
|
_ => {}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2,7 +2,8 @@ use crate::apt_package_row::AptPackageRow;
|
|||||||
use adw::gio::SimpleAction;
|
use adw::gio::SimpleAction;
|
||||||
use adw::prelude::*;
|
use adw::prelude::*;
|
||||||
use apt_deb822_tools::Deb822Repository;
|
use apt_deb822_tools::Deb822Repository;
|
||||||
use regex::Regex;
|
use libflatpak::builders::RemoteRefBuilder;
|
||||||
|
use regex::{bytes, Regex};
|
||||||
use gtk::glib::{property::PropertyGet, clone, BoxedAnyObject};
|
use gtk::glib::{property::PropertyGet, clone, BoxedAnyObject};
|
||||||
use gtk::*;
|
use gtk::*;
|
||||||
use std::cell::Ref;
|
use std::cell::Ref;
|
||||||
@ -16,196 +17,126 @@ use std::process::Command;
|
|||||||
use std::rc::Rc;
|
use std::rc::Rc;
|
||||||
use std::thread;
|
use std::thread;
|
||||||
use tokio::runtime::Runtime;
|
use tokio::runtime::Runtime;
|
||||||
|
use libflatpak::prelude::*;
|
||||||
|
use libflatpak::InstalledRef;
|
||||||
|
|
||||||
pub fn add_dialog_fn(
|
pub fn add_dialog_fn(
|
||||||
window: adw::ApplicationWindow,
|
window: adw::ApplicationWindow,
|
||||||
reload_action: &gio::SimpleAction
|
reload_action: &gio::SimpleAction
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
let unofficial_source_add_dialog_child_box = Box::builder()
|
let flatpak_remote_add_dialog_child_box = Box::builder()
|
||||||
.hexpand(true)
|
.hexpand(true)
|
||||||
.orientation(Orientation::Vertical)
|
.orientation(Orientation::Vertical)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
let unofficial_source_add_name_entry = gtk::Entry::builder()
|
let flatpak_remote_add_name_entry = gtk::Entry::builder()
|
||||||
.placeholder_text("WineHQ Debian")
|
.placeholder_text("Flathub")
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
let unofficial_source_add_name_prefrencesgroup = adw::PreferencesGroup::builder()
|
let flatpak_remote_add_name_prefrencesgroup = adw::PreferencesGroup::builder()
|
||||||
.title(t!("unofficial_source_add_name_prefrencesgroup_title"))
|
.title(t!("flatpak_remote_add_name_prefrencesgroup_title"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
unofficial_source_add_name_prefrencesgroup.add(&unofficial_source_add_name_entry);
|
flatpak_remote_add_name_prefrencesgroup.add(&flatpak_remote_add_name_entry);
|
||||||
|
|
||||||
let unofficial_source_add_uri_entry = gtk::Entry::builder()
|
let flatpak_remote_add_url_entry = gtk::Entry::builder()
|
||||||
.placeholder_text("https://dl.winehq.org/wine-builds/debian")
|
.placeholder_text("https://dl.flathub.org/repo/flathub.flatpakrepo")
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
let unofficial_source_add_uri_prefrencesgroup = adw::PreferencesGroup::builder()
|
let flatpak_remote_add_url_prefrencesgroup = adw::PreferencesGroup::builder()
|
||||||
.title(t!("unofficial_source_add_uri_prefrencesgroup_title"))
|
.title(t!("flatpak_remote_add_url_prefrencesgroup_title"))
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
unofficial_source_add_uri_prefrencesgroup.add(&unofficial_source_add_uri_entry);
|
flatpak_remote_add_url_prefrencesgroup.add(&flatpak_remote_add_url_entry);
|
||||||
|
|
||||||
let unofficial_source_add_suites_entry = gtk::Entry::builder()
|
let flatpak_remote_add_box2 = gtk::Box::builder()
|
||||||
.placeholder_text("trixie bookworm sid")
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_suites_prefrencesgroup = adw::PreferencesGroup::builder()
|
|
||||||
.title(t!("unofficial_source_add_suites_prefrencesgroup_title"))
|
|
||||||
.build();
|
|
||||||
|
|
||||||
unofficial_source_add_suites_prefrencesgroup.add(&unofficial_source_add_suites_entry);
|
|
||||||
|
|
||||||
let unofficial_source_add_components_entry = gtk::Entry::builder()
|
|
||||||
.placeholder_text("main proprietary")
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_components_prefrencesgroup = adw::PreferencesGroup::builder()
|
|
||||||
.title(t!("unofficial_source_add_components_prefrencesgroup_title"))
|
|
||||||
.build();
|
|
||||||
|
|
||||||
unofficial_source_add_components_prefrencesgroup.add(&unofficial_source_add_components_entry);
|
|
||||||
|
|
||||||
let unofficial_source_add_signed_entry = gtk::Entry::builder()
|
|
||||||
.sensitive(false)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_signed_prefrencesgroup = adw::PreferencesGroup::builder()
|
|
||||||
.title(t!("unofficial_source_add_signed_prefrencesgroup_title"))
|
|
||||||
.build();
|
|
||||||
|
|
||||||
unofficial_source_add_signed_prefrencesgroup.add(&unofficial_source_add_signed_entry);
|
|
||||||
|
|
||||||
let unofficial_source_add_archs_entry = gtk::Entry::builder()
|
|
||||||
.placeholder_text("amd64 arm64 i386")
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_archs_prefrencesgroup = adw::PreferencesGroup::builder()
|
|
||||||
.title(t!("unofficial_source_add_archs_prefrencesgroup_title"))
|
|
||||||
.build();
|
|
||||||
|
|
||||||
unofficial_source_add_archs_prefrencesgroup.add(&unofficial_source_add_archs_entry);
|
|
||||||
|
|
||||||
let unofficial_source_add_box2 = gtk::Box::builder()
|
|
||||||
.margin_top(10)
|
.margin_top(10)
|
||||||
.orientation(Orientation::Horizontal)
|
.orientation(Orientation::Horizontal)
|
||||||
.hexpand(true)
|
.hexpand(true)
|
||||||
.spacing(5)
|
.spacing(5)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
let unofficial_source_add_is_source_label = gtk::Label::builder()
|
let flatpak_remote_user_togglebutton = gtk::ToggleButton::builder()
|
||||||
.label(t!("unofficial_source_add_is_source_label_label"))
|
|
||||||
.halign(Align::Start)
|
|
||||||
.valign(Align::Center)
|
.valign(Align::Center)
|
||||||
.build();
|
.hexpand(true)
|
||||||
|
.label(t!("flatpak_remotes_columnview_user"))
|
||||||
let unofficial_source_add_is_source_switch = gtk::Switch::builder()
|
|
||||||
.halign(Align::Start)
|
|
||||||
.valign(Align::Center)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_signed_keyring_checkbutton = gtk::CheckButton::builder()
|
|
||||||
.halign(Align::Start)
|
|
||||||
.valign(Align::Center)
|
|
||||||
.label(t!("unofficial_source_signed_keyring_checkbutton_label"))
|
|
||||||
.active(true)
|
.active(true)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
let unofficial_source_signed_file_checkbutton = gtk::CheckButton::builder()
|
let flatpak_remote_system_togglebutton = gtk::ToggleButton::builder()
|
||||||
.halign(Align::Start)
|
|
||||||
.valign(Align::Center)
|
.valign(Align::Center)
|
||||||
.label(t!("unofficial_source_signed_file_checkbutton_label"))
|
.hexpand(true)
|
||||||
.group(&unofficial_source_signed_keyring_checkbutton)
|
.label(t!("flatpak_remotes_columnview_system"))
|
||||||
.build();
|
.group(&flatpak_remote_user_togglebutton)
|
||||||
|
|
||||||
let unofficial_source_signed_url_checkbutton = gtk::CheckButton::builder()
|
|
||||||
.halign(Align::Start)
|
|
||||||
.valign(Align::Center)
|
|
||||||
.label(t!("unofficial_source_signed_url_checkbutton_label"))
|
|
||||||
.group(&unofficial_source_signed_keyring_checkbutton)
|
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
//
|
//
|
||||||
let unofficial_source_add_dialog_child_clamp = adw::Clamp::builder()
|
let flatpak_remote_add_dialog_child_clamp = adw::Clamp::builder()
|
||||||
.child(&unofficial_source_add_dialog_child_box)
|
.child(&flatpak_remote_add_dialog_child_box)
|
||||||
.maximum_size(500)
|
.maximum_size(500)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
let unofficial_source_add_viewport = gtk::ScrolledWindow::builder()
|
let flatpak_remote_add_viewport = gtk::ScrolledWindow::builder()
|
||||||
.hexpand(true)
|
.hexpand(true)
|
||||||
.vexpand(true)
|
.vexpand(true)
|
||||||
.child(&unofficial_source_add_dialog_child_clamp)
|
.child(&flatpak_remote_add_dialog_child_clamp)
|
||||||
.hscrollbar_policy(PolicyType::Never)
|
.hscrollbar_policy(PolicyType::Never)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
let unofficial_source_add_dialog = adw::MessageDialog::builder()
|
let flatpak_remote_add_dialog = adw::MessageDialog::builder()
|
||||||
.transient_for(&window)
|
.transient_for(&window)
|
||||||
.extra_child(&unofficial_source_add_viewport)
|
.extra_child(&flatpak_remote_add_viewport)
|
||||||
.heading(t!("unofficial_source_add_dialog_heading"))
|
.heading(t!("flatpak_remote_add_dialog_heading"))
|
||||||
.width_request(700)
|
.width_request(700)
|
||||||
.height_request(500)
|
.height_request(400)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
unofficial_source_add_dialog.add_response(
|
flatpak_remote_add_dialog.add_response(
|
||||||
"unofficial_source_add_dialog_add",
|
"flatpak_remote_add_dialog_add",
|
||||||
&t!("unofficial_source_add_dialog_add_label").to_string(),
|
&t!("flatpak_remote_add_dialog_add_label").to_string(),
|
||||||
);
|
);
|
||||||
|
|
||||||
unofficial_source_add_dialog.add_response(
|
flatpak_remote_add_dialog.add_response(
|
||||||
"unofficial_source_add_dialog_cancel",
|
"flatpak_remote_add_dialog_cancel",
|
||||||
&t!("unofficial_source_add_dialog_cancel_label").to_string(),
|
&t!("flatpak_remote_add_dialog_cancel_label").to_string(),
|
||||||
);
|
);
|
||||||
|
|
||||||
unofficial_source_add_dialog.set_response_enabled("unofficial_source_add_dialog_add", false);
|
flatpak_remote_add_dialog.set_response_enabled("flatpak_remote_add_dialog_add", false);
|
||||||
|
|
||||||
unofficial_source_add_dialog.set_response_appearance(
|
flatpak_remote_add_dialog.set_response_appearance(
|
||||||
"unofficial_source_add_dialog_cancel",
|
"flatpak_remote_add_dialog_cancel",
|
||||||
adw::ResponseAppearance::Destructive,
|
adw::ResponseAppearance::Destructive,
|
||||||
);
|
);
|
||||||
|
|
||||||
unofficial_source_add_dialog.set_response_appearance(
|
flatpak_remote_add_dialog.set_response_appearance(
|
||||||
"unofficial_source_add_dialog_add",
|
"flatpak_remote_add_dialog_add",
|
||||||
adw::ResponseAppearance::Suggested,
|
adw::ResponseAppearance::Suggested,
|
||||||
);
|
);
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
||||||
let unofficial_source_add_dialog_clone0 = unofficial_source_add_dialog.clone();
|
let flatpak_remote_add_dialog_clone0 = flatpak_remote_add_dialog.clone();
|
||||||
let unofficial_source_add_name_entry_clone0 = unofficial_source_add_name_entry.clone();
|
let flatpak_remote_add_name_entry_clone0 = flatpak_remote_add_name_entry.clone();
|
||||||
let unofficial_source_add_uri_entry_clone0 = unofficial_source_add_uri_entry.clone();
|
let flatpak_remote_add_url_entry_clone0 = flatpak_remote_add_url_entry.clone();
|
||||||
let unofficial_source_add_suites_entry_clone0 = unofficial_source_add_suites_entry.clone();
|
|
||||||
let unofficial_source_add_components_entry_clone0 = unofficial_source_add_components_entry.clone();
|
|
||||||
let unofficial_source_add_signed_entry_clone0 = unofficial_source_add_signed_entry.clone();
|
|
||||||
let unofficial_source_signed_keyring_checkbutton_clone0 = unofficial_source_signed_keyring_checkbutton.clone();
|
|
||||||
|
|
||||||
let add_button_update_state = move || {
|
let add_button_update_state = move || {
|
||||||
if
|
if
|
||||||
!unofficial_source_add_name_entry_clone0.text().is_empty() &&
|
!flatpak_remote_add_name_entry_clone0.text().is_empty() &&
|
||||||
!unofficial_source_add_uri_entry_clone0.text().is_empty() &&
|
!flatpak_remote_add_url_entry_clone0.text().is_empty()
|
||||||
!unofficial_source_add_suites_entry_clone0.text().is_empty() &&
|
|
||||||
!unofficial_source_add_components_entry_clone0.text().is_empty()
|
|
||||||
{
|
{
|
||||||
if unofficial_source_signed_keyring_checkbutton_clone0.is_active() {
|
flatpak_remote_add_dialog_clone0.set_response_enabled("flatpak_remote_add_dialog_add", true);
|
||||||
unofficial_source_add_dialog_clone0.set_response_enabled("unofficial_source_add_dialog_add", true);
|
|
||||||
} else if !unofficial_source_add_signed_entry_clone0.text().is_empty() {
|
|
||||||
unofficial_source_add_dialog_clone0.set_response_enabled("unofficial_source_add_dialog_add", true);
|
|
||||||
} else {
|
} else {
|
||||||
unofficial_source_add_dialog_clone0.set_response_enabled("unofficial_source_add_dialog_add", false);
|
flatpak_remote_add_dialog_clone0.set_response_enabled("flatpak_remote_add_dialog_add", false);
|
||||||
}
|
|
||||||
} else {
|
|
||||||
unofficial_source_add_dialog_clone0.set_response_enabled("unofficial_source_add_dialog_add", false);
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
||||||
for entry in [
|
for entry in [
|
||||||
&unofficial_source_add_name_entry,
|
&flatpak_remote_add_name_entry,
|
||||||
&unofficial_source_add_uri_entry,
|
&flatpak_remote_add_url_entry,
|
||||||
&unofficial_source_add_suites_entry,
|
|
||||||
&unofficial_source_add_components_entry,
|
|
||||||
&unofficial_source_add_signed_entry,
|
|
||||||
] {
|
] {
|
||||||
entry.connect_text_notify(clone!(
|
entry.connect_text_notify(clone!(
|
||||||
#[strong]
|
#[strong]
|
||||||
@ -220,172 +151,54 @@ pub fn add_dialog_fn(
|
|||||||
|
|
||||||
//
|
//
|
||||||
|
|
||||||
unofficial_source_signed_keyring_checkbutton.connect_toggled(clone!(
|
flatpak_remote_add_box2.append(&flatpak_remote_user_togglebutton);
|
||||||
#[weak]
|
flatpak_remote_add_box2.append(&flatpak_remote_system_togglebutton);
|
||||||
unofficial_source_add_signed_entry,
|
|
||||||
#[strong]
|
|
||||||
add_button_update_state,
|
|
||||||
move |checkbutton|
|
|
||||||
{
|
|
||||||
if checkbutton.is_active() {
|
|
||||||
unofficial_source_add_signed_entry.set_sensitive(false);
|
|
||||||
unofficial_source_add_signed_entry.set_placeholder_text(Some(""));
|
|
||||||
add_button_update_state();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
unofficial_source_signed_file_checkbutton.connect_toggled(clone!(
|
flatpak_remote_add_dialog_child_box.append(&flatpak_remote_add_name_prefrencesgroup);
|
||||||
#[weak]
|
flatpak_remote_add_dialog_child_box.append(&flatpak_remote_add_url_prefrencesgroup);
|
||||||
unofficial_source_add_signed_entry,
|
flatpak_remote_add_dialog_child_box.append(&flatpak_remote_add_box2);
|
||||||
#[strong]
|
|
||||||
add_button_update_state,
|
|
||||||
move |checkbutton|
|
|
||||||
{
|
|
||||||
if checkbutton.is_active() {
|
|
||||||
unofficial_source_add_signed_entry.set_sensitive(true);
|
|
||||||
unofficial_source_add_signed_entry.set_placeholder_text(Some("/etc/apt/keyrings/winehq-archive.key"));
|
|
||||||
add_button_update_state();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
unofficial_source_signed_url_checkbutton.connect_toggled(clone!(
|
|
||||||
#[weak]
|
|
||||||
unofficial_source_add_signed_entry,
|
|
||||||
#[strong]
|
|
||||||
add_button_update_state,
|
|
||||||
move |checkbutton|
|
|
||||||
{
|
|
||||||
if checkbutton.is_active() {
|
|
||||||
unofficial_source_add_signed_entry.set_sensitive(true);
|
|
||||||
unofficial_source_add_signed_entry.set_placeholder_text(Some("https://dl.winehq.org/wine-builds/winehq.key"));
|
|
||||||
add_button_update_state();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
unofficial_source_add_box2.append(&unofficial_source_add_is_source_label);
|
|
||||||
unofficial_source_add_box2.append(&unofficial_source_add_is_source_switch);
|
|
||||||
unofficial_source_add_box2.append(&unofficial_source_signed_keyring_checkbutton);
|
|
||||||
unofficial_source_add_box2.append(&unofficial_source_signed_file_checkbutton);
|
|
||||||
unofficial_source_add_box2.append(&unofficial_source_signed_url_checkbutton);
|
|
||||||
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_name_prefrencesgroup);
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_uri_prefrencesgroup);
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_suites_prefrencesgroup);
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_components_prefrencesgroup);
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_archs_prefrencesgroup);
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_box2);
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_signed_prefrencesgroup);
|
|
||||||
|
|
||||||
let reload_action_clone0 = reload_action.clone();
|
let reload_action_clone0 = reload_action.clone();
|
||||||
|
|
||||||
unofficial_source_add_dialog.clone()
|
flatpak_remote_add_dialog.clone()
|
||||||
.choose(None::<&gio::Cancellable>, move |choice| {
|
.choose(None::<&gio::Cancellable>, move |choice| {
|
||||||
match choice.as_str() {
|
match choice.as_str() {
|
||||||
"unofficial_source_add_dialog_add" => {
|
"flatpak_remote_add_dialog_add" => {
|
||||||
let non_alphanum_regex = Regex::new(r"[^a-zA-Z0-9]").unwrap();
|
let cancellable_no = libflatpak::gio::Cancellable::NONE;
|
||||||
let sign_method = if unofficial_source_signed_file_checkbutton.is_active() {
|
|
||||||
1
|
let flatpak_installation = match flatpak_remote_system_togglebutton.is_active() {
|
||||||
} else if unofficial_source_signed_url_checkbutton.is_active() {
|
true => libflatpak::Installation::new_system(cancellable_no).unwrap(),
|
||||||
2
|
false => libflatpak::Installation::new_user(cancellable_no).unwrap(),
|
||||||
} else {
|
|
||||||
0
|
|
||||||
};
|
};
|
||||||
let repo_file_name = non_alphanum_regex.replace_all(unofficial_source_add_name_entry.text().as_str(), "_").to_string().to_lowercase();
|
|
||||||
let new_repo = Deb822Repository {
|
match libflatpak::Remote::from_file(&flatpak_remote_add_name_entry.text(), &get_data_from_url(&flatpak_remote_add_url_entry.text()).unwrap()) {
|
||||||
repolib_name: Some(unofficial_source_add_name_entry.text().to_string()),
|
Ok(remote) => {
|
||||||
filepath: format!("/etc/apt/sources.list.d/{}.source", repo_file_name),
|
match libflatpak::Installation::add_remote(&flatpak_installation, &remote, true, cancellable_no) {
|
||||||
uris: Some(unofficial_source_add_uri_entry.text().to_string()),
|
|
||||||
types: if unofficial_source_add_is_source_switch.is_active() {
|
|
||||||
Some("deb deb-src".to_string())
|
|
||||||
} else {
|
|
||||||
Some("deb".to_string())
|
|
||||||
},
|
|
||||||
suites: Some(unofficial_source_add_suites_entry.text().to_string()),
|
|
||||||
components: Some(unofficial_source_add_components_entry.text().to_string()),
|
|
||||||
architectures: if unofficial_source_add_archs_entry.text().is_empty() {
|
|
||||||
None
|
|
||||||
} else {
|
|
||||||
Some(unofficial_source_add_archs_entry.text().to_string())
|
|
||||||
},
|
|
||||||
signed_by: match sign_method {
|
|
||||||
1 => Some(unofficial_source_add_signed_entry.text().to_string()),
|
|
||||||
2 => Some(format!("/etc/apt/keyrings/{}.gpg.key", repo_file_name)),
|
|
||||||
_ => None
|
|
||||||
},
|
|
||||||
..Default::default()
|
|
||||||
};
|
|
||||||
if sign_method == 2 {
|
|
||||||
match Deb822Repository::write_to_file(new_repo.clone(), format!("/tmp/{}.sources", repo_file_name).into()) {
|
|
||||||
Ok(_) => {
|
|
||||||
match duct::cmd!("pkexec", "/usr/lib/pika/pikman-update-manager/scripts/modify_repo.sh", "deb822_move_with_wget", &repo_file_name, &unofficial_source_add_signed_entry.text().to_string(), &format!("/etc/apt/keyrings/{}.gpg.key", &repo_file_name)).run() {
|
|
||||||
Ok(_) => {
|
Ok(_) => {
|
||||||
reload_action_clone0.activate(None);
|
reload_action_clone0.activate(None);
|
||||||
}
|
}
|
||||||
Err(e) => {
|
Err(e) => {
|
||||||
let apt_src_create_error_dialog = adw::MessageDialog::builder()
|
let flatpak_remote_add_error_dialog = adw::MessageDialog::builder()
|
||||||
.heading(t!("apt_src_create_error_dialog_heading"))
|
.heading(t!("flatpak_remote_add_error_dialog_heading"))
|
||||||
.body(e.to_string())
|
.body(e.to_string())
|
||||||
.build();
|
.build();
|
||||||
apt_src_create_error_dialog.add_response(
|
flatpak_remote_add_error_dialog.add_response(
|
||||||
"apt_src_create_error_dialog_ok",
|
"flatpak_remote_add_error_dialog_ok",
|
||||||
&t!("apt_src_create_error_dialog_ok_label").to_string(),
|
&t!("flatpak_remote_add_error_dialog_ok_label").to_string(),
|
||||||
);
|
);
|
||||||
apt_src_create_error_dialog.present();
|
flatpak_remote_add_error_dialog.present();
|
||||||
reload_action_clone0.activate(None);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Err(e) => {
|
Err(e) => {
|
||||||
let apt_src_create_error_dialog = adw::MessageDialog::builder()
|
let flatpak_remote_add_error_dialog = adw::MessageDialog::builder()
|
||||||
.heading(t!("apt_src_create_error_dialog_heading"))
|
.heading(t!("flatpak_remote_add_error_dialog_heading"))
|
||||||
.body(e.to_string())
|
.body(e.to_string())
|
||||||
.build();
|
.build();
|
||||||
apt_src_create_error_dialog.add_response(
|
flatpak_remote_add_error_dialog.add_response(
|
||||||
"apt_src_create_error_dialog_ok",
|
"flatpak_remote_add_error_dialog_ok",
|
||||||
&t!("apt_src_create_error_dialog_ok_label").to_string(),
|
&t!("flatpak_remote_add_error_dialog_ok_label").to_string(),
|
||||||
);
|
);
|
||||||
apt_src_create_error_dialog.present();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
match Deb822Repository::write_to_file(new_repo.clone(), format!("/tmp/{}.sources", repo_file_name).into()) {
|
|
||||||
Ok(_) => {
|
|
||||||
match duct::cmd!("pkexec", "/usr/lib/pika/pikman-update-manager/scripts/modify_repo.sh", "deb822_move", repo_file_name).run() {
|
|
||||||
Ok(_) => {
|
|
||||||
reload_action_clone0.activate(None);
|
|
||||||
}
|
|
||||||
Err(e) => {
|
|
||||||
let apt_src_create_error_dialog = adw::MessageDialog::builder()
|
|
||||||
.heading(t!("apt_src_create_error_dialog_heading"))
|
|
||||||
.body(e.to_string())
|
|
||||||
.build();
|
|
||||||
apt_src_create_error_dialog.add_response(
|
|
||||||
"apt_src_create_error_dialog_ok",
|
|
||||||
&t!("apt_src_create_error_dialog_ok_label").to_string(),
|
|
||||||
);
|
|
||||||
apt_src_create_error_dialog.present();
|
|
||||||
reload_action_clone0.activate(None);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Err(e) => {
|
|
||||||
let apt_src_create_error_dialog = adw::MessageDialog::builder()
|
|
||||||
.heading(t!("apt_src_create_error_dialog_heading"))
|
|
||||||
.body(e.to_string())
|
|
||||||
.build();
|
|
||||||
apt_src_create_error_dialog.add_response(
|
|
||||||
"apt_src_create_error_dialog_ok",
|
|
||||||
&t!("apt_src_create_error_dialog_ok_label").to_string(),
|
|
||||||
);
|
|
||||||
apt_src_create_error_dialog.present();
|
|
||||||
reload_action_clone0.activate(None);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -393,3 +206,14 @@ pub fn add_dialog_fn(
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn get_data_from_url(url: &str) -> Result<libflatpak::glib::Bytes, reqwest::Error> {
|
||||||
|
let data = reqwest::blocking::get(url)?
|
||||||
|
.text()
|
||||||
|
.unwrap();
|
||||||
|
|
||||||
|
let bytes = data.as_bytes();
|
||||||
|
|
||||||
|
let glib_bytes = libflatpak::glib::Bytes::from(bytes);
|
||||||
|
Ok(glib_bytes)
|
||||||
|
}
|
@ -1,416 +0,0 @@
|
|||||||
use crate::apt_package_row::AptPackageRow;
|
|
||||||
use adw::gio::SimpleAction;
|
|
||||||
use adw::prelude::*;
|
|
||||||
use apt_deb822_tools::Deb822Repository;
|
|
||||||
use regex::Regex;
|
|
||||||
use gtk::glib::{property::PropertyGet, clone, BoxedAnyObject};
|
|
||||||
use gtk::*;
|
|
||||||
use std::cell::Ref;
|
|
||||||
use std::ops::Deref;
|
|
||||||
use pika_unixsocket_tools::pika_unixsocket_tools::*;
|
|
||||||
use rust_apt::cache::*;
|
|
||||||
use rust_apt::new_cache;
|
|
||||||
use rust_apt::records::RecordField;
|
|
||||||
use std::cell::RefCell;
|
|
||||||
use std::process::Command;
|
|
||||||
use std::rc::Rc;
|
|
||||||
use std::thread;
|
|
||||||
use tokio::runtime::Runtime;
|
|
||||||
use std::path::Path;
|
|
||||||
|
|
||||||
pub fn deb822_edit_dialog_fn(
|
|
||||||
window: adw::ApplicationWindow,
|
|
||||||
deb822_repo: &Deb822Repository,
|
|
||||||
reload_action: &gio::SimpleAction,
|
|
||||||
) {
|
|
||||||
let repofile_path = Path::new(&deb822_repo.filepath);
|
|
||||||
let repo_file_name = repofile_path
|
|
||||||
.file_name()
|
|
||||||
.unwrap()
|
|
||||||
.to_str()
|
|
||||||
.unwrap()
|
|
||||||
.trim_end_matches(".sources")
|
|
||||||
.to_owned();
|
|
||||||
|
|
||||||
let unofficial_source_add_dialog_child_box = Box::builder()
|
|
||||||
.hexpand(true)
|
|
||||||
.orientation(Orientation::Vertical)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_name_entry = gtk::Entry::builder()
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_name_prefrencesgroup = adw::PreferencesGroup::builder()
|
|
||||||
.title(t!("unofficial_source_add_name_prefrencesgroup_title"))
|
|
||||||
.build();
|
|
||||||
|
|
||||||
unofficial_source_add_name_prefrencesgroup.add(&unofficial_source_add_name_entry);
|
|
||||||
|
|
||||||
let unofficial_source_add_uri_entry = gtk::Entry::builder()
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_uri_prefrencesgroup = adw::PreferencesGroup::builder()
|
|
||||||
.title(t!("unofficial_source_add_uri_prefrencesgroup_title"))
|
|
||||||
.build();
|
|
||||||
|
|
||||||
unofficial_source_add_uri_prefrencesgroup.add(&unofficial_source_add_uri_entry);
|
|
||||||
|
|
||||||
let unofficial_source_add_suites_entry = gtk::Entry::builder()
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_suites_prefrencesgroup = adw::PreferencesGroup::builder()
|
|
||||||
.title(t!("unofficial_source_add_suites_prefrencesgroup_title"))
|
|
||||||
.build();
|
|
||||||
|
|
||||||
unofficial_source_add_suites_prefrencesgroup.add(&unofficial_source_add_suites_entry);
|
|
||||||
|
|
||||||
let unofficial_source_add_components_entry = gtk::Entry::builder()
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_components_prefrencesgroup = adw::PreferencesGroup::builder()
|
|
||||||
.title(t!("unofficial_source_add_components_prefrencesgroup_title"))
|
|
||||||
.build();
|
|
||||||
|
|
||||||
unofficial_source_add_components_prefrencesgroup.add(&unofficial_source_add_components_entry);
|
|
||||||
|
|
||||||
let unofficial_source_add_signed_entry = gtk::Entry::builder()
|
|
||||||
.sensitive(false)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_signed_prefrencesgroup = adw::PreferencesGroup::builder()
|
|
||||||
.title(t!("unofficial_source_add_signed_prefrencesgroup_title"))
|
|
||||||
.build();
|
|
||||||
|
|
||||||
unofficial_source_add_signed_prefrencesgroup.add(&unofficial_source_add_signed_entry);
|
|
||||||
|
|
||||||
let unofficial_source_add_archs_entry = gtk::Entry::builder()
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_archs_prefrencesgroup = adw::PreferencesGroup::builder()
|
|
||||||
.title(t!("unofficial_source_add_archs_prefrencesgroup_title"))
|
|
||||||
.build();
|
|
||||||
|
|
||||||
unofficial_source_add_archs_prefrencesgroup.add(&unofficial_source_add_archs_entry);
|
|
||||||
|
|
||||||
let unofficial_source_add_box2 = gtk::Box::builder()
|
|
||||||
.margin_top(10)
|
|
||||||
.orientation(Orientation::Horizontal)
|
|
||||||
.hexpand(true)
|
|
||||||
.spacing(5)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_is_source_label = gtk::Label::builder()
|
|
||||||
.label(t!("unofficial_source_add_is_source_label_label"))
|
|
||||||
.halign(Align::Start)
|
|
||||||
.valign(Align::Center)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
|
|
||||||
let unofficial_source_add_is_enabled_label = gtk::Label::builder()
|
|
||||||
.label(t!("unofficial_source_add_is_enabled_label_label"))
|
|
||||||
.halign(Align::Start)
|
|
||||||
.valign(Align::Center)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_is_source_switch = gtk::Switch::builder()
|
|
||||||
.halign(Align::Start)
|
|
||||||
.valign(Align::Center)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_is_enabled_switch = gtk::Switch::builder()
|
|
||||||
.halign(Align::Start)
|
|
||||||
.valign(Align::Center)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_signed_keyring_checkbutton = gtk::CheckButton::builder()
|
|
||||||
.halign(Align::Start)
|
|
||||||
.valign(Align::Center)
|
|
||||||
.label(t!("unofficial_source_signed_keyring_checkbutton_label"))
|
|
||||||
.active(true)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_signed_file_checkbutton = gtk::CheckButton::builder()
|
|
||||||
.halign(Align::Start)
|
|
||||||
.valign(Align::Center)
|
|
||||||
.label(t!("unofficial_source_signed_file_checkbutton_label"))
|
|
||||||
.group(&unofficial_source_signed_keyring_checkbutton)
|
|
||||||
.build();
|
|
||||||
//
|
|
||||||
let unofficial_source_add_dialog_child_clamp = adw::Clamp::builder()
|
|
||||||
.child(&unofficial_source_add_dialog_child_box)
|
|
||||||
.maximum_size(500)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_viewport = gtk::ScrolledWindow::builder()
|
|
||||||
.hexpand(true)
|
|
||||||
.vexpand(true)
|
|
||||||
.child(&unofficial_source_add_dialog_child_clamp)
|
|
||||||
.hscrollbar_policy(PolicyType::Never)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_dialog = adw::MessageDialog::builder()
|
|
||||||
.transient_for(&window)
|
|
||||||
.extra_child(&unofficial_source_add_viewport)
|
|
||||||
.heading(t!("unofficial_source_edit_dialog_heading").to_string() + " " + &repo_file_name)
|
|
||||||
.width_request(700)
|
|
||||||
.height_request(500)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
unofficial_source_add_dialog.add_response(
|
|
||||||
"unofficial_source_edit_dialog_edit",
|
|
||||||
&t!("unofficial_source_edit_dialog_add_edit").to_string(),
|
|
||||||
);
|
|
||||||
|
|
||||||
unofficial_source_add_dialog.add_response(
|
|
||||||
"unofficial_source_add_dialog_cancel",
|
|
||||||
&t!("unofficial_source_add_dialog_cancel_label").to_string(),
|
|
||||||
);
|
|
||||||
|
|
||||||
unofficial_source_add_dialog.set_response_enabled("unofficial_source_add_dialog_add", false);
|
|
||||||
|
|
||||||
unofficial_source_add_dialog.set_response_appearance(
|
|
||||||
"unofficial_source_add_dialog_cancel",
|
|
||||||
adw::ResponseAppearance::Destructive,
|
|
||||||
);
|
|
||||||
|
|
||||||
unofficial_source_add_dialog.set_response_appearance(
|
|
||||||
"unofficial_source_edit_dialog_edit",
|
|
||||||
adw::ResponseAppearance::Suggested,
|
|
||||||
);
|
|
||||||
|
|
||||||
//
|
|
||||||
|
|
||||||
let unofficial_source_add_dialog_clone0 = unofficial_source_add_dialog.clone();
|
|
||||||
let unofficial_source_add_name_entry_clone0 = unofficial_source_add_name_entry.clone();
|
|
||||||
let unofficial_source_add_uri_entry_clone0 = unofficial_source_add_uri_entry.clone();
|
|
||||||
let unofficial_source_add_suites_entry_clone0 = unofficial_source_add_suites_entry.clone();
|
|
||||||
let unofficial_source_add_components_entry_clone0 = unofficial_source_add_components_entry.clone();
|
|
||||||
let unofficial_source_add_signed_entry_clone0 = unofficial_source_add_signed_entry.clone();
|
|
||||||
let unofficial_source_signed_keyring_checkbutton_clone0 = unofficial_source_signed_keyring_checkbutton.clone();
|
|
||||||
|
|
||||||
let add_button_update_state = move || {
|
|
||||||
if
|
|
||||||
!unofficial_source_add_name_entry_clone0.text().is_empty() &&
|
|
||||||
!unofficial_source_add_uri_entry_clone0.text().is_empty() &&
|
|
||||||
!unofficial_source_add_suites_entry_clone0.text().is_empty() &&
|
|
||||||
!unofficial_source_add_components_entry_clone0.text().is_empty()
|
|
||||||
{
|
|
||||||
if unofficial_source_signed_keyring_checkbutton_clone0.is_active() {
|
|
||||||
unofficial_source_add_dialog_clone0.set_response_enabled("unofficial_source_add_dialog_add", true);
|
|
||||||
} else if !unofficial_source_add_signed_entry_clone0.text().is_empty() {
|
|
||||||
unofficial_source_add_dialog_clone0.set_response_enabled("unofficial_source_add_dialog_add", true);
|
|
||||||
} else {
|
|
||||||
unofficial_source_add_dialog_clone0.set_response_enabled("unofficial_source_add_dialog_add", false);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
unofficial_source_add_dialog_clone0.set_response_enabled("unofficial_source_add_dialog_add", false);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
//
|
|
||||||
|
|
||||||
for entry in [
|
|
||||||
&unofficial_source_add_name_entry,
|
|
||||||
&unofficial_source_add_uri_entry,
|
|
||||||
&unofficial_source_add_suites_entry,
|
|
||||||
&unofficial_source_add_components_entry,
|
|
||||||
&unofficial_source_add_signed_entry,
|
|
||||||
] {
|
|
||||||
entry.connect_text_notify(clone!(
|
|
||||||
#[strong]
|
|
||||||
add_button_update_state,
|
|
||||||
move |_|
|
|
||||||
{
|
|
||||||
add_button_update_state();
|
|
||||||
}
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
|
|
||||||
unofficial_source_signed_keyring_checkbutton.connect_toggled(clone!(
|
|
||||||
#[weak]
|
|
||||||
unofficial_source_add_signed_entry,
|
|
||||||
#[strong]
|
|
||||||
add_button_update_state,
|
|
||||||
move |checkbutton|
|
|
||||||
{
|
|
||||||
if checkbutton.is_active() {
|
|
||||||
unofficial_source_add_signed_entry.set_sensitive(false);
|
|
||||||
add_button_update_state();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
unofficial_source_signed_file_checkbutton.connect_toggled(clone!(
|
|
||||||
#[weak]
|
|
||||||
unofficial_source_add_signed_entry,
|
|
||||||
#[strong]
|
|
||||||
add_button_update_state,
|
|
||||||
move |checkbutton|
|
|
||||||
{
|
|
||||||
if checkbutton.is_active() {
|
|
||||||
unofficial_source_add_signed_entry.set_sensitive(true);
|
|
||||||
add_button_update_state();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
unofficial_source_add_box2.append(&unofficial_source_add_is_source_label);
|
|
||||||
unofficial_source_add_box2.append(&unofficial_source_add_is_source_switch);
|
|
||||||
unofficial_source_add_box2.append(&unofficial_source_add_is_enabled_label);
|
|
||||||
unofficial_source_add_box2.append(&unofficial_source_add_is_enabled_switch);
|
|
||||||
unofficial_source_add_box2.append(&unofficial_source_signed_keyring_checkbutton);
|
|
||||||
unofficial_source_add_box2.append(&unofficial_source_signed_file_checkbutton);
|
|
||||||
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_name_prefrencesgroup);
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_uri_prefrencesgroup);
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_suites_prefrencesgroup);
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_components_prefrencesgroup);
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_archs_prefrencesgroup);
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_box2);
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_signed_prefrencesgroup);
|
|
||||||
|
|
||||||
|
|
||||||
//
|
|
||||||
|
|
||||||
match &deb822_repo.repolib_name {
|
|
||||||
Some(t) => {
|
|
||||||
unofficial_source_add_name_entry.set_text(&t);
|
|
||||||
}
|
|
||||||
None => {}
|
|
||||||
}
|
|
||||||
match &deb822_repo.uris {
|
|
||||||
Some(t) => {
|
|
||||||
unofficial_source_add_uri_entry.set_text(&t);
|
|
||||||
}
|
|
||||||
None => {}
|
|
||||||
}
|
|
||||||
match &deb822_repo.suites {
|
|
||||||
Some(t) => {
|
|
||||||
unofficial_source_add_suites_entry.set_text(&t);
|
|
||||||
}
|
|
||||||
None => {}
|
|
||||||
}
|
|
||||||
match &deb822_repo.components {
|
|
||||||
Some(t) => {
|
|
||||||
unofficial_source_add_components_entry.set_text(&t);
|
|
||||||
}
|
|
||||||
None => {}
|
|
||||||
}
|
|
||||||
match &deb822_repo.signed_by {
|
|
||||||
Some(t) => {
|
|
||||||
unofficial_source_signed_file_checkbutton.set_active(true);
|
|
||||||
unofficial_source_add_signed_entry.set_text(&t);
|
|
||||||
}
|
|
||||||
None => {
|
|
||||||
unofficial_source_signed_keyring_checkbutton.set_active(true)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
match &deb822_repo.architectures {
|
|
||||||
Some(t) => {
|
|
||||||
unofficial_source_add_archs_entry.set_text(&t);
|
|
||||||
}
|
|
||||||
None => {}
|
|
||||||
}
|
|
||||||
match &deb822_repo.enabled {
|
|
||||||
Some(t) => {
|
|
||||||
unofficial_source_add_is_enabled_switch.set_active(match t.to_lowercase().as_str() {
|
|
||||||
"yes" => true,
|
|
||||||
"true" => true,
|
|
||||||
"no" => false,
|
|
||||||
"false" => false,
|
|
||||||
_ => true,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
None => {
|
|
||||||
unofficial_source_add_is_enabled_switch.set_active(true);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
match &deb822_repo.types {
|
|
||||||
Some(t) => {
|
|
||||||
unofficial_source_add_is_source_switch.set_active(t.contains("deb-src"));
|
|
||||||
}
|
|
||||||
None => {}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
let deb822_repo_clone0 = deb822_repo.clone();
|
|
||||||
|
|
||||||
let reload_action_clone0 = reload_action.clone();
|
|
||||||
|
|
||||||
unofficial_source_add_dialog.clone()
|
|
||||||
.choose(None::<&gio::Cancellable>, move |choice| {
|
|
||||||
match choice.as_str() {
|
|
||||||
"unofficial_source_edit_dialog_edit" => {
|
|
||||||
let sign_method = if unofficial_source_signed_file_checkbutton.is_active() {
|
|
||||||
1
|
|
||||||
} else {
|
|
||||||
0
|
|
||||||
};
|
|
||||||
let new_repo = Deb822Repository {
|
|
||||||
repolib_name: Some(unofficial_source_add_name_entry.text().to_string()),
|
|
||||||
filepath: format!("/etc/apt/sources.list.d/{}.source", repo_file_name),
|
|
||||||
uris: Some(unofficial_source_add_uri_entry.text().to_string()),
|
|
||||||
types: if unofficial_source_add_is_source_switch.is_active() {
|
|
||||||
Some("deb deb-src".to_string())
|
|
||||||
} else {
|
|
||||||
Some("deb".to_string())
|
|
||||||
},
|
|
||||||
suites: Some(unofficial_source_add_suites_entry.text().to_string()),
|
|
||||||
components: Some(unofficial_source_add_components_entry.text().to_string()),
|
|
||||||
architectures: if unofficial_source_add_archs_entry.text().is_empty() {
|
|
||||||
None
|
|
||||||
} else {
|
|
||||||
Some(unofficial_source_add_archs_entry.text().to_string())
|
|
||||||
},
|
|
||||||
signed_by: match sign_method {
|
|
||||||
1 => Some(unofficial_source_add_signed_entry.text().to_string()),
|
|
||||||
_ => None
|
|
||||||
},
|
|
||||||
enabled: match unofficial_source_add_is_enabled_switch.is_active() {
|
|
||||||
true => Some("yes".to_string()),
|
|
||||||
false => Some("no".to_string())
|
|
||||||
},
|
|
||||||
..deb822_repo_clone0
|
|
||||||
};
|
|
||||||
match Deb822Repository::write_to_file(new_repo.clone(), format!("/tmp/{}.sources", repo_file_name).into()) {
|
|
||||||
Ok(_) => {
|
|
||||||
match duct::cmd!("pkexec", "/usr/lib/pika/pikman-update-manager/scripts/modify_repo.sh", "deb822_move", repo_file_name).run() {
|
|
||||||
Ok(_) => {}
|
|
||||||
Err(e) => {
|
|
||||||
let apt_src_create_error_dialog = adw::MessageDialog::builder()
|
|
||||||
.heading(t!("apt_src_create_error_dialog_heading"))
|
|
||||||
.body(e.to_string())
|
|
||||||
.build();
|
|
||||||
apt_src_create_error_dialog.add_response(
|
|
||||||
"apt_src_create_error_dialog_ok",
|
|
||||||
&t!("apt_src_create_error_dialog_ok_label").to_string(),
|
|
||||||
);
|
|
||||||
apt_src_create_error_dialog.present();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
reload_action_clone0.activate(None);
|
|
||||||
}
|
|
||||||
Err(e) => {
|
|
||||||
let apt_src_create_error_dialog = adw::MessageDialog::builder()
|
|
||||||
.heading(t!("apt_src_create_error_dialog_heading"))
|
|
||||||
.body(e.to_string())
|
|
||||||
.build();
|
|
||||||
apt_src_create_error_dialog.add_response(
|
|
||||||
"apt_src_create_error_dialog_ok",
|
|
||||||
&t!("apt_src_create_error_dialog_ok_label").to_string(),
|
|
||||||
);
|
|
||||||
apt_src_create_error_dialog.present();
|
|
||||||
reload_action_clone0.activate(None);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
_ => {}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
@ -1,272 +0,0 @@
|
|||||||
use crate::apt_package_row::AptPackageRow;
|
|
||||||
use adw::gio::SimpleAction;
|
|
||||||
use adw::prelude::*;
|
|
||||||
use apt_legacy_tools::LegacyAptSource;
|
|
||||||
use regex::Regex;
|
|
||||||
use gtk::glib::{property::PropertyGet, clone, BoxedAnyObject};
|
|
||||||
use gtk::*;
|
|
||||||
use std::cell::Ref;
|
|
||||||
use std::ops::Deref;
|
|
||||||
use pika_unixsocket_tools::pika_unixsocket_tools::*;
|
|
||||||
use rust_apt::cache::*;
|
|
||||||
use rust_apt::new_cache;
|
|
||||||
use rust_apt::records::RecordField;
|
|
||||||
use std::cell::RefCell;
|
|
||||||
use std::process::Command;
|
|
||||||
use std::rc::Rc;
|
|
||||||
use std::thread;
|
|
||||||
use tokio::runtime::Runtime;
|
|
||||||
use std::path::Path;
|
|
||||||
|
|
||||||
pub fn legacy_edit_dialog_fn(
|
|
||||||
window: adw::ApplicationWindow,
|
|
||||||
legacy_repo: &LegacyAptSource,
|
|
||||||
reload_action: &gio::SimpleAction,
|
|
||||||
) {
|
|
||||||
let repofile_path = Path::new(&legacy_repo.filepath);
|
|
||||||
let repo_file_name = repofile_path
|
|
||||||
.file_name()
|
|
||||||
.unwrap()
|
|
||||||
.to_str()
|
|
||||||
.unwrap()
|
|
||||||
.trim_end_matches(".list")
|
|
||||||
.to_owned();
|
|
||||||
|
|
||||||
let unofficial_source_add_dialog_child_box = Box::builder()
|
|
||||||
.hexpand(true)
|
|
||||||
.orientation(Orientation::Vertical)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_uri_entry = gtk::Entry::builder()
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_uri_prefrencesgroup = adw::PreferencesGroup::builder()
|
|
||||||
.title(t!("unofficial_source_add_uri_prefrencesgroup_title"))
|
|
||||||
.build();
|
|
||||||
|
|
||||||
unofficial_source_add_uri_prefrencesgroup.add(&unofficial_source_add_uri_entry);
|
|
||||||
|
|
||||||
let unofficial_source_add_suites_entry = gtk::Entry::builder()
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_suites_prefrencesgroup = adw::PreferencesGroup::builder()
|
|
||||||
.title(t!("unofficial_source_add_suites_prefrencesgroup_title"))
|
|
||||||
.build();
|
|
||||||
|
|
||||||
unofficial_source_add_suites_prefrencesgroup.add(&unofficial_source_add_suites_entry);
|
|
||||||
|
|
||||||
let unofficial_source_add_components_entry = gtk::Entry::builder()
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_components_prefrencesgroup = adw::PreferencesGroup::builder()
|
|
||||||
.title(t!("unofficial_source_add_components_prefrencesgroup_title"))
|
|
||||||
.build();
|
|
||||||
|
|
||||||
unofficial_source_add_components_prefrencesgroup.add(&unofficial_source_add_components_entry);
|
|
||||||
|
|
||||||
let unofficial_source_add_legacy_options_entry = gtk::Entry::builder()
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_legacy_options_prefrencesgroup = adw::PreferencesGroup::builder()
|
|
||||||
.title(t!("unofficial_source_add_legacy_options_prefrencesgroup_title"))
|
|
||||||
.build();
|
|
||||||
|
|
||||||
unofficial_source_add_legacy_options_prefrencesgroup.add(&unofficial_source_add_legacy_options_entry);
|
|
||||||
|
|
||||||
let unofficial_source_add_box2 = gtk::Box::builder()
|
|
||||||
.margin_top(10)
|
|
||||||
.orientation(Orientation::Horizontal)
|
|
||||||
.hexpand(true)
|
|
||||||
.spacing(5)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_is_source_label = gtk::Label::builder()
|
|
||||||
.label(t!("unofficial_source_add_is_legacy_source_label_label"))
|
|
||||||
.halign(Align::Start)
|
|
||||||
.valign(Align::Center)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
|
|
||||||
let unofficial_source_add_is_enabled_label = gtk::Label::builder()
|
|
||||||
.label(t!("unofficial_source_add_is_enabled_label_label"))
|
|
||||||
.halign(Align::Start)
|
|
||||||
.valign(Align::Center)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_is_source_switch = gtk::Switch::builder()
|
|
||||||
.halign(Align::Start)
|
|
||||||
.valign(Align::Center)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_is_enabled_switch = gtk::Switch::builder()
|
|
||||||
.halign(Align::Start)
|
|
||||||
.valign(Align::Center)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
//
|
|
||||||
let unofficial_source_add_dialog_child_clamp = adw::Clamp::builder()
|
|
||||||
.child(&unofficial_source_add_dialog_child_box)
|
|
||||||
.maximum_size(500)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_viewport = gtk::ScrolledWindow::builder()
|
|
||||||
.hexpand(true)
|
|
||||||
.vexpand(true)
|
|
||||||
.child(&unofficial_source_add_dialog_child_clamp)
|
|
||||||
.hscrollbar_policy(PolicyType::Never)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_dialog = adw::MessageDialog::builder()
|
|
||||||
.transient_for(&window)
|
|
||||||
.extra_child(&unofficial_source_add_viewport)
|
|
||||||
.heading(t!("unofficial_source_edit_dialog_heading").to_string() + " " + &repo_file_name)
|
|
||||||
.width_request(700)
|
|
||||||
.height_request(500)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
unofficial_source_add_dialog.add_response(
|
|
||||||
"unofficial_source_edit_dialog_edit",
|
|
||||||
&t!("unofficial_source_edit_dialog_add_edit").to_string(),
|
|
||||||
);
|
|
||||||
|
|
||||||
unofficial_source_add_dialog.add_response(
|
|
||||||
"unofficial_source_add_dialog_cancel",
|
|
||||||
&t!("unofficial_source_add_dialog_cancel_label").to_string(),
|
|
||||||
);
|
|
||||||
|
|
||||||
unofficial_source_add_dialog.set_response_enabled("unofficial_source_add_dialog_add", false);
|
|
||||||
|
|
||||||
unofficial_source_add_dialog.set_response_appearance(
|
|
||||||
"unofficial_source_add_dialog_cancel",
|
|
||||||
adw::ResponseAppearance::Destructive,
|
|
||||||
);
|
|
||||||
|
|
||||||
unofficial_source_add_dialog.set_response_appearance(
|
|
||||||
"unofficial_source_edit_dialog_edit",
|
|
||||||
adw::ResponseAppearance::Suggested,
|
|
||||||
);
|
|
||||||
|
|
||||||
//
|
|
||||||
|
|
||||||
let unofficial_source_add_dialog_clone0 = unofficial_source_add_dialog.clone();
|
|
||||||
let unofficial_source_add_uri_entry_clone0 = unofficial_source_add_uri_entry.clone();
|
|
||||||
let unofficial_source_add_suites_entry_clone0 = unofficial_source_add_suites_entry.clone();
|
|
||||||
let unofficial_source_add_components_entry_clone0 = unofficial_source_add_components_entry.clone();
|
|
||||||
|
|
||||||
let add_button_update_state = move || {
|
|
||||||
if
|
|
||||||
!unofficial_source_add_uri_entry_clone0.text().is_empty() &&
|
|
||||||
!unofficial_source_add_suites_entry_clone0.text().is_empty() &&
|
|
||||||
!unofficial_source_add_components_entry_clone0.text().is_empty()
|
|
||||||
{
|
|
||||||
unofficial_source_add_dialog_clone0.set_response_enabled("unofficial_source_add_dialog_add", true);
|
|
||||||
} else {
|
|
||||||
unofficial_source_add_dialog_clone0.set_response_enabled("unofficial_source_add_dialog_add", false);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
//
|
|
||||||
|
|
||||||
for entry in [
|
|
||||||
&unofficial_source_add_uri_entry,
|
|
||||||
&unofficial_source_add_suites_entry,
|
|
||||||
&unofficial_source_add_components_entry,
|
|
||||||
&unofficial_source_add_legacy_options_entry,
|
|
||||||
] {
|
|
||||||
entry.connect_text_notify(clone!(
|
|
||||||
#[strong]
|
|
||||||
add_button_update_state,
|
|
||||||
move |_|
|
|
||||||
{
|
|
||||||
add_button_update_state();
|
|
||||||
}
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
|
|
||||||
unofficial_source_add_box2.append(&unofficial_source_add_is_source_label);
|
|
||||||
unofficial_source_add_box2.append(&unofficial_source_add_is_source_switch);
|
|
||||||
unofficial_source_add_box2.append(&unofficial_source_add_is_enabled_label);
|
|
||||||
unofficial_source_add_box2.append(&unofficial_source_add_is_enabled_switch);
|
|
||||||
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_uri_prefrencesgroup);
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_suites_prefrencesgroup);
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_components_prefrencesgroup);
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_box2);
|
|
||||||
unofficial_source_add_dialog_child_box.append(&unofficial_source_add_legacy_options_prefrencesgroup);
|
|
||||||
|
|
||||||
|
|
||||||
//
|
|
||||||
|
|
||||||
unofficial_source_add_uri_entry.set_text(&legacy_repo.url);
|
|
||||||
unofficial_source_add_suites_entry.set_text(&legacy_repo.suite);
|
|
||||||
unofficial_source_add_components_entry.set_text(&legacy_repo.components);
|
|
||||||
match &legacy_repo.options {
|
|
||||||
Some(t) => {
|
|
||||||
unofficial_source_add_legacy_options_entry.set_text(&t);
|
|
||||||
}
|
|
||||||
None => {}
|
|
||||||
}
|
|
||||||
unofficial_source_add_is_enabled_switch.set_active(legacy_repo.enabled);
|
|
||||||
|
|
||||||
unofficial_source_add_is_source_switch.set_active(legacy_repo.is_source);
|
|
||||||
|
|
||||||
//
|
|
||||||
let legacy_repo_clone0 = legacy_repo.clone();
|
|
||||||
|
|
||||||
let reload_action_clone0 = reload_action.clone();
|
|
||||||
|
|
||||||
unofficial_source_add_dialog.clone()
|
|
||||||
.choose(None::<&gio::Cancellable>, move |choice| {
|
|
||||||
match choice.as_str() {
|
|
||||||
"unofficial_source_edit_dialog_edit" => {
|
|
||||||
let mut new_apt_legacy_vec = LegacyAptSource::get_legacy_sources().unwrap();
|
|
||||||
new_apt_legacy_vec.retain(|x| x != &legacy_repo_clone0);
|
|
||||||
let new_repo = LegacyAptSource {
|
|
||||||
url: unofficial_source_add_uri_entry.text().to_string(),
|
|
||||||
is_source: unofficial_source_add_is_source_switch.is_active(),
|
|
||||||
suite: unofficial_source_add_suites_entry.text().to_string(),
|
|
||||||
components: unofficial_source_add_components_entry.text().to_string(),
|
|
||||||
options: Some(unofficial_source_add_legacy_options_entry.text().to_string()),
|
|
||||||
enabled: unofficial_source_add_is_enabled_switch.is_active(),
|
|
||||||
..legacy_repo_clone0
|
|
||||||
};
|
|
||||||
new_apt_legacy_vec.push(new_repo.clone());
|
|
||||||
match LegacyAptSource::save_to_file(new_repo, new_apt_legacy_vec, &format!("/tmp/{}.list", repo_file_name)) {
|
|
||||||
Ok(_) => {
|
|
||||||
match duct::cmd!("pkexec", "/usr/lib/pika/pikman-update-manager/scripts/modify_repo.sh", "legacy_move", repo_file_name).run() {
|
|
||||||
Ok(_) => {}
|
|
||||||
Err(e) => {
|
|
||||||
let apt_src_create_error_dialog = adw::MessageDialog::builder()
|
|
||||||
.heading(t!("apt_src_create_error_dialog_heading"))
|
|
||||||
.body(e.to_string())
|
|
||||||
.build();
|
|
||||||
apt_src_create_error_dialog.add_response(
|
|
||||||
"apt_src_create_error_dialog_ok",
|
|
||||||
&t!("apt_src_create_error_dialog_ok_label").to_string(),
|
|
||||||
);
|
|
||||||
apt_src_create_error_dialog.present();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
reload_action_clone0.activate(None);
|
|
||||||
}
|
|
||||||
Err(e) => {
|
|
||||||
let apt_src_create_error_dialog = adw::MessageDialog::builder()
|
|
||||||
.heading(t!("apt_src_create_error_dialog_heading"))
|
|
||||||
.body(e.to_string())
|
|
||||||
.build();
|
|
||||||
apt_src_create_error_dialog.add_response(
|
|
||||||
"apt_src_create_error_dialog_ok",
|
|
||||||
&t!("apt_src_create_error_dialog_ok_label").to_string(),
|
|
||||||
);
|
|
||||||
apt_src_create_error_dialog.present();
|
|
||||||
reload_action_clone0.activate(None);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
_ => {}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
@ -3,7 +3,6 @@ use add_dialog::add_dialog_fn;
|
|||||||
use adw::gio::SimpleAction;
|
use adw::gio::SimpleAction;
|
||||||
use adw::prelude::*;
|
use adw::prelude::*;
|
||||||
use apt_deb822_tools::Deb822Repository;
|
use apt_deb822_tools::Deb822Repository;
|
||||||
use regex::Regex;
|
|
||||||
use gtk::glib::{property::PropertyGet, clone, BoxedAnyObject};
|
use gtk::glib::{property::PropertyGet, clone, BoxedAnyObject};
|
||||||
use gtk::*;
|
use gtk::*;
|
||||||
use std::cell::Ref;
|
use std::cell::Ref;
|
||||||
@ -17,31 +16,25 @@ use std::process::Command;
|
|||||||
use std::rc::Rc;
|
use std::rc::Rc;
|
||||||
use std::thread;
|
use std::thread;
|
||||||
use tokio::runtime::Runtime;
|
use tokio::runtime::Runtime;
|
||||||
|
use crate::flatpak_ref_row::FlatpakRefRow;
|
||||||
|
use adw::prelude::*;
|
||||||
|
use gtk::glib::*;
|
||||||
|
use gtk::*;
|
||||||
|
use libflatpak::prelude::*;
|
||||||
|
use libflatpak::InstalledRef;
|
||||||
|
|
||||||
mod add_dialog;
|
mod add_dialog;
|
||||||
mod deb822_edit_dialog;
|
|
||||||
mod legacy_edit_dialog;
|
|
||||||
|
|
||||||
enum AptSourceConfig {
|
enum FlatpakRemote {
|
||||||
Legacy(apt_legacy_tools::LegacyAptSource),
|
System(libflatpak::Remote),
|
||||||
DEB822(apt_deb822_tools::Deb822Repository)
|
User(libflatpak::Remote)
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn apt_manage_page(
|
pub fn flatpak_manage_page(
|
||||||
window: adw::ApplicationWindow,
|
window: adw::ApplicationWindow,
|
||||||
retry_signal_action: &SimpleAction,
|
retry_signal_action: &SimpleAction,
|
||||||
) -> gtk::Box {
|
) -> gtk::Box {
|
||||||
|
let cancellable_no = libflatpak::gio::Cancellable::NONE;
|
||||||
let deb822_sources = Deb822Repository::get_deb822_sources().unwrap();
|
|
||||||
|
|
||||||
let system_source = deb822_sources.iter().filter(|x| {
|
|
||||||
match &x.repolib_id {
|
|
||||||
Some(t) => {
|
|
||||||
t == "system"
|
|
||||||
}
|
|
||||||
None => false
|
|
||||||
}
|
|
||||||
}).next().unwrap();
|
|
||||||
|
|
||||||
let main_box = Box::builder()
|
let main_box = Box::builder()
|
||||||
.hexpand(true)
|
.hexpand(true)
|
||||||
@ -51,8 +44,8 @@ pub fn apt_manage_page(
|
|||||||
|
|
||||||
//
|
//
|
||||||
|
|
||||||
let system_mirror_label0 = gtk::Label::builder()
|
let flatpak_remotes_label0 = gtk::Label::builder()
|
||||||
.label(t!("system_mirror_label0_label"))
|
.label(t!("flatpak_remotes_label"))
|
||||||
.halign(gtk::Align::Start)
|
.halign(gtk::Align::Start)
|
||||||
.valign(gtk::Align::Start)
|
.valign(gtk::Align::Start)
|
||||||
.hexpand(true)
|
.hexpand(true)
|
||||||
@ -61,10 +54,10 @@ pub fn apt_manage_page(
|
|||||||
.margin_end(15)
|
.margin_end(15)
|
||||||
.margin_bottom(5)
|
.margin_bottom(5)
|
||||||
.build();
|
.build();
|
||||||
system_mirror_label0.add_css_class("heading");
|
flatpak_remotes_label0.add_css_class("heading");
|
||||||
|
|
||||||
let system_mirror_label1 = gtk::Label::builder()
|
let flatpak_remotes_label1 = gtk::Label::builder()
|
||||||
.label(t!("system_mirror_label1_label"))
|
.label(t!("flatpak_remotes_label1_label"))
|
||||||
.halign(gtk::Align::Start)
|
.halign(gtk::Align::Start)
|
||||||
.valign(gtk::Align::Start)
|
.valign(gtk::Align::Start)
|
||||||
.hexpand(true)
|
.hexpand(true)
|
||||||
@ -72,94 +65,60 @@ pub fn apt_manage_page(
|
|||||||
.margin_end(15)
|
.margin_end(15)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
let system_mirror_entry = gtk::Entry::builder()
|
let flatpak_remotes_selection_model_rc: Rc<RefCell<gtk::SingleSelection>> = Rc::new(RefCell::default());
|
||||||
.placeholder_text(system_source.repolib_default_mirror.as_deref().unwrap())
|
|
||||||
.text(system_source.uris.as_deref().unwrap())
|
|
||||||
.valign(gtk::Align::Start)
|
|
||||||
.margin_top(5)
|
|
||||||
.margin_bottom(5)
|
|
||||||
.margin_start(15)
|
|
||||||
.margin_end(15)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
//
|
let flatpak_remotes_selection_model_rc_clone0 = Rc::clone(&flatpak_remotes_selection_model_rc);
|
||||||
|
|
||||||
let unofficial_sources_label0 = gtk::Label::builder()
|
let flatpak_remotes_columnview_bin = adw::Bin::new();
|
||||||
.label(t!("unofficial_sources_label"))
|
|
||||||
.halign(gtk::Align::Start)
|
|
||||||
.valign(gtk::Align::Start)
|
|
||||||
.hexpand(true)
|
|
||||||
.margin_top(15)
|
|
||||||
.margin_start(15)
|
|
||||||
.margin_end(15)
|
|
||||||
.margin_bottom(5)
|
|
||||||
.build();
|
|
||||||
unofficial_sources_label0.add_css_class("heading");
|
|
||||||
|
|
||||||
let unofficial_sources_label1 = gtk::Label::builder()
|
let flatpak_remotes_columnview_bin_clone0 = flatpak_remotes_columnview_bin.clone();
|
||||||
.label(t!("unofficial_sources_label1_label"))
|
|
||||||
.halign(gtk::Align::Start)
|
|
||||||
.valign(gtk::Align::Start)
|
|
||||||
.hexpand(true)
|
|
||||||
.margin_start(15)
|
|
||||||
.margin_end(15)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_sources_selection_model_rc: Rc<RefCell<gtk::SingleSelection>> = Rc::new(RefCell::default());
|
|
||||||
|
|
||||||
let unofficial_sources_selection_model_rc_clone0 = Rc::clone(&unofficial_sources_selection_model_rc);
|
|
||||||
|
|
||||||
let unofficial_sources_columnview_bin = adw::Bin::new();
|
|
||||||
|
|
||||||
let unofficial_sources_columnview_bin_clone0 = unofficial_sources_columnview_bin.clone();
|
|
||||||
|
|
||||||
retry_signal_action.connect_activate(clone!(
|
retry_signal_action.connect_activate(clone!(
|
||||||
#[weak]
|
#[weak]
|
||||||
unofficial_sources_columnview_bin_clone0,
|
flatpak_remotes_columnview_bin_clone0,
|
||||||
|
#[strong]
|
||||||
|
cancellable_no,
|
||||||
move |_, _| {
|
move |_, _| {
|
||||||
|
|
||||||
let mut unofficial_deb822_sources = Deb822Repository::get_deb822_sources().unwrap();
|
let flatpak_system_installation =
|
||||||
|
libflatpak::Installation::new_system(cancellable_no).unwrap();
|
||||||
|
let flatpak_user_installation =
|
||||||
|
libflatpak::Installation::new_user(cancellable_no).unwrap();
|
||||||
|
|
||||||
unofficial_deb822_sources.retain(|x| {
|
let system_remotes = match libflatpak::Installation::list_remotes(&flatpak_system_installation, cancellable_no) {
|
||||||
match &x.repolib_id {
|
Ok(t) => t,
|
||||||
Some(t) => {
|
Err(_) => Vec::new()
|
||||||
!(t == "system")
|
|
||||||
}
|
|
||||||
None => true
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
let legacy_apt_repos = apt_legacy_tools::LegacyAptSource::get_legacy_sources();
|
|
||||||
|
|
||||||
let unofficial_sources_list_store = gio::ListStore::new::<BoxedAnyObject>();
|
|
||||||
|
|
||||||
for deb822_source in unofficial_deb822_sources {
|
|
||||||
unofficial_sources_list_store.append(&BoxedAnyObject::new(AptSourceConfig::DEB822(deb822_source)));
|
|
||||||
};
|
};
|
||||||
|
|
||||||
match legacy_apt_repos {
|
let user_remotes = match libflatpak::Installation::list_remotes(&flatpak_user_installation, cancellable_no) {
|
||||||
Ok(vec) => {
|
Ok(t) => t,
|
||||||
for legacy_repo in vec {
|
Err(_) => Vec::new()
|
||||||
unofficial_sources_list_store.append(&BoxedAnyObject::new(AptSourceConfig::Legacy(legacy_repo)));
|
|
||||||
};
|
};
|
||||||
}
|
|
||||||
Err(_) => {}
|
|
||||||
}
|
|
||||||
|
|
||||||
let unofficial_sources_selection_model = SingleSelection::new(Some(unofficial_sources_list_store));
|
let flatpak_remotes_list_store = gio::ListStore::new::<BoxedAnyObject>();
|
||||||
|
|
||||||
(*unofficial_sources_selection_model_rc_clone0.borrow_mut() = unofficial_sources_selection_model.clone());
|
for remote in system_remotes {
|
||||||
|
flatpak_remotes_list_store.append(&BoxedAnyObject::new(FlatpakRemote::System(remote)));
|
||||||
|
};
|
||||||
|
|
||||||
let unofficial_sources_columnview = ColumnView::builder()
|
for remote in user_remotes {
|
||||||
|
flatpak_remotes_list_store.append(&BoxedAnyObject::new(FlatpakRemote::User(remote)));
|
||||||
|
};
|
||||||
|
|
||||||
|
let flatpak_remotes_selection_model = SingleSelection::new(Some(flatpak_remotes_list_store));
|
||||||
|
|
||||||
|
(*flatpak_remotes_selection_model_rc_clone0.borrow_mut() = flatpak_remotes_selection_model.clone());
|
||||||
|
|
||||||
|
let flatpak_remotes_columnview = ColumnView::builder()
|
||||||
.vexpand(true)
|
.vexpand(true)
|
||||||
.model(&unofficial_sources_selection_model)
|
.model(&flatpak_remotes_selection_model)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
||||||
let unofficial_sources_columnview_factory0 = gtk::SignalListItemFactory::new();
|
let flatpak_remotes_columnview_factory0 = gtk::SignalListItemFactory::new();
|
||||||
|
|
||||||
unofficial_sources_columnview_factory0.connect_setup(move |_factory, item| {
|
flatpak_remotes_columnview_factory0.connect_setup(move |_factory, item| {
|
||||||
let item = item.downcast_ref::<gtk::ListItem>().unwrap();
|
let item = item.downcast_ref::<gtk::ListItem>().unwrap();
|
||||||
let row = Label::builder()
|
let row = Label::builder()
|
||||||
.halign(Align::Start)
|
.halign(Align::Start)
|
||||||
@ -167,54 +126,66 @@ pub fn apt_manage_page(
|
|||||||
item.set_child(Some(&row));
|
item.set_child(Some(&row));
|
||||||
});
|
});
|
||||||
|
|
||||||
unofficial_sources_columnview_factory0.connect_bind(move |_factory, item| {
|
flatpak_remotes_columnview_factory0.connect_bind(move |_factory, item| {
|
||||||
let item: &ListItem = item.downcast_ref::<gtk::ListItem>().unwrap();
|
let item: &ListItem = item.downcast_ref::<gtk::ListItem>().unwrap();
|
||||||
let child = item.child().and_downcast::<Label>().unwrap();
|
let child = item.child().and_downcast::<Label>().unwrap();
|
||||||
let entry: BoxedAnyObject = item.item().and_downcast::<BoxedAnyObject>().unwrap();
|
let entry: BoxedAnyObject = item.item().and_downcast::<BoxedAnyObject>().unwrap();
|
||||||
let entry_borrow = entry.borrow::<AptSourceConfig>();
|
let entry_borrow = entry.borrow::<FlatpakRemote>();
|
||||||
let repo_name = match entry_borrow.deref() {
|
let remote_title = match entry_borrow.deref() {
|
||||||
AptSourceConfig::DEB822(src) => {
|
FlatpakRemote::System(remote) => {
|
||||||
match &src.repolib_name {
|
remote.title().unwrap_or_default()
|
||||||
Some(name) => name,
|
|
||||||
None => match(&src.uris, &src.suites, &src.components) {
|
|
||||||
(Some(uris),Some(suites),Some(components)) => {
|
|
||||||
&format!("{} {} {}", uris, suites, components)
|
|
||||||
}
|
}
|
||||||
(_,_,_) => {
|
FlatpakRemote::User(remote) => {
|
||||||
&t!("apt_source_parse_error").to_string()
|
remote.title().unwrap_or_default()
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
AptSourceConfig::Legacy(src) => {
|
|
||||||
&format!("{} {} {} {}",
|
|
||||||
if src.is_source {
|
|
||||||
"(Legacy Src)"
|
|
||||||
} else {
|
|
||||||
"(Legacy)"
|
|
||||||
},
|
|
||||||
&src.url,
|
|
||||||
&src.suite,
|
|
||||||
&src.components
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
child.set_label(&repo_name);
|
child.set_label(&remote_title);
|
||||||
});
|
});
|
||||||
|
|
||||||
let unofficial_sources_columnview_col0 = gtk::ColumnViewColumn::builder()
|
let flatpak_remotes_columnview_col0 = gtk::ColumnViewColumn::builder()
|
||||||
.title(t!("unofficial_sources_columnview_col0_title"))
|
.title(t!("flatpak_remotes_columnview_col0_title"))
|
||||||
.factory(&unofficial_sources_columnview_factory0)
|
.factory(&flatpak_remotes_columnview_factory0)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
//
|
||||||
|
|
||||||
|
let flatpak_remotes_columnview_factory1 = gtk::SignalListItemFactory::new();
|
||||||
|
|
||||||
|
flatpak_remotes_columnview_factory1.connect_setup(move |_factory, item| {
|
||||||
|
let item = item.downcast_ref::<gtk::ListItem>().unwrap();
|
||||||
|
let row = Label::builder()
|
||||||
|
.halign(Align::Start)
|
||||||
|
.build();
|
||||||
|
item.set_child(Some(&row));
|
||||||
|
});
|
||||||
|
|
||||||
|
flatpak_remotes_columnview_factory1.connect_bind(move |_factory, item| {
|
||||||
|
let item: &ListItem = item.downcast_ref::<gtk::ListItem>().unwrap();
|
||||||
|
let child = item.child().and_downcast::<Label>().unwrap();
|
||||||
|
let entry: BoxedAnyObject = item.item().and_downcast::<BoxedAnyObject>().unwrap();
|
||||||
|
let entry_borrow = entry.borrow::<FlatpakRemote>();
|
||||||
|
let remote_url = match entry_borrow.deref() {
|
||||||
|
FlatpakRemote::System(remote) => {
|
||||||
|
remote.url().unwrap_or_default()
|
||||||
|
}
|
||||||
|
FlatpakRemote::User(remote) => {
|
||||||
|
remote.url().unwrap_or_default()
|
||||||
|
}
|
||||||
|
};
|
||||||
|
child.set_label(&remote_url);
|
||||||
|
});
|
||||||
|
|
||||||
|
let flatpak_remotes_columnview_col1 = gtk::ColumnViewColumn::builder()
|
||||||
|
.title(t!("flatpak_remotes_columnview_col1_title"))
|
||||||
|
.factory(&flatpak_remotes_columnview_factory1)
|
||||||
.expand(true)
|
.expand(true)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
||||||
let unofficial_sources_columnview_factory1 = gtk::SignalListItemFactory::new();
|
let flatpak_remotes_columnview_factory2 = gtk::SignalListItemFactory::new();
|
||||||
|
|
||||||
unofficial_sources_columnview_factory1.connect_setup(move |_factory, item| {
|
flatpak_remotes_columnview_factory2.connect_setup(move |_factory, item| {
|
||||||
let item = item.downcast_ref::<gtk::ListItem>().unwrap();
|
let item = item.downcast_ref::<gtk::ListItem>().unwrap();
|
||||||
let row = Label::builder()
|
let row = Label::builder()
|
||||||
.halign(Align::Start)
|
.halign(Align::Start)
|
||||||
@ -222,49 +193,36 @@ pub fn apt_manage_page(
|
|||||||
item.set_child(Some(&row));
|
item.set_child(Some(&row));
|
||||||
});
|
});
|
||||||
|
|
||||||
unofficial_sources_columnview_factory1.connect_bind(move |_factory, item| {
|
flatpak_remotes_columnview_factory2.connect_bind(move |_factory, item| {
|
||||||
let item: &ListItem = item.downcast_ref::<gtk::ListItem>().unwrap();
|
let item: &ListItem = item.downcast_ref::<gtk::ListItem>().unwrap();
|
||||||
let child = item.child().and_downcast::<Label>().unwrap();
|
let child = item.child().and_downcast::<Label>().unwrap();
|
||||||
let entry: BoxedAnyObject = item.item().and_downcast::<BoxedAnyObject>().unwrap();
|
let entry: BoxedAnyObject = item.item().and_downcast::<BoxedAnyObject>().unwrap();
|
||||||
let entry_borrow = entry.borrow::<AptSourceConfig>();
|
let entry_borrow = entry.borrow::<FlatpakRemote>();
|
||||||
let repo_enabled = match entry_borrow.deref() {
|
match entry_borrow.deref() {
|
||||||
AptSourceConfig::DEB822(src) => {
|
FlatpakRemote::System(remote) => {
|
||||||
match &src.enabled {
|
child.set_label(&t!("flatpak_remotes_columnview_system").to_string());
|
||||||
Some(t) => match t.to_lowercase().as_str() {
|
|
||||||
"yes" => true,
|
|
||||||
"true" => true,
|
|
||||||
"no" => false,
|
|
||||||
"false" => false,
|
|
||||||
_ => true,
|
|
||||||
}
|
}
|
||||||
None => true,
|
FlatpakRemote::User(remote) => {
|
||||||
}
|
child.set_label(&t!("flatpak_remotes_columnview_user").to_string());
|
||||||
}
|
|
||||||
AptSourceConfig::Legacy(src) => {
|
|
||||||
src.enabled
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
if repo_enabled {
|
|
||||||
child.set_label(&t!("apt_repo_enabled"));
|
|
||||||
} else {
|
|
||||||
child.set_label(&t!("apt_repo_disabled"));
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
let unofficial_sources_columnview_col1 = gtk::ColumnViewColumn::builder()
|
let flatpak_remotes_columnview_col2 = gtk::ColumnViewColumn::builder()
|
||||||
.title(t!("unofficial_sources_columnview_col1_title"))
|
.title(t!("flatpak_remotes_columnview_col2_title"))
|
||||||
.factory(&unofficial_sources_columnview_factory1)
|
.factory(&flatpak_remotes_columnview_factory2)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
//
|
//
|
||||||
unofficial_sources_columnview.append_column(&unofficial_sources_columnview_col0);
|
flatpak_remotes_columnview.append_column(&flatpak_remotes_columnview_col0);
|
||||||
unofficial_sources_columnview.append_column(&unofficial_sources_columnview_col1);
|
flatpak_remotes_columnview.append_column(&flatpak_remotes_columnview_col1);
|
||||||
unofficial_sources_columnview_bin_clone0.set_child(Some(&unofficial_sources_columnview));
|
flatpak_remotes_columnview.append_column(&flatpak_remotes_columnview_col2);
|
||||||
|
flatpak_remotes_columnview_bin_clone0.set_child(Some(&flatpak_remotes_columnview));
|
||||||
}));
|
}));
|
||||||
|
|
||||||
retry_signal_action.activate(None);
|
retry_signal_action.activate(None);
|
||||||
|
|
||||||
let unofficial_sources_box = Box::builder()
|
let flatpak_remotes_box = Box::builder()
|
||||||
.orientation(Orientation::Vertical)
|
.orientation(Orientation::Vertical)
|
||||||
.margin_bottom(3)
|
.margin_bottom(3)
|
||||||
.margin_top(3)
|
.margin_top(3)
|
||||||
@ -272,7 +230,7 @@ pub fn apt_manage_page(
|
|||||||
.margin_start(3)
|
.margin_start(3)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
let unofficial_sources_viewport = ScrolledWindow::builder()
|
let flatpak_remotes_viewport = ScrolledWindow::builder()
|
||||||
.vexpand(true)
|
.vexpand(true)
|
||||||
.hexpand(true)
|
.hexpand(true)
|
||||||
.has_frame(true)
|
.has_frame(true)
|
||||||
@ -280,41 +238,34 @@ pub fn apt_manage_page(
|
|||||||
.margin_top(15)
|
.margin_top(15)
|
||||||
.margin_end(15)
|
.margin_end(15)
|
||||||
.margin_start(15)
|
.margin_start(15)
|
||||||
.child(&unofficial_sources_box)
|
.child(&flatpak_remotes_box)
|
||||||
.height_request(390)
|
.height_request(390)
|
||||||
.build();
|
.build();
|
||||||
unofficial_sources_viewport.add_css_class("round-all-scroll");
|
flatpak_remotes_viewport.add_css_class("round-all-scroll");
|
||||||
|
|
||||||
//
|
//
|
||||||
|
|
||||||
let unofficial_sources_edit_box = gtk::Box::builder()
|
let flatpak_remotes_edit_box = gtk::Box::builder()
|
||||||
.orientation(Orientation::Horizontal)
|
.orientation(Orientation::Horizontal)
|
||||||
.homogeneous(true)
|
.homogeneous(true)
|
||||||
.build();
|
.build();
|
||||||
unofficial_sources_edit_box.add_css_class("linked");
|
flatpak_remotes_edit_box.add_css_class("linked");
|
||||||
|
|
||||||
let unofficial_source_edit_button = Button::builder()
|
let flatpak_remote_add_button = Button::builder()
|
||||||
.icon_name("document-edit-symbolic")
|
|
||||||
.tooltip_text(t!("unofficial_source_edit_button_tooltip_text"))
|
|
||||||
//.halign(Align::End)
|
|
||||||
.valign(Align::End)
|
|
||||||
.build();
|
|
||||||
|
|
||||||
let unofficial_source_add_button = Button::builder()
|
|
||||||
.icon_name("list-add-symbolic")
|
.icon_name("list-add-symbolic")
|
||||||
.tooltip_text(t!("unofficial_source_add_button_tooltip_text"))
|
.tooltip_text(t!("flatpak_remote_add_button_tooltip_text"))
|
||||||
//.halign(Align::End)
|
//.halign(Align::End)
|
||||||
.valign(Align::End)
|
.valign(Align::End)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
let unofficial_source_remove_button = Button::builder()
|
let flatpak_remote_remove_button = Button::builder()
|
||||||
.icon_name("edit-delete-symbolic")
|
.icon_name("edit-delete-symbolic")
|
||||||
.tooltip_text(t!("unofficial_source_remove_button_tooltip_text"))
|
.tooltip_text(t!("flatpak_remote_remove_button_tooltip_text"))
|
||||||
//.halign(Align::End)
|
//.halign(Align::End)
|
||||||
.valign(Align::End)
|
.valign(Align::End)
|
||||||
.build();
|
.build();
|
||||||
|
|
||||||
unofficial_source_add_button.connect_clicked(clone!(
|
flatpak_remote_add_button.connect_clicked(clone!(
|
||||||
#[strong]
|
#[strong]
|
||||||
window,
|
window,
|
||||||
#[strong]
|
#[strong]
|
||||||
@ -330,85 +281,50 @@ pub fn apt_manage_page(
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
unofficial_source_edit_button.connect_clicked(clone!(
|
flatpak_remote_remove_button.connect_clicked(clone!(
|
||||||
#[strong]
|
#[strong]
|
||||||
window,
|
window,
|
||||||
#[strong]
|
#[strong]
|
||||||
unofficial_sources_selection_model_rc,
|
flatpak_remotes_selection_model_rc,
|
||||||
#[strong]
|
#[strong]
|
||||||
retry_signal_action,
|
retry_signal_action,
|
||||||
move
|
|
||||||
|_|
|
|
||||||
{
|
|
||||||
let unofficial_sources_selection_model = unofficial_sources_selection_model_rc.borrow();
|
|
||||||
let selection = unofficial_sources_selection_model.selected_item().unwrap();
|
|
||||||
let item = selection.downcast_ref::<BoxedAnyObject>().unwrap();
|
|
||||||
let apt_src: Ref<AptSourceConfig> = item.borrow();
|
|
||||||
match apt_src.deref() {
|
|
||||||
AptSourceConfig::DEB822(src) => {
|
|
||||||
deb822_edit_dialog::deb822_edit_dialog_fn(window.clone(), src, &retry_signal_action);
|
|
||||||
}
|
|
||||||
AptSourceConfig::Legacy(list) => {
|
|
||||||
legacy_edit_dialog::legacy_edit_dialog_fn(window.clone(), list, &retry_signal_action)
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
|
||||||
)
|
|
||||||
);
|
|
||||||
|
|
||||||
unofficial_source_remove_button.connect_clicked(clone!(
|
|
||||||
#[strong]
|
#[strong]
|
||||||
window,
|
cancellable_no,
|
||||||
#[strong]
|
|
||||||
unofficial_sources_selection_model_rc,
|
|
||||||
#[strong]
|
|
||||||
retry_signal_action,
|
|
||||||
move
|
move
|
||||||
|_|
|
|_|
|
||||||
{
|
{
|
||||||
{
|
{
|
||||||
let mut command = duct::cmd!("");
|
let (mut installation, mut remote_name): (libflatpak::Installation, libflatpak::glib::GString);
|
||||||
{
|
{
|
||||||
let unofficial_sources_selection_model = unofficial_sources_selection_model_rc.borrow();
|
let flatpak_remotes_selection_model = flatpak_remotes_selection_model_rc.borrow();
|
||||||
let selection = unofficial_sources_selection_model.selected_item().unwrap();
|
let selection = flatpak_remotes_selection_model.selected_item().unwrap();
|
||||||
let item = selection.downcast_ref::<BoxedAnyObject>().unwrap();
|
let item = selection.downcast_ref::<BoxedAnyObject>().unwrap();
|
||||||
let apt_src: Ref<AptSourceConfig> = item.borrow();
|
let flatpak_remote: Ref<FlatpakRemote> = item.borrow();
|
||||||
match apt_src.deref() {
|
(installation, remote_name) = match flatpak_remote.deref() {
|
||||||
AptSourceConfig::DEB822(src) => {
|
FlatpakRemote::System(remote) => {
|
||||||
match &src.signed_by {
|
(libflatpak::Installation::new_system(cancellable_no).unwrap(), remote.name().unwrap_or_default())
|
||||||
Some(t) => {command = duct::cmd!("pkexec", "/usr/lib/pika/pikman-update-manager/scripts/modify_repo.sh", "delete_deb822", &src.filepath, t)}
|
|
||||||
None => {command = duct::cmd!("pkexec", "/usr/lib/pika/pikman-update-manager/scripts/modify_repo.sh", "delete_legacy", &src.filepath)}
|
|
||||||
}
|
}
|
||||||
|
FlatpakRemote::User(remote) => {
|
||||||
|
(libflatpak::Installation::new_user(cancellable_no).unwrap(), remote.name().unwrap_or_default())
|
||||||
}
|
}
|
||||||
AptSourceConfig::Legacy(list) => {command = duct::cmd!("pkexec", "/usr/lib/pika/pikman-update-manager/scripts/modify_repo.sh", "delete_legacy", &list.filepath)}
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
let apt_src_remove_warning_dialog = adw::MessageDialog::builder()
|
match libflatpak::Installation::remove_remote(&installation, &remote_name, cancellable_no) {
|
||||||
.heading(t!("apt_src_remove_warning_dialog_heading"))
|
Ok(_) => {
|
||||||
.body(t!("apt_src_remove_warning_dialog_body"))
|
retry_signal_action.activate(None);
|
||||||
.transient_for(&window)
|
}
|
||||||
|
Err(e) => {
|
||||||
|
let flatpak_remote_add_error_dialog = adw::MessageDialog::builder()
|
||||||
|
.heading(t!("flatpak_remote_add_error_dialog_heading"))
|
||||||
|
.body(e.to_string())
|
||||||
.build();
|
.build();
|
||||||
apt_src_remove_warning_dialog.add_response(
|
flatpak_remote_add_error_dialog.add_response(
|
||||||
"apt_src_remove_warning_dialog_cancel",
|
"flatpak_remote_add_error_dialog_ok",
|
||||||
&t!("apt_src_remove_warning_dialog_cancel_label").to_string(),
|
&t!("flatpak_remote_add_error_dialog_ok_label").to_string(),
|
||||||
);
|
);
|
||||||
apt_src_remove_warning_dialog.add_response(
|
flatpak_remote_add_error_dialog.present();
|
||||||
"apt_src_remove_warning_dialog_ok",
|
|
||||||
&t!("apt_src_remove_warning_dialog_ok_label").to_string(),
|
|
||||||
);
|
|
||||||
apt_src_remove_warning_dialog.set_response_appearance("apt_src_remove_warning_dialog_ok", adw::ResponseAppearance::Destructive);
|
|
||||||
let retry_signal_action_clone0 = retry_signal_action.clone();
|
|
||||||
apt_src_remove_warning_dialog.clone()
|
|
||||||
.choose(None::<&gio::Cancellable>, move |choice| {
|
|
||||||
match choice.as_str() {
|
|
||||||
"apt_src_remove_warning_dialog_ok" => {
|
|
||||||
let _ = command.run().unwrap();
|
|
||||||
retry_signal_action_clone0.activate(None);
|
|
||||||
}
|
}
|
||||||
_ => {}
|
|
||||||
}
|
}
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
@ -416,22 +332,16 @@ pub fn apt_manage_page(
|
|||||||
|
|
||||||
//
|
//
|
||||||
|
|
||||||
unofficial_sources_edit_box.append(&unofficial_source_add_button);
|
flatpak_remotes_edit_box.append(&flatpak_remote_add_button);
|
||||||
unofficial_sources_edit_box.append(&unofficial_source_edit_button);
|
flatpak_remotes_edit_box.append(&flatpak_remote_remove_button);
|
||||||
unofficial_sources_edit_box.append(&unofficial_source_remove_button);
|
|
||||||
|
|
||||||
unofficial_sources_box.append(&unofficial_sources_columnview_bin);
|
flatpak_remotes_box.append(&flatpak_remotes_columnview_bin);
|
||||||
unofficial_sources_box.append(&unofficial_sources_edit_box);
|
flatpak_remotes_box.append(&flatpak_remotes_edit_box);
|
||||||
|
|
||||||
//
|
//
|
||||||
|
main_box.append(&flatpak_remotes_label0);
|
||||||
main_box.append(&system_mirror_label0);
|
main_box.append(&flatpak_remotes_label1);
|
||||||
main_box.append(&system_mirror_label1);
|
main_box.append(&flatpak_remotes_viewport);
|
||||||
main_box.append(&system_mirror_entry);
|
|
||||||
//
|
|
||||||
main_box.append(&unofficial_sources_label0);
|
|
||||||
main_box.append(&unofficial_sources_label1);
|
|
||||||
main_box.append(&unofficial_sources_viewport);
|
|
||||||
|
|
||||||
main_box
|
main_box
|
||||||
}
|
}
|
@ -56,7 +56,7 @@ pub fn flatpak_update_page(
|
|||||||
thread::spawn(move || {
|
thread::spawn(move || {
|
||||||
let cancellable_no = libflatpak::gio::Cancellable::NONE;
|
let cancellable_no = libflatpak::gio::Cancellable::NONE;
|
||||||
let flatpak_system_installation =
|
let flatpak_system_installation =
|
||||||
libflatpak::Installation::new_user(cancellable_no).unwrap();
|
libflatpak::Installation::new_system(cancellable_no).unwrap();
|
||||||
if let Ok(remotes) =
|
if let Ok(remotes) =
|
||||||
libflatpak::Installation::list_remotes(&flatpak_system_installation, cancellable_no)
|
libflatpak::Installation::list_remotes(&flatpak_system_installation, cancellable_no)
|
||||||
{
|
{
|
||||||
|
@ -5,6 +5,7 @@ mod build_ui;
|
|||||||
mod config;
|
mod config;
|
||||||
mod flatpak_ref_row;
|
mod flatpak_ref_row;
|
||||||
mod flatpak_update_page;
|
mod flatpak_update_page;
|
||||||
|
mod flatpak_manage_page;
|
||||||
|
|
||||||
use crate::config::APP_ID;
|
use crate::config::APP_ID;
|
||||||
use adw::prelude::*;
|
use adw::prelude::*;
|
||||||
|
Loading…
Reference in New Issue
Block a user