Skip to content

Commit

Permalink
fix: security prototype pollution
Browse files Browse the repository at this point in the history
Optimist has been deprecated over 2 years ago as has a security vulnerability. With this change we use it's successor `yargs`.

Closes: angular#5413
  • Loading branch information
alan-agius4 committed Mar 31, 2020
1 parent 23e4b30 commit 4acc0a1
Show file tree
Hide file tree
Showing 6 changed files with 282 additions and 77 deletions.
4 changes: 2 additions & 2 deletions docs/faq.md
Original file line number Diff line number Diff line change
Expand Up @@ -188,11 +188,11 @@ is complete before continuing.
How do I switch off an option in the CLI?
-----------------------------------------
i.e. `webdriver-manager update --chrome=false` does not work.
This has to do with the way `optimist` parses command line args. In order to pass a false value, do one of the following:
This has to do with the way `yargs` parses command line args. In order to pass a false value, do one of the following:

1) `webdriver-manager update --chrome=0`

2) `webdriver-manager update --no-chrome` (see https://github.com/substack/node-optimist#negate-fields)
2) `webdriver-manager update --no-chrome` (see https://github.com/yargs/yargs/blob/HEAD/docs/tricks.md#negate)

Why does Protractor fail when I decorate $timeout?
--------------------------------------------------
Expand Down
29 changes: 16 additions & 13 deletions lib/cli.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import * as fs from 'fs';
import * as optimist from 'optimist';
import * as path from 'path';
import * as yargs from 'yargs';

/**
* The command line interface for interacting with the Protractor runner.
Expand Down Expand Up @@ -115,7 +115,7 @@ let allowedNames = [
'stackTrace'
];

let optimistOptions: any = {
let yargsOptions: any = {
describes: {
help: 'Print Protractor help menu',
version: 'Print Protractor version',
Expand Down Expand Up @@ -153,30 +153,33 @@ let optimistOptions: any = {
strings: {'capabilities.tunnel-identifier': ''}
};

optimist.usage(
yargs.usage(
'Usage: protractor [configFile] [options]\n' +
'configFile defaults to protractor.conf.js\n' +
'The [options] object will override values from the config file.\n' +
'See the reference config for a full list of options.');
for (let key of Object.keys(optimistOptions.describes)) {
optimist.describe(key, optimistOptions.describes[key]);
for (let key of Object.keys(yargsOptions.describes)) {
yargs.describe(key, yargsOptions.describes[key]);
}
for (let key of Object.keys(optimistOptions.aliases)) {
optimist.alias(key, optimistOptions.aliases[key]);
for (let key of Object.keys(yargsOptions.aliases)) {
yargs.alias(key, yargsOptions.aliases[key]);
}
for (let key of Object.keys(optimistOptions.strings)) {
optimist.string(key);
for (let key of Object.keys(yargsOptions.strings)) {
yargs.string(key);
}
optimist.check(function(arg: any) {

yargs.check(function(arg: any) {
if (arg._.length > 1) {
throw new Error('Error: more than one config file specified');
}

return true;
});

let argv: any = optimist.parse(args);
let argv: any = yargs.parse(args);

if (argv.help) {
optimist.showHelp();
yargs.showHelp();
process.exit(0);
}

Expand Down Expand Up @@ -233,7 +236,7 @@ if (!configFile && !argv.elementExplorer && args.length < 3) {
console.log(
'**you must either specify a configuration file ' +
'or at least 3 options. See below for the options:\n');
optimist.showHelp();
yargs.showHelp();
process.exit(1);
}

Expand Down
Loading

0 comments on commit 4acc0a1

Please sign in to comment.