1 | import { join, normalize, relative, strings, JsonParseMode, parseJson, basename, dirname as dirname$1, tags, resolve } from '@angular-devkit/core';
|
2 | import { __values, __spread, __makeTemplateObject, __assign, __extends } from 'tslib';
|
3 | import { SyntaxKind, forEachChild, isClassDeclaration, createSourceFile, ScriptTarget } from 'typescript';
|
4 | import { SchematicsException } from '@angular-devkit/schematics';
|
5 | import { dirname, join as join$1, normalize as normalize$1, parse } from 'path';
|
6 | import { isString, cloneDeep } from 'lodash';
|
7 | import { isString as isString$1, assertObject, isNil, isNotNil, assertArray, isArray, isPlainObject } from '@ibm-wch-sdk/utils';
|
8 | export { wchGetDeliveryUrlFromApiURL } from '@ibm-wch-sdk/utils';
|
9 | import { ok } from 'assert';
|
10 | import { validate } from 'email-validator';
|
11 | import { isWebUri, isUri } from 'valid-url';
|
12 | import { ajax } from 'rxjs/ajax';
|
13 | import { map, catchError, mergeMap, mapTo, pluck, switchMap, switchMapTo, first, filter, takeUntil, tap } from 'rxjs/operators';
|
14 | import { Observable, of, bindNodeCallback, throwError, defer, fromEvent } from 'rxjs';
|
15 | import { readFile } from 'fs';
|
16 | import { exec } from 'child_process';
|
17 | import { RSA_PKCS1_PADDING } from 'constants';
|
18 | import { privateDecrypt } from 'crypto';
|
19 | import { homedir, platform } from 'os';
|
20 | import { env } from 'process';
|
21 | import 'sshpk';
|
22 | import { satisfies, coerce } from 'semver';
|
23 | import { KEY_BASICAUTH_LOGIN_PASSWORD, KEY_BASICAUTH_LOGIN_USERNAME, REL_PATH_BASICAUTH_LOGIN, REL_PATH_CURRENT_USER } from '@ibm-wch-sdk/api';
|
24 | import { VError } from 'verror';
|
25 | import { get } from 'request';
|
26 | import { Writable } from 'stream';
|
27 | import { Parse } from 'unzip';
|
28 | import { 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 | */
|
40 | function 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 | */
|
78 | function 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 | */
|
106 | function 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 | */
|
141 | var /**
|
142 | * An operation that does nothing.
|
143 | */
|
144 | NoopChange = /** @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 | */
|
162 | var /**
|
163 | * Will add text to the source code.
|
164 | */
|
165 | InsertChange = /** @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 | */
|
204 | var /**
|
205 | * Will remove text from the source code.
|
206 | */
|
207 | RemoveChange = /** @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 | */
|
242 | var /**
|
243 | * Will replace text from the source code.
|
244 | */
|
245 | ReplaceChange = /** @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 | */
|
298 | function 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 | */
|
366 | function 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 | */
|
408 | function 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 | */
|
431 | function 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 | */
|
449 | function 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 | */
|
465 | function 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 | */
|
488 | function 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 | */
|
504 | function _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 | */
|
560 | function 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 | */
|
619 | function 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 | */
|
631 | function 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 | */
|
653 | function 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 | */
|
803 | function 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 | */
|
814 | function 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 | */
|
825 | function 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 | */
|
836 | function 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 | */
|
847 | function 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 | */
|
858 | function 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 | */
|
868 | function 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 | */
|
899 | function 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 | */
|
910 | function 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 | */
|
928 | function 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 {?} */
|
943 | var configPath = '/.angular-cli.json';
|
944 | /**
|
945 | * @param {?} host
|
946 | * @return {?}
|
947 | */
|
948 | function 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 | */
|
963 | function 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 | */
|
982 | function 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 | */
|
1030 | function 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 | */
|
1067 | function 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 | */
|
1086 | function 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 | */
|
1105 | function 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 {?} */
|
1111 | var htmlSelectorRe = /^[a-zA-Z][.0-9a-zA-Z]*(:?-[a-zA-Z][.0-9a-zA-Z]*)*$/;
|
1112 | /**
|
1113 | * @param {?} selector
|
1114 | * @return {?}
|
1115 | */
|
1116 | function 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 | */
|
1125 | function 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 | */
|
1150 | function 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 | }
|
1174 | var 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 | */
|
1189 | function _ensureTrailingSlash(aUrl) {
|
1190 | return aUrl.endsWith('/') ? aUrl : aUrl + '/';
|
1191 | }
|
1192 | /**
|
1193 | * @param {?} aUrl
|
1194 | * @return {?}
|
1195 | */
|
1196 | function _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 | */
|
1209 | function 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 | */
|
1219 | function assertParameter(aValue, aParameterName) {
|
1220 | ok(!!aValue, "Please specify the '--" + aParameterName + "' parameter.");
|
1221 | }
|
1222 | /**
|
1223 | * @param {?} aValue
|
1224 | * @return {?}
|
1225 | */
|
1226 | function isValidUrl(aValue) {
|
1227 | return isString$1(aValue) && !!isWebUri(aValue);
|
1228 | }
|
1229 | /**
|
1230 | * @param {?} aValue
|
1231 | * @param {?=} aName
|
1232 | * @return {?}
|
1233 | */
|
1234 | function 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 | */
|
1244 | function isValidEmail(aValue) {
|
1245 | return isString$1(aValue) && !!validate(aValue);
|
1246 | }
|
1247 | /**
|
1248 | * @param {?} aValue
|
1249 | * @return {?}
|
1250 | */
|
1251 | function isValidUserName(aValue) {
|
1252 | return isString$1(aValue) && (!!validate(aValue) || aValue === 'apikey');
|
1253 | }
|
1254 | /**
|
1255 | * @param {?} aValue
|
1256 | * @param {?=} aName
|
1257 | * @return {?}
|
1258 | */
|
1259 | function 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 | */
|
1270 | function 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 | */
|
1280 | function 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 {?} */
|
1291 | var HEX_REGEXP_STRING = '[0-9a-fA-F]';
|
1292 | /** @type {?} */
|
1293 | var 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 {?} */
|
1295 | var TENANT_BASED_URL = "^(?:\\/api)?\\/(" + UUID_V4_REGEXP_STRING + ")(?:\\/)?(?:.*)$";
|
1296 | /** @type {?} */
|
1297 | var 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 {?} */
|
1304 | var createXHR = function () {
|
1305 | /** @type {?} */
|
1306 | var XMLHttpRequest = require('xhr2');
|
1307 | return new XMLHttpRequest();
|
1308 | };
|
1309 | /** @type {?} */
|
1310 | var 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 | */
|
1317 | function rxGet(aUri) {
|
1318 | // setup the request
|
1319 | return ajaxRequest({
|
1320 | url: aUri
|
1321 | });
|
1322 | }
|
1323 | /**
|
1324 | * @param {?} aUri
|
1325 | * @return {?}
|
1326 | */
|
1327 | function 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 | */
|
1335 | function 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 | */
|
1352 | function 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 | */
|
1374 | function _isValidCredential(aCred) {
|
1375 | return !!(aCred &&
|
1376 | isValidUserName(aCred.username) &&
|
1377 | isString(aCred.password));
|
1378 | }
|
1379 | /**
|
1380 | * @return {?}
|
1381 | */
|
1382 | function _emptyCredentials() {
|
1383 | return {
|
1384 | username: '',
|
1385 | password: ''
|
1386 | };
|
1387 | }
|
1388 | /**
|
1389 | * @return {?}
|
1390 | */
|
1391 | function _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 | */
|
1407 | function _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 {?} */
|
1425 | var PADDING_MODE = RSA_PKCS1_PADDING;
|
1426 | /**
|
1427 | * @return {?}
|
1428 | */
|
1429 | function _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 {?} */
|
1435 | var ENCRYPTED_ENCODING = 'base64';
|
1436 | /** @type {?} */
|
1437 | var DECTYPTED_ENCODING = 'utf8';
|
1438 | /**
|
1439 | * @param {?} aHash
|
1440 | * @param {?} aKey
|
1441 | * @return {?}
|
1442 | */
|
1443 | function _decryptPassword(aHash, aKey) {
|
1444 | return privateDecrypt(aKey, Buffer.from(aHash, ENCRYPTED_ENCODING)).toString(DECTYPTED_ENCODING);
|
1445 | }
|
1446 | /**
|
1447 | * @param {?} aApiBase
|
1448 | * @return {?}
|
1449 | */
|
1450 | function _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 | */
|
1469 | function _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 | */
|
1502 | function _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 | */
|
1519 | function 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} */
|
1529 | var DEP_TYPE = {
|
1530 | PEER: 0,
|
1531 | RUNTIME: 1,
|
1532 | DEVELOPMENT: 2,
|
1533 | };
|
1534 | DEP_TYPE[DEP_TYPE.PEER] = 'PEER';
|
1535 | DEP_TYPE[DEP_TYPE.RUNTIME] = 'RUNTIME';
|
1536 | DEP_TYPE[DEP_TYPE.DEVELOPMENT] = 'DEVELOPMENT';
|
1537 | /**
|
1538 | * @param {?=} aType
|
1539 | * @return {?}
|
1540 | */
|
1541 | function 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 | */
|
1557 | function 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 {?} */
|
1572 | var rxReadFile$1 = bindNodeCallback(readFile);
|
1573 | /**
|
1574 | * @param {?} aDir
|
1575 | * @return {?}
|
1576 | */
|
1577 | function 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 | */
|
1595 | function _isValidPassword(aPassword) {
|
1596 | return aPassword && aPassword.length > 0;
|
1597 | }
|
1598 | /**
|
1599 | * @param {?} aApiUrl
|
1600 | * @param {?} aError
|
1601 | * @return {?}
|
1602 | */
|
1603 | function _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 | */
|
1610 | function _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 | */
|
1619 | function _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 | */
|
1627 | function 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 | */
|
1651 | function _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 | */
|
1665 | function 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 {?} */
|
1688 | var PACKAGE_JSON = /** @type {?} */ ('/package.json');
|
1689 | /** @type {?} */
|
1690 | var FALLBACK = /** @type {?} */ ('/data');
|
1691 | /** @type {?} */
|
1692 | var OPTIONS = /** @type {?} */ ('.wchtoolsoptions.json');
|
1693 | /** @type {?} */
|
1694 | var SDK_IMPORT = '@ibm-wch-sdk/ng';
|
1695 | /** @type {?} */
|
1696 | var CLI_IMPORT = '@ibm-wch-sdk/cli';
|
1697 | /** @type {?} */
|
1698 | var WCHTOOLS_DEPENDENCIES = 'wchtools-dependencies';
|
1699 | /**
|
1700 | * @return {?}
|
1701 | */
|
1702 | function _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 | */
|
1713 | function _fromDependency(aVersion) {
|
1714 | /** @type {?} */
|
1715 | var parsed = coerce(aVersion);
|
1716 | return !!parsed ? of(parsed.version) : _findBuildVersion();
|
1717 | }
|
1718 | /**
|
1719 | * @param {?} host
|
1720 | * @return {?}
|
1721 | */
|
1722 | function 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 | */
|
1742 | function 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 | */
|
1760 | function findWchToolsOptions(host) {
|
1761 | return resolve(findDataDir(host), OPTIONS);
|
1762 | }
|
1763 | /**
|
1764 | * @param {?} aDeps
|
1765 | * @param {?} aPkg
|
1766 | * @return {?}
|
1767 | */
|
1768 | function 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 {?} */
|
1780 | var _keys = Object.keys;
|
1781 | /** @type {?} */
|
1782 | var 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 | */
|
1793 | function _compareNumber(aLeft, aRight) {
|
1794 | return aLeft < aRight ? -1 : aLeft > aRight ? +1 : 0;
|
1795 | }
|
1796 | /**
|
1797 | * @param {?} aName
|
1798 | * @return {?}
|
1799 | */
|
1800 | function _getKey(aName) {
|
1801 | return KEY_WEIGHTS[aName] || Number.MAX_SAFE_INTEGER;
|
1802 | }
|
1803 | /**
|
1804 | * @param {?} aLeft
|
1805 | * @param {?} aRight
|
1806 | * @return {?}
|
1807 | */
|
1808 | function _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 | */
|
1821 | function _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 | */
|
1844 | function 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 | */
|
1853 | function 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 | */
|
1871 | function serializeLines(aSource) {
|
1872 | return aSource ? aSource.join('\n') : undefined;
|
1873 | }
|
1874 | /**
|
1875 | * @param {?=} aSource
|
1876 | * @return {?}
|
1877 | */
|
1878 | function parseLines(aSource) {
|
1879 | return aSource ? aSource.split('\n') : [];
|
1880 | }
|
1881 | /**
|
1882 | * @param {?} aSource
|
1883 | * @param {?} aInsert
|
1884 | * @return {?}
|
1885 | */
|
1886 | function 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 | */
|
1911 | function 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 | */
|
1938 | function 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 | */
|
1955 | function 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 | */
|
1973 | function _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 | }
|
1989 | var 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 | */
|
2033 | function _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 | */
|
2067 | function 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 | */
|
2090 | function _parseHtml(aString) {
|
2091 | return of(load(isNotNil(aString) ? /** @type {?} */ ((aString)) : ''));
|
2092 | }
|
2093 | /**
|
2094 | * @param {?} aHtml
|
2095 | * @return {?}
|
2096 | */
|
2097 | function _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 | */
|
2109 | function 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 | */
|
2132 | function 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 | */
|
2154 | function 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 | */
|
2175 | function 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 | */
|
2193 | function 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 | */
|
2208 | function byType(aType) {
|
2209 | return function (node) { return node && node.kind === aType; };
|
2210 | }
|
2211 | /**
|
2212 | * @param {?} aText
|
2213 | * @return {?}
|
2214 | */
|
2215 | function byText(aText) {
|
2216 | return function (node) { return node && node.getText() === aText; };
|
2217 | }
|
2218 | /**
|
2219 | * @param {?} aText
|
2220 | * @return {?}
|
2221 | */
|
2222 | function 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 | */
|
2230 | function byTypeAndName(aType, aName) {
|
2231 | return function (node) { return node && node.kind === aType && node.getText() === aName; };
|
2232 | }
|
2233 | /**
|
2234 | * @param {?} aName
|
2235 | * @return {?}
|
2236 | */
|
2237 | function 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 |
|
2261 | export { 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 |