1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
use serde::{Deserialize, Serialize};
use std::vec::Vec;
#[derive(Serialize, Deserialize, Debug, Clone)]
pub struct ReleaseInfo {
pub name: String,
pub published_at: String,
pub body: String,
}
// Fetches repo release API and returns response as string
async fn fetch_github_releases_api(url: &str) -> Result<String, String> {
println!("Fetching releases notes from GitHub API");
let user_agent = "R2NorthstarTools/FlightCore";
let client = reqwest::Client::new();
let res = client
.get(url)
.header(reqwest::header::USER_AGENT, user_agent)
.send()
.await
.unwrap()
.text()
.await
.unwrap();
Ok(res)
}
/// Checks if installed FlightCore version is up-to-date
/// false -> FlightCore install is up-to-date
/// true -> FlightCore install is outdated
pub async fn check_is_flightcore_outdated() -> Result<bool, String> {
// Get newest version number from GitHub API
println!("Checking GitHub API");
let url = "https://api.github.com/repos/R2NorthstarTools/FlightCore/releases/latest";
let res = fetch_github_releases_api(url).await?;
let json_response: serde_json::Value =
serde_json::from_str(&res).expect("JSON was not well-formatted");
println!("Done checking GitHub API");
// Extract version number from JSON
let newest_release_version = json_response
.get("tag_name")
.and_then(|value| value.as_str())
.unwrap();
// Get version of installed FlightCore...
let version = env!("CARGO_PKG_VERSION");
// ...and format it
let version = format!("v{}", version);
// TODO: This shouldn't be a string compare but promper semver compare
let is_outdated = version != newest_release_version;
// If outdated, check how new the update is
if is_outdated {
// Extract release date from JSON
let release_date = json_response
.get("published_at")
.and_then(|value| value.as_str())
.unwrap();
// Time to wait (2h) h * m * s
let threshold_seconds = 2 * 60 * 60;
// Get current time
let current_time = chrono::Utc::now();
// Get latest release time from GitHub API response
let result = chrono::DateTime::parse_from_rfc3339(release_date)
.unwrap()
.with_timezone(&chrono::Utc);
// Check if current time is outside of threshold
let diff = current_time - result;
if diff.num_seconds() < threshold_seconds {
// User would be outdated but the newest release is recent
// therefore we do not wanna show outdated warning.
return Ok(false);
}
return Ok(true);
}
Ok(is_outdated)
}
#[tauri::command]
pub async fn get_northstar_release_notes() -> Result<Vec<ReleaseInfo>, String> {
let url = "https://api.github.com/repos/R2Northstar/Northstar/releases";
let res = fetch_github_releases_api(url).await?;
let json_response: Vec<serde_json::Value> =
serde_json::from_str(&res).expect("JSON was not well-formatted");
println!("Done checking GitHub API");
return Ok(json_response
.iter()
.map(|release| ReleaseInfo {
name: release
.get("name")
.and_then(|value| value.as_str())
.unwrap()
.to_string(),
published_at: release
.get("published_at")
.and_then(|value| value.as_str())
.unwrap()
.to_string(),
body: release
.get("body")
.and_then(|value| value.as_str())
.unwrap()
.to_string(),
})
.collect());
}
|