2018-06-04 22:51:18 +02:00
|
|
|
#[macro_use]
|
|
|
|
extern crate serde_derive;
|
|
|
|
#[macro_use]
|
|
|
|
extern crate log;
|
|
|
|
|
|
|
|
extern crate reqwest;
|
|
|
|
extern crate serde;
|
2018-06-07 22:39:25 +02:00
|
|
|
extern crate serde_json;
|
2018-06-04 22:51:18 +02:00
|
|
|
extern crate simple_logger;
|
2018-06-07 22:39:25 +02:00
|
|
|
extern crate select;
|
2018-06-04 22:51:18 +02:00
|
|
|
|
|
|
|
use std::collections::HashMap;
|
2018-06-07 22:39:25 +02:00
|
|
|
use std::fs;
|
|
|
|
use std::path::{Path, PathBuf};
|
2018-06-04 22:51:18 +02:00
|
|
|
use reqwest::header::{Headers, UserAgent};
|
2018-06-07 22:39:25 +02:00
|
|
|
use select::document::Document;
|
|
|
|
use select::predicate::{Class, Name};
|
2018-06-04 22:51:18 +02:00
|
|
|
|
|
|
|
#[derive(Deserialize)]
|
|
|
|
struct Realm {
|
2018-06-07 22:39:25 +02:00
|
|
|
v: String
|
2018-06-04 22:51:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Deserialize)]
|
|
|
|
struct Champion {
|
|
|
|
data: HashMap<String, ChampInfo>
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Deserialize)]
|
|
|
|
struct ChampInfo {
|
2018-06-07 22:39:25 +02:00
|
|
|
id: String
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(Serialize, Deserialize)]
|
|
|
|
struct ItemSet {
|
|
|
|
title: String,
|
|
|
|
#[serde(rename = "type")]
|
|
|
|
type_: String,
|
|
|
|
map: String,
|
|
|
|
mode: String,
|
|
|
|
priority: bool,
|
|
|
|
sortrank: i32,
|
|
|
|
blocks: Vec<String>
|
2018-06-04 22:51:18 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
const USER_AGENT: &str = "Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:60.0) Gecko/20100101 Firefox/60.0";
|
2018-06-07 22:39:25 +02:00
|
|
|
const LOL_CHAMPS_DIR: &str = ".\\champs";
|
2018-06-04 22:51:18 +02:00
|
|
|
|
|
|
|
fn main() {
|
|
|
|
simple_logger::init_with_level(log::Level::Info).unwrap();
|
|
|
|
|
|
|
|
info!("CGG Item Sets");
|
|
|
|
|
|
|
|
let mut headers = Headers::new();
|
|
|
|
headers.set(UserAgent::new(USER_AGENT));
|
|
|
|
|
|
|
|
let client = reqwest::Client::builder().default_headers(headers).build().unwrap();
|
|
|
|
|
|
|
|
let realm: Realm = client.get("https://ddragon.leagueoflegends.com/realms/euw.json").send().unwrap().json().unwrap();
|
|
|
|
info!("LoL version: {}", realm.v);
|
|
|
|
|
2018-06-05 00:02:35 +02:00
|
|
|
let champion: Champion = client.get(&format!("https://ddragon.leagueoflegends.com/cdn/{}/data/en_US/champion.json", realm.v)).send().unwrap().json().unwrap();
|
2018-06-04 22:51:18 +02:00
|
|
|
info!("LoL numbers of champs: {}", champion.data.len());
|
2018-06-05 00:02:35 +02:00
|
|
|
|
2018-06-07 22:39:25 +02:00
|
|
|
let (champs, patch) = get_champs_with_positions_and_patch(&client);
|
2018-06-05 00:02:35 +02:00
|
|
|
|
|
|
|
info!("CGG version: {}", patch);
|
|
|
|
info!("CGG numbers of champs: {}", champs.len());
|
|
|
|
|
2018-06-07 22:39:25 +02:00
|
|
|
for (id, positions) in champs {
|
|
|
|
if champion.data.contains_key(&id) {
|
|
|
|
let path = Path::new(LOL_CHAMPS_DIR).join(&id).join("Recommended");
|
|
|
|
fs::create_dir_all(&path).unwrap();
|
|
|
|
for pos in positions {
|
|
|
|
write_item_set(&id, pos, &patch, &path, &client)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
info!("{} not found in LoL champs", &id);
|
2018-06-05 00:02:35 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-06-07 22:39:25 +02:00
|
|
|
fn get_champs_with_positions_and_patch(client: &reqwest::Client) -> (HashMap<String, Vec<String>>, String) {
|
2018-06-05 00:02:35 +02:00
|
|
|
let page = client.get("https://champion.gg").send().unwrap().text().unwrap();
|
2018-06-07 22:39:25 +02:00
|
|
|
let document = Document::from(&*page);
|
2018-06-05 00:02:35 +02:00
|
|
|
|
2018-06-07 22:39:25 +02:00
|
|
|
let patch = document.find(Class("analysis-holder")).next().unwrap().find(Name("strong")).next().unwrap().text();
|
2018-06-05 00:02:35 +02:00
|
|
|
|
|
|
|
let mut champions = HashMap::new();
|
2018-06-07 22:39:25 +02:00
|
|
|
for node in document.find(Class("champ-height")) {
|
|
|
|
let id = node.find(Class("home-champion")).next().unwrap().attr("class").unwrap().split(' ').last().unwrap().to_string();
|
|
|
|
let positions = node.find(Name("a"))
|
|
|
|
.skip(1)
|
|
|
|
.map(|x| x.attr("href").unwrap().split('/').last().unwrap().to_string())
|
|
|
|
.collect();
|
|
|
|
champions.insert(id, positions);
|
2018-06-05 00:02:35 +02:00
|
|
|
}
|
2018-06-07 22:39:25 +02:00
|
|
|
|
|
|
|
(champions, patch)
|
2018-06-04 22:51:18 +02:00
|
|
|
}
|
2018-06-07 22:39:25 +02:00
|
|
|
|
|
|
|
fn write_item_set(id: &String, pos: String, ver: &String, path: &PathBuf, client: &reqwest::Client) {
|
|
|
|
info!("Retrieving data for {} at {}", id, pos);
|
|
|
|
|
|
|
|
let item_set = ItemSet {
|
|
|
|
title: format!("CGG {}", pos),
|
|
|
|
type_: "custom".to_string(),
|
|
|
|
map: "any".to_string(),
|
|
|
|
mode: "any".to_string(),
|
|
|
|
priority: false,
|
|
|
|
sortrank: 0,
|
|
|
|
blocks: vec![]
|
|
|
|
};
|
|
|
|
|
|
|
|
info!("Writing item set for {} at {}", id, pos);
|
|
|
|
fs::write(path.join(format!("CGG_{}_{}.json", id, pos)), serde_json::to_string_pretty(&item_set).unwrap()).unwrap();
|
|
|
|
}
|