2021-06-30 16:34:34 -07:00
|
|
|
const util = require('util');
|
|
|
|
const fs = require('fs');
|
|
|
|
fs.readFileAsync = util.promisify(fs.readFile);
|
|
|
|
fs.writeFileAsync = util.promisify(fs.writeFile);
|
|
|
|
const req = require("request-promise-native");
|
|
|
|
|
|
|
|
process.chdir(__dirname);
|
|
|
|
|
|
|
|
const files = [
|
|
|
|
[
|
|
|
|
'http://raw.communitydragon.org/pbe/plugins/rcp-be-lol-game-data/global/default/v1/champion-summary.json',
|
|
|
|
'.champion.json'
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'http://www.mingweisamuel.com/riotapi-schema/openapi-3.0.0.json',
|
|
|
|
'.spec.json'
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'http://www.mingweisamuel.com/riotapi-schema/enums/seasons.json',
|
|
|
|
'.seasons.json'
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'http://www.mingweisamuel.com/riotapi-schema/enums/queues.json',
|
|
|
|
'.queues.json'
|
|
|
|
],
|
2022-06-21 00:09:08 -07:00
|
|
|
[
|
|
|
|
'http://www.mingweisamuel.com/riotapi-schema/enums/queueTypes.json',
|
|
|
|
'.queueTypes.json'
|
|
|
|
],
|
2021-06-30 16:34:34 -07:00
|
|
|
[
|
|
|
|
'http://www.mingweisamuel.com/riotapi-schema/enums/gameTypes.json',
|
|
|
|
'.gameTypes.json'
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'http://www.mingweisamuel.com/riotapi-schema/enums/gameModes.json',
|
|
|
|
'.gameModes.json'
|
|
|
|
],
|
|
|
|
[
|
|
|
|
'http://www.mingweisamuel.com/riotapi-schema/enums/maps.json',
|
|
|
|
'.maps.json'
|
2022-06-21 00:09:08 -07:00
|
|
|
],
|
2023-01-07 20:07:35 -08:00
|
|
|
[
|
|
|
|
'https://raw.githubusercontent.com/MingweiSamuel/riotapi-schema/master/src/data/routesTable.json',
|
|
|
|
'.routesTable.json'
|
|
|
|
],
|
2022-06-21 00:09:08 -07:00
|
|
|
];
|
2021-06-30 16:34:34 -07:00
|
|
|
|
|
|
|
const downloadFilesPromise = Promise.all(files.map(([url, file]) => req(url)
|
|
|
|
.then(body => fs.writeFileAsync(file, body, "utf8"))));
|
|
|
|
|
|
|
|
const doT = require('dot');
|
|
|
|
const glob = require('glob-promise');
|
|
|
|
|
|
|
|
const log = a => { console.log(a); return a; };
|
|
|
|
const suffix = '.dt';
|
|
|
|
|
|
|
|
doT.templateSettings = {
|
|
|
|
evaluate: /\r?\n?\{\{([\s\S]+?)\}\}/g,
|
|
|
|
interpolate: /\r?\n?\{\{=([\s\S]+?)\}\}/g,
|
|
|
|
encode: /\r?\n?\{\{!([\s\S]+?)\}\}/g,
|
|
|
|
use: /\r?\n?\{\{#([\s\S]+?)\}\}/g,
|
|
|
|
define: /\r?\n?\{\{##\s*([\w\.$]+)\s*(\:|=)([\s\S]+?)#\}\}/g,
|
|
|
|
conditional: /\r?\n?\{\{\?(\?)?\s*([\s\S]*?)\s*\}\}/g,
|
|
|
|
iterate: /\r?\n?\{\{~\s*(?:\}\}|([\s\S]+?)\s*\:\s*([\w$]+)\s*(?:\:\s*([\w$]+))?\s*\}\})/g,
|
|
|
|
varname: 'it',
|
|
|
|
strip: false,
|
|
|
|
append: false,
|
|
|
|
selfcontained: false
|
|
|
|
};
|
|
|
|
|
|
|
|
global.require = require;
|
|
|
|
|
|
|
|
downloadFilesPromise.then(() => glob.promise("**/*" + suffix, { ignore: ["**/node_modules/**"] }))
|
|
|
|
.then(files => Promise.all(files
|
|
|
|
.map(log)
|
|
|
|
.map(file => fs.readFileAsync(file, "utf8")
|
|
|
|
.then(input => {
|
|
|
|
try {
|
|
|
|
return doT.template(input)({});
|
|
|
|
}
|
|
|
|
catch (e) {
|
|
|
|
console.error(`Error thrown while running "${file}":`, e);
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
})
|
|
|
|
.then(output => fs.writeFileAsync("../src/" + file.slice(0, -suffix.length), output, "utf8"))
|
|
|
|
)
|
|
|
|
))
|
2019-10-19 02:25:09 -07:00
|
|
|
.catch(console.error);
|