@adobe/helix-pipeline
Version:
This project provides helper functions and default implementations for creating Hypermedia Processing Pipelines.
44 lines (39 loc) • 1.57 kB
JavaScript
/*
* Copyright 2018 Adobe. All rights reserved.
* This file is licensed to you under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License. You may obtain a copy
* of the License at http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software distributed under
* the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
* OF ANY KIND, either express or implied. See the License for the specific language
* governing permissions and limitations under the License.
*/
import { ConsoleLogger, SimpleInterface } from '@adobe/helix-log';
import Pipeline from '../pipeline.js';
/**
* Constructs a pipeline function that is capable of
* - calling a continuation function
* - wrapping the response in a friendly response format
* @param {Function} next the continuation function
* @param {Object} context the initial context
* @param {Object} action the action
* @returns {Function} a function to execute.
*/
export function pipe(next, context, action) {
const mypipeline = new Pipeline(action);
mypipeline.use(next);
return mypipeline.run(context);
}
/**
*
* @param {Function} cont the continuation function
* @returns {Function} the wrapped main function
*/
export const pre = (cont) => cont;
export const log = new SimpleInterface({
level: 'debug',
logger: new ConsoleLogger(),
});
// keep backward compatible with winston logger
log.log = (level, ...msg) => log._logImpl(level, ...msg, {});