Files
xml-servicefile-parser/index.js

105 lines
3.7 KiB
JavaScript
Raw Normal View History

2021-05-06 12:36:25 +05:30
const { parseString } = require('xml2js');
const path = require('path');
const fs = require('fs');
const assert = require('assert');
2019-06-25 22:44:22 +05:30
2021-05-06 12:36:25 +05:30
console.log('Loading configuration: settings.json')
const settings = JSON.parse(
fs.readFileSync(path.join(__dirname, 'settings.json'))
);
assert(typeof settings?.scriptConfig?.general?.command ==='string','Expected command')
assert(Array.isArray(settings?.scriptConfig?.env),'Expected an array of environment statuses')
assert(typeof settings?.fileName==='string', 'Expected a filename');
assert(typeof settings?.serviceScript==='string','Expected a result filename')
console.log('Loaded configuration');
2019-06-25 22:44:22 +05:30
//console.log(settings)
//console.log(process.argv)
2021-05-06 12:36:25 +05:30
fs.readFile(settings.fileName, (err, data) => {
if (err) {
throw new Error(
`${err.code}: Could not read file. Try again. ${err.name}`
);
2019-06-25 22:44:22 +05:30
}
2021-05-06 12:36:25 +05:30
console.log(`Reading ${settings.fileName}`);
parseString(data, (err, res) => {
if (err) {
throw new Error(`${err.code}: Error parsing file. :${err.name}`);
2019-06-25 22:44:22 +05:30
}
2021-05-06 12:36:25 +05:30
console.log(`Parsing ${settings.fileName}`);
assert(
typeof res?.flashing?.header?.[0]?.phone_model[0]?.$?.model ===
'string',
'Expected a model number'
);
console.log('Model: ', res.flashing.header[0].phone_model[0].$.model);
2019-06-25 22:44:22 +05:30
2021-05-06 12:36:25 +05:30
assert(
Array.isArray(res?.flashing?.steps),
'Expected steps to be an array!'
);
2019-06-25 22:44:22 +05:30
// Store steps
2021-05-06 12:36:25 +05:30
const steps = res.flashing.steps[0];
2019-06-25 22:44:22 +05:30
//console.log(steps.$.interface)
2021-05-06 12:36:25 +05:30
assert(steps?.$?.interface === 'AP', 'Expected an Interface of AP');
// if (steps.$.interface !== "AP") {
// throw new Error("Does not look like servicefile.xml. Aborting.");
// }
//settings.scriptConfig.env[settings.defaultMode].preconfig + '\n'
2019-06-25 23:40:01 +05:30
//sScript+= `${settings.scriptConfig.env[settings.defaultMode].commentPre} Generated for ${res.flashing.header[0].phone_model[0].$.model} \n`
2021-05-06 12:36:25 +05:30
const sScript = steps.step.reduce((t, e) => {
switch (e.$.operation) {
case 'oem':
case 'getvar':
t +=
`${settings.scriptConfig.general.command} ${e.$.operation} ${e.$.var}` +
'\n';
2019-06-25 22:44:22 +05:30
break;
2021-05-06 12:36:25 +05:30
case 'flash':
t +=
`${settings.scriptConfig.general.command} ${e.$.operation} ${e.$.partition} ${e.$.filename}` +
'\n';
2019-06-25 22:44:22 +05:30
break;
2021-05-06 12:36:25 +05:30
case 'erase':
t +=
`${settings.scriptConfig.general.command} ${e.$.operation} ${e.$.partition}` +
'\n';
2019-06-25 22:44:22 +05:30
break;
default:
2021-05-06 12:36:25 +05:30
throw new Error(`Unkown: ${e.$.operation}`);
2019-06-25 22:44:22 +05:30
}
2021-05-06 12:36:25 +05:30
return t;
});
//Write the data down
settings.scriptConfig.env.forEach((e) => {
const data =
e.preConfig +
'\n' +
`${e.commentPre} Generated for ${res.flashing.header[0].phone_model[0].$.model}` +
'\n' +
sScript;
fs.writeFile(
settings.serviceScript + e.extension,
data,
{ mode: 0o765 },
(err) => {
if (err) {
throw new Error(
`${err.errno}: Error Writing Script: ${err.name}`
);
}
console.log(
`Done: ${settings.serviceScript + e.extension}`
);
2019-06-25 23:40:01 +05:30
}
2021-05-06 12:36:25 +05:30
);
});
2019-06-25 22:44:22 +05:30
//console.log(sScript)
2021-05-06 12:36:25 +05:30
});
});