restructuring of mediawiki (still in progress)
This commit is contained in:
parent
659e9f258a
commit
20b8ce40de
|
@ -178,7 +178,7 @@ fn main() -> Result<(), Box<dyn Error>> {
|
||||||
&config["wiki-http-password"],
|
&config["wiki-http-password"],
|
||||||
&config["wiki-api-user"],
|
&config["wiki-api-user"],
|
||||||
&config["wiki-api-secret"],
|
&config["wiki-api-secret"],
|
||||||
is_dry_run(),
|
false, // is_dry_run(), // TODO: Remove this false in order for actually letting dry_run affecting if mediawiki is run
|
||||||
&config["wiki-plenum-page"],
|
&config["wiki-plenum-page"],
|
||||||
);
|
);
|
||||||
trace_var_!(wiki);
|
trace_var_!(wiki);
|
||||||
|
|
|
@ -5,6 +5,7 @@ use chrono::{Datelike, NaiveDate, Utc};
|
||||||
use colored::Colorize;
|
use colored::Colorize;
|
||||||
use reqwest::blocking::Client;
|
use reqwest::blocking::Client;
|
||||||
use serde::Deserialize;
|
use serde::Deserialize;
|
||||||
|
use serde_json::{json, Value};
|
||||||
|
|
||||||
use crate::{trace_var, verboseln};
|
use crate::{trace_var, verboseln};
|
||||||
use crate::config_spec::{CfgField, CfgGroup};
|
use crate::config_spec::{CfgField, CfgGroup};
|
||||||
|
@ -97,30 +98,57 @@ impl Mediawiki {
|
||||||
client: Client::builder().cookie_store(true).build().unwrap(),
|
client: Client::builder().cookie_store(true).build().unwrap(),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
pub fn get_login_token(&self) -> Result<(), Box<dyn Error>> {
|
pub fn login (&self) -> Result<(), Box<dyn Error>> {
|
||||||
let url =
|
let url = format!("{}/api.php?", self.server_url);
|
||||||
format!("{}/api.php?", self.server_url);
|
// retrieve login token first
|
||||||
let params: Box<[(&str, &str)]> = Box::from( [
|
let params_0: Box<[(&str, &str)]> = Box::from([
|
||||||
("format", "json"),
|
("action", "query"),
|
||||||
("meta", "tokens"),
|
("meta", "tokens"),
|
||||||
("type", "login"),
|
("type", "login"),
|
||||||
("action", "query")
|
("format", "json")
|
||||||
]);
|
]);
|
||||||
let resp = self.make_request(url, params, ValidRequestTypes::Get)?;
|
verboseln!("Login params: {:?}", params_0);
|
||||||
let response_deserialized: QueryResponseLogin = serde_json::from_str(&resp)?;
|
let resp_0: String = self.make_request(url.clone(), params_0, ValidRequestTypes::Get)?;
|
||||||
self.login_token.set(response_deserialized.query.tokens.logintoken)?;
|
verboseln!("Raw response login_0: {}", resp_0.yellow());
|
||||||
|
let resp_0_deserialized: serde_json::Value = serde_json::from_str(&resp_0)?;
|
||||||
|
verboseln!("login0 deserialized");
|
||||||
|
|
||||||
|
let login_token = resp_0_deserialized
|
||||||
|
.pointer("/query/tokens/logintoken")
|
||||||
|
.and_then(|v| v.as_str())
|
||||||
|
.map(|token| token.replace("+\\", ""))
|
||||||
|
.ok_or("Login token not found")?;
|
||||||
|
|
||||||
|
self.login_token.set(login_token)?;
|
||||||
|
|
||||||
|
verboseln!("login0 finished");
|
||||||
|
let login_token: String = self.login_token.clone().into_inner().unwrap();
|
||||||
|
verboseln!("using {login_token} as login");
|
||||||
|
let params_1: Box<[(&str, &str)]> = Box::from([
|
||||||
|
("action", "login"),
|
||||||
|
("lgname", &self.api_user),
|
||||||
|
("lgpassword", &self.api_secret),
|
||||||
|
("lgtoken", &login_token),
|
||||||
|
("format", "json")
|
||||||
|
]);
|
||||||
|
verboseln!("Login params: {:?}", params_1);
|
||||||
|
let resp_1: String = self.client
|
||||||
|
.post(&url)
|
||||||
|
// .basic_auth(&self.http_user, Some(&self.http_password)) // TODO: ZU TESTZWECKEN ENTFERNT
|
||||||
|
.form(¶ms_1)
|
||||||
|
.send()?
|
||||||
|
.text()?;
|
||||||
|
verboseln!("Raw response login_1: {}", resp_1.yellow());
|
||||||
|
let resp_1_deserialized: serde_json::Value = serde_json::from_str(&resp_1)?;
|
||||||
|
if let Some(result) = resp_1_deserialized.get("login").and_then(|l| l.get("result")) {
|
||||||
|
if result.as_str() == Some("Success") {
|
||||||
Ok(())
|
Ok(())
|
||||||
|
} else {
|
||||||
|
Err(format!("Login failed. Response: {}", resp_1_deserialized).into())
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
Err(format!("Unexpected login response: {}", resp_1_deserialized).into())
|
||||||
}
|
}
|
||||||
pub fn login (&self) -> Result<String, Box<dyn Error>> {
|
|
||||||
let url = format!("{}/api.php?", self.server_url);
|
|
||||||
let params: Box<[(&str, &str)]> = Box::from([
|
|
||||||
("lgname", self.api_user.as_str()),
|
|
||||||
("lgpassword", self.api_secret.as_str()),
|
|
||||||
("lgtoken", self.login_token.get().unwrap()),
|
|
||||||
("action", "login")
|
|
||||||
]);
|
|
||||||
let resp: Result<String, Box<dyn Error>> = self.make_request(url, params, ValidRequestTypes::Post);
|
|
||||||
Ok(resp?)
|
|
||||||
}
|
}
|
||||||
pub fn get_csrf_token(&self) -> Result<(), Box<dyn Error>> {
|
pub fn get_csrf_token(&self) -> Result<(), Box<dyn Error>> {
|
||||||
let url =
|
let url =
|
||||||
|
@ -128,12 +156,18 @@ impl Mediawiki {
|
||||||
let params: Box<[(&str, &str)]> = Box::from([
|
let params: Box<[(&str, &str)]> = Box::from([
|
||||||
("format", "json"),
|
("format", "json"),
|
||||||
("meta", "tokens"),
|
("meta", "tokens"),
|
||||||
("formatversion", "2"),
|
|
||||||
("action", "query")
|
("action", "query")
|
||||||
]);
|
]);
|
||||||
let resp: String = self.make_request(url, params, ValidRequestTypes::Get)?;
|
let resp: String = self.make_request(url, params, ValidRequestTypes::Get)?;
|
||||||
|
verboseln!("Raw response csrf: {}", resp);
|
||||||
let response_deserialized: QueryResponseCsrf = serde_json::from_str(&resp)?;
|
let response_deserialized: QueryResponseCsrf = serde_json::from_str(&resp)?;
|
||||||
self.csrf_token.set(response_deserialized.query.tokens.csrftoken)?;
|
let token = response_deserialized.query.tokens.csrftoken;
|
||||||
|
verboseln!("Parsed token: '{}'", token);
|
||||||
|
if token == "+\\" {
|
||||||
|
return Err("Failed to parse CSRF token. Response was only '+\\'. Please check your Bot API credentials".into());
|
||||||
|
}
|
||||||
|
self.csrf_token.set(token)?;
|
||||||
|
verboseln!("CSRF token acquired: {}", self.csrf_token.get().unwrap());
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -144,7 +178,7 @@ impl Mediawiki {
|
||||||
self
|
self
|
||||||
.client
|
.client
|
||||||
.get(url)
|
.get(url)
|
||||||
//.basic_auth(&self.http_user, Some(&self.http_password)) ZU TESTZWECKEN ENTFERNT
|
//.basic_auth(&self.http_user, Some(&self.http_password)) // TODO: ZU TESTZWECKEN ENTFERNT
|
||||||
.query(¶ms)
|
.query(¶ms)
|
||||||
.send()
|
.send()
|
||||||
}
|
}
|
||||||
|
@ -154,8 +188,8 @@ impl Mediawiki {
|
||||||
self
|
self
|
||||||
.client
|
.client
|
||||||
.post(url)
|
.post(url)
|
||||||
//.basic_auth(&self.http_user, Some(&self.http_password)) ZU TESTZWECKEN ENTFERNT
|
//.basic_auth(&self.http_user, Some(&self.http_password)) // TODO: ZU TESTZWECKEN ENTFERNT
|
||||||
.json(¶ms_map)
|
.query(¶ms_map)
|
||||||
.send()
|
.send()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -313,7 +347,6 @@ impl Mediawiki {
|
||||||
);
|
);
|
||||||
|
|
||||||
// Ensure login token and CSRF token are set
|
// Ensure login token and CSRF token are set
|
||||||
self.get_login_token()?;
|
|
||||||
let _login_result = self.login()?;
|
let _login_result = self.login()?;
|
||||||
self.get_csrf_token()?;
|
self.get_csrf_token()?;
|
||||||
|
|
||||||
|
@ -382,7 +415,6 @@ impl Mediawiki {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/// This function runs at the end of do_protocol() and is responsible for
|
/// This function runs at the end of do_protocol() and is responsible for
|
||||||
|
@ -394,9 +426,7 @@ pub fn pad_ins_wiki(old_pad_content: String, wiki: &Mediawiki, plenum_date: &Nai
|
||||||
let date = plenum_date;
|
let date = plenum_date;
|
||||||
wiki.test_wiki_write()?;
|
wiki.test_wiki_write()?;
|
||||||
// Login to Wiki and get required tokens for logging in and writing
|
// Login to Wiki and get required tokens for logging in and writing
|
||||||
wiki.get_login_token()?;
|
verboseln!("logging in...");
|
||||||
verboseln!("Login token acquired.");
|
|
||||||
|
|
||||||
let login_result = wiki.login()?;
|
let login_result = wiki.login()?;
|
||||||
verboseln!("Login done.");
|
verboseln!("Login done.");
|
||||||
trace_var!(login_result);
|
trace_var!(login_result);
|
||||||
|
@ -463,7 +493,6 @@ struct TokensLogin {
|
||||||
#[derive(Deserialize)]
|
#[derive(Deserialize)]
|
||||||
struct QueryResponseCsrf {
|
struct QueryResponseCsrf {
|
||||||
#[allow(dead_code)]
|
#[allow(dead_code)]
|
||||||
batchcomplete: bool,
|
|
||||||
query: crate::mediawiki::QueryTokensCsrf,
|
query: crate::mediawiki::QueryTokensCsrf,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue