@angular-devkit/architect 0.1600.0-next.5 → 0.1600.0-next.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@angular-devkit/architect",
3
- "version": "0.1600.0-next.5",
3
+ "version": "0.1600.0-next.7",
4
4
  "description": "Angular Build Facade",
5
5
  "experimental": true,
6
6
  "main": "src/index.js",
7
7
  "typings": "src/index.d.ts",
8
8
  "dependencies": {
9
- "@angular-devkit/core": "16.0.0-next.5",
9
+ "@angular-devkit/core": "16.0.0-next.7",
10
10
  "rxjs": "7.8.0"
11
11
  },
12
12
  "builders": "./builders/builders.json",
@@ -22,9 +22,8 @@ function createBuilder(fn) {
22
22
  const scheduler = context.scheduler;
23
23
  const progressChannel = context.createChannel('progress');
24
24
  const logChannel = context.createChannel('log');
25
+ const addTeardown = context.addTeardown.bind(context);
25
26
  let currentState = api_1.BuilderProgressState.Stopped;
26
- const teardownLogics = [];
27
- let tearingDown = false;
28
27
  let current = 0;
29
28
  let status = '';
30
29
  let total = 1;
@@ -54,15 +53,8 @@ function createBuilder(fn) {
54
53
  const subscriptions = [];
55
54
  const inputSubscription = context.inboundBus.subscribe((i) => {
56
55
  switch (i.kind) {
57
- case jobs_1.JobInboundMessageKind.Stop:
58
- // Run teardown logic then complete.
59
- tearingDown = true;
60
- Promise.all(teardownLogics.map((fn) => fn() || Promise.resolve())).then(() => observer.complete(), (err) => observer.error(err));
61
- break;
62
56
  case jobs_1.JobInboundMessageKind.Input:
63
- if (!tearingDown) {
64
- onInput(i.value);
65
- }
57
+ onInput(i.value);
66
58
  break;
67
59
  }
68
60
  });
@@ -139,9 +131,7 @@ function createBuilder(fn) {
139
131
  progress({ state: currentState, current, total, status }, context);
140
132
  }
141
133
  },
142
- addTeardown(teardown) {
143
- teardownLogics.push(teardown);
144
- },
134
+ addTeardown,
145
135
  };
146
136
  context.reportRunning();
147
137
  let result;
@@ -189,4 +179,4 @@ exports.createBuilder = createBuilder;
189
179
  function isAsyncIterable(obj) {
190
180
  return !!obj && typeof obj[Symbol.asyncIterator] === 'function';
191
181
  }
192
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-builder.js","sourceRoot":"","sources":["../../../../../../../packages/angular_devkit/architect/src/create-builder.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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\nimport { json, logging } from '@angular-devkit/core';\nimport {\n  Observable,\n  Subscription,\n  defaultIfEmpty,\n  firstValueFrom,\n  from,\n  isObservable,\n  mergeMap,\n  of,\n  tap,\n  throwError,\n} from 'rxjs';\nimport {\n  BuilderContext,\n  BuilderHandlerFn,\n  BuilderInfo,\n  BuilderInput,\n  BuilderOutput,\n  BuilderProgressState,\n  ScheduleOptions,\n  Target,\n  TypedBuilderProgress,\n  fromAsyncIterable,\n  isBuilderOutput,\n  targetStringFromTarget,\n} from './api';\nimport { Builder, BuilderSymbol, BuilderVersionSymbol } from './internal';\nimport { JobInboundMessageKind, createJobHandler } from './jobs';\nimport { scheduleByName, scheduleByTarget } from './schedule-by-name';\n\n// eslint-disable-next-line max-lines-per-function\nexport function createBuilder<OptT = json.JsonObject, OutT extends BuilderOutput = BuilderOutput>(\n  fn: BuilderHandlerFn<OptT>,\n): Builder<OptT & json.JsonObject> {\n  const cjh = createJobHandler;\n  // eslint-disable-next-line max-lines-per-function\n  const handler = cjh<json.JsonObject, BuilderInput, OutT>((options, context) => {\n    const scheduler = context.scheduler;\n    const progressChannel = context.createChannel('progress');\n    const logChannel = context.createChannel('log');\n    let currentState: BuilderProgressState = BuilderProgressState.Stopped;\n    const teardownLogics: Array<() => PromiseLike<void> | void> = [];\n    let tearingDown = false;\n    let current = 0;\n    let status = '';\n    let total = 1;\n\n    function log(entry: logging.LogEntry) {\n      logChannel.next(entry);\n    }\n    function progress(progress: TypedBuilderProgress, context: BuilderContext) {\n      currentState = progress.state;\n      if (progress.state === BuilderProgressState.Running) {\n        current = progress.current;\n        total = progress.total !== undefined ? progress.total : total;\n\n        if (progress.status === undefined) {\n          progress.status = status;\n        } else {\n          status = progress.status;\n        }\n      }\n\n      progressChannel.next({\n        ...(progress as json.JsonObject),\n        ...(context.target && { target: context.target }),\n        ...(context.builder && { builder: context.builder }),\n        id: context.id,\n      });\n    }\n\n    return new Observable<OutT>((observer) => {\n      const subscriptions: Subscription[] = [];\n\n      const inputSubscription = context.inboundBus.subscribe((i) => {\n        switch (i.kind) {\n          case JobInboundMessageKind.Stop:\n            // Run teardown logic then complete.\n            tearingDown = true;\n            Promise.all(teardownLogics.map((fn) => fn() || Promise.resolve())).then(\n              () => observer.complete(),\n              (err) => observer.error(err),\n            );\n            break;\n          case JobInboundMessageKind.Input:\n            if (!tearingDown) {\n              onInput(i.value);\n            }\n            break;\n        }\n      });\n\n      function onInput(i: BuilderInput) {\n        const builder = i.info as BuilderInfo;\n        const loggerName = i.target\n          ? targetStringFromTarget(i.target as Target)\n          : builder.builderName;\n        const logger = new logging.Logger(loggerName);\n\n        subscriptions.push(logger.subscribe((entry) => log(entry)));\n\n        const context: BuilderContext = {\n          builder,\n          workspaceRoot: i.workspaceRoot,\n          currentDirectory: i.currentDirectory,\n          target: i.target as Target,\n          logger: logger,\n          id: i.id,\n          async scheduleTarget(\n            target: Target,\n            overrides: json.JsonObject = {},\n            scheduleOptions: ScheduleOptions = {},\n          ) {\n            const run = await scheduleByTarget(target, overrides, {\n              scheduler,\n              logger: scheduleOptions.logger || logger.createChild(''),\n              workspaceRoot: i.workspaceRoot,\n              currentDirectory: i.currentDirectory,\n            });\n\n            // We don't want to subscribe errors and complete.\n            subscriptions.push(run.progress.subscribe((event) => progressChannel.next(event)));\n\n            return run;\n          },\n          async scheduleBuilder(\n            builderName: string,\n            options: json.JsonObject = {},\n            scheduleOptions: ScheduleOptions = {},\n          ) {\n            const run = await scheduleByName(builderName, options, {\n              scheduler,\n              target: scheduleOptions.target,\n              logger: scheduleOptions.logger || logger.createChild(''),\n              workspaceRoot: i.workspaceRoot,\n              currentDirectory: i.currentDirectory,\n            });\n\n            // We don't want to subscribe errors and complete.\n            subscriptions.push(run.progress.subscribe((event) => progressChannel.next(event)));\n\n            return run;\n          },\n          async getTargetOptions(target: Target) {\n            return firstValueFrom(\n              scheduler.schedule<Target, json.JsonValue, json.JsonObject>(\n                '..getTargetOptions',\n                target,\n              ).output,\n            );\n          },\n          async getProjectMetadata(target: Target | string) {\n            return firstValueFrom(\n              scheduler.schedule<Target | string, json.JsonValue, json.JsonObject>(\n                '..getProjectMetadata',\n                target,\n              ).output,\n            );\n          },\n          async getBuilderNameForTarget(target: Target) {\n            return firstValueFrom(\n              scheduler.schedule<Target, json.JsonValue, string>(\n                '..getBuilderNameForTarget',\n                target,\n              ).output,\n            );\n          },\n          async validateOptions<T extends json.JsonObject = json.JsonObject>(\n            options: json.JsonObject,\n            builderName: string,\n          ) {\n            return firstValueFrom(\n              scheduler.schedule<[string, json.JsonObject], json.JsonValue, T>(\n                '..validateOptions',\n                [builderName, options],\n              ).output,\n            );\n          },\n          reportRunning() {\n            switch (currentState) {\n              case BuilderProgressState.Waiting:\n              case BuilderProgressState.Stopped:\n                progress({ state: BuilderProgressState.Running, current: 0, total }, context);\n                break;\n            }\n          },\n          reportStatus(status: string) {\n            switch (currentState) {\n              case BuilderProgressState.Running:\n                progress({ state: currentState, status, current, total }, context);\n                break;\n              case BuilderProgressState.Waiting:\n                progress({ state: currentState, status }, context);\n                break;\n            }\n          },\n          reportProgress(current: number, total?: number, status?: string) {\n            switch (currentState) {\n              case BuilderProgressState.Running:\n                progress({ state: currentState, current, total, status }, context);\n            }\n          },\n          addTeardown(teardown: () => Promise<void> | void): void {\n            teardownLogics.push(teardown);\n          },\n        };\n\n        context.reportRunning();\n        let result;\n        try {\n          result = fn(i.options as unknown as OptT, context);\n          if (isBuilderOutput(result)) {\n            result = of(result);\n          } else if (!isObservable(result) && isAsyncIterable(result)) {\n            result = fromAsyncIterable(result);\n          } else {\n            result = from(result);\n          }\n        } catch (e) {\n          result = throwError(e);\n        }\n\n        // Manage some state automatically.\n        progress({ state: BuilderProgressState.Running, current: 0, total: 1 }, context);\n        subscriptions.push(\n          result\n            .pipe(\n              defaultIfEmpty({ success: false } as unknown),\n              tap(() => {\n                progress({ state: BuilderProgressState.Running, current: total }, context);\n                progress({ state: BuilderProgressState.Stopped }, context);\n              }),\n              mergeMap(async (value) => {\n                // Allow the log queue to flush\n                await new Promise<void>(setImmediate);\n\n                return value;\n              }),\n            )\n            .subscribe(\n              (message) => observer.next(message as OutT),\n              (error) => observer.error(error),\n              () => observer.complete(),\n            ),\n        );\n      }\n\n      return () => {\n        subscriptions.forEach((x) => x.unsubscribe());\n        inputSubscription.unsubscribe();\n      };\n    });\n  });\n\n  return {\n    handler,\n    [BuilderSymbol]: true,\n    [BuilderVersionSymbol]: require('../package.json').version,\n  };\n}\n\nfunction isAsyncIterable<T>(obj: unknown): obj is AsyncIterable<T> {\n  return !!obj && typeof (obj as AsyncIterable<T>)[Symbol.asyncIterator] === 'function';\n}\n"]}
182
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-builder.js","sourceRoot":"","sources":["../../../../../../../packages/angular_devkit/architect/src/create-builder.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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\nimport { json, logging } from '@angular-devkit/core';\nimport {\n  Observable,\n  Subscription,\n  defaultIfEmpty,\n  firstValueFrom,\n  from,\n  isObservable,\n  mergeMap,\n  of,\n  tap,\n  throwError,\n} from 'rxjs';\nimport {\n  BuilderContext,\n  BuilderHandlerFn,\n  BuilderInfo,\n  BuilderInput,\n  BuilderOutput,\n  BuilderProgressState,\n  ScheduleOptions,\n  Target,\n  TypedBuilderProgress,\n  fromAsyncIterable,\n  isBuilderOutput,\n  targetStringFromTarget,\n} from './api';\nimport { Builder, BuilderSymbol, BuilderVersionSymbol } from './internal';\nimport { JobInboundMessageKind, createJobHandler } from './jobs';\nimport { scheduleByName, scheduleByTarget } from './schedule-by-name';\n\n// eslint-disable-next-line max-lines-per-function\nexport function createBuilder<OptT = json.JsonObject, OutT extends BuilderOutput = BuilderOutput>(\n  fn: BuilderHandlerFn<OptT>,\n): Builder<OptT & json.JsonObject> {\n  const cjh = createJobHandler;\n  // eslint-disable-next-line max-lines-per-function\n  const handler = cjh<json.JsonObject, BuilderInput, OutT>((options, context) => {\n    const scheduler = context.scheduler;\n    const progressChannel = context.createChannel('progress');\n    const logChannel = context.createChannel('log');\n    const addTeardown = context.addTeardown.bind(context);\n    let currentState: BuilderProgressState = BuilderProgressState.Stopped;\n    let current = 0;\n    let status = '';\n    let total = 1;\n\n    function log(entry: logging.LogEntry) {\n      logChannel.next(entry);\n    }\n    function progress(progress: TypedBuilderProgress, context: BuilderContext) {\n      currentState = progress.state;\n      if (progress.state === BuilderProgressState.Running) {\n        current = progress.current;\n        total = progress.total !== undefined ? progress.total : total;\n\n        if (progress.status === undefined) {\n          progress.status = status;\n        } else {\n          status = progress.status;\n        }\n      }\n\n      progressChannel.next({\n        ...(progress as json.JsonObject),\n        ...(context.target && { target: context.target }),\n        ...(context.builder && { builder: context.builder }),\n        id: context.id,\n      });\n    }\n\n    return new Observable<OutT>((observer) => {\n      const subscriptions: Subscription[] = [];\n\n      const inputSubscription = context.inboundBus.subscribe((i) => {\n        switch (i.kind) {\n          case JobInboundMessageKind.Input:\n            onInput(i.value);\n            break;\n        }\n      });\n\n      function onInput(i: BuilderInput) {\n        const builder = i.info as BuilderInfo;\n        const loggerName = i.target\n          ? targetStringFromTarget(i.target as Target)\n          : builder.builderName;\n        const logger = new logging.Logger(loggerName);\n\n        subscriptions.push(logger.subscribe((entry) => log(entry)));\n\n        const context: BuilderContext = {\n          builder,\n          workspaceRoot: i.workspaceRoot,\n          currentDirectory: i.currentDirectory,\n          target: i.target as Target,\n          logger: logger,\n          id: i.id,\n          async scheduleTarget(\n            target: Target,\n            overrides: json.JsonObject = {},\n            scheduleOptions: ScheduleOptions = {},\n          ) {\n            const run = await scheduleByTarget(target, overrides, {\n              scheduler,\n              logger: scheduleOptions.logger || logger.createChild(''),\n              workspaceRoot: i.workspaceRoot,\n              currentDirectory: i.currentDirectory,\n            });\n\n            // We don't want to subscribe errors and complete.\n            subscriptions.push(run.progress.subscribe((event) => progressChannel.next(event)));\n\n            return run;\n          },\n          async scheduleBuilder(\n            builderName: string,\n            options: json.JsonObject = {},\n            scheduleOptions: ScheduleOptions = {},\n          ) {\n            const run = await scheduleByName(builderName, options, {\n              scheduler,\n              target: scheduleOptions.target,\n              logger: scheduleOptions.logger || logger.createChild(''),\n              workspaceRoot: i.workspaceRoot,\n              currentDirectory: i.currentDirectory,\n            });\n\n            // We don't want to subscribe errors and complete.\n            subscriptions.push(run.progress.subscribe((event) => progressChannel.next(event)));\n\n            return run;\n          },\n          async getTargetOptions(target: Target) {\n            return firstValueFrom(\n              scheduler.schedule<Target, json.JsonValue, json.JsonObject>(\n                '..getTargetOptions',\n                target,\n              ).output,\n            );\n          },\n          async getProjectMetadata(target: Target | string) {\n            return firstValueFrom(\n              scheduler.schedule<Target | string, json.JsonValue, json.JsonObject>(\n                '..getProjectMetadata',\n                target,\n              ).output,\n            );\n          },\n          async getBuilderNameForTarget(target: Target) {\n            return firstValueFrom(\n              scheduler.schedule<Target, json.JsonValue, string>(\n                '..getBuilderNameForTarget',\n                target,\n              ).output,\n            );\n          },\n          async validateOptions<T extends json.JsonObject = json.JsonObject>(\n            options: json.JsonObject,\n            builderName: string,\n          ) {\n            return firstValueFrom(\n              scheduler.schedule<[string, json.JsonObject], json.JsonValue, T>(\n                '..validateOptions',\n                [builderName, options],\n              ).output,\n            );\n          },\n          reportRunning() {\n            switch (currentState) {\n              case BuilderProgressState.Waiting:\n              case BuilderProgressState.Stopped:\n                progress({ state: BuilderProgressState.Running, current: 0, total }, context);\n                break;\n            }\n          },\n          reportStatus(status: string) {\n            switch (currentState) {\n              case BuilderProgressState.Running:\n                progress({ state: currentState, status, current, total }, context);\n                break;\n              case BuilderProgressState.Waiting:\n                progress({ state: currentState, status }, context);\n                break;\n            }\n          },\n          reportProgress(current: number, total?: number, status?: string) {\n            switch (currentState) {\n              case BuilderProgressState.Running:\n                progress({ state: currentState, current, total, status }, context);\n            }\n          },\n          addTeardown,\n        };\n\n        context.reportRunning();\n        let result;\n        try {\n          result = fn(i.options as unknown as OptT, context);\n          if (isBuilderOutput(result)) {\n            result = of(result);\n          } else if (!isObservable(result) && isAsyncIterable(result)) {\n            result = fromAsyncIterable(result);\n          } else {\n            result = from(result);\n          }\n        } catch (e) {\n          result = throwError(e);\n        }\n\n        // Manage some state automatically.\n        progress({ state: BuilderProgressState.Running, current: 0, total: 1 }, context);\n        subscriptions.push(\n          result\n            .pipe(\n              defaultIfEmpty({ success: false } as unknown),\n              tap(() => {\n                progress({ state: BuilderProgressState.Running, current: total }, context);\n                progress({ state: BuilderProgressState.Stopped }, context);\n              }),\n              mergeMap(async (value) => {\n                // Allow the log queue to flush\n                await new Promise<void>(setImmediate);\n\n                return value;\n              }),\n            )\n            .subscribe(\n              (message) => observer.next(message as OutT),\n              (error) => observer.error(error),\n              () => observer.complete(),\n            ),\n        );\n      }\n\n      return () => {\n        subscriptions.forEach((x) => x.unsubscribe());\n        inputSubscription.unsubscribe();\n      };\n    });\n  });\n\n  return {\n    handler,\n    [BuilderSymbol]: true,\n    [BuilderVersionSymbol]: require('../package.json').version,\n  };\n}\n\nfunction isAsyncIterable<T>(obj: unknown): obj is AsyncIterable<T> {\n  return !!obj && typeof (obj as AsyncIterable<T>)[Symbol.asyncIterator] === 'function';\n}\n"]}
@@ -18,6 +18,7 @@ export declare class ChannelAlreadyExistException extends BaseException {
18
18
  export interface SimpleJobHandlerContext<A extends JsonValue, I extends JsonValue, O extends JsonValue> extends JobHandlerContext<A, I, O> {
19
19
  createChannel: (name: string) => Observer<JsonValue>;
20
20
  input: Observable<I>;
21
+ addTeardown(teardown: () => Promise<void> | void): void;
21
22
  }
22
23
  /**
23
24
  * A simple version of the JobHandler. This simplifies a lot of the interaction with the job
@@ -30,6 +30,8 @@ function createJobHandler(fn, options = {}) {
30
30
  const inboundBus = context.inboundBus;
31
31
  const inputChannel = new rxjs_1.Subject();
32
32
  let subscription;
33
+ const teardownLogics = [];
34
+ let tearingDown = false;
33
35
  return new rxjs_1.Observable((subject) => {
34
36
  function complete() {
35
37
  if (subscription) {
@@ -46,12 +48,19 @@ function createJobHandler(fn, options = {}) {
46
48
  subject.next({ kind: api_1.JobOutboundMessageKind.Pong, description, id: message.id });
47
49
  break;
48
50
  case api_1.JobInboundMessageKind.Stop:
49
- // There's no way to cancel a promise or a synchronous function, but we do cancel
50
- // observables where possible.
51
- complete();
51
+ // Run teardown logic then complete.
52
+ tearingDown = true;
53
+ if (teardownLogics.length) {
54
+ Promise.all(teardownLogics.map((fn) => fn())).then(() => complete(), () => complete());
55
+ }
56
+ else {
57
+ complete();
58
+ }
52
59
  break;
53
60
  case api_1.JobInboundMessageKind.Input:
54
- inputChannel.next(message.value);
61
+ if (!tearingDown) {
62
+ inputChannel.next(message.value);
63
+ }
55
64
  break;
56
65
  }
57
66
  });
@@ -60,6 +69,9 @@ function createJobHandler(fn, options = {}) {
60
69
  const newContext = {
61
70
  ...context,
62
71
  input: inputChannel.asObservable(),
72
+ addTeardown(teardown) {
73
+ teardownLogics.push(teardown);
74
+ },
63
75
  createChannel(name) {
64
76
  if (channels.has(name)) {
65
77
  throw new ChannelAlreadyExistException(name);
@@ -131,4 +143,4 @@ function createLoggerJob(job, logger) {
131
143
  return Object.assign(handler, job);
132
144
  }
133
145
  exports.createLoggerJob = createLoggerJob;
134
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-job-handler.js","sourceRoot":"","sources":["../../../../../../../../packages/angular_devkit/architect/src/jobs/create-job-handler.ts"],"names":[],"mappings":";AAAA;;;;;;GAMG;;;AAEH,+CAAoF;AACpF,+BAUc;AACd,+BAOe;AAEf,MAAa,4BAA6B,SAAQ,oBAAa;IAC7D,YAAY,IAAY;QACtB,KAAK,CAAC,WAAW,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;IAC1D,CAAC;CACF;AAJD,oEAIC;AAyBD;;;;;;GAMG;AACH,SAAgB,gBAAgB,CAC9B,EAA+B,EAC/B,UAAmC,EAAE;IAErC,MAAM,OAAO,GAAG,CAAC,QAAW,EAAE,OAAmC,EAAE,EAAE;QACnE,MAAM,WAAW,GAAG,OAAO,CAAC,WAAW,CAAC;QACxC,MAAM,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;QACtC,MAAM,YAAY,GAAG,IAAI,cAAO,EAAK,CAAC;QACtC,IAAI,YAA0B,CAAC;QAE/B,OAAO,IAAI,iBAAU,CAAwB,CAAC,OAAO,EAAE,EAAE;YACvD,SAAS,QAAQ;gBACf,IAAI,YAAY,EAAE;oBAChB,YAAY,CAAC,WAAW,EAAE,CAAC;iBAC5B;gBACD,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,4BAAsB,CAAC,GAAG,EAAE,WAAW,EAAE,CAAC,CAAC;gBAChE,OAAO,CAAC,QAAQ,EAAE,CAAC;gBACnB,YAAY,CAAC,QAAQ,EAAE,CAAC;YAC1B,CAAC;YAED,gBAAgB;YAChB,MAAM,UAAU,GAAG,UAAU,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE;gBAClD,QAAQ,OAAO,CAAC,IAAI,EAAE;oBACpB,KAAK,2BAAqB,CAAC,IAAI;wBAC7B,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,4BAAsB,CAAC,IAAI,EAAE,WAAW,EAAE,EAAE,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC;wBACjF,MAAM;oBAER,KAAK,2BAAqB,CAAC,IAAI;wBAC7B,iFAAiF;wBACjF,8BAA8B;wBAC9B,QAAQ,EAAE,CAAC;wBACX,MAAM;oBAER,KAAK,2BAAqB,CAAC,KAAK;wBAC9B,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;wBACjC,MAAM;iBACT;YACH,CAAC,CAAC,CAAC;YAEH,oDAAoD;YACpD,MAAM,QAAQ,GAAG,IAAI,GAAG,EAA8B,CAAC;YAEvD,MAAM,UAAU,GAAqC;gBACnD,GAAG,OAAO;gBACV,KAAK,EAAE,YAAY,CAAC,YAAY,EAAE;gBAClC,aAAa,CAAC,IAAY;oBACxB,IAAI,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;wBACtB,MAAM,IAAI,4BAA4B,CAAC,IAAI,CAAC,CAAC;qBAC9C;oBACD,MAAM,cAAc,GAAG,IAAI,cAAO,EAAa,CAAC;oBAChD,MAAM,UAAU,GAAG,cAAc,CAAC,SAAS,CACzC,CAAC,OAAO,EAAE,EAAE;wBACV,OAAO,CAAC,IAAI,CAAC;4BACX,IAAI,EAAE,4BAAsB,CAAC,cAAc;4BAC3C,WAAW;4BACX,IAAI;4BACJ,OAAO;yBACR,CAAC,CAAC;oBACL,CAAC,EACD,CAAC,KAAK,EAAE,EAAE;wBACR,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,4BAAsB,CAAC,YAAY,EAAE,WAAW,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;wBACtF,wBAAwB;wBACxB,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;oBACxB,CAAC,EACD,GAAG,EAAE;wBACH,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,4BAAsB,CAAC,eAAe,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC;wBAClF,wBAAwB;wBACxB,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;oBACxB,CAAC,CACF,CAAC;oBAEF,QAAQ,CAAC,GAAG,CAAC,IAAI,EAAE,cAAc,CAAC,CAAC;oBACnC,IAAI,YAAY,EAAE;wBAChB,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;qBAC9B;oBAED,OAAO,cAAc,CAAC;gBACxB,CAAC;aACF,CAAC;YAEF,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,4BAAsB,CAAC,KAAK,EAAE,WAAW,EAAE,CAAC,CAAC;YAClE,IAAI,MAAM,GAAG,EAAE,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;YACtC,0FAA0F;YAC1F,IAAI,IAAA,gBAAS,EAAC,MAAM,CAAC,EAAE;gBACrB,MAAM,GAAG,IAAA,WAAI,EAAC,MAAM,CAAC,CAAC;aACvB;iBAAM,IAAI,CAAC,IAAA,mBAAY,EAAC,MAAM,CAAC,EAAE;gBAChC,MAAM,GAAG,IAAA,SAAE,EAAC,MAAW,CAAC,CAAC;aAC1B;YAED,YAAY,GAAI,MAAwB,CAAC,SAAS,CAChD,CAAC,KAAQ,EAAE,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,4BAAsB,CAAC,MAAM,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,EACvF,CAAC,KAAK,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,EAC/B,GAAG,EAAE,CAAC,QAAQ,EAAE,CACjB,CAAC;YACF,YAAY,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;YAE7B,OAAO,YAAY,CAAC;QACtB,CAAC,CAAC,CAAC;IACL,CAAC,CAAC;IAEF,OAAO,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,cAAc,EAAE,OAAO,EAAE,CAAC,CAAC;AAC7D,CAAC;AArGD,4CAqGC;AAED;;;;GAIG;AACH,SAAgB,gBAAgB,CAC9B,MAA0C,EAC1C,UAAmC,EAAE;IAErC,MAAM,OAAO,GAAG,CAAC,QAAW,EAAE,OAAmC,EAAE,EAAE;QACnE,OAAO,IAAA,WAAI,EAAC,MAAM,EAAE,CAAC,CAAC,IAAI,CAAC,IAAA,gBAAS,EAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IACvE,CAAC,CAAC;IAEF,OAAO,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,EAAE,cAAc,EAAE,OAAO,EAAE,CAAC,CAAC;AAC7D,CAAC;AATD,4CASC;AAED;;;GAGG;AACH,SAAgB,eAAe,CAC7B,GAAwB,EACxB,MAAyB;IAEzB,MAAM,OAAO,GAAG,CAAC,QAAW,EAAE,OAAmC,EAAE,EAAE;QACnE,OAAO,CAAC,UAAU;aACf,IAAI,CAAC,IAAA,UAAG,EAAC,CAAC,OAAO,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;aACxE,SAAS,EAAE,CAAC;QAEf,OAAO,GAAG,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC,IAAI,CAChC,IAAA,UAAG,EACD,CAAC,OAAO,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,CAAC,EAC/D,CAAC,KAAK,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,EACzD,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,CAC/B,CACF,CAAC;IACJ,CAAC,CAAC;IAEF,OAAO,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;AACrC,CAAC;AAnBD,0CAmBC","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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\nimport { BaseException, JsonValue, isPromise, logging } from '@angular-devkit/core';\nimport {\n  Observable,\n  Observer,\n  Subject,\n  Subscription,\n  from,\n  isObservable,\n  of,\n  switchMap,\n  tap,\n} from 'rxjs';\nimport {\n  JobDescription,\n  JobHandler,\n  JobHandlerContext,\n  JobInboundMessageKind,\n  JobOutboundMessage,\n  JobOutboundMessageKind,\n} from './api';\n\nexport class ChannelAlreadyExistException extends BaseException {\n  constructor(name: string) {\n    super(`Channel ${JSON.stringify(name)} already exist.`);\n  }\n}\n\n/**\n * Interface for the JobHandler context that is used when using `createJobHandler()`. It extends\n * the basic `JobHandlerContext` with additional functionality.\n */\nexport interface SimpleJobHandlerContext<\n  A extends JsonValue,\n  I extends JsonValue,\n  O extends JsonValue,\n> extends JobHandlerContext<A, I, O> {\n  createChannel: (name: string) => Observer<JsonValue>;\n  input: Observable<I>;\n}\n\n/**\n * A simple version of the JobHandler. This simplifies a lot of the interaction with the job\n * scheduler and registry. For example, instead of returning a JobOutboundMessage observable, you\n * can directly return an output.\n */\nexport type SimpleJobHandlerFn<A extends JsonValue, I extends JsonValue, O extends JsonValue> = (\n  input: A,\n  context: SimpleJobHandlerContext<A, I, O>,\n) => O | Promise<O> | Observable<O>;\n\n/**\n * Make a simple job handler that sets start and end from a function that's synchronous.\n *\n * @param fn The function to create a handler for.\n * @param options An optional set of properties to set on the handler. Some fields might be\n *   required by registry or schedulers.\n */\nexport function createJobHandler<A extends JsonValue, I extends JsonValue, O extends JsonValue>(\n  fn: SimpleJobHandlerFn<A, I, O>,\n  options: Partial<JobDescription> = {},\n): JobHandler<A, I, O> {\n  const handler = (argument: A, context: JobHandlerContext<A, I, O>) => {\n    const description = context.description;\n    const inboundBus = context.inboundBus;\n    const inputChannel = new Subject<I>();\n    let subscription: Subscription;\n\n    return new Observable<JobOutboundMessage<O>>((subject) => {\n      function complete() {\n        if (subscription) {\n          subscription.unsubscribe();\n        }\n        subject.next({ kind: JobOutboundMessageKind.End, description });\n        subject.complete();\n        inputChannel.complete();\n      }\n\n      // Handle input.\n      const inboundSub = inboundBus.subscribe((message) => {\n        switch (message.kind) {\n          case JobInboundMessageKind.Ping:\n            subject.next({ kind: JobOutboundMessageKind.Pong, description, id: message.id });\n            break;\n\n          case JobInboundMessageKind.Stop:\n            // There's no way to cancel a promise or a synchronous function, but we do cancel\n            // observables where possible.\n            complete();\n            break;\n\n          case JobInboundMessageKind.Input:\n            inputChannel.next(message.value);\n            break;\n        }\n      });\n\n      // Execute the function with the additional context.\n      const channels = new Map<string, Subject<JsonValue>>();\n\n      const newContext: SimpleJobHandlerContext<A, I, O> = {\n        ...context,\n        input: inputChannel.asObservable(),\n        createChannel(name: string) {\n          if (channels.has(name)) {\n            throw new ChannelAlreadyExistException(name);\n          }\n          const channelSubject = new Subject<JsonValue>();\n          const channelSub = channelSubject.subscribe(\n            (message) => {\n              subject.next({\n                kind: JobOutboundMessageKind.ChannelMessage,\n                description,\n                name,\n                message,\n              });\n            },\n            (error) => {\n              subject.next({ kind: JobOutboundMessageKind.ChannelError, description, name, error });\n              // This can be reopened.\n              channels.delete(name);\n            },\n            () => {\n              subject.next({ kind: JobOutboundMessageKind.ChannelComplete, description, name });\n              // This can be reopened.\n              channels.delete(name);\n            },\n          );\n\n          channels.set(name, channelSubject);\n          if (subscription) {\n            subscription.add(channelSub);\n          }\n\n          return channelSubject;\n        },\n      };\n\n      subject.next({ kind: JobOutboundMessageKind.Start, description });\n      let result = fn(argument, newContext);\n      // If the result is a promise, simply wait for it to complete before reporting the result.\n      if (isPromise(result)) {\n        result = from(result);\n      } else if (!isObservable(result)) {\n        result = of(result as O);\n      }\n\n      subscription = (result as Observable<O>).subscribe(\n        (value: O) => subject.next({ kind: JobOutboundMessageKind.Output, description, value }),\n        (error) => subject.error(error),\n        () => complete(),\n      );\n      subscription.add(inboundSub);\n\n      return subscription;\n    });\n  };\n\n  return Object.assign(handler, { jobDescription: options });\n}\n\n/**\n * Lazily create a job using a function.\n * @param loader A factory function that returns a promise/observable of a JobHandler.\n * @param options Same options as createJob.\n */\nexport function createJobFactory<A extends JsonValue, I extends JsonValue, O extends JsonValue>(\n  loader: () => Promise<JobHandler<A, I, O>>,\n  options: Partial<JobDescription> = {},\n): JobHandler<A, I, O> {\n  const handler = (argument: A, context: JobHandlerContext<A, I, O>) => {\n    return from(loader()).pipe(switchMap((fn) => fn(argument, context)));\n  };\n\n  return Object.assign(handler, { jobDescription: options });\n}\n\n/**\n * Creates a job that logs out input/output messages of another Job. The messages are still\n * propagated to the other job.\n */\nexport function createLoggerJob<A extends JsonValue, I extends JsonValue, O extends JsonValue>(\n  job: JobHandler<A, I, O>,\n  logger: logging.LoggerApi,\n): JobHandler<A, I, O> {\n  const handler = (argument: A, context: JobHandlerContext<A, I, O>) => {\n    context.inboundBus\n      .pipe(tap((message) => logger.info(`Input: ${JSON.stringify(message)}`)))\n      .subscribe();\n\n    return job(argument, context).pipe(\n      tap(\n        (message) => logger.info(`Message: ${JSON.stringify(message)}`),\n        (error) => logger.warn(`Error: ${JSON.stringify(error)}`),\n        () => logger.info(`Completed`),\n      ),\n    );\n  };\n\n  return Object.assign(handler, job);\n}\n"]}
146
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-job-handler.js","sourceRoot":"","sources":["../../../../../../../../packages/angular_devkit/architect/src/jobs/create-job-handler.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google LLC 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\nimport { BaseException, JsonValue, isPromise, logging } from '@angular-devkit/core';\nimport {\n  Observable,\n  Observer,\n  Subject,\n  Subscription,\n  from,\n  isObservable,\n  of,\n  switchMap,\n  tap,\n} from 'rxjs';\nimport {\n  JobDescription,\n  JobHandler,\n  JobHandlerContext,\n  JobInboundMessageKind,\n  JobOutboundMessage,\n  JobOutboundMessageKind,\n} from './api';\n\nexport class ChannelAlreadyExistException extends BaseException {\n  constructor(name: string) {\n    super(`Channel ${JSON.stringify(name)} already exist.`);\n  }\n}\n\n/**\n * Interface for the JobHandler context that is used when using `createJobHandler()`. It extends\n * the basic `JobHandlerContext` with additional functionality.\n */\nexport interface SimpleJobHandlerContext<\n  A extends JsonValue,\n  I extends JsonValue,\n  O extends JsonValue,\n> extends JobHandlerContext<A, I, O> {\n  createChannel: (name: string) => Observer<JsonValue>;\n  input: Observable<I>;\n  addTeardown(teardown: () => Promise<void> | void): void;\n}\n\n/**\n * A simple version of the JobHandler. This simplifies a lot of the interaction with the job\n * scheduler and registry. For example, instead of returning a JobOutboundMessage observable, you\n * can directly return an output.\n */\nexport type SimpleJobHandlerFn<A extends JsonValue, I extends JsonValue, O extends JsonValue> = (\n  input: A,\n  context: SimpleJobHandlerContext<A, I, O>,\n) => O | Promise<O> | Observable<O>;\n\n/**\n * Make a simple job handler that sets start and end from a function that's synchronous.\n *\n * @param fn The function to create a handler for.\n * @param options An optional set of properties to set on the handler. Some fields might be\n *   required by registry or schedulers.\n */\nexport function createJobHandler<A extends JsonValue, I extends JsonValue, O extends JsonValue>(\n  fn: SimpleJobHandlerFn<A, I, O>,\n  options: Partial<JobDescription> = {},\n): JobHandler<A, I, O> {\n  const handler = (argument: A, context: JobHandlerContext<A, I, O>) => {\n    const description = context.description;\n    const inboundBus = context.inboundBus;\n    const inputChannel = new Subject<I>();\n    let subscription: Subscription;\n    const teardownLogics: Array<() => PromiseLike<void> | void> = [];\n    let tearingDown = false;\n\n    return new Observable<JobOutboundMessage<O>>((subject) => {\n      function complete() {\n        if (subscription) {\n          subscription.unsubscribe();\n        }\n        subject.next({ kind: JobOutboundMessageKind.End, description });\n        subject.complete();\n        inputChannel.complete();\n      }\n\n      // Handle input.\n      const inboundSub = inboundBus.subscribe((message) => {\n        switch (message.kind) {\n          case JobInboundMessageKind.Ping:\n            subject.next({ kind: JobOutboundMessageKind.Pong, description, id: message.id });\n            break;\n\n          case JobInboundMessageKind.Stop:\n            // Run teardown logic then complete.\n            tearingDown = true;\n            if (teardownLogics.length) {\n              Promise.all(teardownLogics.map((fn) => fn())).then(\n                () => complete(),\n                () => complete(),\n              );\n            } else {\n              complete();\n            }\n            break;\n\n          case JobInboundMessageKind.Input:\n            if (!tearingDown) {\n              inputChannel.next(message.value);\n            }\n            break;\n        }\n      });\n\n      // Execute the function with the additional context.\n      const channels = new Map<string, Subject<JsonValue>>();\n\n      const newContext: SimpleJobHandlerContext<A, I, O> = {\n        ...context,\n        input: inputChannel.asObservable(),\n        addTeardown(teardown: () => Promise<void> | void): void {\n          teardownLogics.push(teardown);\n        },\n        createChannel(name: string) {\n          if (channels.has(name)) {\n            throw new ChannelAlreadyExistException(name);\n          }\n          const channelSubject = new Subject<JsonValue>();\n          const channelSub = channelSubject.subscribe(\n            (message) => {\n              subject.next({\n                kind: JobOutboundMessageKind.ChannelMessage,\n                description,\n                name,\n                message,\n              });\n            },\n            (error) => {\n              subject.next({ kind: JobOutboundMessageKind.ChannelError, description, name, error });\n              // This can be reopened.\n              channels.delete(name);\n            },\n            () => {\n              subject.next({ kind: JobOutboundMessageKind.ChannelComplete, description, name });\n              // This can be reopened.\n              channels.delete(name);\n            },\n          );\n\n          channels.set(name, channelSubject);\n          if (subscription) {\n            subscription.add(channelSub);\n          }\n\n          return channelSubject;\n        },\n      };\n\n      subject.next({ kind: JobOutboundMessageKind.Start, description });\n      let result = fn(argument, newContext);\n      // If the result is a promise, simply wait for it to complete before reporting the result.\n      if (isPromise(result)) {\n        result = from(result);\n      } else if (!isObservable(result)) {\n        result = of(result as O);\n      }\n\n      subscription = (result as Observable<O>).subscribe(\n        (value: O) => subject.next({ kind: JobOutboundMessageKind.Output, description, value }),\n        (error) => subject.error(error),\n        () => complete(),\n      );\n      subscription.add(inboundSub);\n\n      return subscription;\n    });\n  };\n\n  return Object.assign(handler, { jobDescription: options });\n}\n\n/**\n * Lazily create a job using a function.\n * @param loader A factory function that returns a promise/observable of a JobHandler.\n * @param options Same options as createJob.\n */\nexport function createJobFactory<A extends JsonValue, I extends JsonValue, O extends JsonValue>(\n  loader: () => Promise<JobHandler<A, I, O>>,\n  options: Partial<JobDescription> = {},\n): JobHandler<A, I, O> {\n  const handler = (argument: A, context: JobHandlerContext<A, I, O>) => {\n    return from(loader()).pipe(switchMap((fn) => fn(argument, context)));\n  };\n\n  return Object.assign(handler, { jobDescription: options });\n}\n\n/**\n * Creates a job that logs out input/output messages of another Job. The messages are still\n * propagated to the other job.\n */\nexport function createLoggerJob<A extends JsonValue, I extends JsonValue, O extends JsonValue>(\n  job: JobHandler<A, I, O>,\n  logger: logging.LoggerApi,\n): JobHandler<A, I, O> {\n  const handler = (argument: A, context: JobHandlerContext<A, I, O>) => {\n    context.inboundBus\n      .pipe(tap((message) => logger.info(`Input: ${JSON.stringify(message)}`)))\n      .subscribe();\n\n    return job(argument, context).pipe(\n      tap(\n        (message) => logger.info(`Message: ${JSON.stringify(message)}`),\n        (error) => logger.warn(`Error: ${JSON.stringify(error)}`),\n        () => logger.info(`Completed`),\n      ),\n    );\n  };\n\n  return Object.assign(handler, job);\n}\n"]}