UNPKG

233 kBJavaScriptView Raw
1import { join, normalize, relative, strings, JsonParseMode, parseJson, basename, dirname as dirname$1, tags, resolve } from '@angular-devkit/core';
2import { __values, __spread, __makeTemplateObject, __assign, __extends } from 'tslib';
3import { SyntaxKind, forEachChild, isClassDeclaration, createSourceFile, ScriptTarget } from 'typescript';
4import { SchematicsException } from '@angular-devkit/schematics';
5import { dirname, join as join$1, normalize as normalize$1, parse } from 'path';
6import { isString, cloneDeep } from 'lodash';
7import { isString as isString$1, assertObject, isNil, isNotNil, assertArray, isArray, isPlainObject } from '@ibm-wch-sdk/utils';
8export { wchGetDeliveryUrlFromApiURL } from '@ibm-wch-sdk/utils';
9import { ok } from 'assert';
10import { validate } from 'email-validator';
11import { isWebUri, isUri } from 'valid-url';
12import { ajax } from 'rxjs/ajax';
13import { map, catchError, mergeMap, mapTo, pluck, switchMap, switchMapTo, first, filter, takeUntil, tap } from 'rxjs/operators';
14import { Observable, of, bindNodeCallback, throwError, defer, fromEvent } from 'rxjs';
15import { readFile } from 'fs';
16import { exec } from 'child_process';
17import { RSA_PKCS1_PADDING } from 'constants';
18import { privateDecrypt } from 'crypto';
19import { homedir, platform } from 'os';
20import { env } from 'process';
21import 'sshpk';
22import { satisfies, coerce } from 'semver';
23import { KEY_BASICAUTH_LOGIN_PASSWORD, KEY_BASICAUTH_LOGIN_USERNAME, REL_PATH_BASICAUTH_LOGIN, REL_PATH_CURRENT_USER } from '@ibm-wch-sdk/api';
24import { VError } from 'verror';
25import { get } from 'request';
26import { Writable } from 'stream';
27import { Parse } from 'unzip';
28import { load } from 'cheerio';
29
30/**
31 * @fileoverview added by tsickle
32 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
33 */
34/**
35 * Find the module referred by a set of options passed to the schematics.
36 * @param {?} host
37 * @param {?} options
38 * @return {?}
39 */
40function findModuleFromOptions(host, options) {
41 if (options.hasOwnProperty('skipImport') && options.skipImport) {
42 return undefined;
43 }
44 if (!options.module) {
45 /** @type {?} */
46 var pathToCheck = (options.path || '')
47 + (options.flat ? '' : '/' + strings.dasherize(options.name));
48 return normalize(findModule(host, pathToCheck));
49 }
50 else {
51 /** @type {?} */
52 var modulePath = normalize('/' + (options.path) + '/' + options.module);
53 /** @type {?} */
54 var moduleBaseName = normalize(modulePath).split('/').pop();
55 if (host.exists(modulePath)) {
56 return normalize(modulePath);
57 }
58 else if (host.exists(modulePath + '.ts')) {
59 return normalize(modulePath + '.ts');
60 }
61 else if (host.exists(modulePath + '.module.ts')) {
62 return normalize(modulePath + '.module.ts');
63 }
64 else if (host.exists(modulePath + '/' + moduleBaseName + '.module.ts')) {
65 return normalize(modulePath + '/' + moduleBaseName + '.module.ts');
66 }
67 else {
68 throw new Error('Specified module does not exist');
69 }
70 }
71}
72/**
73 * Function to find the "closest" module to a generated file's path.
74 * @param {?} host
75 * @param {?} generateDir
76 * @return {?}
77 */
78function findModule(host, generateDir) {
79 /** @type {?} */
80 var dir = host.getDir('/' + generateDir);
81 /** @type {?} */
82 var moduleRe = /\.module\.ts$/;
83 /** @type {?} */
84 var routingModuleRe = /-routing\.module\.ts/;
85 while (dir) {
86 /** @type {?} */
87 var matches = dir.subfiles.filter(function (p) { return moduleRe.test(p) && !routingModuleRe.test(p); });
88 if (matches.length == 1) {
89 return join(dir.path, matches[0]);
90 }
91 else if (matches.length > 1) {
92 throw new Error('More than one module matches. Use skip-import option to skip importing '
93 + 'the component into the closest module.');
94 }
95 dir = dir.parent;
96 }
97 throw new Error('Could not find an NgModule. Use the skip-import '
98 + 'option to skip importing in NgModule.');
99}
100/**
101 * Build a relative path from one file path to another file path.
102 * @param {?} from
103 * @param {?} to
104 * @return {?}
105 */
106function buildRelativePath(from, to) {
107 from = normalize(from);
108 to = normalize(to);
109 /** @type {?} */
110 var fromParts = from.split('/');
111 /** @type {?} */
112 var toParts = to.split('/');
113 // Remove file names (preserving destination)
114 fromParts.pop();
115 /** @type {?} */
116 var toFileName = toParts.pop();
117 /** @type {?} */
118 var relativePath = relative(normalize(fromParts.join('/')), normalize(toParts.join('/')));
119 /** @type {?} */
120 var pathPrefix = '';
121 // Set the path prefix for same dir or child dir, parent dir starts with `..`
122 if (!relativePath) {
123 pathPrefix = '.';
124 }
125 else if (!relativePath.startsWith('.')) {
126 pathPrefix = "./";
127 }
128 if (pathPrefix && !pathPrefix.endsWith('/')) {
129 pathPrefix += '/';
130 }
131 return pathPrefix + (relativePath ? relativePath + '/' : '') + toFileName;
132}
133
134/**
135 * @fileoverview added by tsickle
136 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
137 */
138/**
139 * An operation that does nothing.
140 */
141var /**
142 * An operation that does nothing.
143 */
144NoopChange = /** @class */ (function () {
145 function NoopChange() {
146 this.description = 'No operation.';
147 this.order = Infinity;
148 this.path = null;
149 }
150 /**
151 * @return {?}
152 */
153 NoopChange.prototype.apply = /**
154 * @return {?}
155 */
156 function () { return Promise.resolve(); };
157 return NoopChange;
158}());
159/**
160 * Will add text to the source code.
161 */
162var /**
163 * Will add text to the source code.
164 */
165InsertChange = /** @class */ (function () {
166 function InsertChange(path, pos, toAdd) {
167 this.path = path;
168 this.pos = pos;
169 this.toAdd = toAdd;
170 if (pos < 0) {
171 throw new Error('Negative positions are invalid');
172 }
173 this.description = "Inserted " + toAdd + " into position " + pos + " of " + path;
174 this.order = pos;
175 }
176 /**
177 * This method does not insert spaces if there is none in the original string.
178 */
179 /**
180 * This method does not insert spaces if there is none in the original string.
181 * @param {?} host
182 * @return {?}
183 */
184 InsertChange.prototype.apply = /**
185 * This method does not insert spaces if there is none in the original string.
186 * @param {?} host
187 * @return {?}
188 */
189 function (host) {
190 var _this = this;
191 return host.read(this.path).then(function (content) {
192 /** @type {?} */
193 var prefix = content.substring(0, _this.pos);
194 /** @type {?} */
195 var suffix = content.substring(_this.pos);
196 return host.write(_this.path, "" + prefix + _this.toAdd + suffix);
197 });
198 };
199 return InsertChange;
200}());
201/**
202 * Will remove text from the source code.
203 */
204var /**
205 * Will remove text from the source code.
206 */
207RemoveChange = /** @class */ (function () {
208 function RemoveChange(path, pos, toRemove) {
209 this.path = path;
210 this.pos = pos;
211 this.toRemove = toRemove;
212 if (pos < 0) {
213 throw new Error('Negative positions are invalid');
214 }
215 this.description = "Removed " + toRemove + " into position " + pos + " of " + path;
216 this.order = pos;
217 }
218 /**
219 * @param {?} host
220 * @return {?}
221 */
222 RemoveChange.prototype.apply = /**
223 * @param {?} host
224 * @return {?}
225 */
226 function (host) {
227 var _this = this;
228 return host.read(this.path).then(function (content) {
229 /** @type {?} */
230 var prefix = content.substring(0, _this.pos);
231 /** @type {?} */
232 var suffix = content.substring(_this.pos + _this.toRemove.length);
233 // TODO: throw error if toRemove doesn't match removed string.
234 return host.write(_this.path, "" + prefix + suffix);
235 });
236 };
237 return RemoveChange;
238}());
239/**
240 * Will replace text from the source code.
241 */
242var /**
243 * Will replace text from the source code.
244 */
245ReplaceChange = /** @class */ (function () {
246 function ReplaceChange(path, pos, oldText, newText) {
247 this.path = path;
248 this.pos = pos;
249 this.oldText = oldText;
250 this.newText = newText;
251 if (pos < 0) {
252 throw new Error('Negative positions are invalid');
253 }
254 this.description = "Replaced " + oldText + " into position " + pos + " of " + path + " with " + newText;
255 this.order = pos;
256 }
257 /**
258 * @param {?} host
259 * @return {?}
260 */
261 ReplaceChange.prototype.apply = /**
262 * @param {?} host
263 * @return {?}
264 */
265 function (host) {
266 var _this = this;
267 return host.read(this.path).then(function (content) {
268 /** @type {?} */
269 var prefix = content.substring(0, _this.pos);
270 /** @type {?} */
271 var suffix = content.substring(_this.pos + _this.oldText.length);
272 /** @type {?} */
273 var text = content.substring(_this.pos, _this.pos + _this.oldText.length);
274 if (text !== _this.oldText) {
275 return Promise.reject(new Error("Invalid replace: \"" + text + "\" != \"" + _this.oldText + "\"."));
276 }
277 // TODO: throw error if oldText doesn't match removed string.
278 return host.write(_this.path, "" + prefix + _this.newText + suffix);
279 });
280 };
281 return ReplaceChange;
282}());
283
284/**
285 * @fileoverview added by tsickle
286 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
287 */
288/**
289 * Add Import `import { symbolName } from fileName` if the import doesn't exit
290 * already. Assumes fileToEdit can be resolved and accessed.
291 * @param {?} source
292 * @param {?} fileToEdit (file we want to add import to)
293 * @param {?} symbolName (item to import)
294 * @param {?} fileName (path to the file)
295 * @param {?=} isDefault (if true, import follows style for importing default exports)
296 * @return {?} Change
297 */
298function insertImport(source, fileToEdit, symbolName, fileName, isDefault) {
299 if (isDefault === void 0) { isDefault = false; }
300 /** @type {?} */
301 var rootNode = source;
302 /** @type {?} */
303 var allImports = findNodes(rootNode, SyntaxKind.ImportDeclaration);
304 /** @type {?} */
305 var relevantImports = allImports.filter(function (node) {
306 /** @type {?} */
307 var importFiles = node
308 .getChildren()
309 .filter(function (child) { return child.kind === SyntaxKind.StringLiteral; })
310 .map(function (n) { return (/** @type {?} */ (n)).text; });
311 return importFiles.filter(function (file) { return file === fileName; }).length === 1;
312 });
313 if (relevantImports.length > 0) {
314 /** @type {?} */
315 var importsAsterisk_1 = false;
316 /** @type {?} */
317 var imports_1 = [];
318 relevantImports.forEach(function (n) {
319 Array.prototype.push.apply(imports_1, findNodes(n, SyntaxKind.Identifier));
320 if (findNodes(n, SyntaxKind.AsteriskToken).length > 0) {
321 importsAsterisk_1 = true;
322 }
323 });
324 // if imports * from fileName, don't add symbolName
325 if (importsAsterisk_1) {
326 return new NoopChange();
327 }
328 /** @type {?} */
329 var importTextNodes = imports_1.filter(function (n) { return (/** @type {?} */ (n)).text === symbolName; });
330 // insert import if it's not there
331 if (importTextNodes.length === 0) {
332 /** @type {?} */
333 var fallbackPos_1 = findNodes(relevantImports[0], SyntaxKind.CloseBraceToken)[0].getStart() ||
334 findNodes(relevantImports[0], SyntaxKind.FromKeyword)[0].getStart();
335 return insertAfterLastOccurrence(imports_1, ", " + symbolName, fileToEdit, fallbackPos_1);
336 }
337 return new NoopChange();
338 }
339 /** @type {?} */
340 var useStrict = findNodes(rootNode, SyntaxKind.StringLiteral).filter(function (n) { return n.text === 'use strict'; });
341 /** @type {?} */
342 var fallbackPos = 0;
343 if (useStrict.length > 0) {
344 fallbackPos = useStrict[0].end;
345 }
346 /** @type {?} */
347 var open = isDefault ? '' : '{ ';
348 /** @type {?} */
349 var close = isDefault ? '' : ' }';
350 /** @type {?} */
351 var insertAtBeginning = allImports.length === 0 && useStrict.length === 0;
352 /** @type {?} */
353 var separator = insertAtBeginning ? '' : ';\n';
354 /** @type {?} */
355 var toInsert = separator + "import " + open + symbolName + close +
356 (" from '" + fileName + "'" + (insertAtBeginning ? ';\n' : ''));
357 return insertAfterLastOccurrence(allImports, toInsert, fileToEdit, fallbackPos, SyntaxKind.StringLiteral);
358}
359/**
360 * Find all nodes from the AST in the subtree of node of SyntaxKind kind.
361 * @param {?} node
362 * @param {?} kind
363 * @param {?=} max The maximum number of items to return.
364 * @return {?} all nodes of kind, or [] if none is found
365 */
366function findNodes(node, kind, max) {
367 if (max === void 0) { max = Infinity; }
368 var e_1, _a;
369 if (!node || max == 0) {
370 return [];
371 }
372 /** @type {?} */
373 var arr = [];
374 if (node.kind === kind) {
375 arr.push(node);
376 max--;
377 }
378 if (max > 0) {
379 try {
380 for (var _b = __values(node.getChildren()), _c = _b.next(); !_c.done; _c = _b.next()) {
381 var child = _c.value;
382 findNodes(child, kind, max).forEach(function (node) {
383 if (max > 0) {
384 arr.push(node);
385 }
386 max--;
387 });
388 if (max <= 0) {
389 break;
390 }
391 }
392 }
393 catch (e_1_1) { e_1 = { error: e_1_1 }; }
394 finally {
395 try {
396 if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
397 }
398 finally { if (e_1) throw e_1.error; }
399 }
400 }
401 return arr;
402}
403/**
404 * Get all the nodes from a source.
405 * @param {?} sourceFile The source file object.
406 * @return {?} An observable of all the nodes in the source.
407 */
408function getSourceNodes(sourceFile) {
409 /** @type {?} */
410 var nodes = [sourceFile];
411 /** @type {?} */
412 var result = [];
413 while (nodes.length > 0) {
414 /** @type {?} */
415 var node = nodes.shift();
416 if (node) {
417 result.push(node);
418 if (node.getChildCount(sourceFile) >= 0) {
419 nodes.unshift.apply(nodes, __spread(node.getChildren()));
420 }
421 }
422 }
423 return result;
424}
425/**
426 * @param {?} node
427 * @param {?} kind
428 * @param {?} text
429 * @return {?}
430 */
431function findNode(node, kind, text) {
432 if (node.kind === kind && node.getText() === text) {
433 // throw new Error(node.getText());
434 return node;
435 }
436 /** @type {?} */
437 var foundNode = null;
438 forEachChild(node, function (childNode) {
439 foundNode = foundNode || findNode(childNode, kind, text);
440 });
441 return foundNode;
442}
443/**
444 * Helper for sorting nodes.
445 * @param {?} first
446 * @param {?} second
447 * @return {?} function to sort nodes in increasing order of position in sourceFile
448 */
449function nodesByPosition(first$$1, second) {
450 return first$$1.getStart() - second.getStart();
451}
452/**
453 * Insert `toInsert` after the last occurence of `ts.SyntaxKind[nodes[i].kind]`
454 * or after the last of occurence of `syntaxKind` if the last occurence is a sub child
455 * of ts.SyntaxKind[nodes[i].kind] and save the changes in file.
456 *
457 * \@throw Error if toInsert is first occurence but fall back is not set
458 * @param {?} nodes insert after the last occurence of nodes
459 * @param {?} toInsert string to insert
460 * @param {?} file file to insert changes into
461 * @param {?} fallbackPos position to insert if toInsert happens to be the first occurence
462 * @param {?=} syntaxKind the ts.SyntaxKind of the subchildren to insert after
463 * @return {?} Change instance
464 */
465function insertAfterLastOccurrence(nodes, toInsert, file, fallbackPos, syntaxKind) {
466 /** @type {?} */
467 var lastItem = __spread(nodes).sort(nodesByPosition).pop();
468 if (!lastItem) {
469 throw new Error();
470 }
471 if (syntaxKind) {
472 lastItem = findNodes(lastItem, syntaxKind)
473 .sort(nodesByPosition)
474 .pop();
475 }
476 if (!lastItem && fallbackPos == undefined) {
477 throw new Error("tried to insert " + toInsert + " as first occurence with no fallback position");
478 }
479 /** @type {?} */
480 var lastItemPosition = lastItem ? lastItem.getEnd() : fallbackPos;
481 return new InsertChange(file, lastItemPosition, toInsert);
482}
483/**
484 * @param {?} _source
485 * @param {?} node
486 * @return {?}
487 */
488function getContentOfKeyLiteral(_source, node) {
489 if (node.kind == SyntaxKind.Identifier) {
490 return (/** @type {?} */ (node)).text;
491 }
492 else if (node.kind == SyntaxKind.StringLiteral) {
493 return (/** @type {?} */ (node)).text;
494 }
495 else {
496 return null;
497 }
498}
499/**
500 * @param {?} node
501 * @param {?} _sourceFile
502 * @return {?}
503 */
504function _angularImportsFromNode(node, _sourceFile) {
505 var _a;
506 /** @type {?} */
507 var ms = node.moduleSpecifier;
508 /** @type {?} */
509 var modulePath;
510 switch (ms.kind) {
511 case SyntaxKind.StringLiteral:
512 modulePath = (/** @type {?} */ (ms)).text;
513 break;
514 default:
515 return {};
516 }
517 if (!modulePath.startsWith('@angular/')) {
518 return {};
519 }
520 if (node.importClause) {
521 if (node.importClause.name) {
522 // This is of the form `import Name from 'path'`. Ignore.
523 return {};
524 }
525 else if (node.importClause.namedBindings) {
526 /** @type {?} */
527 var nb = node.importClause.namedBindings;
528 if (nb.kind == SyntaxKind.NamespaceImport) {
529 // This is of the form `import * as name from 'path'`. Return `name.`.
530 return _a = {},
531 _a[(/** @type {?} */ (nb)).name.text + '.'] = modulePath,
532 _a;
533 }
534 else {
535 /** @type {?} */
536 var namedImports = /** @type {?} */ (nb);
537 return namedImports.elements
538 .map(function (is) {
539 return is.propertyName ? is.propertyName.text : is.name.text;
540 })
541 .reduce(function (acc, curr) {
542 acc[curr] = modulePath;
543 return acc;
544 }, {});
545 }
546 }
547 return {};
548 }
549 else {
550 // This is of the form `import 'path';`. Nothing to do.
551 return {};
552 }
553}
554/**
555 * @param {?} source
556 * @param {?} identifier
557 * @param {?} module
558 * @return {?}
559 */
560function getDecoratorMetadata(source, identifier, module) {
561 /** @type {?} */
562 var angularImports = findNodes(source, SyntaxKind.ImportDeclaration)
563 .map(function (node) { return _angularImportsFromNode(node, source); })
564 .reduce(function (acc, current) {
565 var e_2, _a;
566 try {
567 for (var _b = __values(Object.keys(current)), _c = _b.next(); !_c.done; _c = _b.next()) {
568 var key = _c.value;
569 acc[key] = current[key];
570 }
571 }
572 catch (e_2_1) { e_2 = { error: e_2_1 }; }
573 finally {
574 try {
575 if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
576 }
577 finally { if (e_2) throw e_2.error; }
578 }
579 return acc;
580 }, {});
581 return getSourceNodes(source)
582 .filter(function (node) {
583 return (node.kind == SyntaxKind.Decorator &&
584 (/** @type {?} */ (node)).expression.kind == SyntaxKind.CallExpression);
585 })
586 .map(function (node) { return ((/** @type {?} */ (node)).expression); })
587 .filter(function (expr) {
588 if (expr.expression.kind == SyntaxKind.Identifier) {
589 /** @type {?} */
590 var id = /** @type {?} */ (expr.expression);
591 return (id.getFullText(source) == identifier &&
592 angularImports[id.getFullText(source)] === module);
593 }
594 else if (expr.expression.kind == SyntaxKind.PropertyAccessExpression) {
595 /** @type {?} */
596 var paExpr = /** @type {?} */ (expr.expression);
597 // If the left expression is not an identifier, just give up at that point.
598 if (paExpr.expression.kind !== SyntaxKind.Identifier) {
599 return false;
600 }
601 /** @type {?} */
602 var id = paExpr.name.text;
603 /** @type {?} */
604 var moduleId = (/** @type {?} */ (paExpr.expression)).getText(source);
605 return id === identifier && angularImports[moduleId + '.'] === module;
606 }
607 return false;
608 })
609 .filter(function (expr) {
610 return expr.arguments[0] &&
611 expr.arguments[0].kind == SyntaxKind.ObjectLiteralExpression;
612 })
613 .map(function (expr) { return (expr.arguments[0]); });
614}
615/**
616 * @param {?} node
617 * @return {?}
618 */
619function findClassDeclarationParent(node) {
620 if (isClassDeclaration(node)) {
621 return node;
622 }
623 return node.parent && findClassDeclarationParent(node.parent);
624}
625/**
626 * Given a source file with \@NgModule class(es), find the name of the first \@NgModule class.
627 *
628 * @param {?} source source file containing one or more \@NgModule
629 * @return {?} the name of the first \@NgModule, or `undefined` if none is found
630 */
631function getFirstNgModuleName(source) {
632 /** @type {?} */
633 var ngModulesMetadata = getDecoratorMetadata(source, 'NgModule', '@angular/core');
634 if (ngModulesMetadata.length === 0) {
635 return undefined;
636 }
637 /** @type {?} */
638 var moduleClass = findClassDeclarationParent(ngModulesMetadata[0]);
639 if (!moduleClass || !moduleClass.name) {
640 return undefined;
641 }
642 // Get the class name of the module ClassDeclaration.
643 return moduleClass.name.text;
644}
645/**
646 * @param {?} source
647 * @param {?} ngModulePath
648 * @param {?} metadataField
649 * @param {?} symbolName
650 * @param {?=} importPath
651 * @return {?}
652 */
653function addSymbolToNgModuleMetadata(source, ngModulePath, metadataField, symbolName, importPath) {
654 if (importPath === void 0) { importPath = null; }
655 /** @type {?} */
656 var nodes = getDecoratorMetadata(source, 'NgModule', '@angular/core');
657 /** @type {?} */
658 var node = nodes[0]; // tslint:disable-line:no-any
659 // Find the decorator declaration.
660 if (!node) {
661 return [];
662 }
663 /** @type {?} */
664 var matchingProperties = (/** @type {?} */ (node)).properties
665 .filter(function (prop) { return prop.kind == SyntaxKind.PropertyAssignment; })
666 // Filter out every fields that's not "metadataField". Also handles string literals
667 // (but not expressions).
668 .filter(function (prop) {
669 /** @type {?} */
670 var name = prop.name;
671 switch (name.kind) {
672 case SyntaxKind.Identifier:
673 return (/** @type {?} */ (name)).getText(source) == metadataField;
674 case SyntaxKind.StringLiteral:
675 return (/** @type {?} */ (name)).text == metadataField;
676 }
677 return false;
678 });
679 // Get the last node of the array literal.
680 if (!matchingProperties) {
681 return [];
682 }
683 if (matchingProperties.length == 0) {
684 /** @type {?} */
685 var expr = /** @type {?} */ (node);
686 /** @type {?} */
687 var position_1 = void 0;
688 /** @type {?} */
689 var toInsert_1 = void 0;
690 if (expr.properties.length == 0) {
691 position_1 = expr.getEnd() - 1;
692 toInsert_1 = " " + metadataField + ": [" + symbolName + "]\n";
693 }
694 else {
695 node = expr.properties[expr.properties.length - 1];
696 position_1 = node.getEnd();
697 /** @type {?} */
698 var text = node.getFullText(source);
699 /** @type {?} */
700 var matches = text.match(/^\r?\n\s*/);
701 if (matches.length > 0) {
702 toInsert_1 = "," + matches[0] + metadataField + ": [" + symbolName + "]";
703 }
704 else {
705 toInsert_1 = ", " + metadataField + ": [" + symbolName + "]";
706 }
707 }
708 if (importPath !== null) {
709 return [
710 new InsertChange(ngModulePath, position_1, toInsert_1),
711 insertImport(source, ngModulePath, symbolName.replace(/\..*$/, ''), importPath)
712 ];
713 }
714 else {
715 return [new InsertChange(ngModulePath, position_1, toInsert_1)];
716 }
717 }
718 /** @type {?} */
719 var assignment = /** @type {?} */ (matchingProperties[0]);
720 // If it's not an array, nothing we can do really.
721 if (assignment.initializer.kind !== SyntaxKind.ArrayLiteralExpression) {
722 return [];
723 }
724 /** @type {?} */
725 var arrLiteral = /** @type {?} */ (assignment.initializer);
726 if (arrLiteral.elements.length == 0) {
727 // Forward the property.
728 node = arrLiteral;
729 }
730 else {
731 node = arrLiteral.elements;
732 }
733 if (!node) {
734 console.log('No app module found. Please add your new class to your component.');
735 return [];
736 }
737 if (Array.isArray(node)) {
738 /** @type {?} */
739 var nodeArray = /** @type {?} */ ((/** @type {?} */ (node)));
740 /** @type {?} */
741 var symbolsArray = nodeArray.map(function (node) { return node.getText(); });
742 if (symbolsArray.indexOf(symbolName) >= 0) {
743 return [];
744 }
745 node = node[node.length - 1];
746 }
747 /** @type {?} */
748 var toInsert;
749 /** @type {?} */
750 var position = node.getEnd();
751 if (node.kind == SyntaxKind.ObjectLiteralExpression) {
752 /** @type {?} */
753 var expr = /** @type {?} */ (node);
754 if (expr.properties.length == 0) {
755 position = expr.getEnd() - 1;
756 toInsert = " " + metadataField + ": [" + symbolName + "]\n";
757 }
758 else {
759 node = expr.properties[expr.properties.length - 1];
760 position = node.getEnd();
761 /** @type {?} */
762 var text = node.getFullText(source);
763 if (text.match('^\r?\r?\n')) {
764 toInsert = "," + text.match(/^\r?\n\s+/)[0] + metadataField + ": [" + symbolName + "]";
765 }
766 else {
767 toInsert = ", " + metadataField + ": [" + symbolName + "]";
768 }
769 }
770 }
771 else if (node.kind == SyntaxKind.ArrayLiteralExpression) {
772 // We found the field but it's empty. Insert it just before the `]`.
773 position--;
774 toInsert = "" + symbolName;
775 }
776 else {
777 /** @type {?} */
778 var text = node.getFullText(source);
779 if (text.match(/^\r?\n/)) {
780 toInsert = "," + text.match(/^\r?\n(\r?)\s+/)[0] + symbolName;
781 }
782 else {
783 toInsert = ", " + symbolName;
784 }
785 }
786 if (importPath !== null) {
787 return [
788 new InsertChange(ngModulePath, position, toInsert),
789 insertImport(source, ngModulePath, symbolName.replace(/\..*$/, ''), importPath)
790 ];
791 }
792 return [new InsertChange(ngModulePath, position, toInsert)];
793}
794/**
795 * Custom function to insert a declaration (component, pipe, directive)
796 * into NgModule declarations. It also imports the component.
797 * @param {?} source
798 * @param {?} modulePath
799 * @param {?} classifiedName
800 * @param {?} importPath
801 * @return {?}
802 */
803function addDeclarationToModule(source, modulePath, classifiedName, importPath) {
804 return addSymbolToNgModuleMetadata(source, modulePath, 'declarations', classifiedName, importPath);
805}
806/**
807 * Custom function to insert an NgModule into NgModule imports. It also imports the module.
808 * @param {?} source
809 * @param {?} modulePath
810 * @param {?} classifiedName
811 * @param {?} importPath
812 * @return {?}
813 */
814function addImportToModule(source, modulePath, classifiedName, importPath) {
815 return addSymbolToNgModuleMetadata(source, modulePath, 'imports', classifiedName, importPath);
816}
817/**
818 * Custom function to insert a provider into NgModule. It also imports it.
819 * @param {?} source
820 * @param {?} modulePath
821 * @param {?} classifiedName
822 * @param {?} importPath
823 * @return {?}
824 */
825function addProviderToModule(source, modulePath, classifiedName, importPath) {
826 return addSymbolToNgModuleMetadata(source, modulePath, 'providers', classifiedName, importPath);
827}
828/**
829 * Custom function to insert an export into NgModule. It also imports it.
830 * @param {?} source
831 * @param {?} modulePath
832 * @param {?} classifiedName
833 * @param {?} importPath
834 * @return {?}
835 */
836function addExportToModule(source, modulePath, classifiedName, importPath) {
837 return addSymbolToNgModuleMetadata(source, modulePath, 'exports', classifiedName, importPath);
838}
839/**
840 * Custom function to insert an export into NgModule. It also imports it.
841 * @param {?} source
842 * @param {?} modulePath
843 * @param {?} classifiedName
844 * @param {?} importPath
845 * @return {?}
846 */
847function addBootstrapToModule(source, modulePath, classifiedName, importPath) {
848 return addSymbolToNgModuleMetadata(source, modulePath, 'bootstrap', classifiedName, importPath);
849}
850/**
851 * Custom function to insert an entryComponent into NgModule. It also imports it.
852 * @param {?} source
853 * @param {?} modulePath
854 * @param {?} classifiedName
855 * @param {?} importPath
856 * @return {?}
857 */
858function addEntryComponentToModule(source, modulePath, classifiedName, importPath) {
859 return addSymbolToNgModuleMetadata(source, modulePath, 'entryComponents', classifiedName, importPath);
860}
861/**
862 * Determine if an import already exists.
863 * @param {?} source
864 * @param {?} classifiedName
865 * @param {?} importPath
866 * @return {?}
867 */
868function isImported(source, classifiedName, importPath) {
869 /** @type {?} */
870 var allNodes = getSourceNodes(source);
871 /** @type {?} */
872 var matchingNodes = allNodes
873 .filter(function (node) { return node.kind === SyntaxKind.ImportDeclaration; })
874 .filter(function (imp) {
875 return imp.moduleSpecifier.kind === SyntaxKind.StringLiteral;
876 })
877 .filter(function (imp) {
878 return (/** @type {?} */ (imp.moduleSpecifier)).text === importPath;
879 })
880 .filter(function (imp) {
881 if (!imp.importClause) {
882 return false;
883 }
884 /** @type {?} */
885 var nodes = findNodes(imp.importClause, SyntaxKind.ImportSpecifier).filter(function (n) { return n.getText() === classifiedName; });
886 return nodes.length > 0;
887 });
888 return matchingNodes.length > 0;
889}
890
891/**
892 * @fileoverview added by tsickle
893 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
894 */
895/**
896 * @param {?} host
897 * @return {?}
898 */
899function getWorkspacePath(host) {
900 /** @type {?} */
901 var possibleFiles = ['/angular.json', '/.angular.json'];
902 /** @type {?} */
903 var path = possibleFiles.filter(function (path) { return host.exists(path); })[0];
904 return path;
905}
906/**
907 * @param {?} host
908 * @return {?}
909 */
910function getWorkspace(host) {
911 /** @type {?} */
912 var path = getWorkspacePath(host);
913 /** @type {?} */
914 var configBuffer = host.read(path);
915 if (configBuffer === null) {
916 throw new SchematicsException("Could not find (" + path + ")");
917 }
918 /** @type {?} */
919 var content = configBuffer.toString();
920 return /** @type {?} */ ((parseJson(content, JsonParseMode.Loose)));
921}
922/**
923 * @param {?} workspace
924 * @param {?} name
925 * @param {?} project
926 * @return {?}
927 */
928function addProjectToWorkspace(workspace, name, project) {
929 return function (host, context) {
930 if (workspace.projects[name]) {
931 throw new Error("Project '" + name + "' already exists in workspace.");
932 }
933 // Add project to workspace.
934 workspace.projects[name] = project;
935 if (!workspace.defaultProject && Object.keys(workspace.projects).length === 1) {
936 // Make the new project the default one.
937 workspace.defaultProject = name;
938 }
939 host.overwrite(getWorkspacePath(host), JSON.stringify(workspace, null, 2));
940 };
941}
942/** @type {?} */
943var configPath = '/.angular-cli.json';
944/**
945 * @param {?} host
946 * @return {?}
947 */
948function getConfig(host) {
949 /** @type {?} */
950 var configBuffer = host.read(configPath);
951 if (configBuffer === null) {
952 throw new SchematicsException('Could not find .angular-cli.json');
953 }
954 /** @type {?} */
955 var config = /** @type {?} */ ((parseJson(configBuffer.toString(), JsonParseMode.Loose)));
956 return config;
957}
958/**
959 * @param {?} config
960 * @param {?} appIndexOrName
961 * @return {?}
962 */
963function getAppFromConfig(config, appIndexOrName) {
964 if (!config.apps) {
965 return null;
966 }
967 if (parseInt(appIndexOrName) >= 0) {
968 return config.apps[parseInt(appIndexOrName)];
969 }
970 return config.apps.filter(function (app) { return app.name === appIndexOrName; })[0];
971}
972
973/**
974 * @fileoverview added by tsickle
975 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
976 */
977/**
978 * @param {?} host
979 * @param {?} mainPath
980 * @return {?}
981 */
982function findBootstrapModuleCall(host, mainPath) {
983 var e_1, _a;
984 /** @type {?} */
985 var mainBuffer = host.read(mainPath);
986 if (!mainBuffer) {
987 throw new SchematicsException("Main file (" + mainPath + ") not found");
988 }
989 /** @type {?} */
990 var mainText = mainBuffer.toString('utf-8');
991 /** @type {?} */
992 var source = createSourceFile(mainPath, mainText, ScriptTarget.Latest, true);
993 /** @type {?} */
994 var allNodes = getSourceNodes(source);
995 /** @type {?} */
996 var bootstrapCall = null;
997 try {
998 for (var allNodes_1 = __values(allNodes), allNodes_1_1 = allNodes_1.next(); !allNodes_1_1.done; allNodes_1_1 = allNodes_1.next()) {
999 var node = allNodes_1_1.value;
1000 /** @type {?} */
1001 var bootstrapCallNode = null;
1002 bootstrapCallNode = findNode(node, SyntaxKind.Identifier, 'bootstrapModule');
1003 // Walk up the parent until CallExpression is found.
1004 while (bootstrapCallNode && bootstrapCallNode.parent
1005 && bootstrapCallNode.parent.kind !== SyntaxKind.CallExpression) {
1006 bootstrapCallNode = bootstrapCallNode.parent;
1007 }
1008 if (bootstrapCallNode !== null &&
1009 bootstrapCallNode.parent !== undefined &&
1010 bootstrapCallNode.parent.kind === SyntaxKind.CallExpression) {
1011 bootstrapCall = /** @type {?} */ (bootstrapCallNode.parent);
1012 break;
1013 }
1014 }
1015 }
1016 catch (e_1_1) { e_1 = { error: e_1_1 }; }
1017 finally {
1018 try {
1019 if (allNodes_1_1 && !allNodes_1_1.done && (_a = allNodes_1.return)) _a.call(allNodes_1);
1020 }
1021 finally { if (e_1) throw e_1.error; }
1022 }
1023 return bootstrapCall;
1024}
1025/**
1026 * @param {?} host
1027 * @param {?} mainPath
1028 * @return {?}
1029 */
1030function findBootstrapModulePath(host, mainPath) {
1031 /** @type {?} */
1032 var bootstrapCall = findBootstrapModuleCall(host, mainPath);
1033 if (!bootstrapCall) {
1034 throw new SchematicsException('Bootstrap call not found');
1035 }
1036 /** @type {?} */
1037 var bootstrapModule = bootstrapCall.arguments[0];
1038 /** @type {?} */
1039 var mainBuffer = host.read(mainPath);
1040 if (!mainBuffer) {
1041 throw new SchematicsException("Client app main file (" + mainPath + ") not found");
1042 }
1043 /** @type {?} */
1044 var mainText = mainBuffer.toString('utf-8');
1045 /** @type {?} */
1046 var source = createSourceFile(mainPath, mainText, ScriptTarget.Latest, true);
1047 /** @type {?} */
1048 var allNodes = getSourceNodes(source);
1049 /** @type {?} */
1050 var bootstrapModuleRelativePath = allNodes
1051 .filter(function (node) { return node.kind === SyntaxKind.ImportDeclaration; })
1052 .filter(function (imp) {
1053 return findNode(imp, SyntaxKind.Identifier, bootstrapModule.getText());
1054 })
1055 .map(function (imp) {
1056 /** @type {?} */
1057 var modulePathStringLiteral = /** @type {?} */ (imp.moduleSpecifier);
1058 return modulePathStringLiteral.text;
1059 })[0];
1060 return bootstrapModuleRelativePath;
1061}
1062/**
1063 * @param {?} host
1064 * @param {?} mainPath
1065 * @return {?}
1066 */
1067function getAppModulePath(host, mainPath) {
1068 /** @type {?} */
1069 var moduleRelativePath = findBootstrapModulePath(host, mainPath);
1070 /** @type {?} */
1071 var mainDir = dirname(mainPath);
1072 /** @type {?} */
1073 var modulePath = normalize("/" + mainDir + "/" + moduleRelativePath + ".ts");
1074 return modulePath;
1075}
1076
1077/**
1078 * @fileoverview added by tsickle
1079 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1080 */
1081/**
1082 * @param {?} path
1083 * @param {?} name
1084 * @return {?}
1085 */
1086function parseName(path, name) {
1087 /** @type {?} */
1088 var nameWithoutPath = basename(/** @type {?} */ (name));
1089 /** @type {?} */
1090 var namePath = dirname$1(/** @type {?} */ ((path + '/' + name)));
1091 return {
1092 name: nameWithoutPath,
1093 path: normalize('/' + namePath),
1094 };
1095}
1096
1097/**
1098 * @fileoverview added by tsickle
1099 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1100 */
1101/**
1102 * @param {?} name
1103 * @return {?}
1104 */
1105function validateName(name) {
1106 if (name && /^\d/.test(name)) {
1107 throw new SchematicsException(tags.oneLine(templateObject_1 || (templateObject_1 = __makeTemplateObject(["name (", ")\n can not start with a digit."], ["name (", ")\n can not start with a digit."])), name));
1108 }
1109}
1110/** @type {?} */
1111var htmlSelectorRe = /^[a-zA-Z][.0-9a-zA-Z]*(:?-[a-zA-Z][.0-9a-zA-Z]*)*$/;
1112/**
1113 * @param {?} selector
1114 * @return {?}
1115 */
1116function validateHtmlSelector(selector) {
1117 if (selector && !htmlSelectorRe.test(selector)) {
1118 throw new SchematicsException(tags.oneLine(templateObject_2 || (templateObject_2 = __makeTemplateObject(["Selector (", ")\n is invalid."], ["Selector (", ")\n is invalid."])), selector));
1119 }
1120}
1121/**
1122 * @param {?} projectName
1123 * @return {?}
1124 */
1125function validateProjectName(projectName) {
1126 /** @type {?} */
1127 var errorIndex = getRegExpFailPosition(projectName);
1128 /** @type {?} */
1129 var unsupportedProjectNames = ['test', 'ember', 'ember-cli', 'vendor', 'app'];
1130 /** @type {?} */
1131 var packageNameRegex = /^(?:@[a-zA-Z0-9_-]+\/)?[a-zA-Z0-9_-]+$/;
1132 if (errorIndex !== null) {
1133 /** @type {?} */
1134 var firstMessage = tags.oneLine(templateObject_3 || (templateObject_3 = __makeTemplateObject(["\n Project name \"", "\" is not valid. New project names must\n start with a letter, and must contain only alphanumeric characters or dashes.\n When adding a dash the segment after the dash must also start with a letter.\n "], ["\n Project name \"", "\" is not valid. New project names must\n start with a letter, and must contain only alphanumeric characters or dashes.\n When adding a dash the segment after the dash must also start with a letter.\n "])), projectName);
1135 /** @type {?} */
1136 var msg = tags.stripIndent(templateObject_4 || (templateObject_4 = __makeTemplateObject(["\n ", "\n ", "\n ", "\n "], ["\n ", "\n ", "\n ", "\n "])), firstMessage, projectName, Array(errorIndex + 1).join(' ') + '^');
1137 throw new SchematicsException(msg);
1138 }
1139 else if (unsupportedProjectNames.indexOf(projectName) !== -1) {
1140 throw new SchematicsException("Project name " + JSON.stringify(projectName) + " is not a supported name.");
1141 }
1142 else if (!packageNameRegex.test(projectName)) {
1143 throw new SchematicsException("Project name " + JSON.stringify(projectName) + " is invalid.");
1144 }
1145}
1146/**
1147 * @param {?} str
1148 * @return {?}
1149 */
1150function getRegExpFailPosition(str) {
1151 /** @type {?} */
1152 var isScope = /^@.*\/.*/.test(str);
1153 if (isScope) {
1154 // Remove starting @
1155 str = str.replace(/^@/, '');
1156 // Change / to - for validation
1157 str = str.replace(/\//g, '-');
1158 }
1159 /** @type {?} */
1160 var parts = str.indexOf('-') >= 0 ? str.split('-') : [str];
1161 /** @type {?} */
1162 var matched = [];
1163 /** @type {?} */
1164 var projectNameRegexp = /^[a-zA-Z][.0-9a-zA-Z]*(-[.0-9a-zA-Z]*)*$/;
1165 parts.forEach(function (part) {
1166 if (part.match(projectNameRegexp)) {
1167 matched.push(part);
1168 }
1169 });
1170 /** @type {?} */
1171 var compare = matched.join('-');
1172 return (str !== compare) ? compare.length : null;
1173}
1174var templateObject_1, templateObject_2, templateObject_3, templateObject_4;
1175
1176/**
1177 * @fileoverview added by tsickle
1178 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1179 */
1180
1181/**
1182 * @fileoverview added by tsickle
1183 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1184 */
1185/**
1186 * @param {?} aUrl
1187 * @return {?}
1188 */
1189function _ensureTrailingSlash(aUrl) {
1190 return aUrl.endsWith('/') ? aUrl : aUrl + '/';
1191}
1192/**
1193 * @param {?} aUrl
1194 * @return {?}
1195 */
1196function _hasTrailingSlash(aUrl) {
1197 return !!(aUrl && isString(aUrl) && aUrl.endsWith('/'));
1198}
1199
1200/**
1201 * @fileoverview added by tsickle
1202 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1203 */
1204/**
1205 * @param {?} aValue
1206 * @param {?=} aName
1207 * @return {?}
1208 */
1209function assertNotNull(aValue, aName) {
1210 ok(aValue != null, aName
1211 ? "Value [" + aName + "] must not be null or undefined."
1212 : 'Value must not be null or undefined.');
1213}
1214/**
1215 * @param {?} aValue
1216 * @param {?} aParameterName
1217 * @return {?}
1218 */
1219function assertParameter(aValue, aParameterName) {
1220 ok(!!aValue, "Please specify the '--" + aParameterName + "' parameter.");
1221}
1222/**
1223 * @param {?} aValue
1224 * @return {?}
1225 */
1226function isValidUrl(aValue) {
1227 return isString$1(aValue) && !!isWebUri(aValue);
1228}
1229/**
1230 * @param {?} aValue
1231 * @param {?=} aName
1232 * @return {?}
1233 */
1234function assertIsUrl(aValue, aName) {
1235 ok(isValidUrl(aValue), aName
1236 ? "Value [" + aName + "] must be a valid URL."
1237 : 'Value must be a valid URL.');
1238 return aValue;
1239}
1240/**
1241 * @param {?} aValue
1242 * @return {?}
1243 */
1244function isValidEmail(aValue) {
1245 return isString$1(aValue) && !!validate(aValue);
1246}
1247/**
1248 * @param {?} aValue
1249 * @return {?}
1250 */
1251function isValidUserName(aValue) {
1252 return isString$1(aValue) && (!!validate(aValue) || aValue === 'apikey');
1253}
1254/**
1255 * @param {?} aValue
1256 * @param {?=} aName
1257 * @return {?}
1258 */
1259function assertIsEmail(aValue, aName) {
1260 ok(isValidEmail(aValue), aName
1261 ? "Value [" + aName + "] must be a valid e-mail address."
1262 : 'Value must be a valid e-mail address.');
1263 return aValue;
1264}
1265/**
1266 * @param {?} aValue
1267 * @param {?=} aName
1268 * @return {?}
1269 */
1270function assertIsValidUserName(aValue, aName) {
1271 ok(isValidUserName(aValue), aName
1272 ? "Value [" + aName + "] must be a valid e-mail address or the term 'apikey'."
1273 : "Value must be a valid e-mail address or the term 'apikey'.");
1274 return aValue;
1275}
1276/**
1277 * @param {?} aValue
1278 * @return {?}
1279 */
1280function assertHasTrailingSlash(aValue) {
1281 ok(isValidUrl(aValue) && _hasTrailingSlash(aValue), 'URL [${aValue}] must end with a slash.');
1282 return aValue;
1283}
1284
1285/**
1286 * @fileoverview added by tsickle
1287 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1288 */
1289/* Copyright IBM Corp. 2018 */
1290/** @type {?} */
1291var HEX_REGEXP_STRING = '[0-9a-fA-F]';
1292/** @type {?} */
1293var UUID_V4_REGEXP_STRING = HEX_REGEXP_STRING + "{8}-" + HEX_REGEXP_STRING + "{4}-4" + HEX_REGEXP_STRING + "{3}-[89abAB]" + HEX_REGEXP_STRING + "{3}-" + HEX_REGEXP_STRING + "{12}";
1294/** @type {?} */
1295var TENANT_BASED_URL = "^(?:\\/api)?\\/(" + UUID_V4_REGEXP_STRING + ")(?:\\/)?(?:.*)$";
1296/** @type {?} */
1297var TENANT_BASED_URL_REGEXP = new RegExp(TENANT_BASED_URL);
1298
1299/**
1300 * @fileoverview added by tsickle
1301 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1302 */
1303/** @type {?} */
1304var createXHR = function () {
1305 /** @type {?} */
1306 var XMLHttpRequest = require('xhr2');
1307 return new XMLHttpRequest();
1308};
1309/** @type {?} */
1310var ajaxRequest = function (req) {
1311 return ajax(__assign({}, req, { responseType: 'text', createXHR: createXHR })).pipe(map(function (resp) { return (resp.response); }));
1312};
1313/**
1314 * @param {?} aUri
1315 * @return {?}
1316 */
1317function rxGet(aUri) {
1318 // setup the request
1319 return ajaxRequest({
1320 url: aUri
1321 });
1322}
1323/**
1324 * @param {?} aUri
1325 * @return {?}
1326 */
1327function rxGetJson(aUri) {
1328 return rxGet(aUri).pipe(map(function (data) { return JSON.parse(data); }));
1329}
1330/**
1331 * @param {?} aUri
1332 * @param {?} aData
1333 * @return {?}
1334 */
1335function rxFormPost(aUri, aData) {
1336 // setup the request
1337 return ajaxRequest({
1338 method: 'POST',
1339 url: aUri,
1340 body: aData
1341 });
1342}
1343
1344/**
1345 * @fileoverview added by tsickle
1346 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1347 */
1348/**
1349 * @param {?} aPath
1350 * @return {?}
1351 */
1352function rxReadFile(aPath) {
1353 return Observable.create(function (observer) {
1354 readFile(aPath, 'utf-8', function (err, data) {
1355 if (err) {
1356 observer.error(err);
1357 }
1358 else {
1359 observer.next(data);
1360 observer.complete();
1361 }
1362 });
1363 });
1364}
1365
1366/**
1367 * @fileoverview added by tsickle
1368 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1369 */
1370/**
1371 * @param {?=} aCred
1372 * @return {?}
1373 */
1374function _isValidCredential(aCred) {
1375 return !!(aCred &&
1376 isValidUserName(aCred.username) &&
1377 isString(aCred.password));
1378}
1379/**
1380 * @return {?}
1381 */
1382function _emptyCredentials() {
1383 return {
1384 username: '',
1385 password: ''
1386 };
1387}
1388/**
1389 * @return {?}
1390 */
1391function _getCredentialsFromEnvironment() {
1392 /** @type {?} */
1393 var username = env['ibm_wch_sdk_cli_username'] || '';
1394 /** @type {?} */
1395 var password = env['ibm_wch_sdk_cli_password'] || '';
1396 // construct
1397 return { username: username, password: password };
1398}
1399/**
1400 * Merge different credentials layers
1401 *
1402 * @param {?} aBase base layer
1403 * @param {?=} aOverride override layer
1404 *
1405 * @return {?} the merged credentials
1406 */
1407function _mergeCredentials(aBase, aOverride) {
1408 // target
1409 if (!aOverride) {
1410 return aBase;
1411 }
1412 /** @type {?} */
1413 var cred = cloneDeep(aBase);
1414 // override
1415 if (!!aOverride.username) {
1416 cred.username = aOverride.username;
1417 }
1418 if (!!aOverride.password) {
1419 cred.password = aOverride.password;
1420 }
1421 // ok
1422 return cred;
1423}
1424/** @type {?} */
1425var PADDING_MODE = RSA_PKCS1_PADDING;
1426/**
1427 * @return {?}
1428 */
1429function _loadPrivateKey() {
1430 /** @type {?} */
1431 var name = join$1(homedir(), '.ssh', 'id_rsa');
1432 return rxReadFile(name).pipe(map(function (key) { return ({ key: key, padding: PADDING_MODE }); }));
1433}
1434/** @type {?} */
1435var ENCRYPTED_ENCODING = 'base64';
1436/** @type {?} */
1437var DECTYPTED_ENCODING = 'utf8';
1438/**
1439 * @param {?} aHash
1440 * @param {?} aKey
1441 * @return {?}
1442 */
1443function _decryptPassword(aHash, aKey) {
1444 return privateDecrypt(aKey, Buffer.from(aHash, ENCRYPTED_ENCODING)).toString(DECTYPTED_ENCODING);
1445}
1446/**
1447 * @param {?} aApiBase
1448 * @return {?}
1449 */
1450function _loadCredentials(aApiBase) {
1451 // validate the URL
1452 assertHasTrailingSlash(aApiBase);
1453 /** @type {?} */
1454 var filename = join$1(homedir(), '.ibm-wch-sdk-cli', '.credentials');
1455 /** @type {?} */
1456 var key = _loadPrivateKey();
1457 // load the file
1458 return rxReadFile(filename).pipe(map(function (data) { return JSON.parse(data); }), map(function (data) { return data[aApiBase]; }), mergeMap(function (cred) {
1459 return key.pipe(map(function (k) { return _decryptPassword(cred.password, k); }), map(function (p) {
1460 cred.password = p;
1461 return cred;
1462 }));
1463 }), catchError(function () { return of(_emptyCredentials()); }));
1464}
1465/**
1466 * @param {?} aApiUrl
1467 * @return {?}
1468 */
1469function _getWindowsCredentials(aApiUrl) {
1470 // validate the URL
1471 assertHasTrailingSlash(aApiUrl);
1472 /** @type {?} */
1473 var path = normalize$1(join$1(__dirname, '..', '..', '..', 'assets', 'credman', process.arch, 'WchCredMan.exe'));
1474 /** @type {?} */
1475 var cmd = "\"" + path + "\" \"" + aApiUrl + "\"";
1476 // construct the observable
1477 return Observable.create(function (observer) {
1478 // execute the command
1479 exec(cmd, {
1480 encoding: 'utf8'
1481 }, function (error, stdout, stderr) {
1482 if (error) {
1483 observer.error(error);
1484 }
1485 else {
1486 try {
1487 // parse
1488 observer.next(JSON.parse(stdout));
1489 observer.complete();
1490 }
1491 catch (e) {
1492 observer.error(e);
1493 }
1494 }
1495 });
1496 });
1497}
1498/**
1499 * @param {?} aApiUrl
1500 * @return {?}
1501 */
1502function _getStoredCredentials(aApiUrl) {
1503 /** @type {?} */
1504 var key = _ensureTrailingSlash(aApiUrl);
1505 // normalize the URL
1506 if (platform() === 'win32') {
1507 // load the credentials module
1508 return _getWindowsCredentials(key).pipe(mergeMap(function (cred) {
1509 return _isValidCredential(cred) ? of(cred) : _loadCredentials(key);
1510 }), catchError(function () { return _loadCredentials(key); }));
1511 }
1512 // linux like fallback
1513 return _loadCredentials(key);
1514}
1515/**
1516 * @param {?} aApiUrl
1517 * @return {?}
1518 */
1519function wchToolsGetCredentials(aApiUrl) {
1520 // return
1521 return _getStoredCredentials(aApiUrl).pipe(map(function (cred) { return _mergeCredentials(_getCredentialsFromEnvironment(), cred); }), catchError(function (err) { return of(_getCredentialsFromEnvironment()); }));
1522}
1523
1524/**
1525 * @fileoverview added by tsickle
1526 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1527 */
1528/** @enum {number} */
1529var DEP_TYPE = {
1530 PEER: 0,
1531 RUNTIME: 1,
1532 DEVELOPMENT: 2,
1533};
1534DEP_TYPE[DEP_TYPE.PEER] = 'PEER';
1535DEP_TYPE[DEP_TYPE.RUNTIME] = 'RUNTIME';
1536DEP_TYPE[DEP_TYPE.DEVELOPMENT] = 'DEVELOPMENT';
1537/**
1538 * @param {?=} aType
1539 * @return {?}
1540 */
1541function getFolderForType(aType) {
1542 return aType === DEP_TYPE.PEER
1543 ? 'peerDependencies'
1544 : aType === DEP_TYPE.DEVELOPMENT
1545 ? 'devDependencies'
1546 : 'dependencies';
1547}
1548/**
1549 * Updates the package JSON to use at least the given version
1550 *
1551 * @param {?} aName name
1552 * @param {?} aMinVersion min version
1553 * @param {?} aPkg package
1554 * @param {?=} aType
1555 * @return {?}
1556 */
1557function updateMinVersion(aName, aMinVersion, aPkg, aType) {
1558 /** @type {?} */
1559 var folder = getFolderForType(aType);
1560 /** @type {?} */
1561 var deps = /** @type {?} */ (assertObject(folder, aPkg));
1562 /** @type {?} */
1563 var oldDep = deps[aName];
1564 if (isNil(oldDep) || !satisfies(aMinVersion, oldDep)) {
1565 // just update
1566 deps[aName] = "^" + aMinVersion;
1567 }
1568 // ok
1569 return aPkg;
1570}
1571/** @type {?} */
1572var rxReadFile$1 = bindNodeCallback(readFile);
1573/**
1574 * @param {?} aDir
1575 * @return {?}
1576 */
1577function findPackageJson(aDir) {
1578 // read
1579 return rxReadFile$1(join$1(aDir, 'package.json'), 'utf-8').pipe(map(function (data) { return JSON.parse(data); }), catchError(function (err) { return findPackageJson(parse(aDir).dir); }));
1580}
1581
1582/**
1583 * @fileoverview added by tsickle
1584 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1585 */
1586
1587/**
1588 * @fileoverview added by tsickle
1589 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1590 */
1591/**
1592 * @param {?} aPassword
1593 * @return {?}
1594 */
1595function _isValidPassword(aPassword) {
1596 return aPassword && aPassword.length > 0;
1597}
1598/**
1599 * @param {?} aApiUrl
1600 * @param {?} aError
1601 * @return {?}
1602 */
1603function _throwInvalidUrl(aApiUrl, aError) {
1604 return throwError(new VError(aError, 'The API URL [%s] is not a valid WCH API URL.', aApiUrl));
1605}
1606/**
1607 * @param {?} aApiUrl
1608 * @return {?}
1609 */
1610function _getCurrentUser(aApiUrl) {
1611 /** @type {?} */
1612 var currentUserUrl = "" + aApiUrl + REL_PATH_CURRENT_USER;
1613 return rxGetJson(currentUserUrl).pipe(catchError(function (error) { return _throwInvalidUrl(aApiUrl, error); }));
1614}
1615/**
1616 * @param {?} aApiUrl
1617 * @return {?}
1618 */
1619function _throwInvalidCredentials(aApiUrl) {
1620 return throwError(new VError('Unable to access credentials for the API URL [%s]. Please follow the directions on https://www.npmjs.com/package/ibm-wch-sdk-cli#credential-management to register credentials.', aApiUrl));
1621}
1622/**
1623 * @param {?} aApiUrl
1624 * @param {?} aCredentials
1625 * @return {?}
1626 */
1627function validateCredentials(aApiUrl, aCredentials) {
1628 var _a;
1629 // check the credentials object
1630 if (!aCredentials ||
1631 !isValidUserName(aCredentials.username) ||
1632 !_isValidPassword(aCredentials.password)) {
1633 return _throwInvalidCredentials(aApiUrl);
1634 }
1635 /** @type {?} */
1636 var loginUrl = "" + aApiUrl + REL_PATH_BASICAUTH_LOGIN;
1637 /** @type {?} */
1638 var body = (_a = {},
1639 _a[KEY_BASICAUTH_LOGIN_USERNAME] = aCredentials.username,
1640 _a[KEY_BASICAUTH_LOGIN_PASSWORD] = aCredentials.password,
1641 _a);
1642 // execute
1643 return rxFormPost(loginUrl, body).pipe(map(function (data) { return JSON.parse(data); }), catchError(function (error) {
1644 return throwError(new VError(error, 'Unable to login to [%s] with user [%s]. Please check your registered password.', loginUrl, aCredentials.username));
1645 }), mapTo(aApiUrl));
1646}
1647/**
1648 * @param {?} aFeed
1649 * @return {?}
1650 */
1651function _validateUser(aFeed) {
1652 // test the feed result
1653 if (!aFeed || !aFeed.externalId) {
1654 return throwError(new VError('Invalid currentuser response'));
1655 }
1656 return of(aFeed);
1657}
1658/**
1659 * Tests if the API URL is valid and if we have sufficient credentials to access the API
1660 *
1661 * @param {?} aUrl the API URL
1662 * @param {?} bValidateWithCredentials
1663 * @return {?} the url
1664 */
1665function validateApiUrl(aUrl, bValidateWithCredentials) {
1666 // check if the URL is valud
1667 if (!isUri(aUrl)) {
1668 return throwError(new VError('Please enter a valid API URL. Copy this URL from the "Hub Information" section of your WCH tenant.'));
1669 }
1670 /** @type {?} */
1671 var normUrl = _ensureTrailingSlash(aUrl);
1672 if (bValidateWithCredentials) {
1673 /** @type {?} */
1674 var onCredentials = wchToolsGetCredentials(normUrl).pipe(catchError(function (error) { return _throwInvalidCredentials(normUrl); }));
1675 /** @type {?} */
1676 var onValidUrl = _getCurrentUser(normUrl).pipe(switchMap(_validateUser), switchMapTo(onCredentials), switchMap(function (cred) { return validateCredentials(normUrl, cred); }));
1677 // ok
1678 return onValidUrl;
1679 }
1680 else {
1681 /** @type {?} */
1682 var onValidUrl = _getCurrentUser(normUrl).pipe(switchMap(_validateUser), mapTo(normUrl));
1683 // ok
1684 return onValidUrl;
1685 }
1686}
1687/** @type {?} */
1688var PACKAGE_JSON = /** @type {?} */ ('/package.json');
1689/** @type {?} */
1690var FALLBACK = /** @type {?} */ ('/data');
1691/** @type {?} */
1692var OPTIONS = /** @type {?} */ ('.wchtoolsoptions.json');
1693/** @type {?} */
1694var SDK_IMPORT = '@ibm-wch-sdk/ng';
1695/** @type {?} */
1696var CLI_IMPORT = '@ibm-wch-sdk/cli';
1697/** @type {?} */
1698var WCHTOOLS_DEPENDENCIES = 'wchtools-dependencies';
1699/**
1700 * @return {?}
1701 */
1702function _findBuildVersion() {
1703 // find the package
1704 return findPackageJson(__dirname).pipe(pluck('version'));
1705}
1706/**
1707 * Decode the version from the dependency
1708 *
1709 * @param {?} aVersion the version
1710 *
1711 * @return {?} observable of the version
1712 */
1713function _fromDependency(aVersion) {
1714 /** @type {?} */
1715 var parsed = coerce(aVersion);
1716 return !!parsed ? of(parsed.version) : _findBuildVersion();
1717}
1718/**
1719 * @param {?} host
1720 * @return {?}
1721 */
1722function findSdkVersion(host) {
1723 /** @type {?} */
1724 var buf = host.read(PACKAGE_JSON);
1725 if (isNil(buf)) {
1726 return _findBuildVersion();
1727 }
1728 /** @type {?} */
1729 var pkg = JSON.parse(buf.toString());
1730 /** @type {?} */
1731 var deps = pkg.dependencies || {};
1732 /** @type {?} */
1733 var devDeps = pkg.devDependencies || {};
1734 /** @type {?} */
1735 var fromPkg = deps[SDK_IMPORT] || devDeps[CLI_IMPORT];
1736 return isNotNil(fromPkg) ? _fromDependency(fromPkg) : _findBuildVersion();
1737}
1738/**
1739 * @param {?} host
1740 * @return {?}
1741 */
1742function findDataDir(host) {
1743 /** @type {?} */
1744 var buf = host.read(PACKAGE_JSON);
1745 if (isNil(buf)) {
1746 return FALLBACK;
1747 }
1748 /** @type {?} */
1749 var pkg = JSON.parse(buf.toString());
1750 /** @type {?} */
1751 var cfg = pkg.config || {};
1752 /** @type {?} */
1753 var data = cfg.data || FALLBACK;
1754 return resolve(/** @type {?} */ ('/'), data);
1755}
1756/**
1757 * @param {?} host
1758 * @return {?}
1759 */
1760function findWchToolsOptions(host) {
1761 return resolve(findDataDir(host), OPTIONS);
1762}
1763/**
1764 * @param {?} aDeps
1765 * @param {?} aPkg
1766 * @return {?}
1767 */
1768function addToWchToolsDependencies(aDeps, aPkg) {
1769 /** @type {?} */
1770 var deps = assertArray(WCHTOOLS_DEPENDENCIES, aPkg);
1771 // filter
1772 deps.push.apply(deps, __spread(aDeps.filter(function (dep) { return deps.indexOf(dep) < 0; })));
1773}
1774
1775/**
1776 * @fileoverview added by tsickle
1777 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1778 */
1779/** @type {?} */
1780var _keys = Object.keys;
1781/** @type {?} */
1782var KEY_WEIGHTS = {
1783 name: 1,
1784 description: 2,
1785 id: 3,
1786 classification: 4
1787};
1788/**
1789 * @param {?} aLeft
1790 * @param {?} aRight
1791 * @return {?}
1792 */
1793function _compareNumber(aLeft, aRight) {
1794 return aLeft < aRight ? -1 : aLeft > aRight ? +1 : 0;
1795}
1796/**
1797 * @param {?} aName
1798 * @return {?}
1799 */
1800function _getKey(aName) {
1801 return KEY_WEIGHTS[aName] || Number.MAX_SAFE_INTEGER;
1802}
1803/**
1804 * @param {?} aLeft
1805 * @param {?} aRight
1806 * @return {?}
1807 */
1808function _compareName(aLeft, aRight) {
1809 /** @type {?} */
1810 var c = _compareNumber(_getKey(aLeft), _getKey(aRight));
1811 if (c === 0) {
1812 c = aLeft.localeCompare(aRight);
1813 }
1814 // ok
1815 return c;
1816}
1817/**
1818 * @param {?} aData
1819 * @return {?}
1820 */
1821function _canonicalize(aData) {
1822 // handle
1823 if (isArray(aData)) {
1824 /** @type {?} */
1825 var copy_1 = [];
1826 aData.forEach(function (v) { return copy_1.push(_canonicalize(v)); });
1827 return copy_1;
1828 }
1829 if (isPlainObject(aData)) {
1830 /** @type {?} */
1831 var copy_2 = {};
1832 _keys(aData)
1833 .sort(_compareName)
1834 .forEach(function (k) { return (copy_2[k] = _canonicalize(aData[k])); });
1835 return copy_2;
1836 }
1837 // nothing to do
1838 return aData;
1839}
1840/**
1841 * @param {?} aData
1842 * @return {?}
1843 */
1844function serializeJson(aData) {
1845 return aData ? JSON.stringify(aData, undefined, 2) : undefined;
1846}
1847/**
1848 * @param {?} aName
1849 * @param {?} aGenerator
1850 * @param {?} aObj
1851 * @return {?}
1852 */
1853function updateField(aName, aGenerator, aObj) {
1854 /** @type {?} */
1855 var oldValue = aObj[aName];
1856 if (isNil(oldValue)) {
1857 // update with the generated value
1858 aObj[aName] = aGenerator();
1859 }
1860 return aObj;
1861}
1862
1863/**
1864 * @fileoverview added by tsickle
1865 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1866 */
1867/**
1868 * @param {?=} aSource
1869 * @return {?}
1870 */
1871function serializeLines(aSource) {
1872 return aSource ? aSource.join('\n') : undefined;
1873}
1874/**
1875 * @param {?=} aSource
1876 * @return {?}
1877 */
1878function parseLines(aSource) {
1879 return aSource ? aSource.split('\n') : [];
1880}
1881/**
1882 * @param {?} aSource
1883 * @param {?} aInsert
1884 * @return {?}
1885 */
1886function insertLines(aSource, aInsert) {
1887 if (aSource) {
1888 /** @type {?} */
1889 var existing_1 = new Set(aSource);
1890 return __spread(aSource, aInsert.filter(function (line) { return !existing_1.has(line); }));
1891 }
1892 else {
1893 // just insert into the empty file
1894 return __spread(aInsert);
1895 }
1896}
1897
1898/**
1899 * @fileoverview added by tsickle
1900 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1901 */
1902/**
1903 * Reads a text file from the tree and then transforms it using the given function. If the result
1904 * is null or undefined, the file will be deleted, else replaced or created.
1905 *
1906 * @param {?} aName name of the file
1907 * @param {?} aOp the operator
1908 * @param {?} aTree the tree to work in
1909 * @return {?}
1910 */
1911function rxTransformTextFile(aName, aOp, aTree) {
1912 /** @type {?} */
1913 var buffer = aTree.read(aName);
1914 /** @type {?} */
1915 var value = isNotNil(buffer) ? buffer.toString() : null;
1916 /** @type {?} */
1917 var op = /** @type {?} */ (aOp);
1918 // replace
1919 return op(value, aName).pipe(first(), map(function (result) {
1920 return isNotNil(result)
1921 ? isNotNil(buffer)
1922 ? aTree.overwrite(aName, result)
1923 : aTree.create(aName, result)
1924 : isNotNil(buffer)
1925 ? aTree.delete(aName)
1926 : undefined;
1927 }), mapTo(aName));
1928}
1929/**
1930 * Reads a JSON file from the tree and then transforms it using the given function. If the result
1931 * is null or undefined, the file will be deleted, else replaced or created.
1932 *
1933 * @param {?} aName name of the file
1934 * @param {?} aOp the operator
1935 * @param {?} aTree the tree to work in
1936 * @return {?}
1937 */
1938function rxTransformJsonFile(aName, aOp, aTree) {
1939 /** @type {?} */
1940 var op = /** @type {?} */ (aOp);
1941 // dispatch
1942 return rxTransformTextFile(aName, function (textContent, path) {
1943 return op(textContent ? JSON.parse(textContent) : undefined, path).pipe(map(_canonicalize), map(serializeJson));
1944 }, aTree);
1945}
1946/**
1947 * Reads a line based file from the tree and then transforms it using the given function. If the result
1948 * is null or undefined, the file will be deleted, else replaced or created.
1949 *
1950 * @param {?} aName name of the file
1951 * @param {?} aOp the operator
1952 * @param {?} aTree the tree to work in
1953 * @return {?}
1954 */
1955function rxTransformLinesFile(aName, aOp, aTree) {
1956 /** @type {?} */
1957 var op = /** @type {?} */ (aOp);
1958 // dispatch
1959 return rxTransformTextFile(aName, function (textContent, path) {
1960 return op(textContent ? parseLines(textContent) : undefined, path).pipe(map(serializeLines));
1961 }, aTree);
1962}
1963
1964/**
1965 * @fileoverview added by tsickle
1966 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
1967 */
1968/**
1969 * @param {?} aName
1970 * @param {?} aCount
1971 * @return {?}
1972 */
1973function _skipPrefix(aName, aCount) {
1974 /** @type {?} */
1975 var idx = 0;
1976 for (var i = 0; i < aCount; ++i) {
1977 /** @type {?} */
1978 var nextIdx = aName.indexOf('/', idx);
1979 if (nextIdx >= idx) {
1980 idx = nextIdx + 1;
1981 }
1982 else {
1983 return null;
1984 }
1985 }
1986 // split
1987 return aName.substring(idx);
1988}
1989var StreamOnBuffer = /** @class */ (function (_super) {
1990 __extends(StreamOnBuffer, _super);
1991 function StreamOnBuffer() {
1992 var _this = _super !== null && _super.apply(this, arguments) || this;
1993 _this.buffers = [];
1994 return _this;
1995 }
1996 /**
1997 * @param {?} chunk
1998 * @param {?} encoding
1999 * @param {?} callback
2000 * @return {?}
2001 */
2002 StreamOnBuffer.prototype._write = /**
2003 * @param {?} chunk
2004 * @param {?} encoding
2005 * @param {?} callback
2006 * @return {?}
2007 */
2008 function (chunk, encoding, callback) {
2009 this.buffers.push(chunk);
2010 callback();
2011 };
2012 /**
2013 * @param {?} callback
2014 * @return {?}
2015 */
2016 StreamOnBuffer.prototype._final = /**
2017 * @param {?} callback
2018 * @return {?}
2019 */
2020 function (callback) {
2021 callback();
2022 this.emit('close');
2023 };
2024 return StreamOnBuffer;
2025}(Writable));
2026/**
2027 * @param {?} aTree
2028 * @param {?} aEntry
2029 * @param {?} aDstDir
2030 * @param {?} aSkip
2031 * @return {?}
2032 */
2033function _rxExtractEntry(aTree, aEntry, aDstDir, aSkip) {
2034 /** @type {?} */
2035 var path = _skipPrefix(aEntry.path, aSkip);
2036 if (!path) {
2037 // nothing
2038 return of('').pipe(tap(function () { return aEntry.autodrain(); }), filter(function () { return false; }));
2039 }
2040 /** @type {?} */
2041 var fileName = normalize$1(join$1(aDstDir, path));
2042 // handle directories
2043 if (aEntry.type === 'Directory') {
2044 // create the directory
2045 return of('').pipe(tap(function () { return aEntry.autodrain(); }), filter(function () { return false; }));
2046 }
2047 else {
2048 /** @type {?} */
2049 var stream_1 = aEntry.pipe(new StreamOnBuffer());
2050 // attach
2051 return fromEvent(stream_1, 'close').pipe(
2052 // just take one
2053 first(),
2054 // copy into the tree
2055 map(function () { return aTree.create(fileName, Buffer.concat(stream_1.buffers)); }),
2056 // map to the target name
2057 mapTo(fileName));
2058 }
2059}
2060/**
2061 * @param {?} aTree
2062 * @param {?} aSrcUrl
2063 * @param {?} aDstDir
2064 * @param {?=} aSkip
2065 * @return {?}
2066 */
2067function rxUnzipFromUrl(aTree, aSrcUrl, aDstDir, aSkip) {
2068 if (aSkip === void 0) { aSkip = 0; }
2069 // defer
2070 return defer(function () {
2071 /** @type {?} */
2072 var stream = get(aSrcUrl).pipe(Parse());
2073 /** @type {?} */
2074 var onEntry = fromEvent(stream, 'entry');
2075 /** @type {?} */
2076 var onClose = fromEvent(stream, 'close');
2077 // return the full stream
2078 return onEntry.pipe(takeUntil(onClose), mergeMap(function (entry) { return _rxExtractEntry(aTree, entry, aDstDir, aSkip); }));
2079 });
2080}
2081
2082/**
2083 * @fileoverview added by tsickle
2084 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
2085 */
2086/**
2087 * @param {?=} aString
2088 * @return {?}
2089 */
2090function _parseHtml(aString) {
2091 return of(load(isNotNil(aString) ? /** @type {?} */ ((aString)) : ''));
2092}
2093/**
2094 * @param {?} aHtml
2095 * @return {?}
2096 */
2097function _serializeHtml(aHtml) {
2098 return of(/** @type {?} */ ((aHtml)).html());
2099}
2100/**
2101 * Reads an HMTL from the tree and then transforms it using the given function. If the result
2102 * is null or undefined, the file will be deleted, else replaced or created.
2103 *
2104 * @param {?} aName name of the file
2105 * @param {?} aOp the operator
2106 * @param {?} aTree the tree to work in
2107 * @return {?}
2108 */
2109function rxTransformHtmlFile(aName, aOp, aTree) {
2110 /** @type {?} */
2111 var op = /** @type {?} */ (aOp);
2112 // dispatch
2113 return rxTransformTextFile(aName, function (textContent, path) {
2114 return _parseHtml(textContent).pipe(switchMap(function (html) { return op(html, path); }), switchMap(_serializeHtml));
2115 }, aTree);
2116}
2117
2118/**
2119 * @fileoverview added by tsickle
2120 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
2121 */
2122
2123/**
2124 * @fileoverview added by tsickle
2125 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
2126 */
2127/**
2128 * @param {?} host
2129 * @param {?} path
2130 * @return {?}
2131 */
2132function getSourceFile(host, path) {
2133 /** @type {?} */
2134 var buffer = host.read(path);
2135 if (!buffer) {
2136 throw new SchematicsException("Could not find " + path + ".");
2137 }
2138 /** @type {?} */
2139 var content = buffer.toString();
2140 /** @type {?} */
2141 var source = createSourceFile(path, content, ScriptTarget.Latest, true);
2142 return source;
2143}
2144
2145/**
2146 * @fileoverview added by tsickle
2147 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
2148 */
2149/**
2150 * @param {?} aChanges
2151 * @param {?} aRecorder
2152 * @return {?}
2153 */
2154function insertChanges(aChanges, aRecorder) {
2155 aChanges.forEach(function (change) {
2156 // delete
2157 if (change instanceof InsertChange) {
2158 aRecorder.insertLeft(change.pos, change.toAdd);
2159 }
2160 else if (change instanceof RemoveChange) ;
2161 else if (change instanceof ReplaceChange) {
2162 /** @type {?} */
2163 var anyChange = /** @type {?} */ (change);
2164 aRecorder.remove(anyChange.pos, anyChange.oldText.length);
2165 aRecorder.insertLeft(anyChange.pos, anyChange.newText);
2166 }
2167 });
2168}
2169/**
2170 * @param {?} aFile
2171 * @param {?} aOp
2172 * @param {?} aHost
2173 * @return {?}
2174 */
2175function changeSourceFile(aFile, aOp, aHost) {
2176 // make sure at least an empty file exists
2177 if (!aHost.exists(aFile)) {
2178 aHost.create(aFile, '');
2179 }
2180 /** @type {?} */
2181 var recorder = aHost.beginUpdate(aFile);
2182 insertChanges(aOp(aFile, getSourceFile(aHost, aFile)), recorder);
2183 aHost.commitUpdate(recorder);
2184}
2185/**
2186 * Changes the identified module by adding a couple of imports
2187 *
2188 * @param {?} aFile the filename
2189 * @param {?} aModules the modules to be added
2190 * @param {?} aHost the tree
2191 * @return {?}
2192 */
2193function addImportsToModule(aFile, aModules, aHost) {
2194 // iterate
2195 Object.keys(aModules).forEach(function (name) {
2196 return changeSourceFile(aFile, function (file, content) { return addImportToModule(content, file, name, aModules[name]); }, aHost);
2197 });
2198}
2199
2200/**
2201 * @fileoverview added by tsickle
2202 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
2203 */
2204/**
2205 * @param {?} aType
2206 * @return {?}
2207 */
2208function byType(aType) {
2209 return function (node) { return node && node.kind === aType; };
2210}
2211/**
2212 * @param {?} aText
2213 * @return {?}
2214 */
2215function byText(aText) {
2216 return function (node) { return node && node.getText() === aText; };
2217}
2218/**
2219 * @param {?} aText
2220 * @return {?}
2221 */
2222function byName(aText) {
2223 return function (node) { return !!(node && node.name && node.name.getText() === aText); };
2224}
2225/**
2226 * @param {?} aType
2227 * @param {?} aName
2228 * @return {?}
2229 */
2230function byTypeAndName(aType, aName) {
2231 return function (node) { return node && node.kind === aType && node.getText() === aName; };
2232}
2233/**
2234 * @param {?} aName
2235 * @return {?}
2236 */
2237function byIdentifier(aName) {
2238 return byTypeAndName(SyntaxKind.Identifier, aName);
2239}
2240
2241/**
2242 * @fileoverview added by tsickle
2243 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
2244 */
2245
2246/**
2247 * @fileoverview added by tsickle
2248 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
2249 */
2250
2251/**
2252 * @fileoverview added by tsickle
2253 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
2254 */
2255
2256/**
2257 * @fileoverview added by tsickle
2258 * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
2259 */
2260
2261export { findModuleFromOptions, findModule, buildRelativePath, insertImport, findNodes, getSourceNodes, findNode, insertAfterLastOccurrence, getContentOfKeyLiteral, getDecoratorMetadata, getFirstNgModuleName, addSymbolToNgModuleMetadata, addDeclarationToModule, addImportToModule, addProviderToModule, addExportToModule, addBootstrapToModule, addEntryComponentToModule, isImported, getWorkspacePath, getWorkspace, addProjectToWorkspace, getConfig, getAppFromConfig, configPath, findBootstrapModuleCall, findBootstrapModulePath, getAppModulePath, parseName, validateName, validateHtmlSelector, validateProjectName, htmlSelectorRe, NoopChange, InsertChange, RemoveChange, ReplaceChange, assertNotNull, assertParameter, isValidUrl, assertIsUrl, isValidEmail, isValidUserName, assertIsEmail, assertIsValidUserName, assertHasTrailingSlash, TENANT_BASED_URL_REGEXP, _ensureTrailingSlash as ensureTrailingSlash, _hasTrailingSlash as hasTrailingSlash, rxGet, rxGetJson, rxFormPost, wchToolsGetCredentials, validateCredentials, validateApiUrl, findSdkVersion, findDataDir, findWchToolsOptions, addToWchToolsDependencies, WCHTOOLS_DEPENDENCIES, rxReadFile, rxTransformTextFile, rxTransformJsonFile, rxTransformLinesFile, serializeJson, updateField, _canonicalize as canonicalizeJSON, rxUnzipFromUrl, rxTransformHtmlFile, getSourceFile, insertChanges, changeSourceFile, addImportsToModule, byType, byText, byName, byTypeAndName, byIdentifier, serializeLines, parseLines, insertLines, getFolderForType, updateMinVersion, findPackageJson, DEP_TYPE };
2262
2263//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"ibm-wch-sdk-schematics-utils.js.map","sources":["ng://@ibm-wch-sdk/schematics-utils/utility/find-module.ts","ng://@ibm-wch-sdk/schematics-utils/utility/change.ts","ng://@ibm-wch-sdk/schematics-utils/utility/ast-utils.ts","ng://@ibm-wch-sdk/schematics-utils/utility/config.ts","ng://@ibm-wch-sdk/schematics-utils/utility/ng-ast-utils.ts","ng://@ibm-wch-sdk/schematics-utils/utility/parse-name.ts","ng://@ibm-wch-sdk/schematics-utils/utility/validation.ts","ng://@ibm-wch-sdk/schematics-utils/wch/url.utils.ts","ng://@ibm-wch-sdk/schematics-utils/wch/assert.ts","ng://@ibm-wch-sdk/schematics-utils/wch/tenant.ts","ng://@ibm-wch-sdk/schematics-utils/wch/rx.request.ts","ng://@ibm-wch-sdk/schematics-utils/wch/rx.file.ts","ng://@ibm-wch-sdk/schematics-utils/wch/wchtools.ts","ng://@ibm-wch-sdk/schematics-utils/package/package.ts","ng://@ibm-wch-sdk/schematics-utils/wch/wch.utils.ts","ng://@ibm-wch-sdk/schematics-utils/wch/json.ts","ng://@ibm-wch-sdk/schematics-utils/text/lines.ts","ng://@ibm-wch-sdk/schematics-utils/wch/rx.tree.ts","ng://@ibm-wch-sdk/schematics-utils/wch/rx.zip.ts","ng://@ibm-wch-sdk/schematics-utils/wch/rx.html.ts","ng://@ibm-wch-sdk/schematics-utils/typescript/source.ts","ng://@ibm-wch-sdk/schematics-utils/typescript/changes.ts","ng://@ibm-wch-sdk/schematics-utils/typescript/finders.ts"],"sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport { Path, join, normalize, relative, strings } from '@angular-devkit/core';\nimport { DirEntry, Tree } from '@angular-devkit/schematics';\n\n\nexport interface ModuleOptions {\n  module?: string;\n  name: string;\n  flat?: boolean;\n  path?: string;\n  skipImport?: boolean;\n}\n\n\n/**\n * Find the module referred by a set of options passed to the schematics.\n */\nexport function findModuleFromOptions(host: Tree, options: ModuleOptions): Path | undefined {\n  if (options.hasOwnProperty('skipImport') && options.skipImport) {\n    return undefined;\n  }\n\n  if (!options.module) {\n    const pathToCheck = (options.path || '')\n                      + (options.flat ? '' : '/' + strings.dasherize(options.name));\n\n    return normalize(findModule(host, pathToCheck));\n  } else {\n    const modulePath = normalize(\n      '/' + (options.path) + '/' + options.module);\n    const moduleBaseName = normalize(modulePath).split('/').pop();\n\n    if (host.exists(modulePath)) {\n      return normalize(modulePath);\n    } else if (host.exists(modulePath + '.ts')) {\n      return normalize(modulePath + '.ts');\n    } else if (host.exists(modulePath + '.module.ts')) {\n      return normalize(modulePath + '.module.ts');\n    } else if (host.exists(modulePath + '/' + moduleBaseName + '.module.ts')) {\n      return normalize(modulePath + '/' + moduleBaseName + '.module.ts');\n    } else {\n      throw new Error('Specified module does not exist');\n    }\n  }\n}\n\n/**\n * Function to find the \"closest\" module to a generated file's path.\n */\nexport function findModule(host: Tree, generateDir: string): Path {\n  let dir: DirEntry | null = host.getDir('/' + generateDir);\n\n  const moduleRe = /\\.module\\.ts$/;\n  const routingModuleRe = /-routing\\.module\\.ts/;\n\n  while (dir) {\n    const matches = dir.subfiles.filter(p => moduleRe.test(p) && !routingModuleRe.test(p));\n\n    if (matches.length == 1) {\n      return join(dir.path, matches[0]);\n    } else if (matches.length > 1) {\n      throw new Error('More than one module matches. Use skip-import option to skip importing '\n        + 'the component into the closest module.');\n    }\n\n    dir = dir.parent;\n  }\n\n  throw new Error('Could not find an NgModule. Use the skip-import '\n    + 'option to skip importing in NgModule.');\n}\n\n/**\n * Build a relative path from one file path to another file path.\n */\nexport function buildRelativePath(from: string, to: string): string {\n  from = normalize(from);\n  to = normalize(to);\n\n  // Convert to arrays.\n  const fromParts = from.split('/');\n  const toParts = to.split('/');\n\n  // Remove file names (preserving destination)\n  fromParts.pop();\n  const toFileName = toParts.pop();\n\n  const relativePath = relative(normalize(fromParts.join('/')), normalize(toParts.join('/')));\n  let pathPrefix = '';\n\n  // Set the path prefix for same dir or child dir, parent dir starts with `..`\n  if (!relativePath) {\n    pathPrefix = '.';\n  } else if (!relativePath.startsWith('.')) {\n    pathPrefix = `./`;\n  }\n  if (pathPrefix && !pathPrefix.endsWith('/')) {\n    pathPrefix += '/';\n  }\n\n  return pathPrefix + (relativePath ? relativePath + '/' : '') + toFileName;\n}\n","/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nexport interface Host {\n  write(path: string, content: string): Promise<void>;\n  read(path: string): Promise<string>;\n}\n\n\nexport interface Change {\n  apply(host: Host): Promise<void>;\n\n  // The file this change should be applied to. Some changes might not apply to\n  // a file (maybe the config).\n  readonly path: string | null;\n\n  // The order this change should be applied. Normally the position inside the file.\n  // Changes are applied from the bottom of a file to the top.\n  readonly order: number;\n\n  // The description of this change. This will be outputted in a dry or verbose run.\n  readonly description: string;\n}\n\n\n/**\n * An operation that does nothing.\n */\nexport class NoopChange implements Change {\n  description = 'No operation.';\n  order = Infinity;\n  path = null;\n  apply() { return Promise.resolve(); }\n}\n\n\n/**\n * Will add text to the source code.\n */\nexport class InsertChange implements Change {\n\n  order: number;\n  description: string;\n\n  constructor(public path: string, public pos: number, public toAdd: string) {\n    if (pos < 0) {\n      throw new Error('Negative positions are invalid');\n    }\n    this.description = `Inserted ${toAdd} into position ${pos} of ${path}`;\n    this.order = pos;\n  }\n\n  /**\n   * This method does not insert spaces if there is none in the original string.\n   */\n  apply(host: Host) {\n    return host.read(this.path).then(content => {\n      const prefix = content.substring(0, this.pos);\n      const suffix = content.substring(this.pos);\n\n      return host.write(this.path, `${prefix}${this.toAdd}${suffix}`);\n    });\n  }\n}\n\n/**\n * Will remove text from the source code.\n */\nexport class RemoveChange implements Change {\n\n  order: number;\n  description: string;\n\n  constructor(public path: string, private pos: number, private toRemove: string) {\n    if (pos < 0) {\n      throw new Error('Negative positions are invalid');\n    }\n    this.description = `Removed ${toRemove} into position ${pos} of ${path}`;\n    this.order = pos;\n  }\n\n  apply(host: Host): Promise<void> {\n    return host.read(this.path).then(content => {\n      const prefix = content.substring(0, this.pos);\n      const suffix = content.substring(this.pos + this.toRemove.length);\n\n      // TODO: throw error if toRemove doesn't match removed string.\n      return host.write(this.path, `${prefix}${suffix}`);\n    });\n  }\n}\n\n/**\n * Will replace text from the source code.\n */\nexport class ReplaceChange implements Change {\n  order: number;\n  description: string;\n\n  constructor(public path: string, private pos: number, private oldText: string,\n              private newText: string) {\n    if (pos < 0) {\n      throw new Error('Negative positions are invalid');\n    }\n    this.description = `Replaced ${oldText} into position ${pos} of ${path} with ${newText}`;\n    this.order = pos;\n  }\n\n  apply(host: Host): Promise<void> {\n    return host.read(this.path).then(content => {\n      const prefix = content.substring(0, this.pos);\n      const suffix = content.substring(this.pos + this.oldText.length);\n      const text = content.substring(this.pos, this.pos + this.oldText.length);\n\n      if (text !== this.oldText) {\n        return Promise.reject(new Error(`Invalid replace: \"${text}\" != \"${this.oldText}\".`));\n      }\n\n      // TODO: throw error if oldText doesn't match removed string.\n      return host.write(this.path, `${prefix}${this.newText}${suffix}`);\n    });\n  }\n}\n","/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport * as ts from 'typescript';\nimport { Change, InsertChange, NoopChange } from './change';\n\n/**\n * Add Import `import { symbolName } from fileName` if the import doesn't exit\n * already. Assumes fileToEdit can be resolved and accessed.\n * @param fileToEdit (file we want to add import to)\n * @param symbolName (item to import)\n * @param fileName (path to the file)\n * @param isDefault (if true, import follows style for importing default exports)\n * @return Change\n */\nexport function insertImport(\n  source: ts.SourceFile,\n  fileToEdit: string,\n  symbolName: string,\n  fileName: string,\n  isDefault = false\n): Change {\n  const rootNode = source;\n  const allImports = findNodes(rootNode, ts.SyntaxKind.ImportDeclaration);\n\n  // get nodes that map to import statements from the file fileName\n  const relevantImports = allImports.filter(node => {\n    // StringLiteral of the ImportDeclaration is the import file (fileName in this case).\n    const importFiles = node\n      .getChildren()\n      .filter(child => child.kind === ts.SyntaxKind.StringLiteral)\n      .map(n => (n as ts.StringLiteral).text);\n\n    return importFiles.filter(file => file === fileName).length === 1;\n  });\n\n  if (relevantImports.length > 0) {\n    let importsAsterisk = false;\n    // imports from import file\n    const imports: ts.Node[] = [];\n    relevantImports.forEach(n => {\n      Array.prototype.push.apply(\n        imports,\n        findNodes(n, ts.SyntaxKind.Identifier)\n      );\n      if (findNodes(n, ts.SyntaxKind.AsteriskToken).length > 0) {\n        importsAsterisk = true;\n      }\n    });\n\n    // if imports * from fileName, don't add symbolName\n    if (importsAsterisk) {\n      return new NoopChange();\n    }\n\n    const importTextNodes = imports.filter(\n      n => (n as ts.Identifier).text === symbolName\n    );\n\n    // insert import if it's not there\n    if (importTextNodes.length === 0) {\n      const fallbackPos =\n        findNodes(\n          relevantImports[0],\n          ts.SyntaxKind.CloseBraceToken\n        )[0].getStart() ||\n        findNodes(relevantImports[0], ts.SyntaxKind.FromKeyword)[0].getStart();\n\n      return insertAfterLastOccurrence(\n        imports,\n        `, ${symbolName}`,\n        fileToEdit,\n        fallbackPos\n      );\n    }\n\n    return new NoopChange();\n  }\n\n  // no such import declaration exists\n  const useStrict = findNodes(rootNode, ts.SyntaxKind.StringLiteral).filter(\n    (n: ts.StringLiteral) => n.text === 'use strict'\n  );\n  let fallbackPos = 0;\n  if (useStrict.length > 0) {\n    fallbackPos = useStrict[0].end;\n  }\n  const open = isDefault ? '' : '{ ';\n  const close = isDefault ? '' : ' }';\n  // if there are no imports or 'use strict' statement, insert import at beginning of file\n  const insertAtBeginning = allImports.length === 0 && useStrict.length === 0;\n  const separator = insertAtBeginning ? '' : ';\\n';\n  const toInsert =\n    `${separator}import ${open}${symbolName}${close}` +\n    ` from '${fileName}'${insertAtBeginning ? ';\\n' : ''}`;\n\n  return insertAfterLastOccurrence(\n    allImports,\n    toInsert,\n    fileToEdit,\n    fallbackPos,\n    ts.SyntaxKind.StringLiteral\n  );\n}\n\n/**\n * Find all nodes from the AST in the subtree of node of SyntaxKind kind.\n * @param node\n * @param kind\n * @param max The maximum number of items to return.\n * @return all nodes of kind, or [] if none is found\n */\nexport function findNodes(\n  node: ts.Node,\n  kind: ts.SyntaxKind,\n  max = Infinity\n): ts.Node[] {\n  if (!node || max == 0) {\n    return [];\n  }\n\n  const arr: ts.Node[] = [];\n  if (node.kind === kind) {\n    arr.push(node);\n    max--;\n  }\n  if (max > 0) {\n    for (const child of node.getChildren()) {\n      findNodes(child, kind, max).forEach(node => {\n        if (max > 0) {\n          arr.push(node);\n        }\n        max--;\n      });\n\n      if (max <= 0) {\n        break;\n      }\n    }\n  }\n\n  return arr;\n}\n\n/**\n * Get all the nodes from a source.\n * @param sourceFile The source file object.\n * @returns An observable of all the nodes in the source.\n */\nexport function getSourceNodes(sourceFile: ts.SourceFile): ts.Node[] {\n  const nodes: ts.Node[] = [sourceFile];\n  const result = [];\n\n  while (nodes.length > 0) {\n    const node = nodes.shift();\n\n    if (node) {\n      result.push(node);\n      if (node.getChildCount(sourceFile) >= 0) {\n        nodes.unshift(...node.getChildren());\n      }\n    }\n  }\n\n  return result;\n}\n\nexport function findNode(\n  node: ts.Node,\n  kind: ts.SyntaxKind,\n  text: string\n): ts.Node | null {\n  if (node.kind === kind && node.getText() === text) {\n    // throw new Error(node.getText());\n    return node;\n  }\n\n  let foundNode: ts.Node | null = null;\n  ts.forEachChild(node, childNode => {\n    foundNode = foundNode || findNode(childNode, kind, text);\n  });\n\n  return foundNode;\n}\n\n/**\n * Helper for sorting nodes.\n * @return function to sort nodes in increasing order of position in sourceFile\n */\nfunction nodesByPosition(first: ts.Node, second: ts.Node): number {\n  return first.getStart() - second.getStart();\n}\n\n/**\n * Insert `toInsert` after the last occurence of `ts.SyntaxKind[nodes[i].kind]`\n * or after the last of occurence of `syntaxKind` if the last occurence is a sub child\n * of ts.SyntaxKind[nodes[i].kind] and save the changes in file.\n *\n * @param nodes insert after the last occurence of nodes\n * @param toInsert string to insert\n * @param file file to insert changes into\n * @param fallbackPos position to insert if toInsert happens to be the first occurence\n * @param syntaxKind the ts.SyntaxKind of the subchildren to insert after\n * @return Change instance\n * @throw Error if toInsert is first occurence but fall back is not set\n */\nexport function insertAfterLastOccurrence(\n  nodes: ts.Node[],\n  toInsert: string,\n  file: string,\n  fallbackPos: number,\n  syntaxKind?: ts.SyntaxKind\n): Change {\n  // sort() has a side effect, so make a copy so that we won't overwrite the parent's object.\n  let lastItem = [...nodes].sort(nodesByPosition).pop();\n  if (!lastItem) {\n    throw new Error();\n  }\n  if (syntaxKind) {\n    lastItem = findNodes(lastItem, syntaxKind)\n      .sort(nodesByPosition)\n      .pop();\n  }\n  if (!lastItem && fallbackPos == undefined) {\n    throw new Error(\n      `tried to insert ${toInsert} as first occurence with no fallback position`\n    );\n  }\n  const lastItemPosition: number = lastItem ? lastItem.getEnd() : fallbackPos;\n\n  return new InsertChange(file, lastItemPosition, toInsert);\n}\n\nexport function getContentOfKeyLiteral(\n  _source: ts.SourceFile,\n  node: ts.Node\n): string | null {\n  if (node.kind == ts.SyntaxKind.Identifier) {\n    return (node as ts.Identifier).text;\n  } else if (node.kind == ts.SyntaxKind.StringLiteral) {\n    return (node as ts.StringLiteral).text;\n  } else {\n    return null;\n  }\n}\n\nfunction _angularImportsFromNode(\n  node: ts.ImportDeclaration,\n  _sourceFile: ts.SourceFile\n): { [name: string]: string } {\n  const ms = node.moduleSpecifier;\n  let modulePath: string;\n  switch (ms.kind) {\n    case ts.SyntaxKind.StringLiteral:\n      modulePath = (ms as ts.StringLiteral).text;\n      break;\n    default:\n      return {};\n  }\n\n  if (!modulePath.startsWith('@angular/')) {\n    return {};\n  }\n\n  if (node.importClause) {\n    if (node.importClause.name) {\n      // This is of the form `import Name from 'path'`. Ignore.\n      return {};\n    } else if (node.importClause.namedBindings) {\n      const nb = node.importClause.namedBindings;\n      if (nb.kind == ts.SyntaxKind.NamespaceImport) {\n        // This is of the form `import * as name from 'path'`. Return `name.`.\n        return {\n          [(nb as ts.NamespaceImport).name.text + '.']: modulePath\n        };\n      } else {\n        // This is of the form `import {a,b,c} from 'path'`\n        const namedImports = nb as ts.NamedImports;\n\n        return namedImports.elements\n          .map(\n            (is: ts.ImportSpecifier) =>\n              is.propertyName ? is.propertyName.text : is.name.text\n          )\n          .reduce((acc: { [name: string]: string }, curr: string) => {\n            acc[curr] = modulePath;\n\n            return acc;\n          }, {});\n      }\n    }\n\n    return {};\n  } else {\n    // This is of the form `import 'path';`. Nothing to do.\n    return {};\n  }\n}\n\nexport function getDecoratorMetadata(\n  source: ts.SourceFile,\n  identifier: string,\n  module: string\n): ts.Node[] {\n  const angularImports: { [name: string]: string } = findNodes(\n    source,\n    ts.SyntaxKind.ImportDeclaration\n  )\n    .map((node: ts.ImportDeclaration) => _angularImportsFromNode(node, source))\n    .reduce(\n      (\n        acc: { [name: string]: string },\n        current: { [name: string]: string }\n      ) => {\n        for (const key of Object.keys(current)) {\n          acc[key] = current[key];\n        }\n\n        return acc;\n      },\n      {}\n    );\n\n  return getSourceNodes(source)\n    .filter(node => {\n      return (\n        node.kind == ts.SyntaxKind.Decorator &&\n        (node as ts.Decorator).expression.kind == ts.SyntaxKind.CallExpression\n      );\n    })\n    .map(node => (node as ts.Decorator).expression as ts.CallExpression)\n    .filter(expr => {\n      if (expr.expression.kind == ts.SyntaxKind.Identifier) {\n        const id = expr.expression as ts.Identifier;\n\n        return (\n          id.getFullText(source) == identifier &&\n          angularImports[id.getFullText(source)] === module\n        );\n      } else if (\n        expr.expression.kind == ts.SyntaxKind.PropertyAccessExpression\n      ) {\n        // This covers foo.NgModule when importing * as foo.\n        const paExpr = expr.expression as ts.PropertyAccessExpression;\n        // If the left expression is not an identifier, just give up at that point.\n        if (paExpr.expression.kind !== ts.SyntaxKind.Identifier) {\n          return false;\n        }\n\n        const id = paExpr.name.text;\n        const moduleId = (paExpr.expression as ts.Identifier).getText(source);\n\n        return id === identifier && angularImports[moduleId + '.'] === module;\n      }\n\n      return false;\n    })\n    .filter(\n      expr =>\n        expr.arguments[0] &&\n        expr.arguments[0].kind == ts.SyntaxKind.ObjectLiteralExpression\n    )\n    .map(expr => expr.arguments[0] as ts.ObjectLiteralExpression);\n}\n\nfunction findClassDeclarationParent(\n  node: ts.Node\n): ts.ClassDeclaration | undefined {\n  if (ts.isClassDeclaration(node)) {\n    return node;\n  }\n\n  return node.parent && findClassDeclarationParent(node.parent);\n}\n\n/**\n * Given a source file with @NgModule class(es), find the name of the first @NgModule class.\n *\n * @param source source file containing one or more @NgModule\n * @returns the name of the first @NgModule, or `undefined` if none is found\n */\nexport function getFirstNgModuleName(\n  source: ts.SourceFile\n): string | undefined {\n  // First, find the @NgModule decorators.\n  const ngModulesMetadata = getDecoratorMetadata(\n    source,\n    'NgModule',\n    '@angular/core'\n  );\n  if (ngModulesMetadata.length === 0) {\n    return undefined;\n  }\n\n  // Then walk parent pointers up the AST, looking for the ClassDeclaration parent of the NgModule\n  // metadata.\n  const moduleClass = findClassDeclarationParent(ngModulesMetadata[0]);\n  if (!moduleClass || !moduleClass.name) {\n    return undefined;\n  }\n\n  // Get the class name of the module ClassDeclaration.\n  return moduleClass.name.text;\n}\n\nexport function addSymbolToNgModuleMetadata(\n  source: ts.SourceFile,\n  ngModulePath: string,\n  metadataField: string,\n  symbolName: string,\n  importPath: string | null = null\n): Change[] {\n  const nodes = getDecoratorMetadata(source, 'NgModule', '@angular/core');\n  let node: any = nodes[0]; // tslint:disable-line:no-any\n\n  // Find the decorator declaration.\n  if (!node) {\n    return [];\n  }\n\n  // Get all the children property assignment of object literals.\n  const matchingProperties: ts.ObjectLiteralElement[] = (node as ts.ObjectLiteralExpression).properties\n    .filter(prop => prop.kind == ts.SyntaxKind.PropertyAssignment)\n    // Filter out every fields that's not \"metadataField\". Also handles string literals\n    // (but not expressions).\n    .filter((prop: ts.PropertyAssignment) => {\n      const name = prop.name;\n      switch (name.kind) {\n        case ts.SyntaxKind.Identifier:\n          return (name as ts.Identifier).getText(source) == metadataField;\n        case ts.SyntaxKind.StringLiteral:\n          return (name as ts.StringLiteral).text == metadataField;\n      }\n\n      return false;\n    });\n\n  // Get the last node of the array literal.\n  if (!matchingProperties) {\n    return [];\n  }\n  if (matchingProperties.length == 0) {\n    // We haven't found the field in the metadata declaration. Insert a new field.\n    const expr = node as ts.ObjectLiteralExpression;\n    let position: number;\n    let toInsert: string;\n    if (expr.properties.length == 0) {\n      position = expr.getEnd() - 1;\n      toInsert = `  ${metadataField}: [${symbolName}]\\n`;\n    } else {\n      node = expr.properties[expr.properties.length - 1];\n      position = node.getEnd();\n      // Get the indentation of the last element, if any.\n      const text = node.getFullText(source);\n      const matches = text.match(/^\\r?\\n\\s*/);\n      if (matches.length > 0) {\n        toInsert = `,${matches[0]}${metadataField}: [${symbolName}]`;\n      } else {\n        toInsert = `, ${metadataField}: [${symbolName}]`;\n      }\n    }\n    if (importPath !== null) {\n      return [\n        new InsertChange(ngModulePath, position, toInsert),\n        insertImport(\n          source,\n          ngModulePath,\n          symbolName.replace(/\\..*$/, ''),\n          importPath\n        )\n      ];\n    } else {\n      return [new InsertChange(ngModulePath, position, toInsert)];\n    }\n  }\n  const assignment = matchingProperties[0] as ts.PropertyAssignment;\n\n  // If it's not an array, nothing we can do really.\n  if (assignment.initializer.kind !== ts.SyntaxKind.ArrayLiteralExpression) {\n    return [];\n  }\n\n  const arrLiteral = assignment.initializer as ts.ArrayLiteralExpression;\n  if (arrLiteral.elements.length == 0) {\n    // Forward the property.\n    node = arrLiteral;\n  } else {\n    node = arrLiteral.elements;\n  }\n\n  if (!node) {\n    console.log(\n      'No app module found. Please add your new class to your component.'\n    );\n\n    return [];\n  }\n\n  if (Array.isArray(node)) {\n    const nodeArray = (node as {}) as Array<ts.Node>;\n    const symbolsArray = nodeArray.map(node => node.getText());\n    if (symbolsArray.indexOf(symbolName) >= 0) {\n      return [];\n    }\n\n    node = node[node.length - 1];\n  }\n\n  let toInsert: string;\n  let position = node.getEnd();\n  if (node.kind == ts.SyntaxKind.ObjectLiteralExpression) {\n    // We haven't found the field in the metadata declaration. Insert a new\n    // field.\n    const expr = node as ts.ObjectLiteralExpression;\n    if (expr.properties.length == 0) {\n      position = expr.getEnd() - 1;\n      toInsert = `  ${metadataField}: [${symbolName}]\\n`;\n    } else {\n      node = expr.properties[expr.properties.length - 1];\n      position = node.getEnd();\n      // Get the indentation of the last element, if any.\n      const text = node.getFullText(source);\n      if (text.match('^\\r?\\r?\\n')) {\n        toInsert = `,${\n          text.match(/^\\r?\\n\\s+/)[0]\n        }${metadataField}: [${symbolName}]`;\n      } else {\n        toInsert = `, ${metadataField}: [${symbolName}]`;\n      }\n    }\n  } else if (node.kind == ts.SyntaxKind.ArrayLiteralExpression) {\n    // We found the field but it's empty. Insert it just before the `]`.\n    position--;\n    toInsert = `${symbolName}`;\n  } else {\n    // Get the indentation of the last element, if any.\n    const text = node.getFullText(source);\n    if (text.match(/^\\r?\\n/)) {\n      toInsert = `,${text.match(/^\\r?\\n(\\r?)\\s+/)[0]}${symbolName}`;\n    } else {\n      toInsert = `, ${symbolName}`;\n    }\n  }\n  if (importPath !== null) {\n    return [\n      new InsertChange(ngModulePath, position, toInsert),\n      insertImport(\n        source,\n        ngModulePath,\n        symbolName.replace(/\\..*$/, ''),\n        importPath\n      )\n    ];\n  }\n\n  return [new InsertChange(ngModulePath, position, toInsert)];\n}\n\n/**\n * Custom function to insert a declaration (component, pipe, directive)\n * into NgModule declarations. It also imports the component.\n */\nexport function addDeclarationToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string\n): Change[] {\n  return addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'declarations',\n    classifiedName,\n    importPath\n  );\n}\n\n/**\n * Custom function to insert an NgModule into NgModule imports. It also imports the module.\n */\nexport function addImportToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string\n): Change[] {\n  return addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'imports',\n    classifiedName,\n    importPath\n  );\n}\n\n/**\n * Custom function to insert a provider into NgModule. It also imports it.\n */\nexport function addProviderToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string\n): Change[] {\n  return addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'providers',\n    classifiedName,\n    importPath\n  );\n}\n\n/**\n * Custom function to insert an export into NgModule. It also imports it.\n */\nexport function addExportToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string\n): Change[] {\n  return addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'exports',\n    classifiedName,\n    importPath\n  );\n}\n\n/**\n * Custom function to insert an export into NgModule. It also imports it.\n */\nexport function addBootstrapToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string\n): Change[] {\n  return addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'bootstrap',\n    classifiedName,\n    importPath\n  );\n}\n\n/**\n * Custom function to insert an entryComponent into NgModule. It also imports it.\n */\nexport function addEntryComponentToModule(\n  source: ts.SourceFile,\n  modulePath: string,\n  classifiedName: string,\n  importPath: string\n): Change[] {\n  return addSymbolToNgModuleMetadata(\n    source,\n    modulePath,\n    'entryComponents',\n    classifiedName,\n    importPath\n  );\n}\n\n/**\n * Determine if an import already exists.\n */\nexport function isImported(\n  source: ts.SourceFile,\n  classifiedName: string,\n  importPath: string\n): boolean {\n  const allNodes = getSourceNodes(source);\n  const matchingNodes = allNodes\n    .filter(node => node.kind === ts.SyntaxKind.ImportDeclaration)\n    .filter(\n      (imp: ts.ImportDeclaration) =>\n        imp.moduleSpecifier.kind === ts.SyntaxKind.StringLiteral\n    )\n    .filter((imp: ts.ImportDeclaration) => {\n      return (<ts.StringLiteral>imp.moduleSpecifier).text === importPath;\n    })\n    .filter((imp: ts.ImportDeclaration) => {\n      if (!imp.importClause) {\n        return false;\n      }\n      const nodes = findNodes(\n        imp.importClause,\n        ts.SyntaxKind.ImportSpecifier\n      ).filter(n => n.getText() === classifiedName);\n\n      return nodes.length > 0;\n    });\n\n  return matchingNodes.length > 0;\n}\n","/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport { JsonParseMode, experimental, parseJson } from '@angular-devkit/core';\nimport { Rule, SchematicContext, SchematicsException, Tree } from '@angular-devkit/schematics';\n\n\n// The interfaces below are generated from the Angular CLI configuration schema\n// https://github.com/angular/angular-cli/blob/master/packages/@angular/cli/lib/config/schema.json\nexport interface AppConfig {\n  /**\n   * Name of the app.\n   */\n  name?: string;\n  /**\n   * Directory where app files are placed.\n   */\n  appRoot?: string;\n  /**\n   * The root directory of the app.\n   */\n  root?: string;\n  /**\n   * The output directory for build results.\n   */\n  outDir?: string;\n  /**\n   * List of application assets.\n   */\n  assets?: (string | {\n      /**\n       * The pattern to match.\n       */\n      glob?: string;\n      /**\n       * The dir to search within.\n       */\n      input?: string;\n      /**\n       * The output path (relative to the outDir).\n       */\n      output?: string;\n  })[];\n  /**\n   * URL where files will be deployed.\n   */\n  deployUrl?: string;\n  /**\n   * Base url for the application being built.\n   */\n  baseHref?: string;\n  /**\n   * The runtime platform of the app.\n   */\n  platform?: ('browser' | 'server');\n  /**\n   * The name of the start HTML file.\n   */\n  index?: string;\n  /**\n   * The name of the main entry-point file.\n   */\n  main?: string;\n  /**\n   * The name of the polyfills file.\n   */\n  polyfills?: string;\n  /**\n   * The name of the test entry-point file.\n   */\n  test?: string;\n  /**\n   * The name of the TypeScript configuration file.\n   */\n  tsconfig?: string;\n  /**\n   * The name of the TypeScript configuration file for unit tests.\n   */\n  testTsconfig?: string;\n  /**\n   * The prefix to apply to generated selectors.\n   */\n  prefix?: string;\n  /**\n   * Experimental support for a service worker from @angular/service-worker.\n   */\n  serviceWorker?: boolean;\n  /**\n   * Global styles to be included in the build.\n   */\n  styles?: (string | {\n      input?: string;\n      [name: string]: any; // tslint:disable-line:no-any\n  })[];\n  /**\n   * Options to pass to style preprocessors\n   */\n  stylePreprocessorOptions?: {\n      /**\n       * Paths to include. Paths will be resolved to project root.\n       */\n      includePaths?: string[];\n  };\n  /**\n   * Global scripts to be included in the build.\n   */\n  scripts?: (string | {\n      input: string;\n      [name: string]: any; // tslint:disable-line:no-any\n  })[];\n  /**\n   * Source file for environment config.\n   */\n  environmentSource?: string;\n  /**\n   * Name and corresponding file for environment config.\n   */\n  environments?: {\n      [name: string]: any; // tslint:disable-line:no-any\n  };\n  appShell?: {\n    app: string;\n    route: string;\n  };\n  budgets?: {\n    /**\n     * The type of budget\n     */\n    type?: ('bundle' | 'initial' | 'allScript' | 'all' | 'anyScript' | 'any');\n    /**\n     * The name of the bundle\n     */\n    name?: string;\n    /**\n     * The baseline size for comparison.\n     */\n    baseline?: string;\n    /**\n     * The maximum threshold for warning relative to the baseline.\n     */\n    maximumWarning?: string;\n    /**\n     * The maximum threshold for error relative to the baseline.\n     */\n    maximumError?: string;\n    /**\n     * The minimum threshold for warning relative to the baseline.\n     */\n    minimumWarning?: string;\n    /**\n     * The minimum threshold for error relative to the baseline.\n     */\n    minimumError?: string;\n    /**\n     * The threshold for warning relative to the baseline (min & max).\n     */\n    warning?: string;\n    /**\n     * The threshold for error relative to the baseline (min & max).\n     */\n    error?: string;\n  }[];\n}\n\nexport interface CliConfig {\n  $schema?: string;\n  /**\n   * The global configuration of the project.\n   */\n  project?: {\n      /**\n       * The name of the project.\n       */\n      name?: string;\n      /**\n       * Whether or not this project was ejected.\n       */\n      ejected?: boolean;\n  };\n  /**\n   * Properties of the different applications in this project.\n   */\n  apps?: AppConfig[];\n  /**\n   * Configuration for end-to-end tests.\n   */\n  e2e?: {\n      protractor?: {\n          /**\n           * Path to the config file.\n           */\n          config?: string;\n      };\n  };\n  /**\n   * Properties to be passed to TSLint.\n   */\n  lint?: {\n      /**\n       * File glob(s) to lint.\n       */\n      files?: (string | string[]);\n      /**\n       * Location of the tsconfig.json project file.\n       * Will also use as files to lint if 'files' property not present.\n       */\n      project: string;\n      /**\n       * Location of the tslint.json configuration.\n       */\n      tslintConfig?: string;\n      /**\n       * File glob(s) to ignore.\n       */\n      exclude?: (string | string[]);\n  }[];\n  /**\n   * Configuration for unit tests.\n   */\n  test?: {\n      karma?: {\n          /**\n           * Path to the karma config file.\n           */\n          config?: string;\n      };\n      codeCoverage?: {\n          /**\n           * Globs to exclude from code coverage.\n           */\n          exclude?: string[];\n      };\n  };\n  /**\n   * Specify the default values for generating.\n   */\n  defaults?: {\n      /**\n       * The file extension to be used for style files.\n       */\n      styleExt?: string;\n      /**\n       * How often to check for file updates.\n       */\n      poll?: number;\n      /**\n       * Use lint to fix files after generation\n       */\n      lintFix?: boolean;\n      /**\n       * Options for generating a class.\n       */\n      class?: {\n          /**\n           * Specifies if a spec file is generated.\n           */\n          spec?: boolean;\n      };\n      /**\n       * Options for generating a component.\n       */\n      component?: {\n          /**\n           * Flag to indicate if a dir is created.\n           */\n          flat?: boolean;\n          /**\n           * Specifies if a spec file is generated.\n           */\n          spec?: boolean;\n          /**\n           * Specifies if the style will be in the ts file.\n           */\n          inlineStyle?: boolean;\n          /**\n           * Specifies if the template will be in the ts file.\n           */\n          inlineTemplate?: boolean;\n          /**\n           * Specifies the view encapsulation strategy.\n           */\n          viewEncapsulation?: ('Emulated' | 'Native' | 'None');\n          /**\n           * Specifies the change detection strategy.\n           */\n          changeDetection?: ('Default' | 'OnPush');\n      };\n      /**\n       * Options for generating a directive.\n       */\n      directive?: {\n          /**\n           * Flag to indicate if a dir is created.\n           */\n          flat?: boolean;\n          /**\n           * Specifies if a spec file is generated.\n           */\n          spec?: boolean;\n      };\n      /**\n       * Options for generating a guard.\n       */\n      guard?: {\n          /**\n           * Flag to indicate if a dir is created.\n           */\n          flat?: boolean;\n          /**\n           * Specifies if a spec file is generated.\n           */\n          spec?: boolean;\n      };\n      /**\n       * Options for generating an interface.\n       */\n      interface?: {\n          /**\n           * Prefix to apply to interface names. (i.e. I)\n           */\n          prefix?: string;\n      };\n      /**\n       * Options for generating a module.\n       */\n      module?: {\n          /**\n           * Flag to indicate if a dir is created.\n           */\n          flat?: boolean;\n          /**\n           * Specifies if a spec file is generated.\n           */\n          spec?: boolean;\n      };\n      /**\n       * Options for generating a pipe.\n       */\n      pipe?: {\n          /**\n           * Flag to indicate if a dir is created.\n           */\n          flat?: boolean;\n          /**\n           * Specifies if a spec file is generated.\n           */\n          spec?: boolean;\n      };\n      /**\n       * Options for generating a service.\n       */\n      service?: {\n          /**\n           * Flag to indicate if a dir is created.\n           */\n          flat?: boolean;\n          /**\n           * Specifies if a spec file is generated.\n           */\n          spec?: boolean;\n      };\n      /**\n       * Properties to be passed to the build command.\n       */\n      build?: {\n          /**\n           * Output sourcemaps.\n           */\n          sourcemaps?: boolean;\n          /**\n           * Base url for the application being built.\n           */\n          baseHref?: string;\n          /**\n           * The ssl key used by the server.\n           */\n          progress?: boolean;\n          /**\n           * Enable and define the file watching poll time period (milliseconds).\n           */\n          poll?: number;\n          /**\n           * Delete output path before build.\n           */\n          deleteOutputPath?: boolean;\n          /**\n           * Do not use the real path when resolving modules.\n           */\n          preserveSymlinks?: boolean;\n          /**\n           * Show circular dependency warnings on builds.\n           */\n          showCircularDependencies?: boolean;\n          /**\n           * Use a separate bundle containing code used across multiple bundles.\n           */\n          commonChunk?: boolean;\n          /**\n           * Use file name for lazy loaded chunks.\n           */\n          namedChunks?: boolean;\n      };\n      /**\n       * Properties to be passed to the serve command.\n       */\n      serve?: {\n          /**\n           * The port the application will be served on.\n           */\n          port?: number;\n          /**\n           * The host the application will be served on.\n           */\n          host?: string;\n          /**\n           * Enables ssl for the application.\n           */\n          ssl?: boolean;\n          /**\n           * The ssl key used by the server.\n           */\n          sslKey?: string;\n          /**\n           * The ssl certificate used by the server.\n           */\n          sslCert?: string;\n          /**\n           * Proxy configuration file.\n           */\n          proxyConfig?: string;\n      };\n      /**\n       * Properties about schematics.\n       */\n      schematics?: {\n          /**\n           * The schematics collection to use.\n           */\n          collection?: string;\n          /**\n           * The new app schematic.\n           */\n          newApp?: string;\n      };\n  };\n  /**\n   * Specify which package manager tool to use.\n   */\n  packageManager?: ('npm' | 'cnpm' | 'yarn' | 'default');\n  /**\n   * Allow people to disable console warnings.\n   */\n  warnings?: {\n      /**\n       * Show a warning when the user enabled the --hmr option.\n       */\n      hmrWarning?: boolean;\n      /**\n       * Show a warning when the node version is incompatible.\n       */\n      nodeDeprecation?: boolean;\n      /**\n       * Show a warning when the user installed angular-cli.\n       */\n      packageDeprecation?: boolean;\n      /**\n       * Show a warning when the global version is newer than the local one.\n       */\n      versionMismatch?: boolean;\n      /**\n       * Show a warning when the TypeScript version is incompatible\n       */\n      typescriptMismatch?: boolean;\n  };\n}\n\nexport type WorkspaceSchema = experimental.workspace.WorkspaceSchema;\nexport type WorkspaceProject = experimental.workspace.WorkspaceProject;\n\n\nexport function getWorkspacePath(host: Tree): string {\n  const possibleFiles = [ '/angular.json', '/.angular.json' ];\n  const path = possibleFiles.filter(path => host.exists(path))[0];\n\n  return path;\n}\n\nexport function getWorkspace(host: Tree): WorkspaceSchema {\n  const path = getWorkspacePath(host);\n  const configBuffer = host.read(path);\n  if (configBuffer === null) {\n    throw new SchematicsException(`Could not find (${path})`);\n  }\n  const content = configBuffer.toString();\n\n  return parseJson(content, JsonParseMode.Loose) as {} as WorkspaceSchema;\n}\n\nexport function addProjectToWorkspace(\n  workspace: WorkspaceSchema,\n  name: string,\n  project: WorkspaceProject,\n): Rule {\n  return (host: Tree, context: SchematicContext) => {\n\n    if (workspace.projects[name]) {\n      throw new Error(`Project '${name}' already exists in workspace.`);\n    }\n\n    // Add project to workspace.\n    workspace.projects[name] = project;\n\n    if (!workspace.defaultProject && Object.keys(workspace.projects).length === 1) {\n      // Make the new project the default one.\n      workspace.defaultProject = name;\n    }\n\n    host.overwrite(getWorkspacePath(host), JSON.stringify(workspace, null, 2));\n  };\n}\n\nexport const configPath = '/.angular-cli.json';\n\nexport function getConfig(host: Tree): CliConfig {\n  const configBuffer = host.read(configPath);\n  if (configBuffer === null) {\n    throw new SchematicsException('Could not find .angular-cli.json');\n  }\n\n  const config = parseJson(configBuffer.toString(), JsonParseMode.Loose) as {} as CliConfig;\n\n  return config;\n}\n\nexport function getAppFromConfig(config: CliConfig, appIndexOrName: string): AppConfig | null {\n  if (!config.apps) {\n    return null;\n  }\n\n  if (parseInt(appIndexOrName) >= 0) {\n    return config.apps[parseInt(appIndexOrName)];\n  }\n\n  return config.apps.filter((app) => app.name === appIndexOrName)[0];\n}\n","/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport { normalize } from '@angular-devkit/core';\nimport { SchematicsException, Tree } from '@angular-devkit/schematics';\nimport { dirname } from 'path';\nimport * as ts from 'typescript';\nimport { findNode, getSourceNodes } from '../utility/ast-utils';\n\nexport function findBootstrapModuleCall(host: Tree, mainPath: string): ts.CallExpression | null {\n  const mainBuffer = host.read(mainPath);\n  if (!mainBuffer) {\n    throw new SchematicsException(`Main file (${mainPath}) not found`);\n  }\n  const mainText = mainBuffer.toString('utf-8');\n  const source = ts.createSourceFile(mainPath, mainText, ts.ScriptTarget.Latest, true);\n\n  const allNodes = getSourceNodes(source);\n\n  let bootstrapCall: ts.CallExpression | null = null;\n\n  for (const node of allNodes) {\n\n    let bootstrapCallNode: ts.Node | null = null;\n    bootstrapCallNode = findNode(node, ts.SyntaxKind.Identifier, 'bootstrapModule');\n\n    // Walk up the parent until CallExpression is found.\n    while (bootstrapCallNode && bootstrapCallNode.parent\n      && bootstrapCallNode.parent.kind !== ts.SyntaxKind.CallExpression) {\n\n      bootstrapCallNode = bootstrapCallNode.parent;\n    }\n\n    if (bootstrapCallNode !== null &&\n      bootstrapCallNode.parent !== undefined &&\n      bootstrapCallNode.parent.kind === ts.SyntaxKind.CallExpression) {\n      bootstrapCall = bootstrapCallNode.parent as ts.CallExpression;\n      break;\n    }\n  }\n\n  return bootstrapCall;\n}\n\nexport function findBootstrapModulePath(host: Tree, mainPath: string): string {\n  const bootstrapCall = findBootstrapModuleCall(host, mainPath);\n  if (!bootstrapCall) {\n    throw new SchematicsException('Bootstrap call not found');\n  }\n\n  const bootstrapModule = bootstrapCall.arguments[0];\n\n  const mainBuffer = host.read(mainPath);\n  if (!mainBuffer) {\n    throw new SchematicsException(`Client app main file (${mainPath}) not found`);\n  }\n  const mainText = mainBuffer.toString('utf-8');\n  const source = ts.createSourceFile(mainPath, mainText, ts.ScriptTarget.Latest, true);\n  const allNodes = getSourceNodes(source);\n  const bootstrapModuleRelativePath = allNodes\n    .filter(node => node.kind === ts.SyntaxKind.ImportDeclaration)\n    .filter(imp => {\n      return findNode(imp, ts.SyntaxKind.Identifier, bootstrapModule.getText());\n    })\n    .map((imp: ts.ImportDeclaration) => {\n      const modulePathStringLiteral = <ts.StringLiteral> imp.moduleSpecifier;\n\n      return modulePathStringLiteral.text;\n    })[0];\n\n  return bootstrapModuleRelativePath;\n}\n\nexport function getAppModulePath(host: Tree, mainPath: string): string {\n  const moduleRelativePath = findBootstrapModulePath(host, mainPath);\n  const mainDir = dirname(mainPath);\n  const modulePath = normalize(`/${mainDir}/${moduleRelativePath}.ts`);\n\n  return modulePath;\n}\n","\n/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n// import { relative, Path } from \"../../../angular_devkit/core/src/virtual-fs\";\nimport { Path, basename, dirname, normalize } from '@angular-devkit/core';\n\nexport interface Location {\n  name: string;\n  path: Path;\n}\n\nexport function parseName(path: string, name: string): Location {\n  const nameWithoutPath = basename(name as Path);\n  const namePath = dirname((path + '/' + name) as Path);\n\n  return {\n    name: nameWithoutPath,\n    path: normalize('/' + namePath),\n  };\n}\n","/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\nimport { tags } from '@angular-devkit/core';\nimport { SchematicsException } from '@angular-devkit/schematics';\n\nexport function validateName(name: string): void {\n  if (name && /^\\d/.test(name)) {\n    throw new SchematicsException(tags.oneLine`name (${name})\n        can not start with a digit.`);\n  }\n}\n\n// Must start with a letter, and must contain only alphanumeric characters or dashes.\n// When adding a dash the segment after the dash must also start with a letter.\nexport const htmlSelectorRe = /^[a-zA-Z][.0-9a-zA-Z]*(:?-[a-zA-Z][.0-9a-zA-Z]*)*$/;\n\nexport function validateHtmlSelector(selector: string): void {\n  if (selector && !htmlSelectorRe.test(selector)) {\n    throw new SchematicsException(tags.oneLine`Selector (${selector})\n        is invalid.`);\n  }\n}\n\n\nexport function validateProjectName(projectName: string) {\n  const errorIndex = getRegExpFailPosition(projectName);\n  const unsupportedProjectNames = ['test', 'ember', 'ember-cli', 'vendor', 'app'];\n  const packageNameRegex = /^(?:@[a-zA-Z0-9_-]+\\/)?[a-zA-Z0-9_-]+$/;\n  if (errorIndex !== null) {\n    const firstMessage = tags.oneLine`\n    Project name \"${projectName}\" is not valid. New project names must\n    start with a letter, and must contain only alphanumeric characters or dashes.\n    When adding a dash the segment after the dash must also start with a letter.\n    `;\n    const msg = tags.stripIndent`\n    ${firstMessage}\n    ${projectName}\n    ${Array(errorIndex + 1).join(' ') + '^'}\n    `;\n    throw new SchematicsException(msg);\n  } else if (unsupportedProjectNames.indexOf(projectName) !== -1) {\n    throw new SchematicsException(\n      `Project name ${JSON.stringify(projectName)} is not a supported name.`);\n  } else if (!packageNameRegex.test(projectName)) {\n    throw new SchematicsException(`Project name ${JSON.stringify(projectName)} is invalid.`);\n  }\n}\n\nfunction getRegExpFailPosition(str: string): number | null {\n  const isScope = /^@.*\\/.*/.test(str);\n  if (isScope) {\n    // Remove starting @\n    str = str.replace(/^@/, '');\n    // Change / to - for validation\n    str = str.replace(/\\//g, '-');\n  }\n\n  const parts = str.indexOf('-') >= 0 ? str.split('-') : [str];\n  const matched: string[] = [];\n\n  const projectNameRegexp = /^[a-zA-Z][.0-9a-zA-Z]*(-[.0-9a-zA-Z]*)*$/;\n\n  parts.forEach(part => {\n    if (part.match(projectNameRegexp)) {\n      matched.push(part);\n    }\n  });\n\n  const compare = matched.join('-');\n\n  return (str !== compare) ? compare.length : null;\n}\n","/* Copyright IBM Corp. 2017 */\nimport { isString } from 'lodash';\n\n/*\n * Makes sure our path ends with a proper trailing slash\n */\nfunction _ensureTrailingSlash(aUrl: string): string {\n  return aUrl.endsWith('/') ? aUrl : aUrl + '/';\n}\n\nfunction _hasTrailingSlash(aUrl: string): boolean {\n  return !!(aUrl && isString(aUrl) && aUrl.endsWith('/'));\n}\n\nexport {\n  _ensureTrailingSlash as ensureTrailingSlash,\n  _hasTrailingSlash as hasTrailingSlash\n};\n","import { isString } from '@ibm-wch-sdk/utils';\nimport * as Assert from 'assert';\nimport { validate as validateEmail } from 'email-validator';\nimport { isWebUri } from 'valid-url';\n\nimport { hasTrailingSlash } from './url.utils';\n\nexport function assertNotNull(aValue: any, aName?: string) {\n  Assert.ok(\n    aValue != null,\n    aName\n      ? `Value [${aName}] must not be null or undefined.`\n      : 'Value must not be null or undefined.'\n  );\n}\n\nexport function assertParameter(aValue: any, aParameterName: string) {\n  Assert.ok(!!aValue, `Please specify the '--${aParameterName}' parameter.`);\n}\n\nexport function isValidUrl(aValue: any): aValue is string {\n  return isString(aValue) && !!isWebUri(aValue);\n}\n\nexport function assertIsUrl(aValue: any, aName?: string): string {\n  Assert.ok(\n    isValidUrl(aValue),\n    aName\n      ? `Value [${aName}] must be a valid URL.`\n      : 'Value must be a valid URL.'\n  );\n  return aValue;\n}\n\nexport function isValidEmail(aValue: any): aValue is string {\n  return isString(aValue) && !!validateEmail(aValue);\n}\n\nexport function isValidUserName(aValue: any): aValue is string {\n  return isString(aValue) && (!!validateEmail(aValue) || aValue === 'apikey');\n}\n\nexport function assertIsEmail(aValue: any, aName?: string): string {\n  Assert.ok(\n    isValidEmail(aValue),\n    aName\n      ? `Value [${aName}] must be a valid e-mail address.`\n      : 'Value must be a valid e-mail address.'\n  );\n  return aValue;\n}\n\nexport function assertIsValidUserName(aValue: any, aName?: string): string {\n  Assert.ok(\n    isValidUserName(aValue),\n    aName\n      ? `Value [${aName}] must be a valid e-mail address or the term 'apikey'.`\n      : \"Value must be a valid e-mail address or the term 'apikey'.\"\n  );\n  return aValue;\n}\n\nexport function assertHasTrailingSlash(aValue: any): string {\n  Assert.ok(\n    isValidUrl(aValue) && hasTrailingSlash(aValue),\n    'URL [${aValue}] must end with a slash.'\n  );\n  return aValue;\n}\n","/* Copyright IBM Corp. 2018 */\n\n// regular expression to detect uuid.v4 strings\nconst HEX_REGEXP_STRING = '[0-9a-fA-F]';\nconst HOST_REGEXP_STRING = '[^\\\\.\\\\:]';\nconst UUID_V4_REGEXP_STRING =\n    `${HEX_REGEXP_STRING}{8}-${HEX_REGEXP_STRING}{4}-4${HEX_REGEXP_STRING}{3}-[89abAB]${HEX_REGEXP_STRING}{3}-${HEX_REGEXP_STRING}{12}`;\nconst TENANT_BASED_URL = `^(?:\\\\/api)?\\\\/(${UUID_V4_REGEXP_STRING})(?:\\\\/)?(?:.*)$`;\nexport const TENANT_BASED_URL_REGEXP = new RegExp(TENANT_BASED_URL);\n","/* Copyright IBM Corp. 2017 */\nimport { Observable, defer, from } from 'rxjs';\nimport { ajax, AjaxRequest } from 'rxjs/ajax';\nimport { pluck, map, tap } from 'rxjs/operators';\n\nconst createXHR = () => {\n  const XMLHttpRequest = require('xhr2');\n  return new XMLHttpRequest();\n};\n\nconst ajaxRequest = (req: AjaxRequest) =>\n  ajax({ ...req, responseType: 'text', createXHR }).pipe(\n    map(resp => resp.response as string)\n  );\n\nexport function rxGet(aUri: string): Observable<string> {\n  // setup the request\n  return ajaxRequest({\n    url: aUri\n  });\n}\n\nexport function rxGetJson(aUri: string): Observable<any> {\n  return rxGet(aUri).pipe(map(data => JSON.parse(data)));\n}\n\nexport function rxFormPost(aUri: string, aData: any): Observable<string> {\n  // setup the request\n  return ajaxRequest({\n    method: 'POST',\n    url: aUri,\n    body: aData\n  });\n}\n","import { Observable, Observer } from 'rxjs';\nimport { readFile } from 'fs';\n\nexport function rxReadFile(aPath: string): Observable<string> {\n  return Observable.create((observer: Observer<string>) => {\n    readFile(aPath, 'utf-8', (err, data) => {\n      if (err) {\n        observer.error(err);\n      } else {\n        observer.next(data);\n        observer.complete();\n      }\n    });\n  });\n}\n","import { exec } from 'child_process';\nimport { RSA_PKCS1_PADDING } from 'constants';\nimport {\n  privateDecrypt,\n  publicEncrypt,\n  RsaPrivateKey,\n  RsaPublicKey\n} from 'crypto';\nimport { cloneDeep, isString } from 'lodash';\nimport { homedir, platform } from 'os';\nimport { join, normalize } from 'path';\nimport { env } from 'process';\nimport { Observable, Observer, of } from 'rxjs';\nimport { catchError, map, mergeMap } from 'rxjs/operators';\nimport { parseKey } from 'sshpk';\n\nimport { assertHasTrailingSlash, isValidUserName } from './assert';\nimport { rxReadFile } from './rx.file';\nimport { ensureTrailingSlash } from './url.utils';\n\nexport { wchGetDeliveryUrlFromApiURL } from '@ibm-wch-sdk/utils';\n\nexport interface Credentials {\n  username: string;\n  password: string;\n}\n\nfunction _isValidCredential(aCred?: Credentials): boolean {\n  return !!(\n    aCred &&\n    isValidUserName(aCred.username) &&\n    isString(aCred.password)\n  );\n}\n\nfunction _emptyCredentials(): Credentials {\n  return {\n    username: '',\n    password: ''\n  };\n}\n\nfunction _createCredentials(aUserName: string, aPassword: string): Credentials {\n  return {\n    username: aUserName,\n    password: aPassword\n  };\n}\n\nfunction _getCredentialsFromEnvironment(): Credentials {\n  // access the credentials from the environment\n  const username = env['ibm_wch_sdk_cli_username'] || '';\n  const password = env['ibm_wch_sdk_cli_password'] || '';\n  // construct\n  return { username, password };\n}\n\n/**\n * Merge different credentials layers\n *\n * @param aBase         base layer\n * @param aOverride     override layer\n *\n * @return the merged credentials\n */\nfunction _mergeCredentials(\n  aBase: Credentials,\n  aOverride?: Credentials\n): Credentials {\n  // target\n  if (!aOverride) {\n    return aBase;\n  }\n  // clone\n  const cred = cloneDeep(aBase);\n  // override\n  if (!!aOverride.username) {\n    cred.username = aOverride.username;\n  }\n  if (!!aOverride.password) {\n    cred.password = aOverride.password;\n  }\n  // ok\n  return cred;\n}\n\nconst PADDING_MODE = RSA_PKCS1_PADDING;\n\nfunction _loadPrivateKey(): Observable<RsaPrivateKey> {\n  // filename\n  const name = join(homedir(), '.ssh', 'id_rsa');\n  return rxReadFile(name).pipe(map(key => ({ key, padding: PADDING_MODE })));\n}\n\nfunction _loadPublicKey(): Observable<RsaPublicKey> {\n  // filename\n  const name = join(homedir(), '.ssh', 'id_rsa.pub');\n  return rxReadFile(name).pipe(\n    map(key => parseKey(key, 'auto').toString('pkcs1')),\n    map(key => ({ key, padding: PADDING_MODE }))\n  );\n}\n\nconst ENCRYPTED_ENCODING = 'base64';\nconst DECTYPTED_ENCODING = 'utf8';\n\nfunction _encryptPassword(aPassword: string, aKey: RsaPublicKey): string {\n  // encrypt\n  return publicEncrypt(\n    aKey,\n    Buffer.from(aPassword, DECTYPTED_ENCODING)\n  ).toString(ENCRYPTED_ENCODING);\n}\n\nfunction _decryptPassword(aHash: string, aKey: RsaPrivateKey): string {\n  return privateDecrypt(aKey, Buffer.from(aHash, ENCRYPTED_ENCODING)).toString(\n    DECTYPTED_ENCODING\n  );\n}\n\nfunction _loadCredentials(aApiBase: string): Observable<Credentials> {\n  // validate the URL\n  assertHasTrailingSlash(aApiBase);\n  // credential file name\n  const filename = join(homedir(), '.ibm-wch-sdk-cli', '.credentials');\n  // read the credential\n  const key = _loadPrivateKey();\n  // load the file\n  return rxReadFile(filename).pipe(\n    map(data => JSON.parse(data)),\n    map(data => data[aApiBase]),\n    mergeMap(cred =>\n      key.pipe(\n        map(k => _decryptPassword(cred.password, k)),\n        map(p => {\n          cred.password = p;\n          return cred;\n        })\n      )\n    ),\n    catchError(() => of(_emptyCredentials()))\n  );\n}\n\nfunction _getWindowsCredentials(aApiUrl: string): Observable<Credentials> {\n  // validate the URL\n  assertHasTrailingSlash(aApiUrl);\n  // the executable\n  const path = normalize(\n    join(\n      __dirname,\n      '..',\n      '..',\n      '..',\n      'assets',\n      'credman',\n      process.arch,\n      'WchCredMan.exe'\n    )\n  );\n  // execute\n  const cmd = `\\\"${path}\\\" \\\"${aApiUrl}\\\"`;\n  // construct the observable\n  return Observable.create((observer: Observer<Credentials>) => {\n    // execute the command\n    exec(\n      cmd,\n      {\n        encoding: 'utf8'\n      },\n      (error, stdout, stderr) => {\n        if (error) {\n          observer.error(error);\n        } else {\n          try {\n            // parse\n            observer.next(JSON.parse(stdout));\n            observer.complete();\n          } catch (e) {\n            observer.error(e);\n          }\n        }\n      }\n    );\n  });\n}\n\nfunction _getStoredCredentials(aApiUrl: string): Observable<Credentials> {\n  // the key\n  const key = ensureTrailingSlash(aApiUrl);\n  // normalize the URL\n  if (platform() === 'win32') {\n    // load the credentials module\n    return _getWindowsCredentials(key).pipe(\n      mergeMap(\n        (cred: Credentials) =>\n          _isValidCredential(cred) ? of(cred) : _loadCredentials(key)\n      ),\n      catchError(() => _loadCredentials(key))\n    );\n  }\n  // linux like fallback\n  return _loadCredentials(key);\n}\n\nexport function wchToolsGetCredentials(\n  aApiUrl: string\n): Observable<Credentials> {\n  // return\n  return _getStoredCredentials(aApiUrl).pipe(\n    map(cred => _mergeCredentials(_getCredentialsFromEnvironment(), cred)),\n    catchError(err => of(_getCredentialsFromEnvironment()))\n  );\n}\n","import { assertObject, isNil } from '@ibm-wch-sdk/utils';\nimport { readFile } from 'fs';\nimport { join, parse } from 'path';\nimport { bindNodeCallback, Observable } from 'rxjs';\nimport { catchError, map } from 'rxjs/operators';\nimport { satisfies } from 'semver';\n\nexport enum DEP_TYPE {\n  PEER,\n  RUNTIME,\n  DEVELOPMENT\n}\n\nexport function getFolderForType(aType?: DEP_TYPE): string {\n  return aType === DEP_TYPE.PEER\n    ? 'peerDependencies'\n    : aType === DEP_TYPE.DEVELOPMENT\n      ? 'devDependencies'\n      : 'dependencies';\n}\n\n/**\n * Updates the package JSON to use at least the given version\n *\n * @param aName     name\n * @param aMinVersion   min version\n * @param aPkg  package\n */\nexport function updateMinVersion(\n  aName: string,\n  aMinVersion: string,\n  aPkg: any,\n  aType?: DEP_TYPE\n): any {\n  // check if we have a version identifier\n  const folder = getFolderForType(aType);\n  // access\n  const deps = assertObject(folder, aPkg) as any;\n  const oldDep = deps[aName];\n  if (isNil(oldDep) || !satisfies(aMinVersion, oldDep)) {\n    // just update\n    deps[aName] = `^${aMinVersion}`;\n  }\n  // ok\n  return aPkg;\n}\n\nconst rxReadFile = bindNodeCallback<string, string, string>(readFile);\n\nexport function findPackageJson(aDir: string): Observable<any> {\n  // read\n  return rxReadFile(join(aDir, 'package.json'), 'utf-8').pipe(\n    map(data => JSON.parse(data)),\n    catchError(err => findPackageJson(parse(aDir).dir))\n  );\n}\n","import { Path, resolve } from '@angular-devkit/core';\nimport { Tree } from '@angular-devkit/schematics';\nimport { coerce } from 'semver';\nimport {\n  KEY_BASICAUTH_LOGIN_PASSWORD,\n  KEY_BASICAUTH_LOGIN_USERNAME,\n  REL_PATH_BASICAUTH_LOGIN,\n  REL_PATH_CURRENT_USER\n} from '@ibm-wch-sdk/api';\nimport { isNil, isNotNil, assertArray } from '@ibm-wch-sdk/utils';\nimport { Observable, of, throwError } from 'rxjs';\nimport {\n  catchError,\n  map,\n  mapTo,\n  pluck,\n  switchMap,\n  switchMapTo\n} from 'rxjs/operators';\nimport { isUri } from 'valid-url';\nimport { VError } from 'verror';\n\nimport { findPackageJson } from './../package';\nimport { isValidUserName } from './assert';\nimport { rxFormPost, rxGetJson } from './rx.request';\nimport { ensureTrailingSlash } from './url.utils';\nimport { Credentials, wchToolsGetCredentials } from './wchtools';\n\nfunction _isApiKey(aName: string): boolean {\n  return aName === 'apikey';\n}\n\nfunction _isValidPassword(aPassword: string): boolean {\n  return aPassword && aPassword.length > 0;\n}\n\nfunction _throwInvalidUrl(aApiUrl: string, aError: Error): Observable<never> {\n  return throwError(\n    new VError(aError, 'The API URL [%s] is not a valid WCH API URL.', aApiUrl)\n  );\n}\n\nfunction _getCurrentUser(aApiUrl: string): Observable<any> {\n  // the URL\n  const currentUserUrl = `${aApiUrl}${REL_PATH_CURRENT_USER}`;\n  return rxGetJson(currentUserUrl).pipe(\n    catchError(error => _throwInvalidUrl(aApiUrl, error))\n  );\n}\n\nfunction _throwInvalidCredentials(aApiUrl: string): Observable<never> {\n  return throwError(\n    new VError(\n      'Unable to access credentials for the API URL [%s]. Please follow the directions on https://www.npmjs.com/package/ibm-wch-sdk-cli#credential-management to register credentials.',\n      aApiUrl\n    )\n  );\n}\n\nexport function validateCredentials(\n  aApiUrl: string,\n  aCredentials: Credentials\n): Observable<string> {\n  // check the credentials object\n  if (\n    !aCredentials ||\n    !isValidUserName(aCredentials.username) ||\n    !_isValidPassword(aCredentials.password)\n  ) {\n    return _throwInvalidCredentials(aApiUrl);\n  }\n  // test if we can login\n  const loginUrl = `${aApiUrl}${REL_PATH_BASICAUTH_LOGIN}`;\n  const body = {\n    [KEY_BASICAUTH_LOGIN_USERNAME]: aCredentials.username,\n    [KEY_BASICAUTH_LOGIN_PASSWORD]: aCredentials.password\n  };\n  // execute\n  return rxFormPost(loginUrl, body).pipe(\n    map(data => JSON.parse(data)),\n    catchError(error =>\n      throwError(\n        new VError(\n          error,\n          'Unable to login to [%s] with user [%s]. Please check your registered password.',\n          loginUrl,\n          aCredentials.username\n        )\n      )\n    ),\n    mapTo(aApiUrl)\n  );\n}\n\nfunction _validateUser(aFeed: any): Observable<any> {\n  // test the feed result\n  if (!aFeed || !aFeed.externalId) {\n    return throwError(new VError('Invalid currentuser response'));\n  }\n  return of(aFeed);\n}\n\n/**\n * Tests if  the API URL is valid and if we have sufficient credentials to access the API\n *\n * @param aUrl  the API URL\n * @return the url\n */\nexport function validateApiUrl(\n  aUrl: string,\n  bValidateWithCredentials: boolean\n): Observable<string> {\n  // check if the URL is valud\n  if (!isUri(aUrl)) {\n    return throwError(\n      new VError(\n        'Please enter a valid API URL. Copy this URL from the \"Hub Information\" section of your WCH tenant.'\n      )\n    );\n  }\n  // check if the URL is valid\n  const normUrl = ensureTrailingSlash(aUrl);\n\n  if (bValidateWithCredentials) {\n    // load the credentials\n    const onCredentials = wchToolsGetCredentials(normUrl).pipe(\n      catchError(error => _throwInvalidCredentials(normUrl))\n    );\n\n    // check if the URL exists\n    const onValidUrl: Observable<string> = _getCurrentUser(normUrl).pipe(\n      switchMap(_validateUser),\n      switchMapTo(onCredentials),\n      switchMap(cred => validateCredentials(normUrl, cred))\n    );\n    // ok\n    return onValidUrl;\n  } else {\n    // check if the URL exists\n    const onValidUrl: Observable<string> = _getCurrentUser(normUrl).pipe(\n      switchMap(_validateUser),\n      mapTo(normUrl)\n    );\n    // ok\n    return onValidUrl;\n  }\n}\n\nconst PACKAGE_JSON = '/package.json' as Path;\nconst FALLBACK = '/data' as Path;\n\nconst OPTIONS = '.wchtoolsoptions.json' as Path;\n\nconst SDK_IMPORT = '@ibm-wch-sdk/ng';\nconst CLI_IMPORT = '@ibm-wch-sdk/cli';\n\nexport const WCHTOOLS_DEPENDENCIES = 'wchtools-dependencies';\n\nfunction _findBuildVersion(): Observable<string> {\n  // find the package\n  return findPackageJson(__dirname).pipe(pluck<any, string>('version'));\n}\n\n/**\n * Decode the version from the dependency\n *\n * @param aVersion  the version\n *\n * @return observable of the version\n */\nfunction _fromDependency(aVersion: string): Observable<string> {\n  const parsed = coerce(aVersion);\n  return !!parsed ? of(parsed.version) : _findBuildVersion();\n}\n\nexport function findSdkVersion(host: Tree): Observable<string> {\n  // try to locate the package json\n  const buf = host.read(PACKAGE_JSON);\n  if (isNil(buf)) {\n    return _findBuildVersion();\n  }\n  // source package\n  const pkg = JSON.parse(buf.toString());\n  // check if we have imports\n  const deps = pkg.dependencies || {};\n  const devDeps = pkg.devDependencies || {};\n\n  const fromPkg = deps[SDK_IMPORT] || devDeps[CLI_IMPORT];\n\n  return isNotNil(fromPkg) ? _fromDependency(fromPkg) : _findBuildVersion();\n}\n\nexport function findDataDir(host: Tree): Path {\n  const buf = host.read(PACKAGE_JSON);\n  if (isNil(buf)) {\n    return FALLBACK;\n  }\n\n  const pkg = JSON.parse(buf.toString());\n  const cfg = pkg.config || {};\n\n  const data = cfg.data || FALLBACK;\n\n  return resolve('/' as Path, data);\n}\n\nexport function findWchToolsOptions(host: Tree): Path {\n  return resolve(findDataDir(host), OPTIONS);\n}\n\nexport function addToWchToolsDependencies(aDeps: string[], aPkg: any) {\n  // add the key\n  const deps = assertArray<string>(WCHTOOLS_DEPENDENCIES, aPkg);\n  // filter\n  deps.push(...aDeps.filter(dep => deps.indexOf(dep) < 0));\n}\n","import { Generator, isArray, isNil, isPlainObject } from '@ibm-wch-sdk/utils';\n\nconst _keys = Object.keys;\n\nconst KEY_WEIGHTS: { [key: string]: number } = {\n  name: 1,\n  description: 2,\n  id: 3,\n  classification: 4\n};\n\nfunction _compareNumber(aLeft: number, aRight: number): number {\n  return aLeft < aRight ? -1 : aLeft > aRight ? +1 : 0;\n}\n\nfunction _getKey(aName: string): number {\n  return KEY_WEIGHTS[aName] || Number.MAX_SAFE_INTEGER;\n}\n\nfunction _compareName(aLeft: string, aRight: string): number {\n  // first by key\n  let c = _compareNumber(_getKey(aLeft), _getKey(aRight));\n  if (c === 0) {\n    c = aLeft.localeCompare(aRight);\n  }\n  // ok\n  return c;\n}\n\nfunction _canonicalize(aData: any): any {\n  // handle\n  if (isArray(aData)) {\n    const copy: any[] = [];\n    aData.forEach(v => copy.push(_canonicalize(v)));\n    return copy;\n  }\n  if (isPlainObject(aData)) {\n    // sort the keys\n    const copy: any = {};\n    _keys(aData)\n      .sort(_compareName)\n      .forEach(k => (copy[k] = _canonicalize(aData[k])));\n    return copy;\n  }\n  // nothing to do\n  return aData;\n}\n\nexport function serializeJson(aData: any): string | undefined {\n  return aData ? JSON.stringify(aData, undefined, 2) : undefined;\n}\n\nexport function updateField(\n  aName: string,\n  aGenerator: Generator<string>,\n  aObj: any\n): any {\n  const oldValue = aObj[aName];\n  if (isNil(oldValue)) {\n    // update with the generated value\n    aObj[aName] = aGenerator();\n  }\n  return aObj;\n}\n\nexport { _canonicalize as canonicalizeJSON };\n","export function serializeLines(aSource?: string[]): string | undefined {\n  return aSource ? aSource.join('\\n') : undefined;\n}\n\nexport function parseLines(aSource?: string): string[] {\n  return aSource ? aSource.split('\\n') : [];\n}\n\nexport function insertLines(\n  aSource: string[] | undefined,\n  aInsert: string[]\n): string[] {\n  if (aSource) {\n    // build the set\n    const existing = new Set<string>(aSource);\n\n    return [...aSource, ...aInsert.filter(line => !existing.has(line))];\n  } else {\n    // just insert into the empty file\n    return [...aInsert];\n  }\n}\n","import { Tree } from '@angular-devkit/schematics';\nimport { isNotNil } from '@ibm-wch-sdk/utils';\nimport { Observable, UnaryFunction } from 'rxjs';\nimport { first, map, mapTo } from 'rxjs/operators';\n\nimport { canonicalizeJSON, serializeJson } from './json';\nimport { parseLines, serializeLines } from './../text/lines';\n\nexport interface TransformWithPath<T> {\n  (aSource: T | undefined, aPath: string): Observable<T | undefined>;\n}\n\nexport interface TransformWithoutPath<T> {\n  (aSource: T | undefined): Observable<T | undefined>;\n}\n\nexport type TransformCallback<T> =\n  | TransformWithPath<T>\n  | TransformWithoutPath<T>;\n\n/**\n * Reads a text file from the tree and then transforms it using the given function. If the result\n * is null or undefined, the file will be deleted, else replaced or created.\n *\n * @param aName   name of the file\n * @param aOp     the operator\n * @param aTree   the tree to work in\n */\nexport function rxTransformTextFile(\n  aName: string,\n  aOp: TransformCallback<string>,\n  aTree: Tree\n): Observable<string> {\n  // load the file if it exists\n  const buffer = aTree.read(aName);\n  const value = isNotNil(buffer) ? buffer.toString() : null;\n  const op: TransformWithPath<string> = aOp as any;\n  // replace\n  return op(value, aName).pipe(\n    first(),\n    map(\n      result =>\n        isNotNil(result)\n          ? isNotNil(buffer)\n            ? aTree.overwrite(aName, result)\n            : aTree.create(aName, result)\n          : isNotNil(buffer)\n            ? aTree.delete(aName)\n            : undefined\n    ),\n    mapTo(aName)\n  );\n}\n\n/**\n * Reads a JSON file from the tree and then transforms it using the given function. If the result\n * is null or undefined, the file will be deleted, else replaced or created.\n *\n * @param aName   name of the file\n * @param aOp     the operator\n * @param aTree   the tree to work in\n */\nexport function rxTransformJsonFile(\n  aName: string,\n  aOp: TransformCallback<any>,\n  aTree: Tree\n): Observable<string> {\n  // cast\n  const op: TransformWithPath<any> = aOp as any;\n  // dispatch\n  return rxTransformTextFile(\n    aName,\n    (textContent, path) =>\n      op(textContent ? JSON.parse(textContent) : undefined, path).pipe(\n        map(canonicalizeJSON),\n        map(serializeJson)\n      ),\n    aTree\n  );\n}\n\n/**\n * Reads a line based file from the tree and then transforms it using the given function. If the result\n * is null or undefined, the file will be deleted, else replaced or created.\n *\n * @param aName   name of the file\n * @param aOp     the operator\n * @param aTree   the tree to work in\n */\nexport function rxTransformLinesFile(\n  aName: string,\n  aOp: TransformCallback<string[]>,\n  aTree: Tree\n): Observable<string> {\n  // cast\n  const op: TransformWithPath<string[]> = aOp as any;\n  // dispatch\n  return rxTransformTextFile(\n    aName,\n    (textContent, path) =>\n      op(textContent ? parseLines(textContent) : undefined, path).pipe(\n        map(serializeLines)\n      ),\n    aTree\n  );\n}\n","/* Copyright IBM Corp. 2018 */\nimport { Tree } from '@angular-devkit/schematics';\nimport { join, normalize } from 'path';\nimport { get } from 'request';\nimport { defer, fromEvent, Observable, of } from 'rxjs';\nimport {\n  filter,\n  first,\n  map,\n  mapTo,\n  mergeMap,\n  takeUntil,\n  tap\n} from 'rxjs/operators';\nimport { Writable } from 'stream';\nimport { Entry, Parse } from 'unzip';\n\nfunction _skipPrefix(aName: string, aCount: number): string | null {\n  // current name\n  let idx = 0;\n  for (let i = 0; i < aCount; ++i) {\n    // find the next separator\n    const nextIdx = aName.indexOf('/', idx);\n    if (nextIdx >= idx) {\n      idx = nextIdx + 1;\n    } else {\n      return null;\n    }\n  }\n  // split\n  return aName.substring(idx);\n}\n\nclass StreamOnBuffer extends Writable {\n  buffers: Buffer[] = [];\n\n  _write(chunk: any, encoding: string, callback: (err?: Error) => void) {\n    this.buffers.push(chunk);\n    callback();\n  }\n\n  _final(callback: Function) {\n    callback();\n    this.emit('close');\n  }\n}\n\nfunction _rxExtractEntry(\n  aTree: Tree,\n  aEntry: Entry,\n  aDstDir: string,\n  aSkip: number\n): Observable<string> {\n  // skip the prefix\n  const path = _skipPrefix(aEntry.path, aSkip);\n  if (!path) {\n    // nothing\n    return of('').pipe(\n      tap(() => aEntry.autodrain()),\n      filter(() => false)\n    );\n  }\n  // create filename\n  const fileName = normalize(join(aDstDir, path));\n  // handle directories\n  if (aEntry.type === 'Directory') {\n    // create the directory\n    return of('').pipe(\n      tap(() => aEntry.autodrain()),\n      filter(() => false)\n    );\n  } else {\n    // construct the stream\n    const stream = aEntry.pipe(new StreamOnBuffer());\n    // attach\n    return fromEvent(stream, 'close').pipe(\n      // just take one\n      first(),\n      // copy into the tree\n      map(() => aTree.create(fileName, Buffer.concat(stream.buffers))),\n      // map to the target name\n      mapTo(fileName)\n    );\n  }\n}\n\nexport function rxUnzipFromUrl(\n  aTree: Tree,\n  aSrcUrl: string,\n  aDstDir: string,\n  aSkip: number = 0\n): Observable<string> {\n  // defer\n  return defer(() => {\n    // construct the stream\n    const stream = get(aSrcUrl).pipe(Parse());\n    // handle\n    const onEntry = fromEvent<Entry>(stream, 'entry');\n    const onClose = fromEvent(stream, 'close');\n    // return the full stream\n    return onEntry.pipe(\n      takeUntil(onClose),\n      mergeMap(entry => _rxExtractEntry(aTree, entry, aDstDir, aSkip))\n    );\n  });\n}\n","import { Tree } from '@angular-devkit/schematics/src/tree/interface';\nimport { isNotNil } from '@ibm-wch-sdk/utils';\nimport { load } from 'cheerio';\nimport { Observable, of } from 'rxjs';\nimport { switchMap } from 'rxjs/operators';\n\nimport { rxTransformTextFile, TransformCallback, TransformWithPath } from './rx.tree';\n\nfunction _parseHtml(aString?: string): Observable<CheerioStatic> {\n  return of(load(isNotNil(aString) ? aString! : ''));\n}\n\nfunction _serializeHtml(aHtml: CheerioStatic): Observable<string> {\n  return of(aHtml!.html());\n}\n\n/**\n * Reads an HMTL from the tree and then transforms it using the given function. If the result\n * is null or undefined, the file will be deleted, else replaced or created.\n *\n * @param aName   name of the file\n * @param aOp     the operator\n * @param aTree   the tree to work in\n */\nexport function rxTransformHtmlFile(\n  aName: string,\n  aOp: TransformCallback<CheerioStatic>,\n  aTree: Tree\n): Observable<string> {\n  // cast\n  const op: TransformWithPath<CheerioStatic> = aOp as any;\n  // dispatch\n  return rxTransformTextFile(\n    aName,\n    (textContent, path) =>\n      _parseHtml(textContent).pipe(\n        switchMap(html => op(html, path)),\n        switchMap(_serializeHtml)\n      ),\n    aTree\n  );\n}\n","import { SchematicsException, Tree } from '@angular-devkit/schematics';\nimport { createSourceFile, ScriptTarget, SourceFile } from 'typescript';\n\nexport function getSourceFile(host: Tree, path: string): SourceFile {\n  const buffer = host.read(path);\n  if (!buffer) {\n    throw new SchematicsException(`Could not find ${path}.`);\n  }\n  const content = buffer.toString();\n  const source = createSourceFile(path, content, ScriptTarget.Latest, true);\n\n  return source;\n}\n","import { Tree, UpdateRecorder } from '@angular-devkit/schematics';\nimport { SourceFile } from 'typescript';\n\nimport {\n  addImportToModule,\n  Change,\n  InsertChange,\n  RemoveChange,\n  ReplaceChange\n} from './../utility';\nimport { getSourceFile } from './source';\n\nexport function insertChanges(aChanges: Change[], aRecorder: UpdateRecorder) {\n  aChanges.forEach((change: Change) => {\n    // delete\n    if (change instanceof InsertChange) {\n      aRecorder.insertLeft(change.pos, change.toAdd);\n    } else if (change instanceof RemoveChange) {\n    } else if (change instanceof ReplaceChange) {\n      // remove old chunk\n      const anyChange = change as any;\n      aRecorder.remove(anyChange.pos, anyChange.oldText.length);\n      aRecorder.insertLeft(anyChange.pos, anyChange.newText);\n    }\n  });\n}\n\nexport function changeSourceFile(\n  aFile: string,\n  aOp: (aFile: string, aContent: SourceFile) => Change[],\n  aHost: Tree\n) {\n  // make sure at least an empty file exists\n  if (!aHost.exists(aFile)) {\n    aHost.create(aFile, '');\n  }\n\n  // update\n  const recorder = aHost.beginUpdate(aFile);\n  insertChanges(aOp(aFile, getSourceFile(aHost, aFile)), recorder);\n\n  aHost.commitUpdate(recorder);\n}\n\n/**\n * Changes the identified module by adding a couple of imports\n *\n * @param aFile the filename\n * @param aModules the modules to be added\n * @param aHost the tree\n */\nexport function addImportsToModule(\n  aFile: string,\n  aModules: { [identifier: string]: string },\n  aHost: Tree\n) {\n  // iterate\n  Object.keys(aModules).forEach(name =>\n    changeSourceFile(\n      aFile,\n      (file, content) => addImportToModule(content, file, name, aModules[name]),\n      aHost\n    )\n  );\n}\n","import { Predicate } from '@ibm-wch-sdk/utils';\nimport { NamedDeclaration, Node, SyntaxKind } from 'typescript';\n\nexport function byType(aType: SyntaxKind): Predicate<Node> {\n  return node => node && node.kind === aType;\n}\n\nexport function byText(aText: string): Predicate<Node> {\n  return node => node && node.getText() === aText;\n}\n\nexport function byName(aText: string): Predicate<NamedDeclaration> {\n  return node => !!(node && node.name && node.name.getText() === aText);\n}\n\nexport function byTypeAndName(\n  aType: SyntaxKind,\n  aName: string\n): Predicate<Node> {\n  return node => node && node.kind === aType && node.getText() === aName;\n}\n\nexport function byIdentifier(aName: string): Predicate<Node> {\n  return byTypeAndName(SyntaxKind.Identifier, aName);\n}\n"],"names":["ts.SyntaxKind","tslib_1.__values","ts.forEachChild","first","tslib_1.__spread","ts.isClassDeclaration","ts.createSourceFile","ts.ScriptTarget","dirname","Assert.ok","isString","validateEmail","hasTrailingSlash","join","normalize","ensureTrailingSlash","rxReadFile","canonicalizeJSON","tslib_1.__extends"],"mappings":"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"}
\No newline at end of file