xss 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. #!/usr/bin/env node
  2. /**
  3. * 命令行工具
  4. *
  5. * @author Zongmin Lei<leizongmin@gmail.com>
  6. */
  7. var fs = require('fs');
  8. var path = require('path');
  9. var program = require('commander');
  10. var xss = require('../');
  11. var packageInfo = require('../package.json');
  12. program
  13. .version(packageInfo.version)
  14. .option('-t, --test', 'active test')
  15. .option('-i, --input <input_file>', 'input file name')
  16. .option('-o, --output <output_file>', 'output filename')
  17. .option('-c, --config <config_file>', 'load custom config')
  18. .option('-s, --strip-ignore-tag', 'set stripIgnoreTag=true')
  19. .option('-b, --strip-ignore-tag-body', 'set stripIgnoreTagBody=true');
  20. program.on('--help', function () {
  21. console.log(' Examples:');
  22. console.log('');
  23. console.log(' $ xss -t');
  24. console.log(' $ xss -i origin.html');
  25. console.log(' $ xss -i origin.html -o targer.html');
  26. console.log(' $ xss -i origin.html -c config.js');
  27. console.log(' $ xss -i origin.html -s');
  28. console.log(' $ xss -i origin.html -s -b');
  29. console.log('');
  30. console.log(' For more details, please see: https://npmjs.org/package/xss')
  31. });
  32. program.parse(process.argv);
  33. if (program.test) {
  34. require('../lib/cli');
  35. return;
  36. }
  37. var config = {};
  38. if (program.config) {
  39. config = require(path.resolve(program.config));
  40. }
  41. if (program.input) {
  42. var input = fs.readFileSync(program.input, 'utf8');
  43. } else {
  44. program.help();
  45. }
  46. if (program['strip-ignore-tag']) {
  47. config.stripIgnoreTag = true;
  48. }
  49. if (program['strip-ignore-tag-body']) {
  50. config.stripIgnoreTagBody = true;
  51. }
  52. var output = xss(input, config);
  53. if (program.output) {
  54. fs.writeFileSync(program.output, output);
  55. } else {
  56. console.log(output);
  57. }