mirror of
https://github.com/aclist/dztui.git
synced 2025-01-04 08:28:06 +01:00
commit
373164b7ee
3 changed files with 85 additions and 50 deletions
28
CHANGELOG.md
28
CHANGELOG.md
|
@ -1,19 +1,29 @@
|
||||||
# Changelog
|
# Changelog
|
||||||
|
|
||||||
## [4.0.4] 2023-11-23
|
## [4.1.0] 2023-12-03
|
||||||
## Fixed
|
|
||||||
- Fetch correct checksums for query helper
|
This update adds support for DayZ servers running on a local area network. To connect or add to your server list, supply the server IP and query port in the format IP:PORT.
|
||||||
|
|
||||||
|
Support for Steam Deck Game Mode has also been restored, with a new dialog format that allows for virtual keyboard input. This should allow you to enter text in form fields by activating the Steam button + X. In addition, you can unlock the mouse and keyboard input when launching DZGUI through Steam by using an internal binding provided by Steam Deck: long-press the three dots button on the right of the device for three seconds to toggle the input state. This allows you to use mouse and keyboard-style bindings on Game Mode and vice versa.
|
||||||
|
|
||||||
|
### Added
|
||||||
|
- Virtual keyboard support for text entry fields on Steam Deck Game Mode
|
||||||
|
- Validate and connect to LAN server IPs
|
||||||
|
|
||||||
|
## [4.0.4] 2023-12-23
|
||||||
|
### Fixed
|
||||||
|
- Enforce version check for Python versions before 3.10
|
||||||
|
|
||||||
## [4.0.3] 2023-11-22
|
## [4.0.3] 2023-11-22
|
||||||
## Fixed
|
### Fixed
|
||||||
- Query helper: backwards compatibility for pre-2021 versions of Python 3
|
- Query helper: backwards compatibility for pre-2021 versions of Python 3
|
||||||
|
|
||||||
## [4.0.2] 2023-11-22
|
## [4.0.2] 2023-11-22
|
||||||
## Fixed
|
### Fixed
|
||||||
- Query helper not loading: fixed a remote link pointing to the wrong destination and added a checksum verification to ensure file is present
|
- Query helper not loading: fixed a remote link pointing to the wrong destination and added a checksum verification to ensure file is present
|
||||||
|
|
||||||
## [4.0.1] 2023-11-22
|
## [4.0.1] 2023-11-22
|
||||||
## Fixed
|
### Fixed
|
||||||
- Emergency hotfix to remove build artifacts leaking into main script: if you updated DZGUI from 3.3.18 to 4.0.0 between 2023-11-22 15:00:02 and 2023-11-22 15:03:37 GMT, there is a small chance it will be unable to launch correctly. If so, please follow the instructions on the manual to reinstall.
|
- Emergency hotfix to remove build artifacts leaking into main script: if you updated DZGUI from 3.3.18 to 4.0.0 between 2023-11-22 15:00:02 and 2023-11-22 15:03:37 GMT, there is a small chance it will be unable to launch correctly. If so, please follow the instructions on the manual to reinstall.
|
||||||
|
|
||||||
## [4.0.0] 2023-11-22
|
## [4.0.0] 2023-11-22
|
||||||
|
@ -29,7 +39,7 @@ If you encounter any problems with this new release or with the migration of con
|
||||||
Attention Fedora 38 users: problems with upstream GNOME packages causing crashes have been reported to GNOME development and a fix has been issued. You have the choice of compiling the zenity package
|
Attention Fedora 38 users: problems with upstream GNOME packages causing crashes have been reported to GNOME development and a fix has been issued. You have the choice of compiling the zenity package
|
||||||
from source or waiting until the latest version is merged into Fedora's package manager.
|
from source or waiting until the latest version is merged into Fedora's package manager.
|
||||||
|
|
||||||
## Added
|
### Added
|
||||||
- Change in game name: dynamically change your profile name via the Advanced Options menu
|
- Change in game name: dynamically change your profile name via the Advanced Options menu
|
||||||
- Connect by ID: supply a Battlemetrics ID to connect to a server; this can be used in lieu of the IP
|
- Connect by ID: supply a Battlemetrics ID to connect to a server; this can be used in lieu of the IP
|
||||||
- Add by IP: supply a standard IP to add a server to your list; this can be used as a more direct way of saving servers
|
- Add by IP: supply a standard IP to add a server to your list; this can be used as a more direct way of saving servers
|
||||||
|
@ -37,7 +47,7 @@ from source or waiting until the latest version is merged into Fedora's package
|
||||||
- Save connected server to favorites: prior to connecting, asks the user if they want to save this server for future use
|
- Save connected server to favorites: prior to connecting, asks the user if they want to save this server for future use
|
||||||
- Generate additional output when generating system logs
|
- Generate additional output when generating system logs
|
||||||
|
|
||||||
## Fixed
|
### Fixed
|
||||||
- Rare cases where the keyword filter would not filter server results correctly
|
- Rare cases where the keyword filter would not filter server results correctly
|
||||||
- Handling of dialog exit signals: made it much more difficult to crash the application in rare cases when spamming input or returning from menus
|
- Handling of dialog exit signals: made it much more difficult to crash the application in rare cases when spamming input or returning from menus
|
||||||
- Update menus in place: when toggling options in the Advanced Options menu, displays the current state/mode of the option for better readability into what option is currently enabled
|
- Update menus in place: when toggling options in the Advanced Options menu, displays the current state/mode of the option for better readability into what option is currently enabled
|
||||||
|
@ -46,7 +56,7 @@ from source or waiting until the latest version is merged into Fedora's package
|
||||||
- Fixed a rare case where dialogs would spawn twice during first-time setup
|
- Fixed a rare case where dialogs would spawn twice during first-time setup
|
||||||
- Properly remain inside of menus when looping where it would make sense to do so : e.g., Delete Servers list, Advanced Options
|
- Properly remain inside of menus when looping where it would make sense to do so : e.g., Delete Servers list, Advanced Options
|
||||||
|
|
||||||
## Changed
|
### Changed
|
||||||
- Query servers directly to reduce API hops: initial bootup and subsequent server queries should be considerably faster
|
- Query servers directly to reduce API hops: initial bootup and subsequent server queries should be considerably faster
|
||||||
- Store complete IP:Port instead of server IDs
|
- Store complete IP:Port instead of server IDs
|
||||||
- Make Battlemetrics API key optional: this is only used for the 'Connect by ID' and 'Add server by ID' methods and is not required. If you prefer, you can simply connect/add by IP.
|
- Make Battlemetrics API key optional: this is only used for the 'Connect by ID' and 'Add server by ID' methods and is not required. If you prefer, you can simply connect/add by IP.
|
||||||
|
|
105
dzgui.sh
105
dzgui.sh
|
@ -1,7 +1,7 @@
|
||||||
#!/usr/bin/env bash
|
#!/usr/bin/env bash
|
||||||
|
|
||||||
set -o pipefail
|
set -o pipefail
|
||||||
version=4.0.4
|
version=4.1.0
|
||||||
|
|
||||||
aid=221100
|
aid=221100
|
||||||
game="dayz"
|
game="dayz"
|
||||||
|
@ -132,6 +132,7 @@ items=(
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
warn(){
|
warn(){
|
||||||
|
logger WARN "$1"
|
||||||
$steamsafe_zenity --info --title="DZGUI" --text="$1" --width=500 --icon-name="dialog-warning" 2>/dev/null
|
$steamsafe_zenity --info --title="DZGUI" --text="$1" --width=500 --icon-name="dialog-warning" 2>/dev/null
|
||||||
}
|
}
|
||||||
info(){
|
info(){
|
||||||
|
@ -375,7 +376,11 @@ steam_deck_mods(){
|
||||||
}
|
}
|
||||||
test_display_mode(){
|
test_display_mode(){
|
||||||
pgrep -a gamescope | grep -q "generate-drm-mode"
|
pgrep -a gamescope | grep -q "generate-drm-mode"
|
||||||
[[ $? -eq 0 ]] && gamemode=1
|
if [[ $? -eq 0 ]]; then
|
||||||
|
echo gm
|
||||||
|
else
|
||||||
|
echo dm
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
foreground(){
|
foreground(){
|
||||||
if [[ $(command -v wmctrl) ]]; then
|
if [[ $(command -v wmctrl) ]]; then
|
||||||
|
@ -389,11 +394,6 @@ manual_mod_install(){
|
||||||
local ip="$1"
|
local ip="$1"
|
||||||
local gameport="$2"
|
local gameport="$2"
|
||||||
|
|
||||||
[[ $is_steam_deck -eq 1 ]] && test_display_mode
|
|
||||||
if [[ $gamemode -eq 1 ]]; then
|
|
||||||
popup 1400
|
|
||||||
return
|
|
||||||
fi
|
|
||||||
local ex="/tmp/dzc.tmp"
|
local ex="/tmp/dzc.tmp"
|
||||||
[[ -f $ex ]] && rm $ex
|
[[ -f $ex ]] && rm $ex
|
||||||
watcher(){
|
watcher(){
|
||||||
|
@ -605,6 +605,10 @@ connect(){
|
||||||
compare
|
compare
|
||||||
[[ $auto_install -eq 2 ]] && merge_modlists > >(pdialog)
|
[[ $auto_install -eq 2 ]] && merge_modlists > >(pdialog)
|
||||||
if [[ -n $diff ]]; then
|
if [[ -n $diff ]]; then
|
||||||
|
if [[ $is_steam_deck -eq 1 ]] && [[ $(test_display_mode) == "gm" ]]; then
|
||||||
|
popup 1400
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
case $auto_install in
|
case $auto_install in
|
||||||
1|2) auto_mod_install "$ip" "$gameport" ;;
|
1|2) auto_mod_install "$ip" "$gameport" ;;
|
||||||
*) manual_mod_install "$ip" "$gameport" ;;
|
*) manual_mod_install "$ip" "$gameport" ;;
|
||||||
|
@ -662,10 +666,9 @@ fetch_ip_metadata(){
|
||||||
curl -Ls "$url"
|
curl -Ls "$url"
|
||||||
}
|
}
|
||||||
|
|
||||||
#TODO: local servers
|
validate_local_ip(){
|
||||||
#local_ip(){
|
<<< "$1" grep -qP '(^127.\d+.\d+.\d+:\d+$)|(^10\.\d+.\d+.\d+:\d+$)|(^172\.1[6-9]\.\d+.\d+:\d+$)|(^172\.2[0-9]\.\d+.\d+:\d+$)|(^172\.3[0-1]\.\d+.\d+:\d+$)|(^192\.168\.\d+.\d+:\d+$)'
|
||||||
#(^127\.)|(^10\.)|(^172\.1[6-9]\.)|(^172\.2[0-9]\.)|(^172\.3[0-1]\.)|(^192\.168\.)
|
}
|
||||||
#}
|
|
||||||
test_steam_api(){
|
test_steam_api(){
|
||||||
local url="https://api.steampowered.com/IGameServersService/GetServerList/v1/?filter=\appid\221100&limit=10&key=$steam_api"
|
local url="https://api.steampowered.com/IGameServersService/GetServerList/v1/?filter=\appid\221100&limit=10&key=$steam_api"
|
||||||
local code=$(curl -ILs "$url" | grep -E "^HTTP")
|
local code=$(curl -ILs "$url" | grep -E "^HTTP")
|
||||||
|
@ -731,35 +734,59 @@ connect_by_ip(){
|
||||||
connect "$ip" "$gameport" "$qport"
|
connect "$ip" "$gameport" "$qport"
|
||||||
}
|
}
|
||||||
parse_ips(){
|
parse_ips(){
|
||||||
|
local res
|
||||||
source $config_file
|
source $config_file
|
||||||
check_steam_api
|
check_steam_api
|
||||||
[[ $? -eq 1 ]] && return
|
[[ $? -eq 1 ]] && return
|
||||||
while true; do
|
while true; do
|
||||||
local ip
|
local ip
|
||||||
ip=$($steamsafe_zenity --entry --text="Enter server IP (omit port)" --title="DZGUI" 2>/dev/null)
|
ip=$(edialog "Enter server IP (for LAN servers, include query port in IP:PORT format)")
|
||||||
[[ $? -eq 1 ]] && return 1
|
[[ $? -eq 1 ]] && return 1
|
||||||
[[ $ip =~ ':' ]] && continue
|
if [[ $ip =~ ':' ]]; then
|
||||||
if validate_ip "$ip"; then
|
if ! validate_local_ip "$ip"; then
|
||||||
local res
|
warn "Invalid local IP. Check IP:PORT combination and try again."
|
||||||
res=$(fetch_ip_metadata "$ip")
|
continue
|
||||||
if [[ ! $? -eq 0 ]] || [[ $(<<< $res jq '.response|length') -eq 0 ]]; then
|
fi
|
||||||
warn "Failed to retrieve IP metadata. Check IP or API key and try again."
|
local lan_ip=$(<<< $ip awk -F: '{print $1}')
|
||||||
|
local lan_qport=$(<<< $ip awk -F: '{print $2}')
|
||||||
|
logger INFO "Given LAN IP was $lan_ip"
|
||||||
|
logger INFO "Given LAN port was $lan_qport"
|
||||||
|
res=$(a2s $lan_ip $lan_qport info)
|
||||||
|
if [[ ! $? -eq 0 ]] || [[ $(<<< $res jq 'length') -eq 0 ]]; then
|
||||||
|
warn "Failed to retrieve server metadata. Check IP:PORT combination and try again."
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
local ct=$(<<< "$res" jq '.response.servers|length')
|
logger INFO "$res"
|
||||||
if [[ $ct -eq 1 ]]; then
|
local name=$(<<< $res jq -r '.name')
|
||||||
local name=$(<<< $res jq -r '.response.servers[].name')
|
local address=$(<<< $res jq -r '.address')
|
||||||
local address=$(<<< $res jq -r '.response.servers[].addr')
|
local ip=$(<<< $address awk -F: '{print $1}')
|
||||||
local ip=$(<<< "$address" awk -F: '{print $1}')
|
local gameport=$(<<< $address awk -F: '{print $2}')
|
||||||
local qport=$(<<< "$address" awk -F: '{print $2}')
|
local qport=$(<<< $res jq -r '.qport')
|
||||||
local gameport=$(<<< $res jq -r '.response.servers[].gameport')
|
logger INFO "Found '${name}' at ${ip}:${gameport}:${qport}"
|
||||||
echo "${name}%%${ip}:${gameport}%%${qport}"
|
echo "${name}%%${ip}:${gameport}%%${qport}"
|
||||||
return 0
|
|
||||||
fi
|
|
||||||
ip_table "$res"
|
|
||||||
return 0
|
return 0
|
||||||
else
|
else
|
||||||
warn "Invalid IP"
|
if validate_ip "$ip"; then
|
||||||
|
res=$(fetch_ip_metadata "$ip")
|
||||||
|
if [[ ! $? -eq 0 ]] || [[ $(<<< $res jq '.response|length') -eq 0 ]]; then
|
||||||
|
warn "Failed to retrieve server metadata. Check IP or API key and try again."
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
local ct=$(<<< "$res" jq '.response.servers|length')
|
||||||
|
if [[ $ct -eq 1 ]]; then
|
||||||
|
local name=$(<<< $res jq -r '.response.servers[].name')
|
||||||
|
local address=$(<<< $res jq -r '.response.servers[].addr')
|
||||||
|
local ip=$(<<< "$address" awk -F: '{print $1}')
|
||||||
|
local qport=$(<<< "$address" awk -F: '{print $2}')
|
||||||
|
local gameport=$(<<< $res jq -r '.response.servers[].gameport')
|
||||||
|
echo "${name}%%${ip}:${gameport}%%${qport}"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
ip_table "$res"
|
||||||
|
return 0
|
||||||
|
else
|
||||||
|
warn "Invalid IP"
|
||||||
|
fi
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
@ -953,8 +980,6 @@ list_mods(){
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
connect_to_fav(){
|
connect_to_fav(){
|
||||||
#TODO: test with broken/bogus fav
|
|
||||||
#TODO: test backing out of connection dialogs
|
|
||||||
logger INFO "${FUNCNAME[0]}"
|
logger INFO "${FUNCNAME[0]}"
|
||||||
|
|
||||||
local fav="$1"
|
local fav="$1"
|
||||||
|
@ -1126,7 +1151,7 @@ popup(){
|
||||||
1100) pop "No results found." ;;
|
1100) pop "No results found." ;;
|
||||||
1200) pop "Timed out. Server may be temporarily offline or not responding to queries." ;;
|
1200) pop "Timed out. Server may be temporarily offline or not responding to queries." ;;
|
||||||
1300) pop "No favorite server configured." ;;
|
1300) pop "No favorite server configured." ;;
|
||||||
1400) pop "DZGUI must be run in Desktop Mode on Steam Deck, preferably via the desktop shortcut." ;;
|
1400) pop "To install missing mods, run DZGUI via Desktop Mode on Steam Deck, preferably via the desktop shortcut." ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
toggle_console_dl(){
|
toggle_console_dl(){
|
||||||
|
@ -1232,6 +1257,7 @@ a2s(){
|
||||||
local ip="$1"
|
local ip="$1"
|
||||||
local qport="$2"
|
local qport="$2"
|
||||||
local mode="$3"
|
local mode="$3"
|
||||||
|
logger A2S "Querying '$ip:$qport' with mode '$mode'"
|
||||||
python3 $helpers_path/query.py "$ip" "$qport" "$mode"
|
python3 $helpers_path/query.py "$ip" "$qport" "$mode"
|
||||||
}
|
}
|
||||||
format_config_address(){
|
format_config_address(){
|
||||||
|
@ -1431,7 +1457,7 @@ choose_filters(){
|
||||||
if [[ $sels =~ Keyword ]]; then
|
if [[ $sels =~ Keyword ]]; then
|
||||||
local search
|
local search
|
||||||
while true; do
|
while true; do
|
||||||
search=$($steamsafe_zenity --entry --text="Search (case insensitive)" --width=500 --title="DZGUI" 2>/dev/null | awk '{print tolower($0)}')
|
search=$(edialog "Search (case insensitive)" | awk '{print tolower($0)}')
|
||||||
[[ $? -eq 1 ]] && return 1
|
[[ $? -eq 1 ]] && return 1
|
||||||
[[ -z $search ]] && warn "Cannot submit an empty keyword"
|
[[ -z $search ]] && warn "Cannot submit an empty keyword"
|
||||||
[[ -n $search ]] && break
|
[[ -n $search ]] && break
|
||||||
|
@ -1749,11 +1775,6 @@ check_architecture(){
|
||||||
if [[ -n "$cpu" ]]; then
|
if [[ -n "$cpu" ]]; then
|
||||||
is_steam_deck=1
|
is_steam_deck=1
|
||||||
logger INFO "Setting architecture to 'Steam Deck'"
|
logger INFO "Setting architecture to 'Steam Deck'"
|
||||||
[[ $is_steam_deck -eq 1 ]] && test_display_mode
|
|
||||||
if [[ $gamemode -eq 1 ]]; then
|
|
||||||
popup 1400 &&
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
else
|
else
|
||||||
is_steam_deck=0
|
is_steam_deck=0
|
||||||
logger INFO "Setting architecture to 'desktop'"
|
logger INFO "Setting architecture to 'desktop'"
|
||||||
|
@ -1839,7 +1860,11 @@ pdialog(){
|
||||||
$steamsafe_zenity --progress --pulsate --auto-close --title="DZGUI" --width=500 2>/dev/null
|
$steamsafe_zenity --progress --pulsate --auto-close --title="DZGUI" --width=500 2>/dev/null
|
||||||
}
|
}
|
||||||
edialog(){
|
edialog(){
|
||||||
$steamsafe_zenity --entry --text="$1" --width=500 --title="DZGUI" 2>/dev/null
|
if [[ $is_steam_deck -eq 1 ]] && [[ $(test_display_mode) == "gm" ]]; then
|
||||||
|
kdialog --inputbox "$1" --title "DZGUI" --geometry 500 2>/dev/null
|
||||||
|
else
|
||||||
|
$steamsafe_zenity --entry --text="$1" --width=500 --title="DZGUI" 2>/dev/null
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
tdialog(){
|
tdialog(){
|
||||||
$steamsafe_zenity --info --text="$1" --width=500 --title="DZGUI" 2>/dev/null
|
$steamsafe_zenity --info --text="$1" --width=500 --title="DZGUI" 2>/dev/null
|
||||||
|
|
2
news
2
news
|
@ -1 +1 @@
|
||||||
NEWS: Major 4.0.0 update. Full details via the View Changelog menu option.
|
NEWS: Added support for LAN servers and restored Steam Deck Game Mode support. See changelog.
|
||||||
|
|
Loading…
Reference in a new issue