mirror of
https://github.com/j-a-n/raspberrymatic-addon-rmupdate.git
synced 2023-10-10 13:37:40 +02:00
Execute cgi instead of using wget to get download url in http-auth enabled environments.
This commit is contained in:
parent
44cfbeda81
commit
eb819849f5
@ -1450,6 +1450,8 @@ proc ::rmupdate::get_addon_info {{fetch_available_version 0} {fetch_download_url
|
|||||||
set addons(${id}::config_url) ""
|
set addons(${id}::config_url) ""
|
||||||
set addons(${id}::operations) ""
|
set addons(${id}::operations) ""
|
||||||
set addons(${id}::download_url) ""
|
set addons(${id}::download_url) ""
|
||||||
|
set addons(${id}::cgi) ""
|
||||||
|
set addons(${id}::cgi_interpreter) ""
|
||||||
foreach line [split $data "\n"] {
|
foreach line [split $data "\n"] {
|
||||||
regexp {^(\S+)\s*:\s*(\S.*)\s*$} $line match key value
|
regexp {^(\S+)\s*:\s*(\S.*)\s*$} $line match key value
|
||||||
if { [info exists key] } {
|
if { [info exists key] } {
|
||||||
@ -1466,12 +1468,12 @@ proc ::rmupdate::get_addon_info {{fetch_available_version 0} {fetch_download_url
|
|||||||
set cgi_data [read $cfd]
|
set cgi_data [read $cfd]
|
||||||
close $cfd
|
close $cfd
|
||||||
set firstline [lindex [split $cgi_data "\n"] 0]
|
set firstline [lindex [split $cgi_data "\n"] 0]
|
||||||
write_log 1 "firstline: ${firstline}"
|
regexp {^#!(.*)$} $firstline match cgi_interpreter
|
||||||
regexp {^#!(.*)$} $firstline match cmd
|
set addons(${id}::cgi) $cgi
|
||||||
set available_version [exec $cmd "$cgi"]
|
set addons(${id}::cgi_interpreter) $cgi_interpreter
|
||||||
if {!$available_version} {
|
set ::env(QUERY_STRING) ""
|
||||||
set available_version [exec /usr/bin/wget "http://localhost${value}" --quiet --output-document=-]
|
set available_version [exec $cgi_interpreter "$cgi"]
|
||||||
}
|
#set available_version [exec /usr/bin/wget "http://localhost${value}" --quiet --output-document=-]
|
||||||
set addons(${id}::available_version) $available_version
|
set addons(${id}::available_version) $available_version
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1489,10 +1491,14 @@ proc ::rmupdate::get_addon_info {{fetch_available_version 0} {fetch_download_url
|
|||||||
set opt [lindex $tmp 2]
|
set opt [lindex $tmp 2]
|
||||||
if {$opt == "update" && $addons($key) != "" && $addons(${addon_id}::available_version) != ""} {
|
if {$opt == "update" && $addons($key) != "" && $addons(${addon_id}::available_version) != ""} {
|
||||||
set available_version $addons(${addon_id}::available_version)
|
set available_version $addons(${addon_id}::available_version)
|
||||||
set url "http://localhost/$addons($key)?cmd=download&version=${available_version}"
|
#set url "http://localhost/$addons($key)?cmd=download&version=${available_version}"
|
||||||
catch {
|
catch {
|
||||||
write_log 4 "Get: ${url}"
|
#write_log 4 "Get: ${url}"
|
||||||
set data [exec /usr/bin/wget "${url}" --quiet --output-document=-]
|
#set data [exec /usr/bin/wget "${url}" --quiet --output-document=-]
|
||||||
|
set cgi $addons(${addon_id}::cgi)
|
||||||
|
set cgi_interpreter $addons(${addon_id}::cgi_interpreter)
|
||||||
|
set ::env(QUERY_STRING) "cmd=download&version=${available_version}"
|
||||||
|
set data [exec $cgi_interpreter "$cgi"]
|
||||||
write_log 4 "Response: ${data}"
|
write_log 4 "Response: ${data}"
|
||||||
regexp {url=([^\s\"\']+)} $data match download_url
|
regexp {url=([^\s\"\']+)} $data match download_url
|
||||||
if { [info exists download_url] } {
|
if { [info exists download_url] } {
|
||||||
|
Loading…
Reference in New Issue
Block a user