forked from CastroFidel/PortWINE
		
	Merge branch 'Boria138-grid-refactoring' into devel
This commit is contained in:
		| @@ -13,14 +13,6 @@ fi | |||||||
| NOSTICONPATH="${PORT_WINE_PATH}/data/img/${name_desktop}.png" | NOSTICONPATH="${PORT_WINE_PATH}/data/img/${name_desktop}.png" | ||||||
| BASESTEAMGRIDDBAPI="https://www.steamgriddb.com/api/v2" | BASESTEAMGRIDDBAPI="https://www.steamgriddb.com/api/v2" | ||||||
|  |  | ||||||
| function checkSGDbApi { |  | ||||||
| 	if [ -z "$SGDBAPIKEY" ] || [ "$SGDBAPIKEY" == "$NON" ]; then |  | ||||||
| 		return 1 |  | ||||||
| 	else |  | ||||||
| 		return 0 |  | ||||||
| 	fi |  | ||||||
| } |  | ||||||
|  |  | ||||||
| ## How Non-Steam AppIDs work, because it took me almost a year to figure this out | ## How Non-Steam AppIDs work, because it took me almost a year to figure this out | ||||||
| ## ---------------------- | ## ---------------------- | ||||||
| ## Steam stores shortcuts in a binary 'shortcuts.vdf', at SROOT/userdata/<id>/config | ## Steam stores shortcuts in a binary 'shortcuts.vdf', at SROOT/userdata/<id>/config | ||||||
| @@ -169,9 +161,8 @@ function downloadArtFromSteamGridDB { | |||||||
|  |  | ||||||
|     RESPONSE_LENGTH=$(jq '.data | length' <<< "$RESPONSE") |     RESPONSE_LENGTH=$(jq '.data | length' <<< "$RESPONSE") | ||||||
|  |  | ||||||
|     if [ "$RESPONSE_LENGTH" -eq 0 ]; then |     if [[ "$RESPONSE_LENGTH" == "0" ]] ; then | ||||||
|         echo "No grid found to download - maybe loosen filters?" |         echo "No grid found to download - maybe loosen filters?" | ||||||
|         return |  | ||||||
|     fi |     fi | ||||||
|  |  | ||||||
|     if jq -e ".data[0].url" <<< "$RESPONSE" > /dev/null; then |     if jq -e ".data[0].url" <<< "$RESPONSE" > /dev/null; then | ||||||
| @@ -182,11 +173,9 @@ function downloadArtFromSteamGridDB { | |||||||
|     for i in $(seq 0 $(("$RESPONSE_LENGTH" - 1))); do |     for i in $(seq 0 $(("$RESPONSE_LENGTH" - 1))); do | ||||||
|         if ! jq -e ".data[$i].success" <<< "$RESPONSE" > /dev/null; then |         if ! jq -e ".data[$i].success" <<< "$RESPONSE" > /dev/null; then | ||||||
|             echo "The server response for '$SEARCHID' wasn't 'success'" |             echo "The server response for '$SEARCHID' wasn't 'success'" | ||||||
|             continue |  | ||||||
|         fi |         fi | ||||||
|         if ! URLSTR=$(jq -e -r ".data[$i].data[0].url" <<< "$RESPONSE"); then |         if ! URLSTR=$(jq -e -r ".data[$i].data[0].url" <<< "$RESPONSE"); then | ||||||
|             echo "No grid found to download for '$SEARCHID' - maybe loosen filters?" |             echo "No grid found to download for '$SEARCHID' - maybe loosen filters?" | ||||||
|             continue |  | ||||||
|         fi |         fi | ||||||
|  |  | ||||||
|         GRIDDLURL="${URLSTR//\"}" |         GRIDDLURL="${URLSTR//\"}" | ||||||
| @@ -208,7 +197,12 @@ function downloadArtFromSteamGridDB { | |||||||
|             fi |             fi | ||||||
|  |  | ||||||
|             if [ "$STARTDL" -eq 1 ]; then |             if [ "$STARTDL" -eq 1 ]; then | ||||||
|                 curl -f -# -A 'Mozilla/5.0 (compatible; Konqueror/2.1.1; X11)' -H 'Cache-Control: no-cache, no-store' -H 'Pragma: no-cache' -L "$DLSRC" -o "$DLDST" | 				filename="$(basename "$DLDST")" | ||||||
|  |                 curl -f -# -A 'Mozilla/5.0 (compatible; Konqueror/2.1.1; X11)' -H 'Cache-Control: no-cache, no-store' -H 'Pragma: no-cache' -L "$DLSRC" -o "$DLDST" 2>&1 | \ | ||||||
|  |                  tr '\r' '\n' | sed -ur 's|[# ]+||g;s|.*=.*||g;s|.*|#Downloading at &\n&|g' | \ | ||||||
|  | 				"$pw_yad" --progress --text="$(gettext "Downloading") $filename" --auto-close --no-escape \ | ||||||
|  | 				--auto-kill --center --text-align="center" --fixed --no-buttons --title "PortProton" --width=500 --height=90 \ | ||||||
|  | 				--window-icon="$PW_GUI_ICON_PATH/portproton.svg" --borders="$PROGRESS_BAR_BORDERS_SIZE" | ||||||
|             fi |             fi | ||||||
|         else |         else | ||||||
|             echo "No grid found to download for '$SEARCHID' - maybe loosen filters?" |             echo "No grid found to download for '$SEARCHID' - maybe loosen filters?" | ||||||
| @@ -231,7 +225,7 @@ function getSGDBGameIDFromTitle { | |||||||
| 	SGDBSEARCHNAME="$1" | 	SGDBSEARCHNAME="$1" | ||||||
|  |  | ||||||
| 	if [ -n "$SGDBSEARCHNAME" ]; then | 	if [ -n "$SGDBSEARCHNAME" ]; then | ||||||
| 	SGDBSEARCHENDPOINT="${BASESTEAMGRIDDBAPI}/search/autocomplete/${SGDBSEARCHNAME}" | 		SGDBSEARCHENDPOINT="${BASESTEAMGRIDDBAPI}/search/autocomplete/${SGDBSEARCHNAME}" | ||||||
| 		SGDBSEARCHNAMERESP="$(curl -H "Authorization: Bearer $SGDBAPIKEY" -s "$SGDBSEARCHENDPOINT" 2>  >(grep -v "SSL_INIT") )" | 		SGDBSEARCHNAMERESP="$(curl -H "Authorization: Bearer $SGDBAPIKEY" -s "$SGDBSEARCHENDPOINT" 2>  >(grep -v "SSL_INIT") )" | ||||||
| 		if jq -e '.success' 1> /dev/null <<< "$SGDBSEARCHNAMERESP"; then | 		if jq -e '.success' 1> /dev/null <<< "$SGDBSEARCHNAMERESP"; then | ||||||
| 			if [ "$(jq '.data | length' <<< "$SGDBSEARCHNAMERESP" )" -gt 0 ]; then | 			if [ "$(jq '.data | length' <<< "$SGDBSEARCHNAMERESP" )" -gt 0 ]; then | ||||||
| @@ -241,9 +235,9 @@ function getSGDBGameIDFromTitle { | |||||||
| 				echo "$SGDBSEARCH_FOUNDGAID" | 				echo "$SGDBSEARCH_FOUNDGAID" | ||||||
| 			fi | 			fi | ||||||
| 		fi | 		fi | ||||||
| else | 	else | ||||||
| 	echo "No game name given." | 		echo "No game name given." | ||||||
| fi | 	fi | ||||||
| } | } | ||||||
|  |  | ||||||
| # Used to get either Steam or Non-Steam artwork depending on a flag -- Used internally and for commandline usage | # Used to get either Steam or Non-Steam artwork depending on a flag -- Used internally and for commandline usage | ||||||
| @@ -281,12 +275,9 @@ function commandlineGetSteamGridDBArtwork { | |||||||
| 	# If we pass a name to search on and we get a Game ID back from SteamGridDB, set this as the ID to search for artwork on | 	# If we pass a name to search on and we get a Game ID back from SteamGridDB, set this as the ID to search for artwork on | ||||||
| 	if [ -n "$GSGDBA_SEARCHNAME" ]; then | 	if [ -n "$GSGDBA_SEARCHNAME" ]; then | ||||||
| 		if [ -n "$GSGDBA_FILENAME" ]; then | 		if [ -n "$GSGDBA_FILENAME" ]; then | ||||||
| 			#writelog "INFO" "${FUNCNAME[0]} - Searching SteamGridDB for game name matching '$GSGDBA_SEARCHNAME'" |  | ||||||
| 			GSGDBA_FOUNDGAMEID="$( getSGDBGameIDFromTitle "$GSGDBA_SEARCHNAME" )" | 			GSGDBA_FOUNDGAMEID="$( getSGDBGameIDFromTitle "$GSGDBA_SEARCHNAME" )" | ||||||
| 			if [ -n "$GSGDBA_FOUNDGAMEID" ]; then | 			if [ -n "$GSGDBA_FOUNDGAMEID" ]; then | ||||||
| 				#writelog "INFO" "${FUNCNAME[0]} - Found game name matching '$GSGDBA_SEARCHNAME' with Game ID '$GSGDBA_FOUNDGAMEID' -- Using this Game ID to search for SteamGridDB Game Art" |  | ||||||
| 				GSGDBA_APPID="$GSGDBA_FOUNDGAMEID" | 				GSGDBA_APPID="$GSGDBA_FOUNDGAMEID" | ||||||
| 				#writelog "INFO" "${FUNCNAME[0]} - Forcing endpoint type as --nonsteam since we're searching with a found SteamGridDB Game ID" |  | ||||||
| 				SGDBENDPOINTTYPE="game" | 				SGDBENDPOINTTYPE="game" | ||||||
| 			fi | 			fi | ||||||
| 		else | 		else | ||||||
| @@ -329,7 +320,8 @@ NOSTSEARCHFLAG="--nonsteam"  # Whether to search using a Steam AppID or SteamGri | |||||||
|  |  | ||||||
| # Only add NOSTAPPNAME as fallback if we don't have an ID to search on, because commandlineGetSteamGridDBArtwork will prefer name over ID, so if we have to fall back to Non-Steam Name (i.e. no entered custom name) then only do so if we don't have an ID given | # Only add NOSTAPPNAME as fallback if we don't have an ID to search on, because commandlineGetSteamGridDBArtwork will prefer name over ID, so if we have to fall back to Non-Steam Name (i.e. no entered custom name) then only do so if we don't have an ID given | ||||||
| if [ -n "$NOSTAPPNAME" ]; then | if [ -n "$NOSTAPPNAME" ]; then | ||||||
|    	NOSTSEARCHNAME="$NOSTAPPNAME" | 	NOSTSEARCHNAME="$NOSTAPPNAME" | ||||||
|  | 	NOSTSEARCHNAME="${NOSTSEARCHNAME// /_}" | ||||||
| fi | fi | ||||||
|  |  | ||||||
| # Store the ID we searched with, so getSteamGridDBNonSteamIcon doesn't have to hit the endpoint again and we save an API call | # Store the ID we searched with, so getSteamGridDBNonSteamIcon doesn't have to hit the endpoint again and we save an API call | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user