Build Bus
The Build Bus classes manage dependency participation in project builds and tasks. They execute declare and intercept files so they can interact with each other.
Modules
- @magento/pwa-buildpack
- BuiltinTargets
- Buildpack/BuildBus
Mapping Tapable hooks to the Buildpack facade of Targets.
- Buildpack/BuildBus
- @magento/pwa-buildpack
- Buildpack/BuildBus
Typedefs
- transformModulesIntercept :
function
Intercept function signature for the transformModules target.
Interceptors of
transformModules
should call theaddTransform()
callback to add module specific transformers. Any returned value will be ignored.- addTransform :
function
Callback to add a transform.
- webpackCompilerIntercept :
function
Intercept function signature for the webpackCompiler target.
Interceptors of
webpackCompiler
should tap hooks on the providedcompiler
object. Any returned value will be ignored.- specialFeaturesIntercept :
function
Intercept function signature for the specialFeatures target.
Interceptors of the
specialFeatures
target can use the mapping object provided to map special build flags to their project modules.- transformUpwardIntercept ⇒
Promise
Intercept function signature for the transformUpward target.
Interceptors of the
transformUpward
target receive the parsed UPWARD definition as a plain JavaScript object. Mutate that object in place to change the finalupward.yml
output by the build.This Target can be used asynchronously. If you need to do asynchronous work to get what you need to modify the UPWARD definition (for example, a network request) then you can provide an
async
function as interceptor (or simply return a Promise from any function).- envValidationInterceptor ⇒
Boolean
Intercept function signature for the validateEnv target.
Interceptors of the
validateEnv
target receive a config object. The config object contains the project env, an onFail callback and the debug function to be used in case of the debug mode to log more inforamtion to the console.This Target can be used asynchronously in the parallel mode. If a validator needs to stop the process immediately, it can throw an error. If it needs to report an error but not stop the whole process, it can do so by calling the onFail function with the error message it wants to report. It can call the onFail multiple times if it wants to report multiple errors.
All the errors will be queued and printed into the console at the end of the validation process and the build process will be stopeed.
- @magento/pwa-buildpack
- ~BuildBus
- instance
- .getTargetsOf(depName) ⇒
Object.<string, Target>
- .init() ⇒
BuildBus
- .runPhase(phase)
- .getTargetsOf(depName) ⇒
- static
- .clear(context)
- .clearAll()
- .for(context) ⇒
BuildBus
- instance
- ~Trackable
- ~BuildBus
Manages dependency participation in project builds and tasks. It executes their declare and intercept files so they can interact with each other.
- ~BuildBus
- instance
- .getTargetsOf(depName) ⇒
Object.<string, Target>
- .init() ⇒
BuildBus
- .runPhase(phase)
- .getTargetsOf(depName) ⇒
- static
- .clear(context)
- .clearAll()
- .for(context) ⇒
BuildBus
- instance
Get TargetProvider for the given named dependency. Use this to
retrieve and run targets in top-level code, when you have a reference to
the BuildBus. Declare and intercept functions should not, and cannot,
use this method. Instead, they retrieve external targets through their
targets.of()
methods.
Returns:
Object.<string, Target>
— TargetProvider for the dependency.
Parameters
Name | Type | Description |
---|---|---|
depName | string | Dependency whose targets to retrieve. |
Run the two defined phases, declare
and intercept
, in order.
This binds all targets which the BuildBus can find by analyzing
dependencies in the project package file.
Chainable
Returns:
BuildBus
— Returns this instance (chainable).
Run the specified phase. The BuildBus finds all dependencies which say
in their package.json
that they need to run code in this phase.
Parameters
Name | Type | Description |
---|---|---|
phase | string | 'declare' or 'intercept' |
Example
Copied to your clipboard<caption>Find all dependencies whith have `pwa-studio: { targets: { declare: './path/to/js' }} defined, and run those functions.bus.runPhase('declare')
Remove the cached BuildBus for the given context.
Parameters
Name | Type | Description |
---|---|---|
context | string | Root directory whose BuildBus to delete. |
Remove all cached BuildBus objects.
Get or create the BuildBus for the given context. This factory is the supported way to construct BuildBus instances. It caches the instances and connects them to the logging infrastructure.
Only one BuildBus is active for a project root directory (context) at any given time. This way, Buildpack code can retrieve the BuildBus for a context even if the bus instance hasn't been sent as a parameter.
Returns: Parameters
Name | Type | Description |
---|---|---|
context | string | Root directory of the BuildBus to get or create. |
Example (Get or create the BuildBus for the package.json file in `./project-dir`, then bind targets, then call a target.)
Copied to your clipboardconst bus = BuildBus.for('./project-dir);bus.init();bus.getTargetsOf('my-extension').myTarget.call();
Generic node in a tree of objects which can log their activity. Implemented for BuildBus, since it will eventually need sophisticated debugging and introspection for developers, but it has no BuildBus-specific functionality.
Attach this Trackable to a tree. Give it a name and an owner. If the
owner is a Trackable, then this Trackable becomes a child node of the
owner. If the owner is a function, then this Trackable becomes a root
node, which will log all of its track calls and its
descendents' calls to the owner
function.
See: Trackable.spec.js
Parameters
Name | Type | Description |
---|---|---|
identifier | string | String identifier of this Trackable |
owner | Trackable | function | Parent or root log callback |
Enable all active Trackable instances. Do not run in production. Carries a possibly significant performance cost.
Disable all active Trackable instances. The parent logging callback will not be called.
- BuiltinTargets
- .envVarDefinitions :
tapable.SyncHook
- .transformModules :
tapable.AsyncSeriesHook
- .webpackCompiler :
tapable.SyncHook
- .specialFeatures :
tapable.SyncHook
- .transformUpward :
tapable.AsyncSeriesHook
- .validateEnv :
tapable.AsyncParallelHook
- .envVarDefinitions :
Called to collect the definitions and documentation for project-wide
configuration values. Core environment variables are defined in the
envVarDefinitions.json
file.
Intercept this target in your project to add new environment variables, typed and documented. This integrates your extension configuration with the project-wide environment variable system.
See
Parameters
Name | Type | Description |
---|---|---|
envVarDefinitions | object | The variable definitions object. Modify in place. |
Example (Add config fields for your extension)
Copied to your clipboardtargets.of('@magento/pwa-buildpack').envVarDefinitions.tap(defs => {defs.sections.push({name: 'My Extension Settings',variables: [{name: 'MY_EXTENSION_API_KEY',type: 'str',desc: 'API key for remote service access.'}]})});
Called when configuring the loading and processing rules for Webpack.
Interceptors receive a function addTransform()
. They may call this function to request that Webpack process a particular file with a particular transform module.
Since the storefront developer is in charge of important dependencies, the interceptor files in the storefront project itself should be able to transform ANY file from ANY dependency. However, interceptor files in the storefront dependencies are prevented from modifying files from other dependencies.
NOTE: This is a very low-level extension point. It should be used as a building block for higher-level extensions that expose functional areas rather than files on disk.
See: transformModules intercept function
Example (Strip unnecessary Lodash code from a specific JS module.)
Copied to your clipboardtargets.of('@magento/pwa-buildpack').transformModules.tap(addTransform => addTransform({type: 'babel',fileToTransform: './lib/uses-pipeline-syntax.js',transformModule: 'babel-plugin-lodash',options: { id: ["async", "lodash-bound" ]}}));
Calls interceptors whenever a Webpack Compiler object is created. This almost always happens once per build, even in dev mode.
Use an intercept function on this target to access the webpack compiler.
Example (Tap the compiler's `watchRun` hook.)
Copied to your clipboardtargets.of('@magento/pwa-buildpack').webpackCompiler.tap(compiler => {compiler.hooks.watchRun.tapPromise(async () => {compiler.getInfrastructureLogger('my-extension').info('I do something special in the dev server!');});});
Collects flags for special build features that dependency packages want to use.
If your extension uses ES Modules instead of CommonJS in
its frontend code (as most should), Webpack will not parse and build
the modules by default. It will expect extension code to be CommonJS
style and will not process the ES Modules.
Likewise, if your extension uses CSS Modules, you must add the cssModules
flag using this target.
Use a specialFeatures intercept function
to add special build features for the modules used in your project.
See: Special flags in configureWebpack()
Example (Declare that your extension contains CSS modules.)
Copied to your clipboardtargets.of('@magento/pwa-buildpack').specialFeatures.tap(featuresByModule => {featuresByModule['my-module'] = { cssModules: true };})
Exposes the fully merged UPWARD definition for fine tuning. The
UpwardIncludePlugin does a simple shallow merge of the upward.yml
files in every package which sets the upward: true
flag in the
specialFeatures
object. After that is complete,
UpwardIncludePlugin calls this target with the parsed and merged
definition.
Parameters
Name | Type |
---|---|
interceptor |
Example (Send empty responses in maintenance mode.)
Copied to your clipboardtargets.of('@magento/pwa-buildpack').transformUpward.tap(def => {const guardMaintenanceMode = (prop, inline) => {def[prop] = {when: [{matches: 'env.MAINTENANCE_MODE',pattern: '.',use: { inline }}],default: def[prop]}}guardMaintenanceMode('status', 503);guardMaintenanceMode('body', '')})
Collect all ENV validation functions that will run against the project's ENV. The functions can be async and they will run in parallel. If a validation function wants to stop the whole process for instance in case of a serious security issue, it can do so by throwing an error. If it wants to report an error, it can do so by using the onFail callback provided as an argument. A validation function can submit multiple errors by calling the onFail function multiple times. All the errors will be queued into an array and displayed on the console at the end of the process.
Parameters
Name | Type |
---|---|
validator |
Example
Copied to your clipboardtargets.of('@magento/pwa-buildpack').validateEnv.tapPromise(validateBackendUrl);
Mapping Tapable hooks to the Buildpack facade of Targets.
- Buildpack/BuildBus
- ~Target ⇐
Trackable
- .call([...args]) ⇒
\*
- .callAsync(...args) ⇒
undefined
- .intercept(options) ⇒
void
- .promise([...args]) ⇒
Promise
- .tap([name], interceptor) ⇒
undefined
- .tapAsync(name, interceptor) ⇒
undefined
- .tapPromise(name, interceptor) ⇒
undefined
- .toJSON() ⇒
object
- .track(args)
- .call([...args]) ⇒
- ~TargetProvider ⇐
Trackable
- new TargetProvider(bus, dep, getExternalTargets)
- instance
- .name :
string
- .own :
Object.<string, Target>
- .phase :
string
- .declare(declarations)
- .of(depName) ⇒
Object.<string, Target>
- .toJSON() ⇒
Object
- .track(args)
- .name :
- inner
- ~types :
Object.<string, Tapable.Hook>
- ~appearsToBeTapable(hookLike) ⇒
boolean
- ~getTapableType(hook) ⇒
string
- ~getExternalTargets ⇒
TargetProvider
- ~Target ⇐
Represents an edge on the graph, or a "route" between stops, created between two extensions when one of them references the target(s) of another. When extension Foo requests targets of extension Bar, the BuildBus provides an Target instead of the literal Tapable instance. This enables better logging, error checking, and validation.
Extends: Trackable
See: Tapable docs
- ~Target ⇐
Trackable
- .call([...args]) ⇒
\*
- .callAsync(...args) ⇒
undefined
- .intercept(options) ⇒
void
- .promise([...args]) ⇒
Promise
- .tap([name], interceptor) ⇒
undefined
- .tapAsync(name, interceptor) ⇒
undefined
- .tapPromise(name, interceptor) ⇒
undefined
- .toJSON() ⇒
object
- .track(args)
- .call([...args]) ⇒
Run .call(...args)
on the underlying Tapable Hook.
Calls interceptors synchronously and in subscription order with the
provided arguments. Returns the final value if it's a Waterfall target,
or the value returned by the first interceptor that returns a value if
it's a Bail target.
Returns:
\*
— Returns whatever the underlying Tapable Hook returns.
Parameters
Name | Type | Description |
---|---|---|
[...args] | \* | All arguments are passed to the interceptor functions that have tapped this Target. |
Run .callAsync(...args)
on the underlying Tapable Hook. Calls
interceptors asynchronously with the provided arguments. Depending on
the Target type, calls interceptors in parallel or in subscription
order. Last argument must be a callback. It will be invoked when all
interceptors have run, or when the first returning interceptor has run
if it's a Bail target.
Returns:
undefined
— callAsync
returns nothing, instead passing any output of the interceptors as the first argument of the callback.
Parameters
Name | Type | Description |
---|---|---|
...args | \* | All arguments except the last argument are passed to the interceptor functions that have tapped this Target. The last argument must be a callback function, which will receive the final output of the interceptors. |
Run .intercept(options)
on the underlying Tapable Hook.
Can register meta-interceptors for other activity on this target.
Use only for logging and debugging.
Returns: Parameters
Name | Type | Description |
---|---|---|
options | object | Options for Tapable#intercept. |
Run .promise(...args)
on the underlying Tapable hook. Calls
interceptors asynchronously with the provided arguments. Depending on
the Target type, calls interceptors in parallel or in series. Returns a
promise. It will be fulfilled when all interceptors have run, or when
the first returning interceptor has run if it's a Bail target.
Returns:
Promise
— A Promise for any output of the target's interceptors.
Parameters
Name | Type | Description |
---|---|---|
[...args] | \* | All arguments are passed to the interceptor functions that have tapped this Target. |
Adds a synchronous interceptor to the target. If you just supply a function, it will use your extension's package name as the name of the tap.
Returns: Parameters
Name | Type | Description |
---|---|---|
[name] | string | object | string or object containing the name of the interceptor (optional) |
interceptor | function | interceptor function |
Adds a callback-style asynchronous interceptor to the Target. The interceptor will receive a callback function as its last argument. Only supported on Async targets.
Returns: Parameters
Name | Type | Description |
---|---|---|
name | string | object | string or object containing the name of the interceptor |
interceptor | function | interceptor function |
Adds a Promise-returning async interceptor to the Target. The interceptor may return a Promise, which the Target will resolve. Only supported on Async targets.
Returns: Parameters
Name | Type | Description |
---|---|---|
name | string | object | string or object containing the name of the interceptor |
interceptor | function | interceptor function |
Provides the JSON object representation of this target
Overrides: toJSON
Returns:
object
— JSON object
Push an event to the parent Trackable, or, if no parent, to the root
output callback provided to Trackable#attach. All .track
calls are tagged with the instance's identifier and then rolled up
recursively until they call the root output callback.
Throws an exception if Trackable#attach has never been called on this instance.
Overrides: track
Parameters
Name | Type | Description |
---|---|---|
args | \* | Any params the root logging function will understand @ |
Handles interactions between a BuildBus and an "extension" package participating in the BuildBus declare/intercept lifecycle.
The targets
object used by declare and intercept functions is a TargetProvider.
Each extension receives its own TargetProvider, which provides methods for
declaring its own targets, intercepting its own targets, and intercepting the
targets of other extensions.
Extends: Trackable
- ~TargetProvider ⇐
Trackable
- new TargetProvider(bus, dep, getExternalTargets)
- instance
- .name :
string
- .own :
Object.<string, Target>
- .phase :
string
- .declare(declarations)
- .of(depName) ⇒
Object.<string, Target>
- .toJSON() ⇒
Object
- .track(args)
- .name :
- inner
Creates an instance of TargetProvider.
Parameters
Name | Type | Description |
---|---|---|
bus | BuildBus | function | BuildBus using this TargetProvider, or, when testing, a logging function. |
dep | Object | The package which owns this TargetProvider. |
dep.name | string | Name of the package which owns this. |
getExternalTargets | getExternalTargets | Function this TargetProvider will use to retrieve external packages when they are requested with .of() . Should usually be a delegate to BuildBus's getExternalTargets() |
The targets this package has declared in the declare
phase.
The phase currently being executed. Either declare
or intercept
.
Call this function in the declare phase to register targets that this package and other packages can intercept.
Parameters
Name | Type | Description |
---|---|---|
declarations | Object.<string, Target> | An object whose keys are the names of targets to declare, and whose properties are newly constructed Targets. |
Call this function in the intercept phase to get the targets of other packages, which
can then be intercepted by calling .tap()
methods on them.
Returns:
Object.<string, Target>
— - An object whose keys are the names
of the requested package's targets, and whose values are the target
objects.
Parameters
Name | Type | Description |
---|---|---|
depName | string | The package whose targets you want to retrieve. |
Serialize this Trackable and any parent Trackables.
Overrides: toJSON
Returns:
Object
— JSON-clean object that recurses up the parent tree.
Push an event to the parent Trackable, or, if no parent, to the root
output callback provided to Trackable#attach. All .track
calls are tagged with the instance's identifier and then rolled up
recursively until they call the root output callback.
Throws an exception if Trackable#attach has never been called on this instance.
Overrides: track
Parameters
Name | Type | Description |
---|---|---|
args | \* | Any params the root logging function will understand @ |
Dictionary of Tapable Hook classes to expose under these new names.
See: Tapable
Use duck typing to validate that the passed object seems like a Tapable hook.
More robust than doing instanceof
checks; allows hooks to be proxied and
otherwise hacked by dependencies.
Returns:
boolean
— True if the object looks like a Tapable hook. False otherwise.
Parameters
Name | Type | Description |
---|---|---|
hookLike | object | Does it look and act like a Tapable hook? |
Get the string type name of a provided object. If it is one of the base
Tapable Hooks supported, returns the name of that Hook (without 'Hook' on
the end). Otherwise, returns <unknown>
.
Returns:
string
— The name of the hook without 'Hook' on the end or <unknown>
Parameters
Name | Type | Description |
---|---|---|
hook | object | Potental Tapable hook object |
Respond to a request from a TargetProvider to retrieve a different(external) TargetProvider.
This callback pattern helps to loosely couple TargetProviders so they are more testable.
Returns:
TargetProvider
— TargetProvider for the requested targets.
Parameters
Name | Type | Description |
---|---|---|
requestor | TargetProvider | TargetProvider making the request. |
requested | string | External targets being requested. |
- Buildpack/BuildBus
- ~Target ⇐
Trackable
- .call([...args]) ⇒
\*
- .callAsync(...args) ⇒
undefined
- .intercept(options) ⇒
void
- .promise([...args]) ⇒
Promise
- .tap([name], interceptor) ⇒
undefined
- .tapAsync(name, interceptor) ⇒
undefined
- .tapPromise(name, interceptor) ⇒
undefined
- .toJSON() ⇒
object
- .track(args)
- .call([...args]) ⇒
- ~TargetProvider ⇐
Trackable
- new TargetProvider(bus, dep, getExternalTargets)
- instance
- .name :
string
- .own :
Object.<string, Target>
- .phase :
string
- .declare(declarations)
- .of(depName) ⇒
Object.<string, Target>
- .toJSON() ⇒
Object
- .track(args)
- .name :
- inner
- ~types :
Object.<string, Tapable.Hook>
- ~appearsToBeTapable(hookLike) ⇒
boolean
- ~getTapableType(hook) ⇒
string
- ~getExternalTargets ⇒
TargetProvider
- ~Target ⇐
Represents an edge on the graph, or a "route" between stops, created between two extensions when one of them references the target(s) of another. When extension Foo requests targets of extension Bar, the BuildBus provides an Target instead of the literal Tapable instance. This enables better logging, error checking, and validation.
Extends: Trackable
See: Tapable docs
- ~Target ⇐
Trackable
- .call([...args]) ⇒
\*
- .callAsync(...args) ⇒
undefined
- .intercept(options) ⇒
void
- .promise([...args]) ⇒
Promise
- .tap([name], interceptor) ⇒
undefined
- .tapAsync(name, interceptor) ⇒
undefined
- .tapPromise(name, interceptor) ⇒
undefined
- .toJSON() ⇒
object
- .track(args)
- .call([...args]) ⇒
Run .call(...args)
on the underlying Tapable Hook.
Calls interceptors synchronously and in subscription order with the
provided arguments. Returns the final value if it's a Waterfall target,
or the value returned by the first interceptor that returns a value if
it's a Bail target.
Returns:
\*
— Returns whatever the underlying Tapable Hook returns.
Parameters
Name | Type | Description |
---|---|---|
[...args] | \* | All arguments are passed to the interceptor functions that have tapped this Target. |
Run .callAsync(...args)
on the underlying Tapable Hook. Calls
interceptors asynchronously with the provided arguments. Depending on
the Target type, calls interceptors in parallel or in subscription
order. Last argument must be a callback. It will be invoked when all
interceptors have run, or when the first returning interceptor has run
if it's a Bail target.
Returns:
undefined
— callAsync
returns nothing, instead passing any output of the interceptors as the first argument of the callback.
Parameters
Name | Type | Description |
---|---|---|
...args | \* | All arguments except the last argument are passed to the interceptor functions that have tapped this Target. The last argument must be a callback function, which will receive the final output of the interceptors. |
Run .intercept(options)
on the underlying Tapable Hook.
Can register meta-interceptors for other activity on this target.
Use only for logging and debugging.
Returns: Parameters
Name | Type | Description |
---|---|---|
options | object | Options for Tapable#intercept. |
Run .promise(...args)
on the underlying Tapable hook. Calls
interceptors asynchronously with the provided arguments. Depending on
the Target type, calls interceptors in parallel or in series. Returns a
promise. It will be fulfilled when all interceptors have run, or when
the first returning interceptor has run if it's a Bail target.
Returns:
Promise
— A Promise for any output of the target's interceptors.
Parameters
Name | Type | Description |
---|---|---|
[...args] | \* | All arguments are passed to the interceptor functions that have tapped this Target. |
Adds a synchronous interceptor to the target. If you just supply a function, it will use your extension's package name as the name of the tap.
Returns: Parameters
Name | Type | Description |
---|---|---|
[name] | string | object | string or object containing the name of the interceptor (optional) |
interceptor | function | interceptor function |
Adds a callback-style asynchronous interceptor to the Target. The interceptor will receive a callback function as its last argument. Only supported on Async targets.
Returns: Parameters
Name | Type | Description |
---|---|---|
name | string | object | string or object containing the name of the interceptor |
interceptor | function | interceptor function |
Adds a Promise-returning async interceptor to the Target. The interceptor may return a Promise, which the Target will resolve. Only supported on Async targets.
Returns: Parameters
Name | Type | Description |
---|---|---|
name | string | object | string or object containing the name of the interceptor |
interceptor | function | interceptor function |
Provides the JSON object representation of this target
Overrides: toJSON
Returns:
object
— JSON object
Push an event to the parent Trackable, or, if no parent, to the root
output callback provided to Trackable#attach. All .track
calls are tagged with the instance's identifier and then rolled up
recursively until they call the root output callback.
Throws an exception if Trackable#attach has never been called on this instance.
Overrides: track
Parameters
Name | Type | Description |
---|---|---|
args | \* | Any params the root logging function will understand @ |
Handles interactions between a BuildBus and an "extension" package participating in the BuildBus declare/intercept lifecycle.
The targets
object used by declare and intercept functions is a TargetProvider.
Each extension receives its own TargetProvider, which provides methods for
declaring its own targets, intercepting its own targets, and intercepting the
targets of other extensions.
Extends: Trackable
- ~TargetProvider ⇐
Trackable
- new TargetProvider(bus, dep, getExternalTargets)
- instance
- .name :
string
- .own :
Object.<string, Target>
- .phase :
string
- .declare(declarations)
- .of(depName) ⇒
Object.<string, Target>
- .toJSON() ⇒
Object
- .track(args)
- .name :
- inner
Creates an instance of TargetProvider.
Parameters
Name | Type | Description |
---|---|---|
bus | BuildBus | function | BuildBus using this TargetProvider, or, when testing, a logging function. |
dep | Object | The package which owns this TargetProvider. |
dep.name | string | Name of the package which owns this. |
getExternalTargets | getExternalTargets | Function this TargetProvider will use to retrieve external packages when they are requested with .of() . Should usually be a delegate to BuildBus's getExternalTargets() |
The targets this package has declared in the declare
phase.
The phase currently being executed. Either declare
or intercept
.
Call this function in the declare phase to register targets that this package and other packages can intercept.
Parameters
Name | Type | Description |
---|---|---|
declarations | Object.<string, Target> | An object whose keys are the names of targets to declare, and whose properties are newly constructed Targets. |
Call this function in the intercept phase to get the targets of other packages, which
can then be intercepted by calling .tap()
methods on them.
Returns:
Object.<string, Target>
— - An object whose keys are the names
of the requested package's targets, and whose values are the target
objects.
Parameters
Name | Type | Description |
---|---|---|
depName | string | The package whose targets you want to retrieve. |
Serialize this Trackable and any parent Trackables.
Overrides: toJSON
Returns:
Object
— JSON-clean object that recurses up the parent tree.
Push an event to the parent Trackable, or, if no parent, to the root
output callback provided to Trackable#attach. All .track
calls are tagged with the instance's identifier and then rolled up
recursively until they call the root output callback.
Throws an exception if Trackable#attach has never been called on this instance.
Overrides: track
Parameters
Name | Type | Description |
---|---|---|
args | \* | Any params the root logging function will understand @ |
Dictionary of Tapable Hook classes to expose under these new names.
See: Tapable
Use duck typing to validate that the passed object seems like a Tapable hook.
More robust than doing instanceof
checks; allows hooks to be proxied and
otherwise hacked by dependencies.
Returns:
boolean
— True if the object looks like a Tapable hook. False otherwise.
Parameters
Name | Type | Description |
---|---|---|
hookLike | object | Does it look and act like a Tapable hook? |
Get the string type name of a provided object. If it is one of the base
Tapable Hooks supported, returns the name of that Hook (without 'Hook' on
the end). Otherwise, returns <unknown>
.
Returns:
string
— The name of the hook without 'Hook' on the end or <unknown>
Parameters
Name | Type | Description |
---|---|---|
hook | object | Potental Tapable hook object |
Respond to a request from a TargetProvider to retrieve a different(external) TargetProvider.
This callback pattern helps to loosely couple TargetProviders so they are more testable.
Returns:
TargetProvider
— TargetProvider for the requested targets.
Parameters
Name | Type | Description |
---|---|---|
requestor | TargetProvider | TargetProvider making the request. |
requested | string | External targets being requested. |
- @magento/pwa-buildpack
- ~BuildBus
- instance
- .getTargetsOf(depName) ⇒
Object.<string, Target>
- .init() ⇒
BuildBus
- .runPhase(phase)
- .getTargetsOf(depName) ⇒
- static
- .clear(context)
- .clearAll()
- .for(context) ⇒
BuildBus
- instance
- ~Trackable
- ~BuildBus
Manages dependency participation in project builds and tasks. It executes their declare and intercept files so they can interact with each other.
- ~BuildBus
- instance
- .getTargetsOf(depName) ⇒
Object.<string, Target>
- .init() ⇒
BuildBus
- .runPhase(phase)
- .getTargetsOf(depName) ⇒
- static
- .clear(context)
- .clearAll()
- .for(context) ⇒
BuildBus
- instance
Get TargetProvider for the given named dependency. Use this to
retrieve and run targets in top-level code, when you have a reference to
the BuildBus. Declare and intercept functions should not, and cannot,
use this method. Instead, they retrieve external targets through their
targets.of()
methods.
Returns:
Object.<string, Target>
— TargetProvider for the dependency.
Parameters
Name | Type | Description |
---|---|---|
depName | string | Dependency whose targets to retrieve. |
Run the two defined phases, declare
and intercept
, in order.
This binds all targets which the BuildBus can find by analyzing
dependencies in the project package file.
Chainable
Returns:
BuildBus
— Returns this instance (chainable).
Run the specified phase. The BuildBus finds all dependencies which say
in their package.json
that they need to run code in this phase.
Parameters
Name | Type | Description |
---|---|---|
phase | string | 'declare' or 'intercept' |
Example
Copied to your clipboard<caption>Find all dependencies whith have `pwa-studio: { targets: { declare: './path/to/js' }} defined, and run those functions.bus.runPhase('declare')
Remove the cached BuildBus for the given context.
Parameters
Name | Type | Description |
---|---|---|
context | string | Root directory whose BuildBus to delete. |
Remove all cached BuildBus objects.
Get or create the BuildBus for the given context. This factory is the supported way to construct BuildBus instances. It caches the instances and connects them to the logging infrastructure.
Only one BuildBus is active for a project root directory (context) at any given time. This way, Buildpack code can retrieve the BuildBus for a context even if the bus instance hasn't been sent as a parameter.
Returns: Parameters
Name | Type | Description |
---|---|---|
context | string | Root directory of the BuildBus to get or create. |
Example (Get or create the BuildBus for the package.json file in `./project-dir`, then bind targets, then call a target.)
Copied to your clipboardconst bus = BuildBus.for('./project-dir);bus.init();bus.getTargetsOf('my-extension').myTarget.call();
Generic node in a tree of objects which can log their activity. Implemented for BuildBus, since it will eventually need sophisticated debugging and introspection for developers, but it has no BuildBus-specific functionality.
Attach this Trackable to a tree. Give it a name and an owner. If the
owner is a Trackable, then this Trackable becomes a child node of the
owner. If the owner is a function, then this Trackable becomes a root
node, which will log all of its track calls and its
descendents' calls to the owner
function.
See: Trackable.spec.js
Parameters
Name | Type | Description |
---|---|---|
identifier | string | String identifier of this Trackable |
owner | Trackable | function | Parent or root log callback |
Enable all active Trackable instances. Do not run in production. Carries a possibly significant performance cost.
Disable all active Trackable instances. The parent logging callback will not be called.
- Buildpack/BuildBus
- ~Target ⇐
Trackable
- .call([...args]) ⇒
\*
- .callAsync(...args) ⇒
undefined
- .intercept(options) ⇒
void
- .promise([...args]) ⇒
Promise
- .tap([name], interceptor) ⇒
undefined
- .tapAsync(name, interceptor) ⇒
undefined
- .tapPromise(name, interceptor) ⇒
undefined
- .toJSON() ⇒
object
- .track(args)
- .call([...args]) ⇒
- ~TargetProvider ⇐
Trackable
- new TargetProvider(bus, dep, getExternalTargets)
- instance
- .name :
string
- .own :
Object.<string, Target>
- .phase :
string
- .declare(declarations)
- .of(depName) ⇒
Object.<string, Target>
- .toJSON() ⇒
Object
- .track(args)
- .name :
- inner
- ~types :
Object.<string, Tapable.Hook>
- ~appearsToBeTapable(hookLike) ⇒
boolean
- ~getTapableType(hook) ⇒
string
- ~getExternalTargets ⇒
TargetProvider
- ~Target ⇐
Represents an edge on the graph, or a "route" between stops, created between two extensions when one of them references the target(s) of another. When extension Foo requests targets of extension Bar, the BuildBus provides an Target instead of the literal Tapable instance. This enables better logging, error checking, and validation.
Extends: Trackable
See: Tapable docs
- ~Target ⇐
Trackable
- .call([...args]) ⇒
\*
- .callAsync(...args) ⇒
undefined
- .intercept(options) ⇒
void
- .promise([...args]) ⇒
Promise
- .tap([name], interceptor) ⇒
undefined
- .tapAsync(name, interceptor) ⇒
undefined
- .tapPromise(name, interceptor) ⇒
undefined
- .toJSON() ⇒
object
- .track(args)
- .call([...args]) ⇒
Run .call(...args)
on the underlying Tapable Hook.
Calls interceptors synchronously and in subscription order with the
provided arguments. Returns the final value if it's a Waterfall target,
or the value returned by the first interceptor that returns a value if
it's a Bail target.
Returns:
\*
— Returns whatever the underlying Tapable Hook returns.
Parameters
Name | Type | Description |
---|---|---|
[...args] | \* | All arguments are passed to the interceptor functions that have tapped this Target. |
Run .callAsync(...args)
on the underlying Tapable Hook. Calls
interceptors asynchronously with the provided arguments. Depending on
the Target type, calls interceptors in parallel or in subscription
order. Last argument must be a callback. It will be invoked when all
interceptors have run, or when the first returning interceptor has run
if it's a Bail target.
Returns:
undefined
— callAsync
returns nothing, instead passing any output of the interceptors as the first argument of the callback.
Parameters
Name | Type | Description |
---|---|---|
...args | \* | All arguments except the last argument are passed to the interceptor functions that have tapped this Target. The last argument must be a callback function, which will receive the final output of the interceptors. |
Run .intercept(options)
on the underlying Tapable Hook.
Can register meta-interceptors for other activity on this target.
Use only for logging and debugging.
Returns: Parameters
Name | Type | Description |
---|---|---|
options | object | Options for Tapable#intercept. |
Run .promise(...args)
on the underlying Tapable hook. Calls
interceptors asynchronously with the provided arguments. Depending on
the Target type, calls interceptors in parallel or in series. Returns a
promise. It will be fulfilled when all interceptors have run, or when
the first returning interceptor has run if it's a Bail target.
Returns:
Promise
— A Promise for any output of the target's interceptors.
Parameters
Name | Type | Description |
---|---|---|
[...args] | \* | All arguments are passed to the interceptor functions that have tapped this Target. |
Adds a synchronous interceptor to the target. If you just supply a function, it will use your extension's package name as the name of the tap.
Returns: Parameters
Name | Type | Description |
---|---|---|
[name] | string | object | string or object containing the name of the interceptor (optional) |
interceptor | function | interceptor function |
Adds a callback-style asynchronous interceptor to the Target. The interceptor will receive a callback function as its last argument. Only supported on Async targets.
Returns: Parameters
Name | Type | Description |
---|---|---|
name | string | object | string or object containing the name of the interceptor |
interceptor | function | interceptor function |
Adds a Promise-returning async interceptor to the Target. The interceptor may return a Promise, which the Target will resolve. Only supported on Async targets.
Returns: Parameters
Name | Type | Description |
---|---|---|
name | string | object | string or object containing the name of the interceptor |
interceptor | function | interceptor function |
Provides the JSON object representation of this target
Overrides: toJSON
Returns:
object
— JSON object
Push an event to the parent Trackable, or, if no parent, to the root
output callback provided to Trackable#attach. All .track
calls are tagged with the instance's identifier and then rolled up
recursively until they call the root output callback.
Throws an exception if Trackable#attach has never been called on this instance.
Overrides: track
Parameters
Name | Type | Description |
---|---|---|
args | \* | Any params the root logging function will understand @ |
Handles interactions between a BuildBus and an "extension" package participating in the BuildBus declare/intercept lifecycle.
The targets
object used by declare and intercept functions is a TargetProvider.
Each extension receives its own TargetProvider, which provides methods for
declaring its own targets, intercepting its own targets, and intercepting the
targets of other extensions.
Extends: Trackable
- ~TargetProvider ⇐
Trackable
- new TargetProvider(bus, dep, getExternalTargets)
- instance
- .name :
string
- .own :
Object.<string, Target>
- .phase :
string
- .declare(declarations)
- .of(depName) ⇒
Object.<string, Target>
- .toJSON() ⇒
Object
- .track(args)
- .name :
- inner
Creates an instance of TargetProvider.
Parameters
Name | Type | Description |
---|---|---|
bus | BuildBus | function | BuildBus using this TargetProvider, or, when testing, a logging function. |
dep | Object | The package which owns this TargetProvider. |
dep.name | string | Name of the package which owns this. |
getExternalTargets | getExternalTargets | Function this TargetProvider will use to retrieve external packages when they are requested with .of() . Should usually be a delegate to BuildBus's getExternalTargets() |
The targets this package has declared in the declare
phase.
The phase currently being executed. Either declare
or intercept
.
Call this function in the declare phase to register targets that this package and other packages can intercept.
Parameters
Name | Type | Description |
---|---|---|
declarations | Object.<string, Target> | An object whose keys are the names of targets to declare, and whose properties are newly constructed Targets. |
Call this function in the intercept phase to get the targets of other packages, which
can then be intercepted by calling .tap()
methods on them.
Returns:
Object.<string, Target>
— - An object whose keys are the names
of the requested package's targets, and whose values are the target
objects.
Parameters
Name | Type | Description |
---|---|---|
depName | string | The package whose targets you want to retrieve. |
Serialize this Trackable and any parent Trackables.
Overrides: toJSON
Returns:
Object
— JSON-clean object that recurses up the parent tree.
Push an event to the parent Trackable, or, if no parent, to the root
output callback provided to Trackable#attach. All .track
calls are tagged with the instance's identifier and then rolled up
recursively until they call the root output callback.
Throws an exception if Trackable#attach has never been called on this instance.
Overrides: track
Parameters
Name | Type | Description |
---|---|---|
args | \* | Any params the root logging function will understand @ |
Dictionary of Tapable Hook classes to expose under these new names.
See: Tapable
Use duck typing to validate that the passed object seems like a Tapable hook.
More robust than doing instanceof
checks; allows hooks to be proxied and
otherwise hacked by dependencies.
Returns:
boolean
— True if the object looks like a Tapable hook. False otherwise.
Parameters
Name | Type | Description |
---|---|---|
hookLike | object | Does it look and act like a Tapable hook? |
Get the string type name of a provided object. If it is one of the base
Tapable Hooks supported, returns the name of that Hook (without 'Hook' on
the end). Otherwise, returns <unknown>
.
Returns:
string
— The name of the hook without 'Hook' on the end or <unknown>
Parameters
Name | Type | Description |
---|---|---|
hook | object | Potental Tapable hook object |
Respond to a request from a TargetProvider to retrieve a different(external) TargetProvider.
This callback pattern helps to loosely couple TargetProviders so they are more testable.
Returns:
TargetProvider
— TargetProvider for the requested targets.
Parameters
Name | Type | Description |
---|---|---|
requestor | TargetProvider | TargetProvider making the request. |
requested | string | External targets being requested. |
Intercept function signature for the transformModules target.
Interceptors of transformModules
should call the addTransform()
callback to add module specific transformers.
Any returned value will be ignored.
Parameters
Name | Type | Description |
---|---|---|
addTransform | Callback to add a transform. |
Callback to add a transform.
See: TransformRequest
Parameters
Name | Type | Description |
---|---|---|
transformRequest | Buildpack/WebpackTools~TransformRequest | Request to apply a transform to a file provided by this dependency. |
Intercept function signature for the webpackCompiler target.
Interceptors of webpackCompiler
should tap hooks on the provided
compiler
object. Any returned value will be ignored.
Parameters
Name | Type | Description |
---|---|---|
compiler | webpack.Compiler | The webpack compiler instance |
Intercept function signature for the specialFeatures target.
Interceptors of the specialFeatures
target can use the mapping object provided
to map special build flags to their project modules.
Parameters
Name | Type | Description |
---|---|---|
featuresByModule | Object.<string, SpecialBuildFlags> | An object mapping of module names to their special build flags |
Intercept function signature for the transformUpward target.
Interceptors of the transformUpward
target receive the parsed UPWARD
definition as a plain JavaScript object. Mutate that object in place to
change the final upward.yml
output by the build.
This Target can be used asynchronously. If you need to do asynchronous work
to get what you need to modify the UPWARD definition (for example, a network
request) then you can provide an async
function as interceptor (or simply
return a Promise from any function).
Returns: Parameters
Name | Type | Description |
---|---|---|
definition | object | Parsed UPWARD definition object. |
Intercept function signature for the validateEnv target.
Interceptors of the validateEnv
target receive a config object.
The config object contains the project env, an onFail callback and
the debug function to be used in case of the debug mode to log more
inforamtion to the console.
This Target can be used asynchronously in the parallel mode. If a validator needs to stop the process immediately, it can throw an error. If it needs to report an error but not stop the whole process, it can do so by calling the onFail function with the error message it wants to report. It can call the onFail multiple times if it wants to report multiple errors.
All the errors will be queued and printed into the console at the end of the validation process and the build process will be stopeed.
Returns: Parameters
Name | Type | Description |
---|---|---|
config.env | Object | Project ENV |
config.onFail | function | On fail callback |
config.debug | function | Debug function to be used for additional reporting in debug mode |
Source Code: pwa-studio/packages/pwa-buildpack/lib/BuildBus/BuildBus.js