@ -23,8 +23,8 @@ use crate::{
error ::{ Error , MapResult } ,
error ::{ Error , MapResult } ,
mail ,
mail ,
util ::{
util ::{
dock er_base_image, format_naive_datetime_local , get_display_size , get_reqwest_client , is_running_in_docker ,
contain er_base_image, format_naive_datetime_local , get_display_size , get_reqwest_client ,
NumberOrString ,
is_running_in_container , NumberOrString ,
} ,
} ,
CONFIG , VERSION ,
CONFIG , VERSION ,
} ;
} ;
@ -608,7 +608,7 @@ use cached::proc_macro::cached;
/// Cache this function to prevent API call rate limit. Github only allows 60 requests per hour, and we use 3 here already.
/// Cache this function to prevent API call rate limit. Github only allows 60 requests per hour, and we use 3 here already.
/// It will cache this function for 300 seconds (5 minutes) which should prevent the exhaustion of the rate limit.
/// It will cache this function for 300 seconds (5 minutes) which should prevent the exhaustion of the rate limit.
#[ cached(time = 300, sync_writes = true) ]
#[ cached(time = 300, sync_writes = true) ]
async fn get_release_info ( has_http_access : bool , running_within_dock er : bool ) -> ( String , String , String ) {
async fn get_release_info ( has_http_access : bool , running_within_contain er : bool ) -> ( String , String , String ) {
// If the HTTP Check failed, do not even attempt to check for new versions since we were not able to connect with github.com anyway.
// If the HTTP Check failed, do not even attempt to check for new versions since we were not able to connect with github.com anyway.
if has_http_access {
if has_http_access {
(
(
@ -625,9 +625,9 @@ async fn get_release_info(has_http_access: bool, running_within_docker: bool) ->
}
}
_ = > "-" . to_string ( ) ,
_ = > "-" . to_string ( ) ,
} ,
} ,
// Do not fetch the web-vault version when running within Dock er.
// Do not fetch the web-vault version when running within a contain er.
// The web-vault version is embedded within the container it self, and should not be updated manually
// The web-vault version is embedded within the container it self, and should not be updated manually
if running_within_dock er {
if running_within_contain er {
"-" . to_string ( )
"-" . to_string ( )
} else {
} else {
match get_json_api ::< GitRelease > (
match get_json_api ::< GitRelease > (
@ -681,7 +681,7 @@ async fn diagnostics(_token: AdminToken, ip_header: IpHeader, mut conn: DbConn)
} ;
} ;
// Execute some environment checks
// Execute some environment checks
let running_within_dock er = is_running_in_dock er ( ) ;
let running_within_contain er = is_running_in_contain er ( ) ;
let has_http_access = has_http_access ( ) . await ;
let has_http_access = has_http_access ( ) . await ;
let uses_proxy = env ::var_os ( "HTTP_PROXY" ) . is_some ( )
let uses_proxy = env ::var_os ( "HTTP_PROXY" ) . is_some ( )
| | env ::var_os ( "http_proxy" ) . is_some ( )
| | env ::var_os ( "http_proxy" ) . is_some ( )
@ -695,7 +695,7 @@ async fn diagnostics(_token: AdminToken, ip_header: IpHeader, mut conn: DbConn)
} ;
} ;
let ( latest_release , latest_commit , latest_web_build ) =
let ( latest_release , latest_commit , latest_web_build ) =
get_release_info ( has_http_access , running_within_dock er ) . await ;
get_release_info ( has_http_access , running_within_contain er ) . await ;
let ip_header_name = match & ip_header . 0 {
let ip_header_name = match & ip_header . 0 {
Some ( h ) = > h ,
Some ( h ) = > h ,
@ -710,8 +710,8 @@ async fn diagnostics(_token: AdminToken, ip_header: IpHeader, mut conn: DbConn)
"web_vault_enabled" : & CONFIG . web_vault_enabled ( ) ,
"web_vault_enabled" : & CONFIG . web_vault_enabled ( ) ,
"web_vault_version" : web_vault_version . version . trim_start_matches ( 'v' ) ,
"web_vault_version" : web_vault_version . version . trim_start_matches ( 'v' ) ,
"latest_web_build" : latest_web_build ,
"latest_web_build" : latest_web_build ,
"running_within_docker" : running_within_dock er ,
"running_within_container" : running_within_contain er ,
"dock er_base_image" : if running_within_docker { dock er_base_image ( ) } else { "Not applicable" } ,
"contain er_base_image" : if running_within_container { contain er_base_image ( ) } else { "Not applicable" } ,
"has_http_access" : has_http_access ,
"has_http_access" : has_http_access ,
"ip_header_exists" : & ip_header . 0. is_some ( ) ,
"ip_header_exists" : & ip_header . 0. is_some ( ) ,
"ip_header_match" : ip_header_name = = CONFIG . ip_header ( ) ,
"ip_header_match" : ip_header_name = = CONFIG . ip_header ( ) ,