patternplate-server
Version:
Programmatically serve atomic patterns via a REST API
109 lines (80 loc) • 4.14 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }();
var _fs = require('fs');
var _fs2 = _interopRequireDefault(_fs);
var _path = require('path');
var _path2 = _interopRequireDefault(_path);
var _getPatternRetriever = require('./utilities/get-pattern-retriever');
var _getPatternRetriever2 = _interopRequireDefault(_getPatternRetriever);
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _asyncToGenerator(fn) { return function () { var gen = fn.apply(this, arguments); return new Promise(function (resolve, reject) { function step(key, arg) { try { var info = gen[key](arg); var value = info.value; } catch (error) { reject(error); return; } if (info.done) { resolve(value); } else { return Promise.resolve(value).then(function (value) { step("next", value); }, function (err) { step("throw", err); }); } } return step("next"); }); }; }
exports.default = getPatternSource;
function getPatternSource(application) {
const cwd = application.runtime.patterncwd;
return (() => {
var _ref = _asyncToGenerator(function* (pathname, type, environment) {
if (type === 'source') {
const sourcePath = _path2.default.resolve(cwd, 'patterns', pathname);
return {
type: _path2.default.extname(sourcePath),
body: _fs2.default.createReadStream(sourcePath)
};
}
const id = _path2.default.dirname(pathname);
const inFormatName = _path2.default.extname(pathname).slice(1);
const format = application.configuration.patterns.formats[inFormatName] || {};
const transforms = format.transforms || [];
const transformName = transforms[transforms.length - 1];
const transform = application.configuration.transforms[transformName];
const basename = _path2.default.basename(pathname);
const concern = _path2.default.basename(pathname, _path2.default.extname(pathname));
// configured transfoms, but invalid
if (transforms.length && !transformName) {
const error = new Error(`Could not determine last transform for "${basename}" of "${id}"`);
error.status = 404;
throw error;
}
// configured transforms for format, but no matching transform config
if (transformName && !transform) {
const error = new Error(`Transform "${transformName}" to be applied on "${basename}" of "${id}" is not configured`);
error.status = 404;
throw error;
}
// fall back to in format
const outFormatName = (transform || {}).outFormat || inFormatName;
const filters = {
baseNames: [concern],
environments: [environment],
outFormats: [outFormatName]
};
const retrieve = (0, _getPatternRetriever2.default)(application);
var _ref2 = yield retrieve(id, filters, environment, ['read', 'transform']);
var _ref3 = _slicedToArray(_ref2, 1);
const pattern = _ref3[0];
if (!pattern) {
const error = new Error(`No pattern with id ${id} found`);
error.status = 404;
throw error;
}
if (!(basename in pattern.files)) {
const files = Object.keys(pattern.files || {});
const error = new Error(`pattern ${id} has no file ${basename}. Available files: ${files.join(', ')}`);
error.status = 404;
throw error;
}
const file = pattern.files[basename];
return {
type: file.out,
body: file.buffer,
meta: pattern.meta
};
});
return function (_x, _x2, _x3) {
return _ref.apply(this, arguments);
};
})();
}
module.exports = exports['default'];
;